嵌入式学习(20)-STM32的ID号读取
在STM32的全系列MCU中均有一个96位的唯一设备标识符。在ST的相关资料中,对其功能的描述有3各方面:用作序列号(例如 USB 字符串序列号或其它终端应用程序)在对内部 Flash 进行编程前将唯一 ID 与软件加密原语和协议结合使用时用作安全密钥以提高 Flash 中代码的安全性激活安全自举过程等在资料中对其特性的描述是:96 位的唯一设备标识符提供了一个对于任何设备和任何上下文都唯一的参考
·
一、概述
在STM32的全系列MCU中均有一个96位的唯一设备标识符。在ST的相关资料中,对其功能的描述有3各方面:用作序列号(例如 USB 字符串序列号或其它终端应用程序)
在对内部 Flash 进行编程前将唯一 ID 与软件加密原语和协议结合使用时用作安全密钥以提高 Flash 中代码的安全性激活安全自举过程等
在资料中对其特性的描述是:96 位的唯一设备标识符提供了一个对于任何设备和任何上下文都唯一的参考号码。用户永远不能改变这些位。96 位的唯一设备标识符也可以以单字节/半字/字等不同方式读取,然后使用自定义算法连接起来。
二、应用
STM32F1xxx系列
三、代码实现
uint32_t ID_H=* ( uint32_t * ) ( 0x1ffff7e8 );
uint32_t ID_M=* ( uint32_t * ) ( 0x1ffff7ec );
uint32_t ID_L=* ( uint32_t * ) ( 0x1ffff7F0 );
printf("%08X-%08X-%08X\r\n",ID_H,ID_M,ID_L);
运行结果
四、参考链接:
更多推荐
所有评论(0)