FLASH_Unlock(FLASH_MEMTYPE_DATA);
if(FLASH_ReadOptionByte(0x4800)!=0xaa)
{
FLASH_ProgramOptionByte(0x4800, 0xaa);
}
FLASH_Lock(FLASH_MEMTYPE_DATA);
使用stm8s003f3。
添加这些代码主要初始化,代码保护(ROP)正在设置,但我的应用程序代码无法正常工作。
如果通过IAR或ST Visual Programmer选项字节选项卡设置选项字节,则应用程序代码和代码保护(ROP)都正常工作。
我需要在代码中设置ROP。
答案 0 :(得分:0)
我使用了以下功能:
void Read_Protect_Flash(void)
{
FLASH_SetProgrammingTime(FLASH_PROGRAMTIME_STANDARD);
FLASH_SetProgrammingTime(FLASH_PROGRAMTIME_STANDARD);
while(FLASH_ReadOptionByte(0x4800) != 0xAA)
{
FLASH_Unlock(FLASH_MEMTYPE_DATA);
FLASH_EraseOptionByte(0x4800);
FLASH_ProgramOptionByte(0x4800, 0xAA);
FLASH_Lock(FLASH_MEMTYPE_DATA);
}
}
答案 1 :(得分:0)
FLASH_Unlock(FLASH_MEMTYPE_DATA);
FLASH->CR2 |= FLASH_CR2_OPT;
FLASH->NCR2 &= (u8)(~FLASH_NCR2_NOPT);
OPT->OPT0=0xAA;
FLASH->CR2 &= (u8)(~FLASH_CR2_OPT);
FLASH->NCR2 |= FLASH_NCR2_NOPT;
当我使用它时,问题就解决了。 ROP已启用且代码正在运行。但这可能会导致另一个不可预测的问题。
因为通常情况下,通过当前函数(FLASH_WaitForLastOperation(FLASH_MEMTYPE_DATA);
)设置OPT0等待标记(assert_param(IS_OPTION_BYTE_ADDRESS_OK(Address));
*((NEAR u8*)Address) = FLASH_CLEAR_BYTE;
*((NEAR u8*)(Address + 1 )) = FLASH_SET_BYTE;
)
现在我使用OPT->OPT0=0xAA;,
删除此函数,所以另一个问题是此代码更改后会发生什么。