使用keil 开发单片机程序时,在absacc.h 这个头文件中,有XBYTE这样一个宏。它的定义是 #define XBYTE ((unsignedchar volatile xdata *) 0)
可以使用XBYTE去访问外部的RAM,也可以用XBYTE去访问扩展的I/0设备注意:这里是利用的英特尔总线进行访问的,那么就会有时序的问题,在C语言中,这些都帮你做完了,所以无需考虑3、关于I/O的控制如下,低字节表示的是P0端口,高字节表示的是P2端口。P2端口通常作为控制端口,而P0通常作为数据端口eg:XBYTE[0x8800] = buz_stu;其中用P2做控制,P0的数据就是buz_stu的状态下面说说这个[]里的偏移量的数值怎么定义。tag:#define XBYTE ((unsignedchar volatile xdata *) 0) XBYTE是一个指针,且值为0,表示的是地址0。XBYTE[56],表示的也就是地址56,和#define TEST ((unsignedchar volatile xdata *) 56)这样定义并使用是一样的,在C语言中,数组名就代表首地址。关于这个问题,如果你扩展的是RAM的话,首先利用p0和p2口发送16位的地址,然后再往此地址读或者写数据。如果你使用外部的io设备,你就利用单片机的先发地址的特性,利用p2口做控制信号,p0口做数据信号。偏移量的值,我们举个例子来说明。现有这样一个外部io器件,有相应的rd wr 引脚,另外还需要一个C/D控制信号(C/D引脚为高电平时,数据总线接受指令,为低电平时接受数据)。这样的话,很明显,这个外部io器件可以使用总线方式进行控制。Rd wr 分别接到单片机的rd wr 引脚。还有一个控制引脚C/D,我们把它接到单片机的p2.0口。(还记得说控制io器件时,p2口做控制口了吧)。当然,p0口做数据口。好了,硬件连线介绍完毕!那怎么用c语言进行控制硬件那。#define DP XBYTE[0xfeff] // 数据口#define CP XBYTE[0xffff] // 命令口我们以向外部io设备发送数据为例分析一下偏移量怎么算的。把0xfeff展开成二进制形式 1111 1110 1111 1111 (低字节表示的是P0端口,高字节表示的是P2端口,还记得,哈)我们主要是控制p2.0口在传送总线数据时是低电平就行了,其他的控制信号,我们并不关心,所以p2口的最低位保证为0,其他位是什么都行。不过,赋值时保证不影响控制就行。我们这里不需要的位全部用的1 。其实,这个偏移量就是外部存储或者io设备的地址。DP=5;表示的含义就是把5送到外部0xfeff这个地址里存储起来。只是,所需的读写时序由单片机自己产生,先送出地址信号,由p2 p0组成,然后再通过p0口送数据。这里,我们使用了这个特性,用p2口作为外部io设备的控制信号。因为只用p0口是复用的,p2口的状态不变,正好作为控制信号。
xbyte
最新推荐文章于 2023-01-12 21:15:37 发布