Keil C51詳細設定
開啟Keil後,左側Project Workspace中的target可改,方法:右擊Target——Manage Compnents——雙擊待修改項即可,若要新增,使用對話方塊內對應工具欄。
二.optionfor target 設定之TARGET項
1 MEMARY MODEL
Small:變數儲存在內部ram裡.
Compact:變數儲存在外部ram裡,使用頁8位間接定址
Large:變數儲存在外部Ram裡,使用16位間接定址.
我們一般使用Small來儲存變數,就是說微控制器優先把變數儲存在內部ram裡,如果內部ram不夠了,才會存到外部去.Compact的方式要自己通過程式來指定頁的高位地址,程式設計比較複雜,如果外部ram很少,只有256個位元組,那麼對該256個位元組的讀取就比較快,用
如果超過256位元組,那麼要不斷地進行切換的話,就比較麻煩.Compact模式適用於比較少的外部ram的情況.Large模式,是指變數會優先分配到外部ram裡,用MOVX A,@DPTR或MOVX @DPTR,A來讀取.要注意的是,3種儲存方式都支援內部256位元組和外部64k位元組的ram.區別是變數的優先(或預設)儲存在哪裡的區別.除非你不想把變數儲存在內部ram,才使用後面的Compact,Large模式.因為變數儲存在內部ram裡,運算速度比儲存在外部ram要快的多,大部分的應用都是選擇Small的模式.使用Small的方式:也不是說變數就不可以儲存在外部,一樣可以儲存在外部,只是你要指定,比如:
unsigned char xdata a;那麼變數a就儲存在外部的ram.
unsigned char a;變數儲存在內部ram.
假如用Large的模式:
unsigned char xdata a;那麼變數a就儲存在外部的ram.
unsigned char a;變數儲存在外部ram.
這就是區別,就是說這幾個選項只是影響沒有特別指定變數的儲存空間的時候,預設儲存在哪裡,比如上面的變數定義unsignedchar a .
2. CODE ROM SIZE
Small: program 2K or less ;適用於89c2051這些晶片,2051只有2k的程式碼空間,所以跳轉地址只有2k,編譯的時候會使用ACALLAJMP這些短跳轉指令,而不會使用LCALL,LJMP指令.如果你的程式碼跳轉超過2k,那麼會出錯.
Compact:2k functiongs ,64k program:表示每個子函式的程式大小不超過2k,整個工程可以有64k的程式碼.就是說在main()裡可以使用LCALL, LJMP指令,但在子程式裡只會使用ACALL,AJMP指令.除非你確認你的每個子程式不會超過2k,否則不要用Compact方式.
Large:64K program:表示程式或子函式都可以大到64k.使用code bank還可以更大.通常我們都選用該方式.Code Rom Size選擇Large方式速度不會比Small慢很多,所以一般沒有必要選擇Compact和Small的方式.我們這裡選擇Large方式.
3. OPERATING
NONE:不適用作業系統
RTX51-TINY:使用TINY作業系統
RTX-FULL:使用FULL作業系統
Keil C51 提供了Tiny多工作業系統,使用定時器0來做任務切換,效率很低,無實用價值。Full需要使用者使用外部RAM,且需要單獨購買執行庫,不能使用,預設選NONE。
4. 儲存器選擇
1. Use On-chip ROM(0x0-0x1fff)
這個選項是使用片上的Flash Rom,我們知道At89c52有8k的flash Rom.取決於你的應用系統,你的微控制器的EA接高電平的話,請選中這個選項,如果你的微控制器的EA接低電平,表示使用外部Rom,那麼不要選中該選項.我們在這裡選中它
2. Off-chip Code memory
表示你在片外接的Rom的開始地址和大小,如果你沒有外接程式儲存器,那麼不要填任何資料.我們在這裡假設使用一個片外的Rom,地址從0x8000開始(不要填成8000,如果是8000,是10進位制的數,一般填16進位制的數),Size為外接Rom的大小.假設接了一塊0x1000位元組的rom.最多可以外接3塊Rom,如果你還用了別的地址,那麼就添上.
3. Off-Chip Xdata Memory
那麼可以填上你外接的Xdata(外部資料儲存器的起始地址和大小,一般的應用是接一個62256,我們在這裡特殊的指定Xdata的起始地址為0x2000,大小為0x8000;
5. Code Banking
使用Code Banking技術.keil可以支援程式程式碼超過64k的情況,最大可以有2兆的程式程式碼.如果你的程式碼超過64k,那麼就要使用CodeBanking技術,以支援更多的程式空間.CodeBanking是一個高階的技術,支援自動的Bank的切換,是建立一個大型系統的需要,比如你要在微控制器裡實現漢字字型檔,實現漢字輸入法,都要用到該技術.我們會在以後的文章裡論述Bank技術.我們在這裡不選中它.
二.option for target 設定之output項
select folder for object:選擇編譯之後的目標檔案所存放的目錄,預設存放在工程資料夾中。
name of executable:設定生成的目標檔案的名字,預設是工程名。
creat executable:生成OMF和HEX檔案,OMF檔名同工程檔名但沒有副檔名。
creat hex file:選中該項編譯後生成可以少些的HEX檔案。
creat library:生成lib庫檔案,預設不選。
after make :1.beep when complete:編譯完成後提示聲響
2.start debugging:編譯完成後馬上啟動除錯(軟體模擬或硬體模擬),預設不選中
3.run user program1,run userprogram2:根據需要設定編譯之後的應用程式,比如自己編寫的燒寫晶片的程式,或呼叫外部模擬程式。
3.listing
select folder for listings:選擇列表檔案存放的目錄,預設為工程檔案所在的目錄。
*.lst,*.m51檔案對了解程式用到了哪些idata、data、bit、xdata、code、RAM、ROM、Stack等有很重要的作用。
Assembly code生產彙編的程式碼,根據需要決定是否選擇。
4.c51
用於對Keil的C51編譯器編譯過程進行控制,其中比較常用的是“code optimization”組,該組中level是優化等級,C51在對源程式進行編譯時可以對程式碼多至9級優化,預設使用8級,一般不必修改。如果在編譯中出現一些問題可以降低優化級別試一試。
emphasis是選擇編譯優先方式,第一項是程式碼量優化(最終生成的程式碼量小),第二項是速度優先(最終生成的程式碼速度快),第三項是預設的,是速度優先,可根據需要更改。
5.BL51 locat
使用KeilC51軟體,可以很方便地將程式碼或者資料絕對定位到某個地址。
1、程式碼定位:
方法1:使用偽指令CSEG。比如要將MyFunc1定位到程式碼區C:0x1000,則新建一個A51檔案,新增以下內容:
PUBLIC MYFUNC1
CSEG AT 1000H
MYFUNC1:
;其它程式碼
RET
在其它原始檔中,就可以呼叫MyFunc()函數了。需要注意的是,編譯器不檢測傳遞引數的數目,僅檢測函式是否有返回值。
方法2:使用BL51 Locate選項。比如在main.c中定義了一個MyFunc2函式,並且要將該函式定位到程式碼區C:0x2000,則從選單中選擇Project->Options forTarget 'Target1',在彈出的對話方塊中選擇BL51 Locate頁,在下面的code欄中寫上?PR?MYFUNC2?MAIN(0x2000)即可。
如果想定位多個函式,也可以使用*萬用字元。
2、變數定位:
只有全域性變數可以絕對定位,區域性變數無法實現絕對定位。
方法1:使用_at_關鍵字。宣告一個全域性變數unsigned char data MyBuf1[8] _at_ 0x20;
方法2:使用BL51 Locate選項。比如將main.c中定義的所有data型的全域性變數定位到資料區D:0x28開始的空間,則從選單中
選擇Project->Options for Target 'Target1',在彈出的對話方塊中選擇BL51 Locate頁,在下面的data欄中寫上?DT?MAIN(0x28)即可。
如果是idata,則使用?ID?MAIN(0x28),如果是xdata,則使用?XD?MAIN(0x28),如果是pdata,則使用?PD?MAIN(0x28)
3、堆疊定位:
在STARTUP.A51檔案中定義了堆疊區?STACK,其起始地址同樣可以在BL51 Locate頁中設定,在Stack欄寫上?STACK(0x80)
4.函式定位:
假如要把C原始檔 tools.c 中的函式
int BIN2HEX(int xx)
{
...
}
放在CODE MEMORY的0x1000處,先編譯該工程,然後開啟該工程的M51檔案,在
* * * C O D E M E M O R Y * * *
行下找出要定位的函式的名稱,應該形如:
CODE xxxxH xxxxH UNIT ?PR?_BCD2HEX?TOOLS
然後在:
Project->Options for Target ...->BL51 Locate:Code
中填寫如下內容:
?PR?_BCD2HEX?TOOLS(0x1000)
再次Build,在M51中會發現該函式已放在CODE MEMORY的0x1000處了
2、賦初值的變數定位:
要將某變數定位在一絕對位置且要賦初值,此時用 _at_ 不能完成,則如下操作:
在工程中建立一個新的檔案,如InitVars.c,在其中對要處理的變數賦初值(假設是code變
量):
char code myVer = {"COPYRIGHT 2001-11"};
然後將該檔案加入工程,編譯,開啟M51檔案,若定義的是code型,則在
* * * C O D E M E M O R Y * * *
下可找到:
CODE xxxxH xxxxH UNIT ?CO?INITVARS
然後在:
Project->Options for Target ...->BL51 Locate:Code
中填入:
?CO?INITVARS(0x200)
再次編譯即可。
相應地,如為xdata變數,則InitVars.c中寫:
char xdata myVer = {"COPYRIGHT 2001-11"};
然後將該檔案加入工程,編譯,開啟M51檔案,在
* * * X D A T A M E M O R Y * * *
下可找到:
XDATA xxxxH xxxxH UNIT ?XD?INITVARS
然後在:
Project->Options for Target ...->BL51 Locate:Xdata
中填入:
?XD?INITVARS(0x200)
再次編譯即可。相應地,若定義的是data/idata等變數,則相應處理即可。
3、若有多個變數或函式要進行絕對地址定位,則應按地址從低到高的順序排列。