1# Third-party Module Adaptation<a name="EN-US_TOPIC_0000001153842842"></a> 2 3To use third-party modules in the **third\_party** directory, you may need to adapt the modules. This section uses mbedTLS as an example to describe how to integrate the adaptation code with the OpenHarmony compilation framework. For the principles of mbedTLS and the specific logic of the adaptation code, see the adaptation guide on the mbedTLS official website. 4 51. <a name="li12446195633211"></a>Write the adaptation layer code. 6 7 Write the required adaptation layer code based on the mbedTLS adaptation guide. In this example, adaptation of the hardware random number is used for illustration, and the paths are relative to **third\_party/mbedtls**: 8 9 1. Copy the **include/mbedtls/config.h** file to the **ports** directory, and enable **MBEDTLS\_ENTROPY\_HARDWARE\_ALT** in the file. 10 2. In the **ports** directory, create the **entropy\_poll\_alt.c** file under **include** and implement the hardware random number API in **entropy\_poll.h**. 11 3. Add the path of the adapted **entropy\_poll\_alt.c** file to **mbedtls\_sources** in the **BUILD.gn** file. 12 4. Add the line **MBEDTLS\_CONFIG\_FILE** to **lite\_library\("mbedtls\_static"\)** in the **BUILD.gn** file to specify the path of the new configuration file. 13 14 ``` 15 lite_library("mbedtks_static") { 16 ... 17 defines += ["MBEDTLS_CONFIG_FILE=<../port/config.h>"] 18 ... 19 } 20 ``` 21 22 You are advised to make the preceding modifications in a new **config.h** file or **_xxx_\_alt.c** file. Do not directly edit the code in the original file. Intrusive modifications may cause a large number of scattered conflicts during subsequent version updates, increasing the update maintenance costs. 23 242. Create a patch. 25 26 The preceding adaptation is hardware-specific. Therefore, when uploading code to the library, you cannot directly store the code in the **third\_party/mbedtls** directory. Instead, you need to integrate the preceding modifications into a patch and inject the patch into the code for a build. 27 28 1. Add the patch configuration file **device/<_company_\>/<_board_\>/patch.yml**. 29 2. In the **device/<_company_\>/<_board_\>/patch.yml** file, add the information about the patch to apply. 30 31 ``` 32 # Path of the patch to apply. This path is relative to the code root directory. 33 third_party/mbedtls: 34 # Directory in which the patch is stored. 35 - device/<company>/<board>/third_party/mbedtls/adapter.patch 36 third_party/wpa_supplicant: 37 # When there are multiple patches in a path, the patches are executed in sequence. 38 - device/<company>/<board>/third_party/wpa_supplicant/xxxxx.patch 39 - device/<company>/<board>/third_party/wpa_supplicant/yyyyy.patch 40 ... 41 ``` 42 43 3. Create a patch file as described in step [1](#li12446195633211) and save it to the corresponding directory. 44 453. Start a build with the patch. 46 47 Add **--patch** when triggering a build. The following is the command for executing a full build with a patch: 48 49 ``` 50 hb build -f --patch 51 ``` 52 53 >![](../public_sys-resources/icon-caution.gif) **CAUTION:** 54 >The information about the product to which the patch is most recently applied will be recorded. Next time the build is performed, the previous patch is rolled back \(that is, **\`patch -p1 -R < xxx\`** is executed\). If the patch fails to be rolled back or a patch fails to be added, the build process is terminated. In this case, resolve the patch conflict and try again. 55 56 57