CC23xx SDK 7.40 to CC23xx SDK 8.10

This section will describe how to port a project from CC23xx SDK 7.40 to a CC23xx SDK 8.10 project.

Note

Vulnerability reports and mitigations can be found on Report potential product security vulnerabilities.

Porting Bluetooth LE Projects

The recommended method for porting an existing project from CC23xx SDK 7.40 to CC23xx SDK 8.10 is to modify the ProjectSpec file to import the project as a CC23xx SDK 8.10 project.

Porting by modifying the CCS ProjectSpec file (.projectspec) can be done when a ProjectSpec file has been updated and maintained throughout the project’s development. All example projects included in the SDK each come with their own ProjectSpec file. During development, the included ProjectSpec file should be updated to match any changes or additions made to the project. This will make a project more easily package-able and ease migration efforts when future SDK’s are released. For example, the ProjectSpec file of the basic_ble project is located in {SDK_INSTALL_DIR}/examples/rtos/{BOARD}/ble5stack/basic_ble/freertos/ticlang

The following steps will detail the changes needed when porting an out of the box example from the SDK such as basic_ble:

Note

This porting method might be more complex for customer specific projects. The following steps are the minimum set of changes required to port a project from CC23xx SDK 7.40 to CC23xx SDK 8.10.

  1. Open the ProjectSpec file in a text editor and modify the product definition line to reflect the new SDK revision and the corresponding SysConfig revision. products="com.ti.SIMPLELINK_LOWPOWER_F3_SDK:x.xx.xx.xx;sysconfig:x.xx.x" Also update line cgtVersion="TICLANG_x.x.x" if it exists in the file. Refer to the Dependencies section in the SDK release notes for the correct SysConfig (and compiler) version. The SDK release notes may be found in {SDK_INSTALL_DIR}/docs/simplelink_mcu_sdk/release_notes_coresdk_lpf3_x_xx_xx_xx.html

  2. In the ProjectSpec file, add the following file paths:

    • <file path="${COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR}/source/ti/bleapp/health_toolkit/inc/debugInfo.h" openOnCreation="false" excludeFromBuild="false" action="link" targetDirectory="common/HealthToolkit/inc"></file>

    • <file path="${COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR}/source/ti/bleapp/health_toolkit/inc/debugInfo_errno.h" openOnCreation="false" excludeFromBuild="false" action="link" targetDirectory="common/HealthToolkit/inc"></file>

    • <file path="${COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR}/source/ti/bleapp/health_toolkit/src/debugInfo.c" openOnCreation="false" excludeFromBuild="false" action="link" targetDirectory="common/HealthToolkit"></file>

  3. In the ProjectSpec file, erase -mcpu=cortex-m4 from the compilerBuildOptions.

  4. In the ProjectSpec file, erase enableSysConfigTool="true".

To learn more information about ProjectSpec files, please reference ProjectSpec Documentation.

It is also possible to migrate a project only using Code Composer Studio interface. The following steps will detail the changes needed when porting an out of the box example from the SDK such as basic_ble:

  1. Import the project into Code Composer Studio.

  2. In order to modify the SDK version and corresponding SysConfig version, do right click on the imported project folder inside the Project Explorer. Go to General and select Products and choose the SimpleLink Low Power F3 SDK version as well as the SysConfig version. Refer to the Dependencies section in the SDK release notes for the correct SysConfig (and compiler) version. The SDK release notes may be found in {SDK_INSTALL_DIR}/docs/simplelink_mcu_sdk/release_notes_coresdk_lpf3_x_xx_xx_xx.html

../../../_images/ccs_migration_SDK_Sys_version.png

Figure 184. Code Composer Studio - Change SDK and SysConfig Version.

  1. In order to add the new file paths, go to Arm Compiler and select Include Options. Then select the option to add another entry and add the following paths:

    • ${COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR}/source/ti/bleapp/health_toolkit/inc/debugInfo.h

    • ${COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR}/source/ti/bleapp/health_toolkit/inc/debugInfo_errno.h

    • ${COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR}/source/ti/bleapp/health_toolkit/src/debugInfo.c

    Please refer to BLE Health Toolkit for more information about this debugging tool.

    ../../../_images/ccs_migration_include_pathfiles.png

    Figure 185. Code Composer Studio - Add file paths.

  2. Please take into consideration that the linker command file has been renamed in this new SDK from cc23x0_app_freertos to lpf3_app_freertos. The lpf3_app_freertos uses features from GenMap (See: GenMap). Therefore, in case of modifying genMap, please consider these changes will not be taken into account in the linker command file unless you modified the file to use the GenMap functionality.

  3. Please take into consideration that the Util_constructClock prototype has been modified. The callback function parameter is no longer void but must be defined now as UtilTimerCback.

Legacy Porting

Warning

The following section covers a legacy porting method. Current SDK porting does not require this process and should instead see Porting Bluetooth LE Projects.

For this guide, a peripheral project from CC23xx SDK 7.40 will be ported over to CC23xx SDK 8.10. The recommended approach is to start with the Basic BLE project on CC23xx SDK 8.10 and modify the base configuration to match the peripheral configuration used in the CC23xx SDK 7.40 project. Afterwards, the custom application code should be transferred to the new project.

  1. Import a CC23xx SDK 8.10 Basic BLE project.

  2. Change the default Basic BLE project configuration options in the BLE Module present in SysConfig to match the configuration used in the CC23xx SDK 7.40 project.

  3. Transfer all custom application logic from the CC23xx SDK 7.40 into the CC23xx SDK 8.10 Basic BLE project.

  4. Move any profiles and services that the application is using to the CC23xx SDK 8.10 project.

  5. Transfer the SysConfig settings either visually through the GUI or open both the old and the new project .syscfg files and copy-paste the desired settings.

  6. If necessary, update the project to use the newer TI drivers that are supplied with the SimpleLink Low Power F3 SDK. Additional details are provided in A Few Noteworthy Changes from CC23xx SDK 7.40 to CC23xx SDK 8.10.

  7. Refer to the Core SDK release notes for additional information and the FreeRTOS examples included with SimpleLink Low Power F3 SDK. The Core SDK release notes may be found in {SDK_INSTALL_DIR}/docs/simplelink_mcu_sdk/release_notes_coresdk_lpf3_x_xx_xx_xx.html

    For additional information on how CC23xx SDK 8.10 uses FreeRTOS see FreeRTOS (RTOS Kernel) Overview.

    For any utilized TI Drivers, review TI Drivers API Reference.

A Few Noteworthy Changes from CC23xx SDK 7.40 to CC23xx SDK 8.10

You can follow the guide above without addressing these updates; they are listed for your information only. All fine grained details might not be mentioned. Please refer to the specific example you need to port and do a compare between the old and new project files. Please refer to the BLE5-Stack Release Notes for all the details.

  1. HealthToolkit - Debug Information. Please refer to BLE Health Toolkit for more information.

  2. Introduction of GenMap. Please refer to GenMap for more information.

  3. Support for new CC23xx variants. Please refer to Comparison of the CC23xx platform devices for more information.

  4. Starting with CC23xx SDK 8.10, in accordance with Bluetooth Core Specifications Version 5.3 the stack will fail the creation of advertisements with Limited Discoverable Flag that do not terminate within 180 seconds. (See: Limited Advertising).

  5. The procedure to enable the RF Observables (PA and LNA signals) has been updated and now involves SysConfig. Please refer to Debugging RF Output for more information.