当前位置:首页 > 模拟 > 模拟
[导读]本文在对该模块进行分析的基础上给出了实现高速外部总线的方案,以及硬件连接和软件底层通用接口,解决了QE128连接外部高速总线设备的问题。

引  言

外部总线接口大都出现在功能和价格较高的高端微处理器中。例如,Freescale半导体公司生产的Coldfire和PowerPC微处理器,在低端的微控制器行列中,一般很少出现,主要原因是微控制器一般内部包含了Flash和SRAM,而不是像微处理器那样需要外扩大容量存储器放置代码和运行程序。但是,微控制器也会遇到需要外扩外部总线设备的情况,笔者在某项目中需要使用MCF51QE128(以下简称“QE128”)微控制器连接外部Flash存储测试数据,存取速度要求较高,因此无法使用串行接口的存储器,只能使用具有地址线和数据线的Flash存储器。

QE128是Freescale半导体公司推出的Flexis系列的首款产品,具有25 MHz的总线速度和多种外设模块;还有一个特点是,其内部包含了与其他微控制器不同的快速GPIO模块。

1  设计思路

使用微控制器中通用I/O模块模拟实现外部总线接口是一个比较好的方法,但目前微控制器中GPIO模块一般仅包含8个I/O口,而大容量的存储芯片一般的地址总线和数据总线都是16位或者更高位数的。这种情况下需要使用2个GPIO端口组合才能模拟,速度不高。

QE128微控制器中的快速GPIO模块(RGPIO)是一个比较特殊的模块。该模块直接与处理器的32位内部总线连接,支持字节、字和双字的访问,支持单周期、零等待的数据传输。这种特性与普通的GPIO有较大区别。区别的根本原因在于普通的GPIO模块都是与微控制器内部的从设备总线连接的。

实现的关键在于,如何使一个RGPIO模块既可以作为地址总线使用,又可以作为数据总线使用。通过对总线的分析,所有的数据通信都由主设备发起,然后发送地址信号,最后发送数据或接收总线数据,这种操作是有先后顺序的。基于这种分析,将RGPIO模块分时复用便可解决此问题。

使用QE128快速GPIO实现外部总线接口的设计示意图如图1所示。



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



2  硬件连接实例

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

图2为QE128与AT491LV1024A的硬件连接实例。在本实例中,锁存器使用的是2片TI公司的8路D型锁存器74HC373.2片74HC373的锁存使能LE(Latch Enable)引脚相连,通过QE128的TE信号控制来选择地址总线和数据总线。



地址/数据信号外的其他控制信号使用GPIO控制。本实例中使用PTF端口的4个引脚。

3  软件设计

RGPIO模块常用的寄存器共有以下6个:数据方向寄存器RGPIO_DIR、数据寄存器RGPIO_DATA、引脚使能寄存器RGPIO_ENB、数据位清零寄存器RGPIO_CLR、数据位置位寄存器RGPIO_SET和数据位翻转寄存器RGPIO_TOG。6个寄存器均为16位寄存器。其中前面3个寄存器是其他的GPIO口都具有的,后面3个寄存器是RGPIO模块比较有特色的地方。这3个寄存器与数据寄存器RGPIO_DATA的每一位是对应的,将RGPIO_CLR中某一位置为0,则相应RGPIO_DATA的对应位就会清零。类似的,将RGPIO_SET或RGPIO_TOG的某一位置1,则会将RGPIO_DATA对应位置1或反转。相对于普通MCU中的读取数据至累加器→置位→写入寄存器的操作。RGPIO可以减少操作的时间,具体比较详见QE128参考手册中RGPIO一章。

了解底层寄存器后,笔者对外部总线接口实现的底层函数做了通用性的封装,共包括3个函数:外部总线接口初始化函数void Exb_Init(void);外部总线写函数void Exb_QueuedWrite(word*pAddr,word*pData,bytenTransfer);外部总线读函数void Exb_QueuedRead(word*pAddr,word*pData,byte nTransfer)。Exb_QueuedWrite函数进行nTransfer次写操作,将数据数组中的数据写入地址数组中的地址。Exb_QueuedRead函数进行nTransfer次读操作,将地址数组中地址对应的数据读出放人数据数组中。其中Exb_Init函数代码如下:



根据这3个通用底层接口函数便可以编写针对不同的外部设备的函数进行操作。本文以对AT49LV1024A的Flash存储器进行数据写入和读出操作为例,基本满足常用功能的需要。具体的AT49LV1024A存储器的命令序列请参考该芯片的技术手册。



结  语

MCF51QE128微控制器的快速GPIO模块是具有特色的一个模块。本文在对该模块进行分析的基础上给出了实现高速外部总线的方案,以及硬件连接和软件底层通用接口,解决了QE128连接外部高速总线设备的问题。
本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

本文中,小编将对无线模块予以介绍,如果你想对无线模块的详细情况有所认识,或者想要增进对它的了解程度,不妨请看以下内容哦。

关键字: 无线模块 寄存器 处理器

最经典的2DFF 1-bit同步器如下,下图结构通常用于单bit控制信号的异步处理:

关键字: 异步电路 寄存器

GPIO全称General Purpose Input Output即通用输入/输出,其实GPIO的本质就是芯片的一个引脚,通常在ARM中所有的I/O都是通用的。不过由于每个开发板上都会设计不同的外围电路,这就造成GPI...

关键字: GPIO 芯片

单片机(Single-Chip Microcomputer)是一种集成电路芯片,是采用超大规模集成电路技术把具有数据处理能力的中央处理器CPU、随机存储器RAM、只读存储器ROM、多种I/O口和中断系统、定时器/计数器等...

关键字: 单片机 寄存器

dsPIC33CH/dsPIC33CK系列数字电源控制器芯片,在目前诸多典型应用中都得到了广泛使用。在闭环控制中,尤其是电压模式控制中,对PWM数据寄存器进行实时更新是必要的一个动作,本文主要就这一话题做一些分析和讨论

关键字: 数字电源控制器 寄存器

中国,北京 – 2022年5月5日 – Analog Devices, Inc.(Nasdaq:ADI)推出新一代16至24位超高精度逐次逼近寄存器(SAR)模数转换器(ADC)系列产品,可简化仪器仪表、工业和医疗健康应...

关键字: ADI 模数转换器 寄存器

星标「嵌入式大杂烩」,一起进步!链接:https://www.cnblogs.com/jozochen/p/8541714.html一、问题复现稳定复现问题才能正确的对问题进行定位、解决以及验证。一般来说,越容易复现的问...

关键字: 嵌入式开发 函数 代码 寄存器

文|周立功日期|2021年11月29日ZLG致远电子创始人周立功你用的mcu涨价了,这还不是最坏的结果。过去20多年里芯片涨价,半年后基本上都会缓和下来。今年不一样,接近年底了,还没有任何迹象表明明年何时恢复供应,很多企...

关键字: MCU 寄存器 软件开发 CK

Q:如果系统中的FPGA/微处理器上只剩下一个GPIO,该如何进行模拟测量?A:可以使用电压-频率转换器代替模数转换器。在关注机器健康和其他物联网(IoT)解决方案的现代应用中,随着检测功能的日趋普及,对更简单的接口以及...

关键字: GPIO 测量温度 数字接口 ADC

时序逻辑电路其任一时刻的输出不仅取决于该时刻的输入,而且还与过去各时刻的输入有关。常见的时序逻辑电路有触发器、计数器、寄存器等。

关键字: 时序逻辑电路 寄存器 计数器

模拟

31144 篇文章

关注

发布文章

编辑精选

技术子站

关闭