Accessing Absolute Memory Locations
絕對存儲器訪問
C編程語言并不支持明確地提定一個靜態(tài)或全部變量的存儲位置。有三種方法可以明確地參考存儲器位置:
(1)絕對存儲器訪問宏
(2)連接器位置控制
(3)關鍵字_at_
Absolute Memory Access Macros
可以使用作為Cx51庫一部分的絕對存儲器訪問宏。使用以下宏可以直接訪問存儲器區(qū)
CBYTE DBYTE PBYTE XBYTE CWORD DWORD
PWORD XWORD
CBYTE的宏定義為:
#define CBYTE ((unsigned char volatile code *)0)
可以這樣使用:
rval = CBYTE [0x0002];
讀出地下地0002h中的字節(jié)內容
DBYTE的定義為:
#define DBYTE ((unsigned char volatile idata *) 0)
可以這樣使用:
rval = DBYTE [0x0002];
DBYTE [0x0002] = 5;
(其他定義及用法的見附)
Linker Location Controls
第二種方法是在一個獨立的C模塊中聲明這些變量,并且使用BL51連接器/定位器的定位指令來指定絕對地址。
在以下例子中,假定有一個結構體名字為alarm_control,要把它定位到xdata區(qū)的地址2000h。首先在一個源文件ALMCTRL.C中聲明這個結構體:
struct alarm_st {
unsigned int alarm_number;
unsigned char enable flag;
unsigned int time_delay;
unsigned char status;
};
xdata struct alarm_st alarm_control;
Cx51編譯器為ALMCTRL.C生成一個目標文件,并且包含了一放在xdata存儲區(qū)的變量段。因為它在這個模塊中只有一個變量,那么alarmcontrl是這個段中僅有的變量,這個段名字為?XD?ALMCTRL.
BL51連接器/定位器允許使用定位指令指定任意一個段的基地址。則可以通過以下指令指定變量的位置:
BL51 … almctrl.obj XDATA(?XD?ALMCTRL(2000h))
將變量定位于code, xdata, pdata, idata和data區(qū)域的指令見附錄
The _at_ Keyword
第三種方法是在聲明變量時使用關鍵字_at_。以下是例示:
struct link {
struct link idata *next;
char code *test;
};
idata struct link list _at_ 0x40; /* list at idata 0x40 */
xdata char text[256] _at_ 0xE000; /* array at xdata 0xE000 */
xdata int i1 _at_ 0x8000; /* int at xdata 0x8000 */
void main ( void ) {
link.next = (void *) 0;
i1 = 0x1234;
text [0] = 'a';
}
Debugging
缺省的,Cx51編譯器使用Intel目標格式(OMF-51)做為目標文件的格式并生成全部的符號信息。所有兼容的調試器都可以用來進行程序調試。DEBUG控制指令地目標文件中嵌入調試信息。而且,OBJECTEXTEND控制指令在目標文件中嵌入附加的變量類型信息。這個目標文件允許在使用特定的調試器的時候變量和結構體的類型顯示
Cx51使用OMF-2目標文件格式。當使用OMF2指令,C51編譯器也使用OMF2格式。OMF2格式需要使用擴展的LX51邊接器/定位器,而不能使用BL51連接器/定位器。OMF2目標文件格式提供了精確的調試信息,μVision2調試器和其他一些調試器都支持這一格式。