This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

CC2652R: onchip 的OAD升级问题

Part Number: CC2652R

查看官网的BLE5-Stack用户向导的BIM for On-Chip OAD (Stack Library)章节,然后又查看了SDK(simplelink_cc13x2_26x2_sdk_5_20_00_52)中bim_onchip_CC26X2R1_LAUNCHXL_nortos_ticlang的工程,发现其main()中的实现与用户向导中的描述有许多不符,猜测可能SDK的工程中改写了算法,而用户向导未改,bim_onchip工程的主要内容如下

1、首先bim会调用Bim_findImage函数,在flash的第0页搜索用户应用程序(镜像类型OAD_IMG_TYPE_APPSTACKLIB),如果成功(即镜像头中的镜像类型正确、镜像验证字段0的个数为偶数、CRC和安全验证都通过),则调用用户应用程序而不返回main()函数

2、如果上述的操作失败,则返回到bim_main()函数,再次调用Bim_findImage函数,从flash的第1页开始搜索持久应用程序(镜像类型OAD_IMG_TYPE_PERSISTENT_APP),如果第1页没有找到,则继续寻找第2页,直到结束。如果成功(即镜像头中的镜像类型正确、镜像验证字段0的个数为偶数、CRC和安全验证都通过),则调用持久应用程序而不返回main()函数,从而下载新的用户程序镜像。如果失败则返回main()函数,调用setLowPowerMode()函数进入低功耗。

总结1:bim选择运行用户应用程序还是持久应用程序时,是通过第0页的用户应用程序的镜像头中的镜像验证字段的0的个数的奇偶数判断的,而持久应用程序的镜像验证字段的0的个数一直为偶数,永远不会改变。

总结2:bim总是先从flash的第0页搜索用户应用程序,如果失败(包括镜像验证字段0的个数不为偶数),会再从第2个扇区开始寻找持久应用程序

推断:用户应用程序接收到中央设备的OAD重置服务后,会将自己的镜像验证字段0的个数改为不是偶数(反转一个位),然后重启设备,这样设备重启之后,搜索用户应用程序会失败(因为镜像验证字段0的个数不为偶数),则继续寻找持久应用程序进行下载镜像

总结3:在用户向导中介绍图211的流程说明中的第7步中有提到复制新的用户镜像。但通过分析bim_onchip工程,并未找到相应的代码,因此有个疑问:复制新的用户镜像到什么地方?因此推测,在通过持久应用程序OAD升级新的程序时,直接复制到原有的用户应用程序的地址,即从flash的第0页开始。这样如果在升级过程中断电,则用户应用程序不能够运行,一致停留在持久应用程序中等待升级

下面代码即我删掉不必要的条件编译后的bim_onchip工程中的main函数

int main(void)
{
    /* Read and populate the static variable intFlashPageSize */
    intFlashPageSize = FlashSectorSizeGet();

    uint8_t imgType;
    uint8_t flashPgNum;

    /*
     * First look for an application image
     */
    imgType = OAD_IMG_TYPE_APPSTACKLIB;

    flashPgNum = 0x00;

    Bim_findImage(flashPgNum, imgType);

    /*
     * If the application image isn't found, look for a persistent image
     */
    imgType = OAD_IMG_TYPE_PERSISTENT_APP;

    flashPgNum++;

    while(flashPgNum < MAX_ONCHIP_FLASH_PAGES)
    {
        Bim_findImage(flashPgNum, imgType);
        flashPgNum++;
    }

    /* If we get here, that means there is an Issue: No valid image found */
    
    /* Set the device to the lowest power state. Does not return. */
    setLowPowerMode();

    return(0);
} /* end of main function */