CC2651R3: Guidance Required to Implement UART Backdoor Bootloader in CC2651R3

Part Number: CC2651R3
Other Parts Discussed in Thread: CC2651P3, UNIFLASH, CC2652R

Tool/software:

Dear Texas Instruments Support Team,

CCS Version - 12.8

SDK Version simplelink_cc13xx_cc26xx_sdk_7_41_00_17

Compiler Version - 3.2.0 LTS

I am reaching out to request assistance with implementing the UART backdoor bootloader functionality on the CC2651R3 microcontroller.

  • I referred to the Serial Bootloader Interface documentation and implemented the necessary changes as outlined,

  • Configured the ccfg.c file to enable the backdoor bootloader and set the required activation pin and logic level

    (ccfg.c file path - bim_offchip_LP_CC2651P3_nortos_ticlang/Application/ccfg_app.c/DeviceFamily_constructPath(startup_files/ccfg.c))

    (refer the below code snippet to enable bootloader)

           

//#####################################
// Bootloader settings
//#####################################

#ifndef SET_CCFG_BL_CONFIG_BOOTLOADER_ENABLE
//#define SET_CCFG_BL_CONFIG_BOOTLOADER_ENABLE            0x00       // Disable ROM boot loader
 #define SET_CCFG_BL_CONFIG_BOOTLOADER_ENABLE         0xC5       // Enable ROM boot loader
#endif

#ifndef SET_CCFG_BL_CONFIG_BL_LEVEL
 #define SET_CCFG_BL_CONFIG_BL_LEVEL                  0x0        // Active low to open boot loader backdoor
//#define SET_CCFG_BL_CONFIG_BL_LEVEL                     0x1        // Active high to open boot loader backdoor
#endif

#ifndef SET_CCFG_BL_CONFIG_BL_PIN_NUMBER
//#define SET_CCFG_BL_CONFIG_BL_PIN_NUMBER                0xFF       // DIO number for boot loader backdoor
#define SET_CCFG_BL_CONFIG_BL_PIN_NUMBER                0x12       // DIO number for boot loader backdoor (SWO Pin 18)
#endif

#ifndef SET_CCFG_BL_CONFIG_BL_ENABLE
 #define SET_CCFG_BL_CONFIG_BL_ENABLE                 0xC5       // Enabled boot loader backdoor
//#define SET_CCFG_BL_CONFIG_BL_ENABLE                    0xFF       // Disabled boot loader backdoor
#endif

However, I am encountering issues during the firmware upload process using UniFlash.

In UniFlash, I am unable to find CC2651R3 (BOOTLOADER) in the device list, which is required for selecting the correct bootloader interface.

Assistance Required:

  1. Guidance on selecting the correct device profile for the CC2651R3 Bootloader in UniFlash.
  2. Confirmation of any additional settings or steps needed to activate and use the UART Backdoor Bootloader on the CC2651R3.

I appreciate your assistance with these issues and look forward to your guidance on successfully implementing the bootloader.

Regards,

Rajnish Singh

  • Hi, 

    Guidance on selecting the correct device profile for the CC2651R3 Bootloader in UniFlash.

    UniFlash does not enable a way to interface with the CC2651R3 bootloader. 

    Confirmation of any additional settings or steps needed to activate and use the UART Backdoor Bootloader on the CC2651R3.

    Your implementation looks correct to me. 

    I hope this will help,

    Best regards,

  • Hi Clement,

    Thanks for your quick response,

    In Uniflash currently I am selecting device name CC2652R1F (BOOTLOADER) to upload the firmware in UART BL Backdoor mode.

    (why CC2652R1F (BOOTLOADER) (because functionalities are same of the CC2651R3 and CC2652R1F)

    Kindly refer the below screenshot......

    When I attempt to upload firmware in Bootloader (BL) mode, I consistently encounter the errors mentioned in screenshot.

    I also tried uploading a .bin file and manually CCFG settings, but the result remains the same.

    Could you please advise if there are additional steps or settings I might be missing? Any guidance to resolve this issue would be greatly appreciated.

    Regards,

    Rajnish Singh

  • Hi, 

    In Uniflash currently I am selecting device name CC2652R1F (BOOTLOADER) to upload the firmware in UART BL Backdoor mode.

    (why CC2652R1F (BOOTLOADER) (because functionalities are same of the CC2651R3 and CC2652R1F)

    This will not work as both devices are different, and the memory check ran by UniFlash will fail. 

    Best regards, 

  • Hi Clement,

    Thanks for your response,

    I understand that the memory check run by UniFlash will fail since the devices are different. However, I just attempted to upload the firmware by selecting the CC2652 device type because both MCUs are compatible.

    I am currently using the sblAppEx library (as per Serial Bootloader Interface documentation) to upload firmware to the CC2651R3 in bootloader mode, as this is the currently available solution due to the lack of support in other tools. While the library works effectively for uploading a single file at a time, I would like to know if there is a way to upload multiple files simultaneously or sequentially without restarting the process for each file manually.

    Could you please provide guidance or suggestions on achieving this functionality using the sblAppEx library? If modifications or additional tools are required, I would appreciate any relevant documentation or examples.

    Thank you for your support.

    Regards,

    Rajnish

  • Include this as well,

    After Bootloader changes done in ccfg.c file, i am not able to enable Backdoor Bootloader option in the project -> project_zero.syscfg -> Device Configuration

    Kindly refer below screenshot...

    What steps are required to enable this?

    Regards,

    Rajnish

  • Hi, 

    For OAD-enabled projects, the CCFG should be configured from the MCUboot project. 

    I hope this will help,

    Best regards, 

  • Hi Clément,

    Thanks for your response,

    I already did the changes in CC2651R3 respective MCUboot Project (you can find start of this thread),

    Configured the ccfg.c file to enable the backdoor bootloader and set the required activation pin and logic level

    (ccfg.c file path - bim_offchip_LP_CC2651P3_nortos_ticlang/Application/ccfg_app.c/DeviceFamily_constructPath(startup_files/ccfg.c))

    With the help of the sblAppEx library, I am able to update the firmware in bootloader mode when a valid image is found.

    However, if no valid image is present in the flash memory, I am unable to burn the firmware in ROM bootloader mode.

    Could you please suggest what might be causing this issue?

    Regards,

    Rajnish

  • Hi, 

    Great progress, thank you for sharing. 

    However, if no valid image is present in the flash memory, I am unable to burn the firmware in ROM bootloader mode.

    If no image valid is present, the device is expected to enter the serial bootloader mode - no matter the state of the back door pin. See Figure 2-1 in https://www.ti.com/lit/swra466 

      

    Best regards, 

  • Hi Clément,

    Thanks for your response,

    I am working on an OAD-enabled project (off-chip OAD) where I need to upload two firmware files (BIM and Application) using the ROM Bootloader in case of valid image not found.

    With the sblAppEx library, I am currently able to upload only one file at a time. However, I noticed that the logic for uploading multiple files is implemented in the sblAppEx.c file, but this option is not accessible in the sblAppEx.exe GUI.

    (refer below code snippet of sblApp.Ex.c) 

    flashing:
    
        file = ifstream();
    
        //
        // If we are loding the second binary, there is no need to create and connect a new SBLDevice.
        //
        if (dualBinaryLoaded == false)
        {
    
            //
            // Create SBL object
            //
            pDevice = SblDevice::Create(deviceType);
            if (pDevice == NULL)
            {
                cout << "No SBL device object.\n";
                goto error;
            }
    
    
            //
            // Connect to device
            //
            cout << "\nConnecting (" << comPort << " @ " << baudRate << " baud) ...\n";
            getTime();
            if (pDevice->connect(comPort, baudRate, bEnableXosc) != SBL_SUCCESS)
            {
                goto error;
            }
            printTimeDelta();
    
        }

    What steps should I take to enable and access this multi-file upload option in the GUI?

    Regards,

    Rajnish

  • Hi Rajnish, 

    The tool can be recompiled - sources are provided as you mentioned. 

    Alternatively, images can be merged prior using the tool. 

    I hope this will help,

    Best regards, 

  • Hi Clément,

    Thanks for your response,

    I tried to rebuild this library using VS Code, but i am facing compilation error.

    The tool can be recompiled - sources are provided as you mentioned. 

    Alternatively, I also tried using a merged image file:

    1. Merged the Hex (BIM + App) using hexmerge.py (successfully generated the merged hex file).
    2. Converted the merged Hex into a Bin file using oad_image_tool.
    3. I can see the converted merged Bin file in the project build directory, but the size of the merged Bin file is the same as the application Bin file.
    4. Successfully flashed the merged Bin file into the device, but the device is not advertising. However, if I flash the same merged Bin file along with the boot project file, it works.
    5. Based on my observations, it seems that the tool is generating the same application Bin file but naming it as the merged Bin file.

    Please find below the post-build steps for the same.

    ${CG_TOOL_ROOT}/bin/tiarmobjcopy -O ihex ${BuildArtifactFileName} ${BuildArtifactFileBaseName}.hex
    ${COM_TI_SIMPLELINK_CC13XX_CC26XX_SDK_INSTALL_DIR}/tools/common/oad/oad_image_tool --verbose ccs ${BuildDirectory} 7 -hex1 ${BuildDirectory}/${BuildArtifactFileBaseName}.hex -k ${COM_TI_SIMPLELINK_CC13XX_CC26XX_SDK_INSTALL_DIR}/tools/common/oad/private.pem -o ${BuildDirectory}/${BuildArtifactFileBaseName}_oad
    python ${COM_TI_SIMPLELINK_CC13XX_CC26XX_SDK_INSTALL_DIR}/tools/ble5stack/hexmerger/scripts/hexmerge.py		-o ${BuildDirectory}/${BuildArtifactFileBaseName}_merged.hex   ${BuildDirectory}/${BuildArtifactFileBaseName}.hex	${BIM_HEX_DIR}/bim_offchip_LP_CC2651P3_nortos_ticlang.hex
    ${COM_TI_SIMPLELINK_CC13XX_CC26XX_SDK_INSTALL_DIR}/tools/common/oad/oad_image_tool --verbose ccs ${BuildDirectory} 7 -h ${BuildDirectory}/${BuildArtifactFileBaseName}_merged.hex   -k ${COM_TI_SIMPLELINK_CC13XX_CC26XX_SDK_INSTALL_DIR}/tools/common/oad/private.pem -o ${PROJECT_ROOT}/${ConfigName}/${ProjName}_merged_oad

    Regards,

    Rajnish

  • Hi Rajnish, 

    I could not identify the issue for now - and I'll be out for two weeks. 

    As a temporary workaround, I'd suggest to flash the two images on a device using the debug interface / UniFlash. After this, you can dump the device flash content to a file and use this file for flashing through the serial boot loader. 

    I hope this will help,

    Best regards, 

  • Hi Clément,

    Thank you for your suggestion regarding the temporary workaround. However, this task is critical, and we cannot afford to wait for two weeks.

    Could you kindly assign this to someone else who can assist us in identifying and resolving the issue promptly? Your support in ensuring timely progress on this task would be greatly appreciated.

    Regards,

    Rajnish 

  • Hi Clément,

    I am now able to successfully upload firmware in bootloader mode using Flash Programmer 2. In Flash Programmer 2, I selected CC2652R as the target device type (since the memory map of CC2651R3 is identical to CC2652R). I first selected the BIM binary file, followed by the application binary file, and assigned addresses 0x56000 and 0x0, respectively, to write the files to custom memory addresses.

    However, when I attempted the same process using Uniflash in bootloader mode, I encountered a limitation. In Uniflash, I am only able to upload one binary file at a time. If I select multiple files, it tries to write both files to the same flash address, resulting in an address overlap error.

    Unlike Flash Programmer 2, Uniflash does not provide an option in bootloader mode to assign custom writing addresses for individual files. This limitation is causing issues in Uniflash.

    Currently, I am using Flash Programmer 2 to upload firmware in bootloader mode.

    Thanks for your support,

    Regards,

    Rajnish