XBYTE的用法

XBYTE

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 <absacc.h>    /* 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來的,以前在論壇裏看到過有人問如何用c語言實現定位存儲,呵呵,當時還說不可能呢! 現在在查找using的時候,無意中看到了XBYTE,點中看看,居然有大發現啊!

 

        百度結果:這個主要是在用C51的P0,P2口做外部擴展時使用,其中XBYTE [0x0002],P2口對應於地址高位,P0口對應於地址低位。一般P2口用於控制信號,P0口作爲數據通道。

        如:P2.7接WR,P2.6接RD,P2.5接CS,那麼就可以確定個外部RAM的一個地址,想往外部RAM的一個地址寫一個字 節時,地址可以定爲XBYTE [0x4000],其中WR,CS爲低,RD爲高,那就是高位的4,當然其餘的可以根據情況自己定,然後通過
XBYTE [0x4000] = 57。這賦值語句,就可以把57寫到外部RAM的0x4000處了,此地址對應一個字節。

 

一下摘自論壇網友的問答:

問:

在一般的讀寫外部RAM的程序中,經常看到這樣的句子:

    XBYTE[address]=data   寫 數據

    data=XBYTE[address]   讀數據

但是我想問的是,爲什麼用了XBYTE後,就不用顧及 其時序了呢?

就是說,讀寫數據的時候,WR和RD怎麼都不用用程序去控制了呢?

參考了很多讀寫外部RAM的程序,都找不 到其控制WR和RD控制線的語句

哪位大俠能幫忙解釋一下這是爲什麼嘛?

最好還能說說XBYTE具體的用法.....
答:
外部總線,

1外部總線由3組總線組成,數據 地址 控制,我們常常一般就叫他外 部總線,既然是有3組不同的信號,那麼他們是怎麼協調工作的呢?一般情況CPU有特殊的外部數據訪問指令如你這裏講51的MOVX指令(在C語言中他會編 譯成這個指令)在執行這個指令的時候3組線是協調工作

mov dptr,#1000h

mov a,#55h

movx @dptr,a

上面3調語句的C語言可以表示如下

#define  W_DATA  XBYTE[0x1000]

W_DATA=0X55;

在 使用外部總線的時候,數據 地址和控制信號是直接按照規定的時序輸出高低電平的,所以不用你管,當然你必須要滿足時序工作

一下摘自網友博客文章:

如何理解#define XBYTE ((unsigned char volatile xdata *

8051 特有的內存型態

code    以 MOVC @A+DPTR 讀取的程序內存
data    可以直接存取的內部數據存儲器
idata    以 Mov @Rn 存取的內部數據存儲器
bdata    可以位尋址(Bit Addressable)的內部存儲器
xdata    以 MOVX @DPTR 存取的外部數據存儲器
pdata    以 MOVX @Rn 存取的外部數據存儲器

特殊資料型態

bit    一般位(bit)變量
sbit    絕對尋址的位(bit)變量
語法
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)
語法
sfr    my_sfr    =    location;    (location 範圍從 0x80 ~ 0xFF)
範例
sfr    P0    =    0x80;
指定絕對地址的變量
在單一模 塊內可以使用下面的語法宣告
[memory_space]    type    variable_name    _at_    location
範例
pdata        char    my_pdata    _at_    0x80;
如果該變 量必須爲多個模塊所使用(Global Variable)則以
抽象指針(Abstract Pointer)的方式在標頭檔(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)所執行的第一個程序模塊並不是使用者的主程序
main(),而是一個隱藏在 KEIL-C51 標準鏈接庫中稱爲 startup.a51 的程序模塊。
startup.a51 的主要工作是把包含 idata、xdata、pdata 在內的內存區塊清除爲 0,並
且初始化遞歸指針。接着 startup.a51 被執行的仍然是一個隱藏在 KEIL-C51 標準鏈接庫
中 稱爲 init.a51 的程序模塊。而 init.a51 的主要工作則是初始化具有非零初始值設定的
變量。
在完成上述的初始化程序 之後,80C51 的控制權纔會交給 main() 開始執行使用者的程序。
#define XBYTE ((unsigned char volatile xdata *) 0)
定義    XBYTE 爲 指向 xdata 地址空間unsigned char 數據類型的指針,指針值爲0
這樣,可以直接用XBYTE[0xnnnn]或*(XBYTE+0xnnnn)訪問外部RAM了
 
 
 

糊弄了半天,還是有點不懂,百度了許多資料回來,慢慢研究!

發佈了9 篇原創文章 · 獲贊 3 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章