STM 32如何实现程序自加密

本文介绍了使用STM32标准库及HAL库实现芯片自加密的方法。通过设置读保护级别,防止外部工具读取固件,确保程序的安全性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值