#define FLASH_ID_OFFSET 30000? ? //任意定義一個數
//把地址直接減去或者加上一個數是不要程序中直接出現這個地址
volatile u32 Flash_ID_addr[3]={??
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 0x1FFFF7E8 - FLASH_ID_OFFSET,?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 0x1FFFF7EC + FLASH_ID_OFFSET,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 0x1FFFF7F0 - FLASH_ID_OFFSET
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? };
?
/**讀取STM32 FLASH ID**/
void Flash_Read_ID(u32 *p)
{
? u32 Addr;
? //因為不想讓程序在反匯編后直接找到這個地址,所以這個地址是運算出來
? //的,跟STM_ID_addr反運算,當然也可以用其他高級算法,不能讓編譯器
? //優化這個地址
? Addr = Flash_ID_addr[0] + FLASH_ID_OFFSET;
? p[0] = *(u32*)(Addr);
? Addr = Flash_ID_addr[1] - FLASH_ID_OFFSET;
? p[1] = *(u32*)(Addr);
? Addr = Flash_ID_addr[2] + FLASH_ID_OFFSET;
? p[2] = *(u32*)(Addr);
}
/*加密ID并保存*/
void Encrypted_ID(void)
{
? u32 FlashID[3],data;
? Flash_Read_ID(FlashID);
? //這里可以用其他一些高級算法,但減和加要一樣
??
? data=(FlashID[0]|FlashID[1]|FlashID[2])&(~FlashID[1])|(~FlashID[2]);
? FLASH_Unlock();
? FLASH_ErasePage(FLSAH_EN_ID_START_ADDR);
? FLASH_ProgramWord(FLSAH_EN_ID_START_ADDR,dat);//保存這個數
? FLASH_Lock();
}
/*比較加密ID,正確返回0 不正確返回1*/
u32 CMP_Encrypted_ID(void)
{
? u32 FlashID[3],data1,dat2;
? Flash_Read_ID(FlashID);
? //這里可以用其他高級算法,但減和加要一樣
? data1=(FlashID[0]|FlashID[1]|FlashID[2])&(~FlashID[1])|(~FlashID[2]);
? data2 = *(u32*)(FLSAH_EN_ID_START_ADDR);
? if(data1==data2) //相同
? ? return 0;
? else? ? ? ? ?//不同
? ? return 1;
}
//ID加密控制
if(CMP_Encrypted_ID())
{
? //生產時給一些條件,條件滿足就對ID加密,加密完后,也可以讓它自宮
? if(****)
? {
? ? Encrypted_ID();
? ? .....
? ? 自宮
? }
}
//校驗ID是否正確
if(CMP_Encrypted_ID())
{
? 程序來到這里當然不正確了,不要讓程序死在這里。一個系統肯定有
? 一些參數才能運行的,你可以改變一些參數,可以讓系統有時正常有
? 時不正常。
}
?