历史上的今天
今天是:2025年08月12日(星期二)
2019年08月12日 | STM32-(15):如何用ID号保护自己的劳动成果
2019-08-12 来源:eefocus
怎样进行版权保护?
1.加密:Flash
2.ID号:每个芯片都有独一无二的ID号,类似于人的身份证号码
一般的盗版的方法:
1、电路板连接进行反向设计(PCB板反向设计),然后能设计出一个一模一样的PCB
2、读取原芯片的程序(获取整个Flash数据),然后把整个数据放到新的芯片中去
当程序代码中加入ID号码的判断,就能起到保护的作用
STM芯片中加入了96位的ID (唯一),这个ID号主要作用有:①序列号 ;②安全性(校验ID号之后才能执行某段程代码);③加密(秘钥)
这个ID号放在 0x1FFFF7E8—0x1FFFF7F4,一共12个字节,96位,我们自由选择用到这96位中的部分或者全部
示例代码
/*Include---------------------------*/
#include"stm32f10x_lib.h" //包含所有的头文件
#include //----------------函数声明-------------------- void Delay_MS(u16 dly); void RCC_Configuration(void); void GPIO_Configuration(void); void USART3_Configuration(void); u8 tab[]="nHello! everyone,welcome to class!"; /******************************************************************************* * Function Name : main * Description : Main program. * Input : None * Output : None * Return : None *******************************************************************************/ int main(void) { #ifdef DEBUG debug(); #endif u8 i; u8 ID_num[12]; //u16 data; //------------初始化------------ RCC_Configuration(); GPIO_Configuration(); USART3_Configuration(); //printf("nThe ID: n"); for(i=0;i<12;i++) { ID_num[i] = *(u8 *)(0x1FFFF7E9+i); //printf("%x",ID_num[i]); } //ID 是否等于 ffcd213355313235631243ff 如果等于置标志flag=1 if(flag==1) { ;;;; } //------------向USART3发送数据------------ while(1) ; } /******************************************************************************* * Function Name : Delay_Ms * Description : delay 1 ms. * Input : dly (ms) * Output : None * Return : None *******************************************************************************/ void Delay_MS(u16 dly) { u16 i,j; for(i=0;i } /******************************************************************************* * Function Name : RCC_Configuration * Description : Configures the different system clocks. * Input : None * Output : None * Return : None *******************************************************************************/ void RCC_Configuration(void) { //----------使用外部RC晶振----------- RCC_DeInit(); //初始化为缺省值 RCC_HSEConfig(RCC_HSE_ON); //使能外部的高速时钟 while(RCC_GetFlagStatus(RCC_FLAG_HSERDY) == RESET); //等待外部高速时钟使能就绪 FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); //Enable Prefetch Buffer FLASH_SetLatency(FLASH_Latency_2); //Flash 2 wait state RCC_HCLKConfig(RCC_SYSCLK_Div1); //HCLK = SYSCLK RCC_PCLK2Config(RCC_HCLK_Div1); //PCLK2 = HCLK RCC_PCLK1Config(RCC_HCLK_Div2); //PCLK1 = HCLK/2 RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9); //PLLCLK = 8MHZ * 9 =72MHZ RCC_PLLCmd(ENABLE); //Enable PLLCLK while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET); //Wait till PLLCLK is ready RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //Select PLL as system clock while(RCC_GetSYSCLKSource()!=0x08); //Wait till PLL is used as system clock source //---------打开相应外设时钟-------------------- RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC | RCC_APB2Periph_AFIO,ENABLE); //使能APB2外设的GPIOA的时钟 RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3,ENABLE); } /******************************************************************************* * Function Name : GPIO_Configuration * Description : 初始化GPIO外设 * Input : None * Output : None * Return : None *******************************************************************************/ void GPIO_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; //声明一个结构体变量 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; //选择PC.10(TXD) 和 PC.11 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //管脚频率为50MHZ GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //输出模式为复用推挽输出 GPIO_Init(GPIOC,&GPIO_InitStructure); //初始化GPIOC寄存器 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11; //选择PC.10(TXD) 和 PC.11(RXD) GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //管脚频率为50MHZ GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //输出模式为浮空输入 GPIO_Init(GPIOC,&GPIO_InitStructure); //初始化GPIOA寄存器 //将USART3的TXD和RXD重映射到PC10和pc11 GPIO_PinRemapConfig(GPIO_PartialRemap_USART3,ENABLE); } void USART3_Configuration(void) { USART_InitTypeDef U3; U3.USART_BaudRate =9600; U3.USART_WordLength = USART_WordLength_8b; U3.USART_StopBits = USART_StopBits_1; U3.USART_Parity = USART_Parity_No; U3.USART_Mode = USART_Mode_Rx|USART_Mode_Tx; U3.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_Init(USART3, &U3); USART_Cmd(USART3,ENABLE); } /******************************************************************************* * Function Name : fputc * Description : 重定向这个C库(stdio)printf函数 文件流——》串口USART1 * Input : ch,*f * Output : None * Return : None *******************************************************************************/ int fputc(int ch,FILE *f) { //ch送给USART1 USART_SendData(USART3, ch); //等待发送完毕 while(USART_GetFlagStatus(USART3, USART_FLAG_TC)==RESET) ; //返回ch return(ch); }
史海拾趣
|
这是一个分辩率达1Hz的2G频率计,大家在自作过程中,有什么不懂的地方,我们可以相互交流 [ 本帖最后由 liuyan_12 于 2009-7-7 09:33 编辑 ]… 查看全部问答> |
|
搞不定了,不得不发帖求助了!——OV2640 200W 摄像头驱动问题 平台 2440 wince6.0 其实这个驱动是4.2BSP下的,我直接搬上来用了。 是比较简单的那种,是单层的。 初始化代码太多了,我就不发了,我发个图片上来让大家提供点思路。 问题一、摄像头中断产生正常,踩到的图像是一片绿色,在摄像头前面放置任何 ...… 查看全部问答> |
|
正在链接... imaging.lib(dllentry.obj) : error LNK2019: unresolved external symbol GpMalloc referenced in function \"void * __cdecl operator new(unsigned int)\" (??2@YAPAXI@Z) imaging.lib(dllentry.obj) : error LNK2019: unresolved ...… 查看全部问答> |
|
本人因项目原因要第一次自己绘制PCB,到底能不能用自动布线呢? 我在为学校制作赛普林斯PSOC 3的一款开发板,原理图设计好了,使用的软件是ALTIUM DESIGNER 6.9,在这里要向有经验的大虾请教了,到底要不要使用自动布线这个功能呢,有的说布局好的情况下可以使用,有的说不能用,我尝试使用了下,感 ...… 查看全部问答> |
|
我公司是国际领先的光电检测设备研发生产厂商,员工500余人,坐落于美丽的浙江杭州,也是一家拟上市公司。 现急招电子工程师10名,年薪7-25W,要求精通模拟电路,有较强的承压能力与学习能力。   ...… 查看全部问答> |




