单片机存储器类型分析(data,xdata,code,pdata,bit)

今天看到51单片机的代码段中有这样两行code,不知道其中的data和code是什么意思,在网上查了下,才弄清是什么意思。
unsigned char code dis_code[11]={0xc0,0xc0,0xa4,0xb0, // 0, 1, 2, 3
0x99,0x92,0x82,0xf8,0x80,0x90, 0xff};// 4, 5, 6, 7, 8, 9, off 

unsigned char data dis_buf[8];
单片机存储器类型分析(data,xdata,code,pdata,bit)完全资料
2010年05月03日 星期一 下午 02:09

data-----指单片机内部自带RAM空间

xdata----指单片机外扩RAM空间

pdata----指单片机外扩RAM空间中的页面空间0x00~0xff(256字节/页),页地址由P2口决定。

bit--------指RAM中位寻址空间0x20~0x7f地址单元。

code-----指内部ROM或外扩FLASH空间。

转自:http://hi.baidu.com/haoyun81/blog/item/e9ded795f339294dd0135e09.html

在51系列中data,idata,xdata,pdata的区别:

data:固定指前面0x00-0x7f的128个RAM,可以用acc直接读写的,速度最快,生成的代码也最小。

idata:固定指前面0x00-0xff的256个RAM,其中前128和data的128完全相同,只是因为访问的方式不同。idata是用类似C中的指针方式访问的。汇编中的语句为:mox ACC,@Rx.(不重要的补充:c中idata做指针式的访问效果很好)

xdata:外部扩展RAM,一般指外部0x0000-0xffff空间,用DPTR访问。

pdata:外部扩展RAM的低256个字节,地址出现在A0-A7的上时读写,用movx ACC,@Rx读写。

bdata如何使用它呢?
若程序需要8个或者更多的bit变量,如果你想一次性给8个变量赋值的话就不方便了,(举个例子说说它的方便之处,想更深入的了解请在应用中自己琢磨)又不可以定义bit数组,只有一个方法

char bdata MODE;
sbit MODE_7 = MODE^7;
sbit MODE_6 = MODE^6;
sbit MODE_5 = MODE^5;
sbit MODE_4 = MODE^4;
sbit MODE_3 = MODE^3;
sbit MODE_2 = MODE^2;
sbit MODE_1 = MODE^1;
sbit MODE_0 = MODE^0;
8个bit变量MODE_n 就定义好了
这是定义语句,Keilc 的特殊数据类型。记住一定要是sbit
不能 bit MODE_0 = MODE^0;

转自:http://blog.sina.com.cn/s/blog_4daf4df90100i5ej.html

再加上一点:

在80C51单片机的内部数据存储器中,20H~2FH为位操作区域,其中没位都有自己的位地址,可以对没一位进行位操作。位的地址空间为00H~07FH,共16*8=128位。20H的最低位为00H,2FH的最高位为7FH。对于字节地址能被8整除的特殊功能寄存器的没一位,也具有可寻址的位地址,其位地制从80H开始。特殊寄存器的地址和它的位的最低位位地址的数字相同,比如P0口的地制是80H,那么P0口的最低位位地制也是80H。这里要把地址和位地址分清楚,前一个是P0口的地址,它有8位,每位有位地址,最低位的位地址是80H,次之是81H,他们在物理结构上是分开的。

在C语言中我们应该这么来定义它:

 

bit a,c,d;   /*定义几个位变量*/

 

uchar bdata put_1;   /*在位寻址区域定义一个变量,而他的8位再分别定义一个标号*/

sbit buzzer=put_1^0;

sbit led1=put_1^1;

sbit led2=put_1^2;

sbit led3=put_1^3;

sbit led4=put_1^4;

sbit run=put_1^5;

sbit up=put_1^6;

sbit down=put_1^7;

 

sbit led=P1^1;  /*定义P1口的1口为led*/

在编程中直接使用标号,可以给编程带来方便。

转自:http://hi.baidu.com/pingyi168/blog/item/6af0e51f70e16161f724e4c5.html

普通51系列单片机存储空间资源分配情况

空间名称
地址范围
说明
DATA
D:00H~7FH
片内RAM直接寻址区
BDATA
D:20H~2FH
片内RAM位寻址区
IDATA
I:00H~FFH
片内RAM间接寻址区
XDATA
X:0000H~FFFFH
64K片外RAM数据区
CODE
C:0000H~FFFFH
64K片内外ROM代码区
BANK0~BANK31
B0:0000H~FFFFH
:
:
B31:0000H~FFFFH
分组代码区,最大可扩展32X64KB ROM

单片机学习网http://www.51hei.com给大家整理出了上下这两个表格,方便大家查询。有问题可在评论或者论坛中提出。

单片机中关键字data,idata,xdata,pdata的区别

data:
固定指前面0x00-0x7f的128个RAM,可以用acc直接读写的,速度最快,生成的代码也最小。

idata:
固定指前面0x00-0xff的256个RAM,其中前128和data的128完全相同,只是因为访问的方式不同。idata是用类似C中的指针方式访问的。汇编中的语句为:mox ACC,@Rx.(不重要的补充:c中idata做指针式的访问效果很好)

xdata:
外 部扩展RAM,一般指外部0x0000-0xffff空间,用DPTR访问。 pdata:外部扩展RAM的低256个字节,地址出现在A0-A7的上时读写,用movx ACC,@Rx读写。这个比较特殊,而且C51好象有对此BUG, 建议少用。但也有他的优点,具体用法属于中级问题,这里不提。

startup.a51的作用
和 汇编一样,在C中定义的那些变量和数组的初始化就在startup.a51中进行,如果你在定义全局变量时带有数值,如unsigned char data xxx="100";,那startup.a51中就会有相关的赋值。如果没有=100,startup.a51就会把他清0。(startup.a51 ==变量的初始化)。 这些初始化完毕后,还会设置SP指针。对非变量区域,如堆栈区,将不会有赋值或清零动作。
有人喜欢改 startup.a51,为了满足自己一些想当然的爱好,这是不必要的,有可能错误的。比如掉电保护的时候想保存一些变量, 但改startup.a51来实现是很笨的方法,实际只要利用非变量区域的特性,定义一个指针变量指向堆栈低部:0xff处就可实现。, 为什么还要去改? 可以这么说:任何时候都可以不需要改startup.a51,如果你明白它的特性

转自:http://blog.sina.com.cn/s/blog_554b1f1b0100baz0.html

下面的一张图可以很好的展示51单片机rom和ram的分配情况(2010.10.22更新)

一些新型的8051使用地址扩展寄存器对传统8051的代码和/或XDATA空间作了扩展。下图所示是为扩展型8051器件编程所用的存储器类型。当我们使用LX51连接/定位器来实现存储器换页(memory banking)时,这些存储器类型可用于传统的8051器件。除了大家知道的BL51连接/定位器的代码换页外,LX51连接/定位器也支持标准8051器件的XDATA和代码区域的数据换页。

存储器类型 地址范围 说明
DATA D:00 - D:7F 可直接寻址的片内RAM
BIT D:20 - D:2F 可位寻址的RAM;使用位指令访问
IDATA I:00 - I:FF 间接寻址的片内RAM;可以使用@R0或@R1访问
XDATA X:0000 - X:FFFF 64KB RAM(读/写访问)。使用MOVX指令访问。
HDATA X:0000 - X: FFFFFF 16MB RAM(读/写访问)。使用MOVX指令和扩展的DPTR访问。
CODE C:0000 - C:FFFF 64KB ROM(只读)。用于存储常量或可执行代码。
ECODE C:0000 - C:FFFFFF 16MB ROM(只读)。用于存储常量。在Dallas 390架构的一些模式下也可能存储程序。
BANK0
...BANK31
B0:0000 - B0:FFFF
B31:0000 - B31:FFFF
用于把程序存储器空间扩展到32×64KB ROM 的代码堆。

     注意
    存储器前缀D: I: X: C: B0: .. B31: 不可用于Ax51汇编器或BL51连接/定位器级。列出存储器前缀只是为了便于更好地理解。Lx51连接/定位器和一些调试工具,例如μVersion 2调试器,使用存储器前缀来标志地址的存储器类型。

    如果我们使用Dallas 390的连续模式,CODE的地址空间可以为C:0000 -C:0xFFFFFF。

 

 

    扩展型8051的存储器布局

    扩展型8051的存储器布局,如下图所示,把变量地址空间扩展为最大16MB。

 

    在一些扩展型8051版本中,使用DPX特殊功能寄存器把DPTR寄存器扩展为一个24位寄存器。例如,Dallas 390提供了一种这种寻址被使能的新的操作模式。使用LX51中的存储器换页,我们甚至可以在传统8051器件中使用HCONST和HDATA存储器类型。

转自:http://blog.21ic.com/more.asp?name=Gonghighloam&id=21237

你可能感兴趣的:(单片机存储器类型分析(data,xdata,code,pdata,bit))