單片機與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 數(shù)據(jù)類型的指針,指針值為0(我也不知道為什么為char型)
至于 volatile的作用就是讓編譯器不至于優(yōu)化掉它的操作(不是特別理解)
這樣,可以直接用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 數(shù)據(jù)類型的指針,指針值為0(我也不知道為什么為char型)
這是c語言中的強制轉(zhuǎn)換,轉(zhuǎn)換成什么類型根據(jù)要轉(zhuǎn)換成的目標的單位長度,單片機是8位的,都是以字節(jié)為單位,所以轉(zhuǎn)換成char。在arm中,一般就要轉(zhuǎn)成unsigned int(4字節(jié))。當然,如果操作的外設的數(shù)據(jù)寬度是16bits,就要轉(zhuǎn)換成unsigned short
評論