poor_c 2023-05-15 15:06 采纳率: 0%
浏览 35

stm32flash读保护

stm32l151读保护设置完,读保护生效了,但是主程序无法运行了。

void Flash_EnableReadProtection(void)
{
    FLASH_Unlock();
    FLASH_OB_Unlock();
    
    if(FLASH_GetStatus() == FLASH_ERROR_WRP){
            FLASH_ClearFlag(FLASH_FLAG_EOP|FLASH_FLAG_WRPERR | FLASH_FLAG_PGAERR    \
                                                | FLASH_FLAG_SIZERR | FLASH_FLAG_OPTVERR);
    }    
    if(FLASH_OB_GetRDP() == RESET)
    {
        FLASH_OB_RDPConfig(OB_RDP_Level_1);
        FLASH_OB_Launch();
    }
    FLASH_OB_Lock();
    FLASH_Lock();
}

  • 写回答

4条回答 默认 最新

  • 红色荷包蛋 2023-05-15 16:23
    关注

    如果对你有启发和帮助,请采纳! 答案参考Chatgpt解答

    Flash读保护功能可以保护Flash存储器中的程序代码不被读取或修改,这对于保护程序的机密性和完整性非常重要。然而,设置读保护后,如果没有正确配置保护级别或密钥,可能会导致无法正确运行程序。
    
    在你的代码中,首先你需要确保已经正确解锁了Flash和Option Bytes区域。然后,你使用`FLASH_OB_GetRDP()`函数来检查读保护级别是否已设置为RESET(未保护)。如果已经设置为RESET,那么你通过调用`FLASH_OB_RDPConfig()`函数将读保护级别设置为`OB_RDP_Level_1`。最后,调用`FLASH_OB_Launch()`函数来将读保护配置应用于Flash存储器。
    
    如果在设置读保护后无法正确运行主程序,可能是由于以下原因之一:
    
    1. 读保护级别不正确:请确保你选择了适当的读保护级别。根据你的应用需求,可以选择不同的读保护级别(例如Level 1或Level 2)。
    
    2. 密钥不正确:如果你选择了Level 2的读保护级别,需要提供正确的密钥来解锁Flash。确保密钥的正确性,并在设置读保护之前正确配置密钥。
    
    3. 程序代码与读保护冲突:某些特殊情况下,读保护的设置可能会影响程序的运行。如果你的程序代码访问了被保护的Flash区域,可能会导致异常。请确保程序代码与读保护设置相兼容。
    
    如果遇到主程序无法运行的问题,你可以尝试以下步骤:
    
    1. 检查读保护级别和密钥的正确性,并确保其与你的应用需求一致。
    
    2. 检查程序代码是否与读保护设置相兼容。如果可能的话,尝试将代码移动到未受保护的Flash区域。
    
    3. 尝试在设置读保护之前备份和恢复原始的Option Bytes设置,确保其他设置没有冲突。
    
    4. 如果问题仍然存在,建议通过调试工具(例如SWD调试器)来检查程序运行时的状态和任何异常情况,以帮助确定具体的问题。
    
    
    评论

报告相同问题?

问题事件

  • 创建了问题 5月15日

悬赏问题

  • ¥15 咨询一下有关于王者荣耀赢藏战绩
  • ¥100 求购一套带接口实现实习自动签到打卡
  • ¥50 MacOS 使用虚拟机安装k8s
  • ¥500 亚马逊 COOKIE我如何才能实现 登录一个亚马逊账户 下发新 COOKIE ..我使用下发新COOKIE 导入ADS 指纹浏览器登录,我把账户密码 修改过后,原来下发新COOKIE 不会失效的方式
  • ¥20 玩游戏gpu和cpu利用率特别低,玩游戏卡顿
  • ¥25 oracle中的正则匹配
  • ¥15 关于#vscode#的问题:把软件卸载不会再出现蓝屏
  • ¥15 vimplus出现的错误
  • ¥15 usb无线网卡转typec口
  • ¥30 怎么使用AVL fire ESE软件自带的优化模式来优化设计Soot和NOx?