新闻中心

EEPW首页>嵌入式系统>设计应用> ARM与8、16、32位宽存储器的地址线连接若干问题

ARM与8、16、32位宽存储器的地址线连接若干问题

作者: 时间:2016-11-11 来源:网络 收藏
ARM是32位,地址空间是2的32次幂,4G地址空间。所有的外设(FLASH,RAM,SD卡等等)都映射到这4G的空间上。比如大部分ARM7都把RAM映射到0x40000000,所以对RAM的操作就在0X40000000开始的地址上。FLASH从0X0开始。使用FLASH还要考虑地址重映射,就是选择片内FLASH或片外FLASH。

FLASH一般是8位或16位,当它接到32位的ARM上时,地址位就会错位。对于16位FLASH,FLASH的A0要接ARM的A1。对于8位FLASH,FLASH的A0要接ARM的A0。ARM的A0对应8位,ARM的A1对应16位,ARM的A2对应32位,如果FLASH是32位,那么FLASH的A0接ARM的A2

本文引用地址://m.amcfsurvey.com/article/201611/316826.htm

32位的FLASH,FLASH的A0要接ARM的A2,因为32位宽数据线表示最小的读写单位为4个字节,每次要跳4个字节的话,那么就是从A2开始才变化,A1 A0不变化

16位的FLASH,FLASH的A0要接ARM的A1,因为16位数据线宽表示最小读写单位为2个字节,每次要跳2个字节的话,那么就是从A1开始才变化,A0不变化

8位的FLASH,FLASH的A0要接ARM的A0,因为8位数据线宽表示最小的数据读写单位为1个字节,每次要跳1个字节的话,那么就是从A0开始才变化。


LPC2200,S3C2410A,S3C2440等都是上述这样的,当然也有不同的。IMX27和BF537这两款CPU都是不管存储器是多少位的的,都是直接A0-B0,没有任何考虑错位的情况,是因为他们的存储控制器已经内部作了处理了,三星的如S3C2443S3C2450S3C6410等后续的也都是这样子了。



评论


技术专区

关闭