关 闭

新闻中心

EEPW首页 > 工控自动化 > 设计应用 > MCF51QEl28快速GPIO的外部总线接口设计

MCF51QEl28快速GPIO的外部总线接口设计

作者:时间:2010-06-25来源:网络收藏

引言
大都出现在功能和价格较高的高端微处理器中。例如,Freescale半导体公司生产的Coldfire和PowerPC微处理器,在低端的微控制器行列中,一般很少出现,主要原因是微控制器一般内部包含了Flash和SRAM,而不是像微处理器那样需要外扩大容量存储器放置代码和运行程序。但是,微控制器也会遇到需要外扩设备的情况,笔者在某项目中需要使用McF51QEl28(以下简称“QEl28”)微控制器连接Flash存储测试数据,存取速度要求较高,因此无法使用串行的存储器,只能使用具有地址线和数据线的Flash存储器。
QEl28是Freescale半导体公司推出的Flexis系列的首款产品,具有25 MHz的速度和多种外设模块;还有一个特点是,其内部包含了与其他微控制器不同的GPI()模块。

本文引用地址:http://www.eepw.com.cn/article/163014.htm

1 思路
使用微控制器中通用I/O模块模拟实现外部总线是一个比较好的方法,但目前微控制器中模块一般仅包含8个I/O口,而大容量的存储芯片一般的地址总线和数据总线都是16位或者更高位数的。这种情况下需要使用2个端口组合才能模拟,速度不高。
QEl28微控制器中的模块(RGPIO)是一个比较特殊的模块。该模块直接与处理器的32位内部总线连接,支持字节、字和双字的访问,支持单周期、零等待的数据传输。这种特性与普通的GPIO有较大区别。区别的根本原因在于普通的GPIO模块都是与微控制器内部的从设备总线连接的。
实现的关键在于,如何使一个RGPIO模块既可以作为地址总线使用,又可以作为数据总线使用。通过对总线的分析,所有的数据通信都由主设备发起,然后发送地址信号,最后发送数据或接收总线数据,这种操作是有先后顺序的。基于这种分析,将RGPIO模块分时复用便可解决此问题。
使用QEl28GPl0实现外部总线接口的示意图如图1所示。


RGPIO模块的16个引脚连接外部设备的地址总线和数据总线(此处需要注意),各信号线的含义如表1所列。其中的GPIO表示微处理器中方向可以为输出的通用输入/输出引脚。需要注意的是,RGPIO模块的16个引脚是与两个通用I/O模块PORTC和PORTE复用的,所以在原理图时,用作控制信号的GPIO引脚应选择PORTC和PORTE端口之外的GPIO。另外,如果RGPI0需要内部上拉,则需要设置PORTC和PORTE的内部上拉寄存器。这一点在软件设计中的外部总线接口初始化函数Exb_Init中有体现。

2 硬件连接实例
以Atmel公司的单电压存储器AT49LVl024A为例。AT49LVl024A存储容量为128 KB(64K×16位),工作电压为3.3 V,可以直接与QEl28连接。AT49LVl024A的地址线和数据线宽度均为16位,控制信号包括芯片使能信号、输出使能信号和写使能信号。


上一页 1 2 下一页

评论


相关推荐

技术专区

关闭