问答

汇集网友智慧,解决技术难题

21ic问答首页 - CW32L010使能读保护后标志位不正确

读保护 CW32L010 flash ev LEVEL se

CW32L010使能读保护后标志位不正确

精灵魔仙2025-05-19
本帖最后由 精灵魔仙 于 2025-5-20 08:16 编辑

手头测试的是TSSOP20,使用官方库 void FLASH_SetReadOutLevel(uint16_t RdLevel) 设置为 FLASH_RDLEVEL1,系统会自动重启,但是重启后使用FLASH_GetReadOutLevel()读取值还是为0,查看是读取的 FLASH_CR1.SECURITY。

使能 FLASH_RDLEVEL1 后,尽管标志位FLASH_CR1.SECURITY为0,但是看起来读保护是起作用的,此时使用SWD无法写入,通过ISP下发0x30清除读保护后,可以继续SWD写入。









回答 +关注 5
4953人浏览 18人回答问题 分享 举报
18 个回答
  • 看起来像是FLASH_CR1.SECURITY位没有正确设置,可能需要检查一下代码逻辑是否有误。
  • 看起来像是FLASH_CR1.SECURITY位没有正确设置,你可以尝试检查一下代码中是否有遗漏或者错误。
  • 看起来像是FLASH_CR1.SECURITY位没有正确设置,可能是库函数的bug或者硬件问题。建议检查库函数的实现和硬件连接。
  • 精灵魔仙 发表于 2025-5-21 12:05
    原次数确实已经用尽,使用新的芯片该部分是全FF。当使能读保护后,FLASH_GetReadOutLevel() 会返回1. 可以 ...

    居然还有一个读保护的操作有效次数限制呀,这个问题要是不问技术支持,估计一时半会还真想不到
    dffzh 2025-5-26 11:24 回复TA
    @精灵魔仙 其他行业不清楚,反正软件开发过程中会经常踩坑,特别是刚接触新MCU芯片的时候,也算是一种实战经验吧。 
    精灵魔仙 2025-5-24 14:21 回复TA
    国内MCU厂商最大的问题,不是怕坑,而是有坑不告诉你。非重要设备用用。 
  • 精灵魔仙 发表于 2025-5-21 12:05
    原次数确实已经用尽,使用新的芯片该部分是全FF。当使能读保护后,FLASH_GetReadOutLevel() 会返回1. 可以 ...

    代码读保护的有效次数用尽之后,以最后一次的保护等级为准,如果是0,则无法进行读保护;如果是1~3,则读保护仍然有效。
  • 本帖最后由 精灵魔仙 于 2025-5-21 12:12 编辑
    pssyx 发表于 2025-5-21 10:18
    CW32L010代码读保护的有效次数只有48次,次数用完之后,读保护就失效了。但此状况与你反馈的现象完全不同 ...

    原次数确实已经用尽,使用新的芯片该部分是全FF。当使能读保护后,FLASH_GetReadOutLevel() 会返回1. 可以澄清返回0是用尽的问题。当用尽后,再调用官方的 FLASH_SetReadOutLevel() 函数就会死循环,建议此函数中添加次数是否用尽的检查。
    现在的疑问:
    48次的限制,是否意味着48次加保护,去保护操作之后,芯片就只能处于非读保护状态了?
    48次读保护限制应该是你们的SPEC,希望写入官方文档,方便用户解惑。



  • 精灵魔仙 发表于 2025-5-21 09:31
    麻烦有空再确认下这个问题,该问题决定着是否要采用CW32L010方案。谢谢

    CW32L010代码读保护的有效次数只有48次,次数用完之后,读保护就失效了。但此状况与你反馈的现象完全不同。
    1、请检查一下读保护次数,附图是48次用尽的情况,其地址为0x100730~0x10075F。
    2、你之前所言,读保护已生效,但CR1.security为0,是如何得知,请告之操作流程,且截图FLASH & SYSCTRL。
    3、建议批量生产时,再使能读保护功能。
  • pssyx 发表于 2025-5-20 15:19
    CW32L010代码读保护示例,请参考!

    麻烦有空再确认下这个问题,该问题决定着是否要采用CW32L010方案。谢谢
  • 本帖最后由 精灵魔仙 于 2025-5-20 17:01 编辑

    以上代码,和我验证的用的代码基本是一致,这里用的是 SYSCTRL_AHBPeriphClk_Enable(SYSCTRL_AHB_PERIPH_FLASH, ENABLE),功能和__SYSCTRL_FLASH_CLK_ENABLE();是一样的。

    这边直接使用以上代码,会导致不停重启,因为在FLASH_SetReadOutLevel(FLASH_RDLEVEL1) 中,因为会调用 FLASH_GetReadOutLevel(),它总是返回0,和 FLASH_RDLEVEL1 不同,就会每次都执行读保护,并重启。可以在 while(1) 里面如下所示多加几个delay, 可以看到LED的闪烁频率不会有任何改变,因为while(1)循环根本跑不到。

    另外这边用的TSSOP20 CW32L010,其他型号没有验证过。

        __SYSCTRL_FLASH_CLK_ENABLE();
        FLASH_SetReadOutLevel(FLASH_RDLEVEL1);

        while(1)
        {
          GPIO_TogglePin(LED_GPIO_PORT, LED_GPIO_PINS);
          Delay(0xFFFF);
          Delay(0xFFFF);
          Delay(0xFFFF);
        }

    void FLASH_SetReadOutLevel(uint16_t RdLevel)
    {
        assert_param(IS_FLASH_RDLEVEL(RdLevel));

        if(FLASH_GetReadOutLevel() != RdLevel) // 此处的FLASH_GetReadOutLevel() 总是返回0,这就是奇怪的地方,第一次返回0,重启后应该返回1才对
        {
            RdLevel = 0x5A50 | (RdLevel & 0x03u);
            *((volatile uint32_t*)(0x4000431C)) = RdLevel;
            *((volatile uint32_t*)(0x40004370)) = 0x5A5AABCD;   //MCU重启以更新读保护等级

            while(1);  //MCU重启以更新保护等级
        }
    }


12下一页

您需要登录后才可以回复 登录 | 注册