#define FLASH_ID_OFFSET 30000    //任意定义一个数

//把地址直接减去或者加上一个数是不要程序中直接出现这个地址

volatile u32 Flash_ID_addr[3]={

0x1FFFF7E8 - FLASH_ID_OFFSET,

0x1FFFF7EC + FLASH_ID_OFFSET,

0x1FFFF7F0 - FLASH_ID_OFFSET

};

/**读取STM32 FLASH ID**/

void Flash_Read_ID(u32 *p)
{
  u32 Addr;
  //因为不想让程序在反汇编后直接找到这个地址,所以这个地址是运算出来

//的,跟STM_ID_addr反运算,当然也可以用其他高级算法,不能让编译器

//优化这个地址

Addr = Flash_ID_addr[0] + FLASH_ID_OFFSET;
  p[0] = *(u32*)(Addr);

Addr = Flash_ID_addr[1] - FLASH_ID_OFFSET;
  p[1] = *(u32*)(Addr);

Addr = Flash_ID_addr[2] + FLASH_ID_OFFSET;
  p[2] = *(u32*)(Addr);
}

/*加密ID并保存*/
void Encrypted_ID(void)
{
  u32 FlashID[3],data;
  Flash_Read_ID(FlashID);
  //这里可以用其他一些高级算法,但减和加要一样
  
  data=(FlashID[0]|FlashID[1]|FlashID[2])&(~FlashID[1])|(~FlashID[2]);

FLASH_Unlock();
  FLASH_ErasePage(FLSAH_EN_ID_START_ADDR);
  FLASH_ProgramWord(FLSAH_EN_ID_START_ADDR,dat);//保存这个数
  FLASH_Lock();
}

/*比较加密ID,正确返回0 不正确返回1*/
u32 CMP_Encrypted_ID(void)
{
  u32 FlashID[3],data1,dat2;
  Flash_Read_ID(FlashID);
  //这里可以用其他高级算法,但减和加要一样
  data1=(FlashID[0]|FlashID[1]|FlashID[2])&(~FlashID[1])|(~FlashID[2]);

data2 = *(u32*)(FLSAH_EN_ID_START_ADDR);

if(data1==data2) //相同
    return 0;
  else         //不同
    return 1;
}

//ID加密控制
if(CMP_Encrypted_ID())
{
  //生产时给一些条件,条件满足就对ID加密,加密完后,也可以让它自宫
  if(****)
  {
    Encrypted_ID();
    .....
    自宫
  }
}

//校验ID是否正确
if(CMP_Encrypted_ID())
{
  程序来到这里当然不正确了,不要让程序死在这里。一个系统肯定有

  一些参数才能运行的,你可以改变一些参数,可以让系统有时正常有

时不正常。

}

STM32的FLASH ID加密的更多相关文章

  1. 关于STM32的FLASH操作【转载】

    说到STM32的FLSAH,我们的第一反应是用来装程序的,实际上,STM32的片内FLASH不仅用来装程序,还用来装芯片配置.芯片ID.自举程序等等.当然, FLASH还可以用来装数据. FLASH分 ...

  2. php利用32进制实现对id加密解密

    前言 最近在项目中遇到一个问题,当前用户分享一个邀请码给好友,好友根据邀请码注册成为新用户之后,则成为当前用户的下级,特定条件下,可以得到下级用户的一系列返利.这里要实现的就是根据当前用户的id,生成 ...

  3. flash stm32的flash编写

    定义一个全局变量数组:const u8 TEXT_Buffer[]={"STM32F103 FLASH TEST"};    //u8和char* 写入到内存里会有什么区别???? ...

  4. STM32全球唯一ID读取方法

    产品唯一的身份标识非常适合:● 用来作为序列号(例如USB字符序列号或者其他的终端应用)● 用来作为密码,在编写闪存时,将此唯一标识与软件加解密算法结合使用,提高代码在闪存存储器内的安全性.● 用来激 ...

  5. STM32唯一的ID

    请看如下程序: /*------------------------------------------------------------------------------------------ ...

  6. USB Mass Storage学习笔记-STM32+FLASH实现U盘

    一.内容概述  采用STM32内部自带USB控制器外加大页NAND FLASH K9F1G08U0A实现一个128M的U盘. 1.STM32的USB控制器 STM32F103的MCU自带USB从控制器 ...

  7. STM32内部flash存储小数——别样的C语言技巧

    今天在进行STM32内部falsh存储的时候,发现固件库历程的函数原型是这样的: 第一个是地址,在我的STM32中是2K一页的,第二个是要写入的数据. 问题就来了,存储一个小数该怎么办呢?固件库给的是 ...

  8. STM32的Flash

    STM32中存储区分为:随机存取存储器RAM和只读存储器ROM. 其中: RAM为常说的内存,比如手机的2G内存4G内存等,就是程序跑起来的时候所占用的存储空间,特点是掉电数据丢失. ROM为常说的硬 ...

  9. stm32的flash操作注意事项

    从STM32编程手册中,可以知道:在进行写或擦除操作时,不能进行代码或数据的读取操作. 比如:你在写Flash期间有接收串口数据,很有可能会丢串口数据. 因为比较耗时,所以,在写数据时,CPU不会执行 ...

随机推荐

  1. 41.SEO----前端SEO技巧

    一.搜索引擎工作原理 当我们在输入框中输入关键词,点击搜索或查询时,然后得到结果.深究其背后的故事,搜索引擎做了很多事情. 在搜索引擎网站,比如百度,在其后台有一个非常庞大的数据库,里面存储了海量的关 ...

  2. XXE攻击学习

    环境:lAMP simplexml_load_string.php代码内容 <?php $data = file_get_contents('php://input'); $xml = simp ...

  3. LeetCode104.二叉树最大深度

    给定一个二叉树,找出其最大深度. 二叉树的深度为根节点到最远叶子节点的最长路径上的节点数. 说明: 叶子节点是指没有子节点的节点. 示例:给定二叉树 [3,9,20,null,null,15,7], ...

  4. C# dataGridView 如何选中整行?

    this.dataGridView1.SelectionMode =DataGridViewSelectionMode.FullRowSelect; dataGridView1即你的dataGridV ...

  5. 软工网络15团队作业4——Alpha阶段敏捷冲刺5.0

    1.每天举行站立式会议,提供当天站立式会议照片一张. 2.项目每个成员的昨天进展.存在问题.今天安排. 成员 昨天已完成 今天计划完成 郭炜埕 完善新建话题界面 实现前端各界面的跳转连接 郑晓丽 进行 ...

  6. [2]传奇3服务器源码分析一 LoginServer

    留存 服务端下载地址: 点击这里

  7. 《大话设计模式》c++实现 代理模式

    代理模式 在代理模式(Proxy Pattern)中,一个类代表另一个类的功能.这种类型的设计模式属于结构型模式. 在代理模式中,我们创建具有现有对象的对象,以便向外界提供功能接口. 介绍 意图:为其 ...

  8. Sitecore营销自动化

    增加与战略性自动化营销系统的互动 Sitecore营销自动化基于DMS中的Sitecore个性化功能.营销自动化系统使用诸如位置,设备和先前访问或购买之类的客户数据来影响用户沿着购买路径的旅程.这些系 ...

  9. jQuery筛选--find(expr|obj|ele)和siblings([expr])

    find(expr|obj|ele) 概述 搜索所有与指定表达式匹配的元素.这个函数是找出正在处理的元素的后代元素的好方法 参数 expr  用于查找的表达式 jQuery object   一个用于 ...

  10. Python学习记录之(五)-----类进阶篇

    静态方法 类方法 属性方法 通过@staticmethod装饰器即可把其装饰的方法变为一个静态方法,什么是静态方法呢?其实不难理解,普通的方法,可以在实例化后直接调用,并且在方法里可以通过self.调 ...