本帖最后由 freeelectron 于 2022-3-4 18:17 编辑
1、关于电子签名
设备的电子签名中包含的存储容量信息和96位的唯一设备ID。它被存储在片上闪存的信息模块 中。96位唯一设备ID对于每颗芯片而言都是唯一的。它可以用作序列号,或安全密钥的一部分, 等等。
2、96位唯一ID和Flash大小
96位ID信息,地址依次为0x1FFFF7E8、0x1FFFF7EC、0x1FFFF7F0; flash大小信息,地址依次0x1FFF F7E0; 设备出厂的时候,已经固化在mcu内部的,用户不可更改。
3、程序读取#define STORAGE_INFO 0x1FFFF7E0
#define STORAGE_INFO_SRAM
#define STORAGE_INFO_FLASH
#define UNIQUE_ID 0x1FFFF7E8
#define UNIQUE_ID_0_31 0x1FFFF7E8
#define UNIQUE_ID_32_63 0x1FFFF7EC
#define UNIQUE_ID_64_95 0x1FFFF7F0
struct McuInfo_t
{
uint32_t Size;
uint8_t UniqueId[12];
}McuInfo;
void GetMcuInfo(void)
{
McuInfo.Size=*(uint32_t*)STORAGE_INFO;
printf("flash size=%dk\r\n\r\n",McuInfo.Size);
printf("unique id:[");
for(uint8_t i=0;i<12;i++)
{
McuInfo.UniqueId[i]=*(uint8_t*)(UNIQUE_ID+i);
printf(" %02x",McuInfo.UniqueId[i]);
}
printf("]\r\n");
}
4、实验现象
可以看出,程序读取的和调试器调试读取的一致。
|