代码中的stm8读出保护(ROP)设置选项字节

时间:2017-09-15 11:45:20

标签: c iar source-code-protection stm8

    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。

2 个答案:

答案 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;,删除此函数,所以另一个问题是此代码更改后会发生什么。