单片机
返回首页

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

}

在这里插入图片描述

进入单片机查看更多内容>>
相关视频
  • RISC-V嵌入式系统开发

  • SOC系统级芯片设计实验

  • 云龙51单片机实训视频教程(王云,字幕版)

  • 2022 Digi-Key KOL 系列: 你见过1GHz主频的单片机吗?Teensy 4.1开发板介绍

  • TI 新一代 C2000™ 微控制器:全方位助力伺服及马达驱动应用

  • MSP430电容触摸技术 - 防水Demo演示

精选电路图
  • 基于IC555的可变PWM振荡器电路

  • 优化电路板布局的简单方法

  • 如何使用LED驱动器LM3915制作振动计

  • 分享一个电网倾角计电路

  • 电谐波图形均衡器示意图

  • 一种构建12V和230V双直流电源的简单方法

    相关电子头条文章