找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 6437|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

C8051F的Flash操作及安全選項(xiàng)

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:105323 發(fā)表于 2016-2-13 00:25 | 只看該作者 回帖獎(jiǎng)勵(lì) |正序?yàn)g覽 |閱讀模式
本帖最后由 51黑黑黑 于 2016-2-13 00:26 編輯

   C8051F020的Flash可以實(shí)現(xiàn)IAP功能(InApplicationProgramming),即程序可對(duì)Flash存儲(chǔ)區(qū)進(jìn)行編程,也就是說(shuō)Flash除了可以存放程序代碼,還可以在剩下的空間內(nèi)存儲(chǔ)數(shù)據(jù),即起到EEPROM的功能,下圖是C8051F020的存儲(chǔ)組織結(jié)構(gòu)圖

  可以看到它的結(jié)構(gòu)是64K+128字節(jié)的形式,0xfe00~0xffff為工廠保留區(qū),不能進(jìn)行操作,當(dāng)64K的Flash用作存儲(chǔ)數(shù)據(jù)時(shí),先確定程序代碼的位置,以免覆蓋程序?qū)е鲁鲥e(cuò),還有操作Flash前必須禁止中斷,否則可能會(huì)出現(xiàn)無(wú)法預(yù)知的錯(cuò)誤,下面是我寫(xiě)的驅(qū)動(dòng),經(jīng)測(cè)試沒(méi)問(wèn)題:

void Flash_area_Erase(bit type,uint addr)
{//flash擦除,type為0代表128字節(jié)儲(chǔ)存區(qū),為1代表64K存儲(chǔ)區(qū)(512字節(jié)/扇區(qū))
bit EA_S;
EA_S=EA;
EA=0;
if(!type) PSCTL=0x07;
else PSCTL=0x03;
FLSCL=0x01;//允許寫(xiě)
*(uchar xdata *)addr=0xff;
PSCTL=0;
FLSCL=0;
EA=EA_S;
}
uchar Flash_area_Read(bit type,uint addr)
{//flash讀取,type為0代表128字節(jié)儲(chǔ)存區(qū),為1代表64K存儲(chǔ)區(qū)(512字節(jié)/扇區(qū))
uchar dat;
bit EA_S;
EA_S=EA;
EA=0;
if(!type) PSCTL=0x04;
else PSCTL=0;
dat=*(uchar code *)addr;
PSCTL=0;
EA=EA_S;
return(dat);
}
void Flash_area_Write(bit type,uint addr,uchar dat)
{//flash寫(xiě)入,type為0代表128字節(jié)儲(chǔ)存區(qū),為1代表64K存儲(chǔ)區(qū)(512字節(jié)/扇區(qū))
bit EA_S;
EA_S=EA;
EA=0;
if(!type) PSCTL=0x05;
else PSCTL=0x01;
FLSCL=0x01;
*(uchar xdata *)addr=dat;
PSCTL=0;
FLSCL=0;
EA=EA_S;
}

   這里要指出的是,在*(uchar code*)addr中,addr轉(zhuǎn)化為指向ROM的uchar型變量的指針,即它指向的數(shù)是uchar型的,但其本身作為一個(gè)地址是uint型的。


  保存在地址0xFDFE和0xFDFF中的安全鎖定字節(jié)集可以保護(hù) FLASH存儲(chǔ)器,使得不能通過(guò)JTAG接口讀取或修改其內(nèi)容。安全鎖定字節(jié)中的每一位保護(hù)一個(gè)8k字節(jié)的存儲(chǔ)器塊。將讀鎖定字節(jié)中的一位清0可防止通過(guò)JTAG接口讀對(duì)應(yīng)的FLASH存儲(chǔ)器塊將寫(xiě)/擦除鎖定字節(jié)中的一位清0可防止通過(guò)JTAG接口寫(xiě)/擦除對(duì)應(yīng)的存儲(chǔ)器塊。當(dāng)所有其它扇區(qū)都被鎖定后128字節(jié)的扇區(qū)才被鎖定。





使用FLASH訪問(wèn)限制(FLACL)這一特殊功能寄存器來(lái)設(shè)置軟件讀限制。所希望的軟件訪問(wèn)限制地址(設(shè)計(jì)者希望的軟件訪問(wèn)保護(hù)的最高地址)的高字節(jié)被裝入FLACL寄存器。該限制地址的低字節(jié)為0x00。如果FLACL寄存器被賦值為0x40,則軟件訪問(wèn)限制地址為0x4000。所有位于地址0x0000到0x4000(包括0x4000)的存儲(chǔ)區(qū)內(nèi)的代碼將不能被在該地址以上執(zhí)行的軟件訪問(wèn)。在FLACL邊界之上執(zhí)行的程序可以用跳轉(zhuǎn)或調(diào)用指令進(jìn)入到FLACL邊界以下的保護(hù)存儲(chǔ)區(qū)。軟件讀限制只對(duì)MOVX和MOVC操作起作用。為了防止對(duì)FLASH的訪問(wèn),應(yīng)使用FLASH安全字節(jié)保護(hù)0x4000以下的存儲(chǔ)區(qū)或進(jìn)行整體保護(hù)。

   這里要提到一個(gè)軟件Flash ProgrammingUtilities,在用Keil編譯完成后生成hex文件,需要量產(chǎn)時(shí),可以按下圖操作


   即下程序前擦出真?zhèn)Flash,下完后對(duì)代碼進(jìn)行鎖定,防止被讀寫(xiě);對(duì)于鎖定了代碼的MCU,需要在FlashErase選項(xiàng)卡中擦除,否則在下面第二個(gè)圖顯示的界面中是無(wú)法用連接上的

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表