0
    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。

4

2 回答 2

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);
    }
}
于 2017-09-18T06:22:09.723 回答
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 已启用并且代码正在运行。但这可能会导致另一个不可预测的问题。

因为通常情况下,通过当前函数()设置 OPT0 时,FLASH_WaitForLastOperation(FLASH_MEMTYPE_DATA);等待标志( assert_param(IS_OPTION_BYTE_ADDRESS_OK(Address)); *((NEAR u8*)Address) = FLASH_CLEAR_BYTE; *((NEAR u8*)(Address + 1 )) = FLASH_SET_BYTE;

现在我删除了这个函数的使用OPT->OPT0=0xAA;,,所以另一个问题是这个代码更改后会发生什么。

于 2017-09-18T10:58:50.390 回答