学前班-怎么看原理图之内存类接口

类似内存接口,RAM-Like接口

这里写图片描述
地址线
数据线
2440上可以接网卡、Nor Flash,SDDRAM,这些外设都一起共用数据线与地址线;当2440访问内存的时候,一定不要让网卡、Nor Flash干扰(即互不干扰),怎么样才能做到这一点?
CS(chip select):片选线,当某个芯片的CS为低电平的时候,才响应。
地址线、数据线接有众多的设备,怎么做到只访问其中一个,避免其余的影响?每一个芯片都有一个单独的片选引脚,访问之前先设置片选引脚为低电平;其他芯片选引脚为高电平。

是否需要我们手工来设置片选引脚?不需要,2440内部有一个内存控制器、CPU;CPU访问某个地址时,CPU发出的地址信号是发给内存控制器,内存控制器根据地址决定哪一个片选引脚输出为低电平。

这里写图片描述

由图可知,对应芯片规定了地址范围。CPU根据这个地址范围可以计算出应该片选中哪个外部芯片。

每一个片选引脚 对应的地址范围称为一个bank,一个bank是 128MB = 2 的 27次方,即可以27条地址线(ADDR0- ADDR26);
CPU32位,并不表示有32条地址线, CPU访问一个地址的时候,假设访问A地址,A地址32位,bit26 - bit0 就出现在地址线,bit31 - bit 27内存控制器根据这几位决定片选中哪一个芯片。

OE: output enalbe 输出使能,读信号。
WE:写信号

这里写图片描述

以上这些信号都统一由内存控制器来管理协调。

不同位宽外设的接线方式?

对于16位的接线方法

CPU认为一个地址对应一个字节,但是NOR Flash内部的字节是16,它认为一个地址对应两个字节。这之前的矛盾怎么协调?假设CPU要访问地址3的一个字节,对NOR Flash(16位为单位)来说,应该访问NOR Flash的第一个单位,把这个两个字节的数据读取出来,发到内存控制器,内存控制器再将地址3的数据挑出来 ,交给CPU。
假设访问地址2的一个字节,与上面同理。

对于32位的地址来说:

地址线Add2接到两个SDARM的A0,add3 ….;
两个SDARM做为一个整体,一次性提供32位数据;
CPU认为一个地址对应一个字节,SDARM认为对应32个字节,怎么处理这个矛盾?
假如CPU要访问0x3000,0000中的一个字节,各自的两个字节分别够成低16位、高16位;内存控制器得到两个SDARM组成的四个字节,把第一个字节挑出来给CPU;假如要访问0x3000,0001,两个SDARM向内存控制器发送的地址是一样的。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值