Keil C51中code、data、bdata、idata、xdata、pdata详解及用法
8051 结构提供给用户3 个不同的存储空间,程序存储器ROM,数据存储器RAM(内部RAM和外部RAM)。随便打开一个8051MCU的datasheet, 现拿N76E003例说:
Keil C51通过以下的关键字定义了不同的存储类型,从而确保用户能够访问到51架构的全部存储空间。
code:访问程序存储器ROM,即我们常说的代码段,用来存放可执行代码,空间可达64K(0x0000~0xffff),该存储空间的代码段是只读的。
定义大量常量数据时可以用 code, 不加在修饰的话RAM里,一般编译不通过,例如:
code unsigned char HS6200_Calibration_Data =
{
HS6200_BANK0_CONFIG, 0x03,
HS6200_BANK0_RF_CH, 0x32,
HS6200_BANK0_RF_SETUP, 0x40,
};
code unsigned char HS6200_Calibration_DCtrl = {1,1,1};
code unsigned char HS6200_Calibration_Analog =
{
HS6200_BANK1_PLL_CTL0, 0x40,0x01,0x10,0xE5,
HS6200_BANK1_CAL_CTL, 0x20,0x08,0x50,0x40,0x50,
HS6200_BANK1_IF_FREQ, 0x00,0x00,0x1F,
HS6200_BANK1_FDEV, 0x20,
HS6200_BANK1_DAC_CAL_HI, 0x7F,
HS6200_BANK1_RF_IVGEN, 0x1F,0x64,0x00,0x81,
};
code unsigned char HS6200_Calibration_ACtrl = {4,5,3,1,1,4};
/*config infor*/
code unsigned char HS6200_Analog_Data=
{
HS6200_BANK1_PLL_CTL0, 0x40,0x01,0x30,0xE1,
HS6200_BANK1_PLL_CTL1, 0x00,0x42,0x10,0x01,
HS6200_BANK1_CAL_CTL, 0x29,0x89,0x75,0x28,0x50,
HS6200_BANK1_RX_CTRL, 0x52,0xC2,0x09,0xAC,
HS6200_BANK1_FAGC_CTRL_1, 0x80,0x14,0x08,0x29,
HS6200_BANK1_RF_IVGEN, 0x1F,0x64,0x00,0x01
};
unsigned char HS6200_Analog_Ctrl={4,4,5,4,4,4};
code unsigned charHS6200_Init_Data=
{
HS6200_BANK0_CONFIG, 0x0e,
HS6200_BANK0_RX_PW_P0, 0x0A, //*根据需要配置*//
HS6200_BANK0_DYNPD, 0x3F,
HS6200_BANK0_FEATURE, 0x07,
HS6200_BANK0_SETUP_VALUE, 0x40,0x5A,0x80,0x06,0x00,
HS6200_BANK0_PRE_GURD, 0x77,
HS6200_BANK0_EN_AA, 0x3F,
HS6200_BANK0_EN_RXADDR, 0x3F,
HS6200_BANK0_SETUP_AW, 0x03,
HS6200_BANK0_SETUP_RETR, 0x0F,//*根据需要配置*//
HS6200_BANK0_RF_CH, 0x46,
HS6200_BANK0_RF_SETUP, 0x47,
HS6200_BANK0_RX_ADDR_P0, 0x55,0x42,0x9C,0x8F,0xC9,
HS6200_BANK0_TX_ADDR, 0x55,0x42,0x9C,0x8F,0xC9,
};
code unsigned char HS6200_Init_Ctrl={1,1,1,1,5,1,1,1,1,1,1,1,5,5};
刚开始没加code, 编译超RAM空间了。
data:访问可直接寻址的片内存储器,即内部RAM,即我们常说的DATA区或数据段,在整个RAM块中只占前128 字节(0x00~0x7f),因为它采用直接寻址方式,对变量最高速的访问最快,通常我们把使用比较频繁的变量或局部变量存储在DATA 段中,但是次数必须节省,因为它的空间毕竟有限。
代码定义的数据(数组)变量一般不加修饰,就是在RAM(DATA)里。
DATA数据段中分为两个子段,第一个子段包含四组寄存器组,每组寄存器组包含八个寄存器,共32 个寄存器;另外一个子段叫做位寻址段BDATA, 大小16 个字节,共128 位,每一位都可单独寻址。
例:
sbit LED= P1^2
bdata:访问位寻址的片内存储器,即访问内部RAM,在其中从20H开始的16字节(0x20~0x2f)。
xdata:访问外部数据存储器,即外部RAM,大小64K(0x0000~0xffff),16 位地址寻,称作外部数
据区简称XDATA 区,访问XDATA 须采用间接寻址。访问速度尽次于RAM(DATA)
例
xdata uint32_t arry;
一般可设置编译自己转大数据到XDATA(XRAM)
idata:访问间接寻址的内部RAM ,256个字节(0x00~0xff),在8051 系列的一些单片机如8052 有附加的128 字节的内部RAM,固定指前面0x00-0xff的256个字节的片内RAM,其中前128字节和data的128字节完全相同,只是因为访问的方式不同。
pdata:访问当前页面内的外部RAM中的XDATA,每一页256字节,按页访问。PDATA 段只有256 个字节,而XDATA段可达65536 个字节(64K嘛),对PDATA 和XDATA 的操作是相似的,但是对PDATA 段寻址比对XDATA 段寻址要快,因为对PDATA 段寻址只需要装入8 位地址,而对XDATA 段寻址需装入16 位地址,所以尽量把外部数据存储在PDATA 段中。
说明不到清楚的地方,请大家指正。欢迎在评论区讨论。
页:
[1]