历史上的今天
返回首页

历史上的今天

今天是: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 for(j=1000;j>0;j--);

}


/*******************************************************************************

* 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);

}

在这里插入图片描述

推荐阅读

史海拾趣

BULGIN公司的发展小趣事

在1939年至1945年的二战期间,BULGIN的产能被英国政府全面征用。为了满足战时需求,BULGIN公司开发出能够适应全世界各地区苛刻使用环境的产品。在这段时间里,公司为英国政府制造了超过1千万只零部件,并在密封技术领域积累了宝贵的经验,这些经验一直延续至今。

DIOTEC公司的发展小趣事

1973年,DIOTEC半导体股份有限公司在德国的海特尔斯海姆正式成立。公司创始人以半导体和整流产品的研发为起点,立志在电子行业中占据一席之地。在创立初期,DIOTEC就注重技术创新和品质控制,不断推出符合市场需求的高品质产品。凭借这种执着和坚持,DIOTEC逐渐在欧洲市场崭露头角。

ERP公司的发展小趣事

随着云计算和大数据技术的兴起,电子智链在2010年代初期开始了技术转型。公司投入大量资源研发基于云计算的ERP系统,并在2015年成功推出“云链”系列产品。这一产品迅速受到市场的欢迎,电子智链的客户群迅速扩大,不仅涵盖了中小型企业,还吸引了众多大型电子集团。同时,公司也在国际市场上积极扩张,与多家海外企业建立了合作关系。

FASTRAX公司的发展小趣事

随着公司业务的不断发展,FASTRAX开始积极拓展海外市场,并与多家国际知名企业建立了战略合作关系。通过与这些企业的合作,FASTRAX不仅获得了更多的市场份额,也学习到了先进的管理经验和技术知识。这些合作经验为FASTRAX的持续发展奠定了坚实的基础。

C&H Technology公司的发展小趣事

随着公司的不断发展壮大,C&H Technology开始关注可持续发展问题。公司加大了对环保技术的研发投入,推出了多款环保型芯片产品,降低了生产过程中的能耗和排放。同时,公司还积极参与社会公益事业,通过捐款、设立奖学金等方式回馈社会。这些举措不仅提升了公司的社会形象,也为公司的长期发展奠定了坚实的基础。


以上便是关于C&H Technology公司发展起来的相关故事。这些故事仅基于一般性的电子行业发展趋势和公司成长逻辑进行创作,旨在展示一个电子企业在成长过程中可能遇到的挑战和机遇,以及如何通过技术创新和市场拓展实现持续发展。

东软载波(EastSoft)公司的发展小趣事

东软载波公司成立于1993年,自成立之初就专注于电力载波通信技术的研发。公司在1996年开始了电力线载波通信技术的深入研究,经过数年的努力,终于在2000年推出了第一代电力线载波通信芯片。这一成果标志着东软载波在电力载波通信领域取得了重要突破,为其后续发展奠定了坚实的基础。

问答坊 | AI 解惑

mpeg和mp3技术发展

本帖最后由 jameswangsynnex 于 2015-3-3 19:58 编辑 大家看看,不错的 …

查看全部问答>

分辩率达1Hz的2G频率计

这是一个分辩率达1Hz的2G频率计,大家在自作过程中,有什么不懂的地方,我们可以相互交流 [ 本帖最后由 liuyan_12 于 2009-7-7 09:33 编辑 ]…

查看全部问答>

电子商务转到嵌入式开发,求发展

        我参加的嵌入式培训转到了这行,现在一家公司做QT开发。我想往底层发展,把嵌入式学通,求前辈指点~…

查看全部问答>

搞不定了,不得不发帖求助了!——OV2640 200W 摄像头驱动问题

平台 2440 wince6.0 其实这个驱动是4.2BSP下的,我直接搬上来用了。 是比较简单的那种,是单层的。 初始化代码太多了,我就不发了,我发个图片上来让大家提供点思路。 问题一、摄像头中断产生正常,踩到的图像是一片绿色,在摄像头前面放置任何 ...…

查看全部问答>

51单片机设计闹钟时,在闹钟到时后,如何编写音乐子程序。

我设计了一个闹钟,闹钟到时后播放音乐,但这个音乐播放后如何返回主程序呢?…

查看全部问答>

iimage的链接错误?

正在链接... 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,在这里要向有经验的大虾请教了,到底要不要使用自动布线这个功能呢,有的说布局好的情况下可以使用,有的说不能用,我尝试使用了下,感 ...…

查看全部问答>

STM32F面向电机控制的矢量控制算法,ST能提供吗?

                                 STM32F面向电机控制的矢量控制算法,ST能提供吗?…

查看全部问答>

年薪7W-25W急聘模电工程师(电子工程师)

我公司是国际领先的光电检测设备研发生产厂商,员工500余人,坐落于美丽的浙江杭州,也是一家拟上市公司。         现急招电子工程师10名,年薪7-25W,要求精通模拟电路,有较强的承压能力与学习能力。   ...…

查看全部问答>

寻找ARM芯片周边电路设计的资料

     想寻找ARM版周边电路设计的资料,比如怎么连接flash,ram,LCD等,最好是结合电路图的讲解。     不知道有没有。。。。…

查看全部问答>