The XBYTE macro accesses individual bytes in the external data memory of the 8051. You may use this macro in your programs as follows:
#include /* Include Macro Definitions */
.
.
.
rval = XBYTE [0x0002];
XBYTE [0x0002] = 57;
.
.
.This example reads and writes the contents of the byte in external data memory at address 0002h.
The range of valid index values for this macro is 0-65535.
http://www.keil.com/support/man/docs/c51/c51_xbyte.htm
上面的是在keil的help里ctrl+c來(lái)的,以前在論壇里看到過(guò)有人問(wèn)如何用c語(yǔ)言實(shí)現(xiàn)定位存儲(chǔ),呵呵,當(dāng)時(shí)還說(shuō)不可能呢!現(xiàn)在在查找using的時(shí)候,無(wú)意中看到了XBYTE,點(diǎn)中看看,居然有大發(fā)現(xiàn)啊!
百度結(jié)果:這個(gè)主要是在用C51的P0,P2口做外部擴(kuò)展時(shí)使用,其中XBYTE [0x0002],P2口對(duì)應(yīng)于地址高位,P0口對(duì)應(yīng)于地址低位。一般P2口用于控制信號(hào),P0口作為數(shù)據(jù)通道。
如:P2.7接WR,P2.6接RD,P2.5接CS,那么就可以確定個(gè)外部RAM的一個(gè)地址,想往外部RAM的一個(gè)地址寫一個(gè)字節(jié)時(shí),地址可以定為XBYTE [0x4000],其中WR,CS為低,RD為高,那就是高位的4,當(dāng)然其余的可以根據(jù)情況自己定,然后通過(guò)
XBYTE [0x4000] = 57。這賦值語(yǔ)句,就可以把57寫到外部RAM的0x4000處了,此地址對(duì)應(yīng)一個(gè)字節(jié)。
一下摘自論壇網(wǎng)友的問(wèn)答:
問(wèn):
在一般的讀寫外部RAM的程序中,經(jīng)??吹竭@樣的句子:
XBYTE[address]=data 寫數(shù)據(jù)
data="XBYTE"[address] 讀數(shù)據(jù)
但是我想問(wèn)的是,為什么用了XBYTE后,就不用顧及其時(shí)序了呢?
就是說(shuō),讀寫數(shù)據(jù)的時(shí)候,WR和RD怎么都不用用程序去控制了呢?
參考了很多讀寫外部RAM的程序,都找不到其控制WR和RD控制線的語(yǔ)句
哪位大俠能幫忙解釋一下這是為什么嘛?
最好還能說(shuō)說(shuō)XBYTE具體的用法.....
答:
外部總線,
1外部總線由3組總線組成,數(shù)據(jù) 地址 控制,我們常常一般就叫他外部總線,既然是有3組不同的信號(hào),那么他們是怎么協(xié)調(diào)工作的呢?一般情況CPU有特殊的外部數(shù)據(jù)訪問(wèn)指令如你這里講51的MOVX指令(在C語(yǔ)言中他會(huì)編譯成這個(gè)指令)在執(zhí)行這個(gè)指令的時(shí)候3組線是協(xié)調(diào)工作
mov dptr,#1000h
mov a,#55h
movx @dptr,a
上面3調(diào)語(yǔ)句的C語(yǔ)言可以表示如下
#define W_DATA XBYTE[0x1000]
W_DATA=0X55;
在使用外部總線的時(shí)候,數(shù)據(jù) 地址和控制信號(hào)是直接按照規(guī)定的時(shí)序輸出高低電平的,所以不用你管,當(dāng)然你必須要滿足時(shí)序工作
一下摘自網(wǎng)友博客文章:
如何理解#define XBYTE ((unsigned char volatile xdata *
8051 特有的內(nèi)存型態(tài)
code 以 MOVC @A+DPTR 讀取的程序內(nèi)存
data 可以直接存取的內(nèi)部數(shù)據(jù)存儲(chǔ)器
idata 以 Mov @Rn 存取的內(nèi)部數(shù)據(jù)存儲(chǔ)器
bdata 可以位尋址(Bit Addressable)的內(nèi)部存儲(chǔ)器
xdata 以 MOVX @DPTR 存取的外部數(shù)據(jù)存儲(chǔ)器
pdata 以 MOVX @Rn 存取的外部數(shù)據(jù)存儲(chǔ)器
特殊資料型態(tài)
bit 一般位(bit)變量
sbit 絕對(duì)尋址的位(bit)變量
語(yǔ)法
sbit my_flag = location; (location 范圍從 0x00 ~ 0x7F)
范例
sbit EA = 0xAF;
或是配合 bdata 宣告的位(bit)變量
char bdata my_flags;
sbit flag0 = my_flags ^ 0;
(注意 sbit 前不可以加 static)
sfr 特殊功能緩存器(Special Function Register)
語(yǔ)法
sfr my_sfr = location; (location 范圍從 0x80 ~ 0xFF)
范例
sfr P0 = 0x80;
指定絕對(duì)地址的變量
在單一模塊內(nèi)可以使用下面的語(yǔ)法宣告
[memory_space] type variable_name _at_ location
范例
pdata char my_pdata _at_ 0x80;
如果該變量必須為多個(gè)模塊所使用(Global Variable)則以
抽象指針(Abstract Pointer)的方式在標(biāo)頭檔(Header File)定義較為方便。
#define variable_name *((data_type *) location)
范例
#define my_pdata *((char pdata *) 0x80)
(注意 char 與 pdata 的順序)
ABSACC.H 提供了下列方便的宏(Macro)定義。
#define CBYTE ((unsigned char volatile code *) 0)
#define DBYTE ((unsigned char volatile data *) 0)
#define PBYTE ((unsigned char volatile pdata *) 0)
#define XBYTE ((unsigned char volatile xdata *) 0)
#define CWORD ((unsigned int volatile code *) 0)
#define DWORD ((unsigned int volatile data *) 0)
#define PWORD ((unsigned int volatile pdata *) 0)
#define XWORD ((unsigned int volatile xdata *) 0)
隱藏的初始化程序
80C51 在電源重置后(Power On Reset)所執(zhí)行的第一個(gè)程序模塊并不是使用者的主程序
main(),而是一個(gè)隱藏在 KEIL-C51 標(biāo)準(zhǔn)鏈接庫(kù)中稱為 startup.a51 的程序模塊。
startup.a51 的主要工作是把包含 idata、xdata、pdata 在內(nèi)的內(nèi)存區(qū)塊清除為 0,并
且初始化遞歸指針。接著 startup.a51 被執(zhí)行的仍然是一個(gè)隱藏在 KEIL-C51 標(biāo)準(zhǔn)鏈接庫(kù)
中稱為 init.a51 的程序模塊。而 init.a51 的主要工作則是初始化具有非零初始值設(shè)定的
變量。
在完成上述的初始化程序之后,80C51 的控制權(quán)才會(huì)交給 main() 開(kāi)始執(zhí)行使用者的程序。
#define XBYTE ((unsigned char volatile xdata *) 0)
定義 XBYTE 為 指向 xdata 地址空間unsigned char 數(shù)據(jù)類型的指針,指針值為0
這樣,可以直接用XBYTE[0xnnnn]或*(XBYTE+0xnnnn)訪問(wèn)外部RAM了