51单片机C语言访问外ram,C51中访问外部RAM的方法

C51的P0,P2口做外部扩展时使用,其中XBYTE [0x0002],P2口对应于地址高位,P0口对应于地址低位。一般P2口用于控制信号,P0口作为数据通道。

XBYTE定义的是外部地址,这样才能和接到你的IO口上的器件通信

在一般的读写外部RAM的程序中,经常看到这样的句子:本文引用地址:http://www.eepw.com.cn/article/201611/322578.htm

XBYTE[address]=data写数据

data=XBYTE[address]读数据1

外部总线由3组总线组成,数据 地址 控制,我们常常一般就叫他外部总线,既然是有3组不同的信号,那么他们是怎么协调工作的呢?一般情况CPU有特殊的外部数据

访问指令如你这里讲51的MOVX指令(在C语言中他会编译成这个指令)在执行这个指令的时候3组线是协调工作

mov dptr,#1000h

mov a,#55h

movx @dptr,a

上面3调语句的C语言可以表示如下

#defineW_DATAXBYTE[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)变量

语法

sbitmy_flag=location;(location 范围从 0x00 ~ 0x7F)

范例

sbitEA =0xAF;

或是配合 bdata 宣告的位(bit)变量

charbdatamy_flags;

sbitflag0 =my_flags ^ 0;

(注意 sbit 前不可以加 static)

sfr特殊功能缓存器(Special Function Register)

语法

sfrmy_sfr=location;(location 范围从 0x80 ~ 0xFF)

范例

sfrP0=0x80;

指定绝对地址的变量

在单一模块内可以使用下面的语法宣告

[memory_space]typevariable_name_at_location

范例

pdatacharmy_pdata_at_0x80;

如果该变量必须为多个模块所使用(Global Variable)则以

抽象指针(Abstract Pointer)的方式在标头档(Header File)定义较为方便。

#definevariable_name*((data_type *)location)

范例

#definemy_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了

其中,初始地址就是0x0000;

百度知道:#define XBYTE((char*)0x20000L)XBYTE[0x8000]=0x41;这段程序是什么意思?#define XBYTE ((char*)0x20000L) 定义了XBYTE是个指向地址 0x20000L 的字符型指针(或者数组)变量XBYTE[0x8000]=0x41; 对数组XBYTE的第 0x8000个变量进行赋值,赋值为0x41。即对地址0x28000L的内存单元赋值为0x41。这说明你用的是带外部数据总线的51芯片,外部的存储器多半是RAM,RAM的容量至少有 0x8000(32k)字节-RAM的容量可能是64k字节?如果还有问题,可以发消息联系补充1:L代表 long,这说明 0x20000L 是一个长整数。一般来说,8位单片机如51,整数用16位二进制表示,长整数用32位二进制表示。还有这样用的:写这样的一个头文件

1000c86c83b8089d90aaf4c549bab54c.png

这样的格式:类型 储存空间 定义别名 关键字_at_ 寄存器的地址_at_这个关键字是绝对定义地址