微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > C8051FXX 加密方法

C8051FXX 加密方法

时间:11-09 来源:互联网 点击:
C8051FXX单片机的加密方式,是通过修改FLASH存储器的0xfdfe和0xfdff这两个字节来实现的。其中0xfdfe是写保护字节。0xfdff是读保护字节。每个字节的8个位分别对应8K的FLASH存储空间,如果该存储空间的对应位被清除,则该空间也被加密。因此我们只要在编程的时候把该字节的写为0,则整个64K存储空间将被加密。

一、Keil C51中如何加密

1、在编译好的HEX文件的倒数第二行加入“:01FDFF000003”即可,或者“:02FDFE00000003”

2、在KEIL工程中增加一个LOCK.C文件,内容只有一行,如下:

unsigned char code lock[1]={0};

然后在“BL51 LOCATE”选项的“CODE”中填入“?CO?LOCK(0xfdff)”。重新编译下载生成的HEX文件即可。

如果是读写都加密则是:

unsigned int code lock[1]={0};

然后在“BL51 LOCATE”选项的“CODE”中填入“?CO?LOCK(0xfdfe)”。重新编译下载生成的HEX文件即可。

二、汇编语言程序中如何加密

1、汇编语言中加密相对简单些,只要在0xfdfe和0xfdff地址填写0即可以,一般常用的方法比如:

org 0fdfeh

nop

nop (占两个字节的空间被清零)

…...

ljmp xxxx.

------------------------

Org 0fdfeh

DW 0

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top