datasheet

STM32学习之:读取芯片的唯一标识ID

2018-10-21来源: eefocus关键字:STM32  读取芯片  唯一标识ID

产品唯一的身份标识的作用:


    ●  用来作为序列号(例如USB字符序列号或者其他的终端应用);


    ●  用来作为密码,在编写闪存时,将此唯一标识与软件加解密算法结合使用,提高代码在闪存存储器内的安全性;


    ●  用来激活带安全机制的自举过程;


     96位的产品唯一身份标识所提供的参考号码对任意一个STM32微控制器,在任何情况下都是唯一的。用户在何种情况下,都不能修改这个身份标识。按照用户不同的用法,可以以字节(8位)为单位读取,也可以以半字(16位)或者全字(32位)读取。嘿嘿,要注意大端小端模式哟~~~


以下是相关代码:


* 函数名:Get_ChipID


 * 描述  :获取芯片ID


 * 输入  :无


 * 输出  :无


 * 说明  :96位的ID是stm32唯一身份标识,可以以8bit、16bit、32bit读取


           提供了大端和小端两种表示方法


void Get_ChipID(void)


{


#if 1


    u32 ChipUniqueID[3];


     地址从小到大,先放低字节,再放高字节:小端模式


     地址从小到大,先放高字节,再放低字节:大端模式


 ChipUniqueID[2] = *(__IO u32*)(0X1FFFF7E8);  // 低字节


 ChipUniqueID[1] = *(__IO u32 *)(0X1FFFF7EC); // 


 ChipUniqueID[0] = *(__IO u32 *)(0X1FFFF7F0); // 高字节


 printf("######## 芯片的唯一ID为: X-X-X  rn",ChipUniqueID[0],ChipUniqueID[1],ChipUniqueID[2]);


          //此条语句输出32位


#else   //调整了大小端模式,与ISP下载软件的一致


    u8 temp[12];   


    u32 temp0,temp1,temp2;


    temp0=*(__IO u32*)(0x1FFFF7E8);    //产品唯一身份标识寄存器(96位)


    temp1=*(__IO u32*)(0x1FFFF7EC);


    temp2=*(__IO u32*)(0x1FFFF7F0);


    temp[0] = (u8)(temp0 & 0x000000FF);


    temp[1] = (u8)((temp0 & 0x0000FF00)>>8);


    temp[2] = (u8)((temp0 & 0x00FF0000)>>16);


    temp[3] = (u8)((temp0 & 0xFF000000)>>24);


    temp[4] = (u8)(temp1 & 0x000000FF);


    temp[5] = (u8)((temp1 & 0x0000FF00)>>8);


    temp[6] = (u8)((temp1 & 0x00FF0000)>>16);


    temp[7] = (u8)((temp1 & 0xFF000000)>>24);


    temp[8] = (u8)(temp2 & 0x000000FF);


    temp[9] = (u8)((temp2 & 0x0000FF00)>>8);


    temp[10] = (u8)((temp2 & 0x00FF0000)>>16);


    temp[11] = (u8)((temp2 & 0xFF000000)>>24);


    printf("######## STM32芯片ID为: %.2X%.2X%.2X%.2X-%.2X%.2X%.2X%.2X-%.2X%.2X%.2X%.2X rn",


  temp[0],temp[1],temp[2],temp[3],temp[4],temp[5],temp[6],temp[7],temp[8],temp[9],temp[10],temp [11]); //串口打印出芯片ID


#endif


}


 * 函数名:Get_ChipInfo(void)


 * 描述  :获取芯片Flash 大小


 * 输入  :无


 * 输出  :无


 * 说明  :


void Get_ChipInfo(void)


{


   uint32_t ChipUniqueID[3];


  u16 STM32_FLASH_SIZE;


   ChipUniqueID[0] = *(__IO u32 *)(0X1FFFF7F0); // 高字节


   ChipUniqueID[1] = *(__IO u32 *)(0X1FFFF7EC); //


   ChipUniqueID[2] = *(__IO u32 *)(0X1FFFF7E8); // 低字节


   STM32_FLASH_SIZE= *(u16*)(0x1FFFF7E0);    //闪存容量寄存器  


   printf("rn########### 芯片的唯一ID为: %X-%X-%X n",


           ChipUniqueID[0],ChipUniqueID[1],ChipUniqueID[2]);  


   printf("rn########### 芯片flash的容量为: %dK n", STM32_FLASH_SIZE);


   printf("rn########### 烧录日期: "__DATE__" - "__TIME__"n");


      //输出使用固件库版本号


  printf("rn########### 代码固件库版本: V %d.%d.%d n",__STM32F10X_STDPERIPH_VERSION_MAIN,__STM32F10X_STDPERIPH_VERSION_SUB1,__STM32F10X_STDPERIPH_VERSION_SUB2);  


}


关键字:STM32  读取芯片  唯一标识ID

编辑:什么鱼 引用地址:http://www.eeworld.com.cn/mcu/2018/ic-news102141966.html
本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:STM32学习之:stm32中C语言的数据类型
下一篇:STM32学习笔记:FSMC详述

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

STM32堆栈设置

1.堆和栈大小 定义大小在startup_stm32f2xx.sStack_Size      EQU     0x00000400                AREA    STACK, NOINIT, READWRITE, ALIGN=3Stack_Mem      
发表于 2019-04-16
STM32堆栈设置

STM32堆和栈(Heap & Stack)的资料理解

源起:在移植cjson的过程中,解析json包的时候发现动态内存分配不足而导致解析失败,为解决这一问题,而深入了解stm32的堆和栈。stm32的存储器结构。Flash,SRAM寄存器和输入输出端口被组织在同一个4GB的线性地址空间内。可访问的存储器空间被分成8个主要块,每个块为512MB。FLASH存储下载的程序。SRAM是存储运行程序中的数据。而SRAM一般分这几个部分:静态存储区:内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。它主要存放静态数据、全局数据和常量。栈区:在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率
发表于 2019-04-16
STM32堆和栈(Heap & Stack)的资料理解

STM32定义堆栈地址到ram区顶部

本设置针对stm32f103rbt6的设置,该芯片RAM大小为20kB,故RAM区地址范围为0x20000000—0x20005000,芯片信息如下图所示;第一步:设置.sct文件;;*************************************************************; *** Scatter-Loading Description Filegenerated by uVision ***; *************************************************************LR_IROM1 0x08000000 0x00020000  
发表于 2019-04-16
STM32定义堆栈地址到ram区顶部

STM32之程序如何防止堆栈溢出

近日为某个项目写了个草稿程序,即非正式程序,后来发现老是进入hardfaulthandler,原来是堆栈溢出,后仔细查看发现函数调用纵深太深,最多的时候可保持7个函数在堆栈中调用。因此有心得如下:一、函数调用不要纵深太深,即以下模式:main(){   fun1();}fun1(){  fun2();}fun2(){   fun3();}fun3(){  fun4();}fun4(){  fun5();}fun5(){  fun6();}fun6(){   fun7();}这样子main函数要调用fun1函数完成某个功能,则要一直调到
发表于 2019-04-16

stm32之堆栈

stm32中的堆栈设置keil编译完成时存储情况当编译成功时,会出现: BUILD://Program Size: Code=340 RO-data=252 RW-data=0 ZI-data=1632Code:程序代码部分RO-data: 程序定义的常量const tempRW-data:已初始化的全局变量ZI-data:未初始化的全局变量片中的:flash=Code+RO-data+RW-dataRAM=RW-data+ZI-data通过上面的BUILD可以看出,这个程序已经用了1600多的RAM,为什么会出用到这么多的RAM呢?在startup_stm32f10x_md.s文件中存在:St
发表于 2019-04-16

说说STM32的堆栈与内存

1.概念这里所说的堆栈,是针对单片机所说的“堆”与“栈”,指的是内存中一片特殊用途的区域。而不是数据结构中的堆栈(虽然其实规则一样)。这里所说的内存,是指RAM,RAM包括SRAM,DRAM等。而不是什么手机内存卡之类。这里所说的flash,指的是用作为ROM的存储器,保存代码与常量数据。而不是动画制作。。。栈的生长方向:指的是入栈方向,从高地址向低地址生长叫做向下生长,或逆向生长;反过来就叫向上生长,或正向生长。STM32的栈是向下生长。2.内存中的堆栈安排确切地说,是keil mdk根据STM32的特性,对stm32的RAM甚至flash进行部署。编译工程后,在生成的.map文件里可以看到具体的安排。双击工程界面的工程根目录
发表于 2019-04-16
说说STM32的堆栈与内存

小广播

何立民专栏

单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2019 EEWORLD.com.cn, Inc. All rights reserved