类似内存接口,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:写信号
以上这些信号都统一由内存控制器来管理协调。
不同位宽外设的接线方式?
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向内存控制器发送的地址是一样的。