打印
[开发工具]

STM32 加密保护程序总结

[复制链接]
326|0
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
tpgf|  楼主 | 2024-4-10 17:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
一、flash 读保护加密
1、hal库:

void Flash_EnableReadProtection(void)

{

  FLASH_OBProgramInitTypeDef OBInit;

  __HAL_FLASH_PREFETCH_BUFFER_DISABLE();

  HAL_FLASHEx_OBGetConfig(&OBInit);

  if(OBInit.RDPLevel == OB_RDP_LEVEL_0)

  {

    OBInit.OptionType |= OPTIONBYTE_RDP;

    OBInit.RDPLevel = OB_RDP_LEVEL_1;

    HAL_FLASH_Unlock();

    HAL_FLASH_OB_Unlock();

    HAL_FLASHEx_OBProgram(&OBInit);

      HAL_FLASH_OB_Launch();//必须添加这个,不然读保护设置不生效

    HAL_FLASH_OB_Lock();

    HAL_FLASH_Lock();

  }

  __HAL_FLASH_PREFETCH_BUFFER_ENABLE();

}


void Flash_DisableReadProtection(void)

{

  FLASH_OBProgramInitTypeDef OBInit;

  __HAL_FLASH_PREFETCH_BUFFER_DISABLE();

  HAL_FLASHEx_OBGetConfig(&OBInit);

  if(OBInit.RDPLevel == OB_RDP_LEVEL_1)

  {

    OBInit.OptionType |= OPTIONBYTE_RDP;

    OBInit.RDPLevel = OB_RDP_LEVEL_0;

    HAL_FLASH_Unlock();

    HAL_FLASH_OB_Unlock();

    HAL_FLASHEx_OBProgram(&OBInit);

    HAL_FLASH_OB_Launch(); //必须添加这个,不然去保护不生效

    HAL_FLASH_OB_Lock();

    HAL_FLASH_Lock();

  }

  __HAL_FLASH_PREFETCH_BUFFER_ENABLE();

}




在main函数初始化中调用,下载后要上电复位一次才能工作,看资料说用reset引脚做的是外部复位是属于系统复位所以不行,但没有进行验证。
————————————————

                            版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/weixin_44131352/article/details/137008307

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1923

主题

15596

帖子

11

粉丝