单片机与8255芯片连接详解
就我们平时所用到8255的功能,本人认为很简单!!
为什么这么说呢?
其实我只是把8255看成一个139译码器(2-4),CS为片选,A0,A1分别选中PA,PB,PC,D口(控制寄存器),唯一不同的是可以通过D口控制PA,PB,PC的工作方式。先来看看8255的引脚图 http://www.51hei.com/chip/161.html
首先CS=0,即P25=0,然后就是通过P21,P22分别选中几个口。所以PA的地址可以0000-D9FF
同理PB:DBFF,PC:DDFF,CON:DFFF。
通过配置D口来控制P口的功能,不管三七二十一,都配置成输出就可以(方式一)。
#include absacc.h>
#define a8255_PA XBYTE[0xD1FF] /*PA口地址*/
#define a8255_PB XBYTE[0xD2FF] /*PB口地址*/
#define a8255_PC XBYTE[0xDDFF] /*PC口地址*/
#define a8255_CON XBYTE[0xDFFF] /*控制字地址*/
a8255_CON=0x81;
以上是例子的程序里面配置的,由于开始没有看到这个头文件,看到这程序感觉有点懵,后面我看了头文件的东西,哈哈,原来是这么回事啊!当然他头文件里面有很多东西,其实只有只一句起作用:#define XBYTE ((unsigned char volatile xdata *) 0)
幸亏看ARM的时候见过这东西,不然真的不知道怎么办了!!!!
#define XBYTE ((unsigned char volatile xdata *) 0)
定义 :XBYTE 为 指向 外部 地址空间
unsigned char 数据类型的指针,指针值为0(我也不知道为什么为char型)
至于 volatile的作用就是让编译器不至于优化掉它的操作(不是特别理解)
这样,可以直接用XBYTE[0xnnnn]或*(XBYTE+0xnnnn)访问外部RAM了。
所以我们用8255的时候可以不用头文件。
#define XBYTE ((unsigned char volatile xdata *) 0)
#define a8255_PA XBYTE[0xD1FF] /*PA口地址*/
#define a8255_PB XBYTE[0xD2FF] /*PB口地址*/
#define a8255_PC XBYTE[0xDDFF] /*PC口地址*/
#define a8255_CON XBYTE[0xDFFF] /*控制字地址*/
只要把上面五行代码拷贝进去就行了!unsigned char 数据类型的指针,指针值为0(我也不知道为什么为char型)
这是c语言中的强制转换,转换成什么类型根据要转换成的目标的单位长度,单片机是8位的,都是以字节为单位,所以转换成char。在arm中,一般就要转成unsigned int(4字节)。当然,如果操作的外设的数据宽度是16bits,就要转换成unsigned short
评论