新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 單片機與8255芯片連接詳解

單片機與8255芯片連接詳解

作者: 時間:2012-08-29 來源:網(wǎng)絡 收藏

就我們平時所用到的功能,本人認為很簡單??!

為什么這么說呢?

其實我只是把看成一個139譯碼器(2-4),CS為片選,A0,A1分別選中PA,PB,PC,D口(控制寄存器),唯一不同的是可以通過D口控制PA,PB,PC的工作方式。先來看看的引腳圖 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



評論


相關推薦

技術專區(qū)

關閉