STM 32如何实现程序自加密

在嵌入式应用开发中,应用开发完成后往往需要对芯片中的程序进行加密处理,用以保护程序安全(不至被竞争对手从芯片把程序固件考走),本节将给大学介绍一个如何实现程序自动给芯片加密功能。下面给大家介绍一个STM32 用程序给MCU加密码的方法:

 

标准库方式:

// 芯片自加密
void FLashProtectCheck(void)
{
    FLASH_Unlock();    // 解锁
    FLASH_UnlockBank1();
    
    
    if( RESET ==  FLASH_GetReadOutProtectionStatus() )
    {
        while( FLASH_COMPLETE != FLASH_ReadOutProtection(ENABLE) );
        // NVIC_SystemReset(); 
    }
    
    FLASH_LockBank1();
    FLASH_Lock();  // 上锁
}

 

HAL 库方式:

// 芯片自加密
void FLashProtectCheck(void)
{
    FLASH_OBProgramInitTypeDef OBInit;
    
    HAL_FLASH_Unlock();     // 解锁
    HAL_FLASH_OB_Unlock();
    
  HAL_FLASHEx_OBGetConfig( &OBInit );
    if( OBInit.RDPLevel !=  OB_RDP_LEVEL_1 )
    {
        OBInit.OptionType = OPTIONBYTE_RDP;
        OBInit.RDPLevel = OB_RDP_LEVEL_1;
        HAL_FLASHEx_OBProgram( &OBInit );
    }
    
    HAL_FLASH_OB_Lock();
    HAL_FLASH_Lock(); // 上锁
}

上面的程序只开启了FLASH的读保护,这样操作后,用外部的工具,如JLINK,STLINK等工具就无法读取芯片的固件了!!

 

 

  • 5
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值