一.加读锁py32使用hal库,带有两个等级的读保护
#define OB_RDP_LEVEL_0 ((uint8_t)0xAAU)
#define OB_RDP_LEVEL_1 ((uint8_t)0x55U)
使用OB_RDP_LEVEL_0,程序无锁,可任意读取或擦写程序
使用OB_RDP_LEVEL_1,读保护生效,此时将无法再烧录程序,无法读程序,强制更改等级,将擦除芯片内部程序,从而起到保护原创代码作用;
请配合普冉该芯片的说明书进行理解操作
二.读保护
注意,读保护不仅仅是保护程序不被读取,也会让芯片无法重新烧录,可以使用专门的烧录工具,如pylink工具配合对应软件,强制更改选项字节保护等级,但同时也会让程序被擦除;
代码如下
static void Flash_Unlock(void)//打开选项字节保护锁以及flash保护锁,从而更改保护权限
{
HAL_FLASH_Unlock();
HAL_FLASH_OB_Unlock();
}
static void Flash_Lock(void)//关闭选项字节保护锁以及flash保护锁,从而防止意外更改
{
HAL_FLASH_OB_Lock();
HAL_FLASH_Lock();
}
static void OB_RDP_Config(uint8_t enable)//选择打开或者关闭保护锁,没有专门的烧录工具,请谨慎使用打开读保护,可以配合按键,取消读保护,从而避免无法烧录情况出现
{
FLASH_OBProgramInitTypeDef OBType;
HAL_FLASH_OBGetConfig(&OBType);
if ((enable && OBType.RDPLevel == OB_RDP_LEVEL_0) || (!enable && OBType.RDPLevel == OB_RDP_LEVEL_1))
{
Flash_Unlock();
OBType.RDPLevel = enable ? OB_RDP_LEVEL_1 : OB_RDP_LEVEL_0;
HAL_FLASH_OBProgram(&OBType);
Flash_Lock();
}
}
三.写保护
流程跟读保护相似,但需要对特定扇区进行设置是否启用写保护,例如代码里面的OBInit.WRPSector = enable ? ((1 << 3) | (1 << 4) | (1 << 5)) : 0;就是对扇区3.4.5进行保护;
static void OB_WRP_Config(uint8_t enable)
{
FLASH_OBProgramInitTypeDef OBInit;
HAL_FLASH_OBGetConfig(&OBInit);
if ((enable && OBInit.WRPSector == 0) || (!enable && OBInit.WRPSector != 0))
{
Flash_Unlock();
OBInit.OptionType = OPTIONBYTE_WRP;
OBInit.WRPSector = enable ? ((1 << 3) | (1 << 4) | (1 << 5)) : 0;
HAL_FLASH_OBProgram(&OBInit);
Flash_Lock();
}
}
验证:
重新烧录程序,烧录失败说明读写锁已生效;
编写写入数据测试,写入失败说明写保护生效;
注意:更改选项字内容,都需要上电复位才能生效!!!!