您的位置 首页 传感器

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

ARM是32位,地址空间是2的32次幂,4G地址空间。所有的外设(FLASH,RAM,SD卡等等)都映射到这4G的空间上。比如大部分ARM7都把RAM映射到0…

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

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,没有任何考虑错位的状况,是由于他们的存储控制器现已内部作了处理了,三星的如S3C2443\S3C2450\S3C6410等后续的也都是这姿态了。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/yingyong/chuanganqi/274823.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部