PIC中的#pragma idata 和#pragma udata
PIC中的#pragma idata 和#pragma udata:
idata表示已經(jīng)初始化的數(shù)據(jù)。udata表示沒(méi)有初始化的數(shù)據(jù)。
當(dāng)一個(gè)數(shù)據(jù)塊沒(méi)有足夠的空間用于存放一個(gè)連續(xù)的數(shù)據(jù)時(shí)(數(shù)組);此時(shí)便可用#pragma idata 或#pragma udata來(lái)定義一個(gè)新的存放數(shù)據(jù)塊的區(qū)域。但是#pragma idata 或#pragma udata申請(qǐng)的空間也還是有限的,一般不能大于256,如果超過(guò)則只能另外想法辦了。
為什么不能大于256?
可以看相關(guān)的IC鏈接文件.lkr,從它里面可以看到它是如何定義bank大小的,沒(méi)有一個(gè)是大于0xff的,因?yàn)镻IC18的命令是雙字節(jié)的即只有16位,但是在一個(gè)操作RAM的命令中只有8位數(shù)據(jù)來(lái)表示RAM地址,其它的為操作碼或者其它。故它最大的尋址范圍只能256,如果大于256只能借助其它寄存器BSR來(lái)擴(kuò)展地址。這也是BANK的由來(lái)。另外由于數(shù)組存放的空間應(yīng)該放在一個(gè)連續(xù)的空間里,故不能大于256,因?yàn)榇笥?56,命令是無(wú)法自動(dòng)跨BANK尋址的,如果要跨BANK則只能事先設(shè)定好BANK區(qū)。
如何查看我們定義的變量存放在哪里?可以查看生成的.map文件。
map文件的生成設(shè)置:project-->build options-->project--->MPLINK mplinker,選擇Generate map file.
它們的用法:
#pragma idata DataArray //一個(gè)數(shù)據(jù)塊的開(kāi)始
char DataArray[256]={0};
#pragma idata //一個(gè)數(shù)據(jù)塊的結(jié)束
#pragma udata DataArray1 //一個(gè)數(shù)據(jù)塊的開(kāi)始
char DataArray1[256];
#pragma udata //一個(gè)數(shù)據(jù)塊的結(jié)束
在PIC中的const關(guān)鍵字,及rom關(guān)鍵字,#pragma rom
在MC18編譯器中。
const char array[300]={0};
這樣定義了一個(gè)超過(guò)bank最大值的變量,在編譯時(shí)會(huì)產(chǎn)生錯(cuò)誤.為什么?
const雖然指明了將變量array存儲(chǔ)在了rom區(qū),但是在MC18編譯器中卻因?yàn)樽兞康闹赶蚴荝AM區(qū),所以它默認(rèn)的情況下還是將數(shù)據(jù)存儲(chǔ)在了RAM區(qū)。即const單獨(dú)無(wú)法實(shí)現(xiàn)將數(shù)據(jù)存放在ROM區(qū)的作用。而在MC18編譯器說(shuō)明中,如果要將數(shù)據(jù)放在ROM區(qū),則要加上rom關(guān)鍵字。即如下定義
rom char array[300]={0};
const rom char array[300]={0};這樣才不會(huì)出錯(cuò)。
或者采用如下方式:
#pragma rom udatasection
const rom char array[300]={0};
#pragma rom
code:用于存放指令代碼
rom:用于存儲(chǔ)數(shù)據(jù)常量的.在map中的段名叫romdata.
1、#pragma code 定位程序代碼在程序存儲(chǔ)器中的位置
2、#pragma romdata 定位數(shù)據(jù)在程序存儲(chǔ)器中的位置
3、#pragma udata 定位未初始化的用戶變量在數(shù)據(jù)存儲(chǔ)器中的位置
4、#pragma idata 定位初始化的用戶變量在數(shù)據(jù)存儲(chǔ)器中的位置
格式:#pragma code(短名稱)(=地址)
#pragma code _entry_scn=0x18