对于具体存储器而言,它的位宽是一定的,所谓位宽,指的是“读/写操作时,最小的数据单元”──别说最小单元是“位”,一般存储器上没有单独的“位操作”,修改位时通过把整个字节、字或双字读出来、修改,再回写。对于处理器来说,一个地址对应的是一个字节(8位),也就是说处理器的地址线对应的最小数据单元是字节。
这里需要注意的是,不要把“存储器的位宽”和“处理器的位数”这两个概念混淆了。存储器的位宽是读写存储器的最小数据单元,处理器位数是处理器可以一次处理的字节数,32位处理器可以一次处理4字节数据。
如果处理器最小数据单元是8位,存储器位宽是16位,那在我们写程序时会特意进行16位操作吗?显然不会,我们写代码时,可不管外设到底是多少位。这是如何实现的呢?原因在于有存储控制器(MemoryController)这个中间层。
存储控制器根据存储器的位宽,每次总是读/写16位数据。
以读操作为例:
处理器进行8位操作时,它选择其中的8位返回给处理器;
处理器进
处理器与NOR flash/pcRAM存储器的错位连接
最新推荐文章于 2021-12-29 20:23:25 发布