32位精简指令集架构的AT91M42800A的设计与应用
(4)显示电路
显示电路可采用数码管显示或液晶显示,由于液晶显示的功耗低,故常采用这种显示方式。该设计选用的液晶显示模块为LCM103。
(5)电源及复位电路
AT91M42800A内部带有看门狗(WatchDog)电路,也可以外加WatchDog电路。本文中的例子采用的就是外加WatchDog电路的接法,所选用的器件是MAXIM公司生产的MAX6316LUK29CY。
4 典型应用
由于单片机AT91M42800A具有低功耗、高性能、片内资源丰富、寻址空间大等优点,所以适合现场总线产品的开发,其简要硬件原理图如图2所示。图中只给出主要器件的主要引脚接法,电源电路及其它引脚限于篇幅图中未画,读者在实际的设计过程中可自行设定。
图2 现场总线开发实例
5 存储器空间分配
在本设计中,由于ARM7TDMI处理器的地址空间非常大(可达4G字节)。因此,在重映射前,可将地址最低的4MB分配给内部存储器,最高的4M 分配给内部外设,其余中间的地址空间(从0x00400000到0xFFFCFFFF)留给外部扩展的设备,这部分设备可由AT91M42800A 的八个片选来选择。笔者选择的AT91M42800A开发环境为ADS1.1,由于在实际的嵌入式系统中,ADS1.1提供的缺省存储器映射不能满足要求,而用户的目标硬件有多个存储器设备,且位于不同的位置,如上例中,AT91M42800A的四个片选分别给了外扩FLASH、外扩的RAM、以及FB3050的内部寄存器片选和存储器片选,因此需要通过Scat-ter 文本文件来指定一段代码或数据在加载和运行时在存储器的不同位置,这个文本文件在命令行中由-scatter开关指定。在arm linker菜单的output 子菜单下有link type一项。link type 选项中,只要选择 scatter,并指定scatter.scf 文件的存储位置就可以了。在下面的例子中,FLASH中的代码和数据存储在0x04000000起始的、长度为32kB的地址空间中。
由于Start. s:汇编引导程序代码在执行重映射后,中断向量表将存放在内部RAM中,其地址范围为0x00000000到0x00000018,因此,用于存放数据的实际地址是从0x00000020开始的。存放在外扩RAM中的代码放在ext_ram.c中,以下类似。上例的scatter 文本文件代码如下:
FLASH 0x04000000 0x8000
{
FLASH 0x04000000 0x8000
{
Start.o (Reset, +First)
* (+RO)
}
RAM ON CHIP 0x0020 0x2000
{
*(+RW,+ZI)
}
RAM OFF CHIP 0x8000000 0x40000
{
ext ram.o(+RW,+ZI)
}
FB3050 SEND 0x30000000 0x00ff
{
sendbuf.o(+RW,+ZI)
}
FB3050 RECEIVE 0x30004000 0x00ff
《32位精简指令集架构的AT91M42800A的设计与应用(第2页)》