S3C2440A 内存接口概念
本文是基于韦东山视频的学习笔记
这一课回答了几个问题
- CPU怎么控制其他设备如GPIO, UART, Nor flash, Nand flash的
就是这样控制咯,其实可以先分两大类设备(把CPU外的都先称为设备吧)。
- CPU可以直接把地址传给他的设备
- CPU不可以直接把地址传给他的设备
第一种,CPU直接寻址访问,然后设备直接把数据送回CPU,如Nor flash、网卡、SDRAM。
第二种,CPU先把地址送给内存控制器,内存控制器再根据地址去控制相关寄存器去控制设备,数据也是原路返回,如GPIO、UART等。
- CPU和设备交换数据时怎么不被其他干扰
对于第一种,在CPU访问设备时,不可以被其他设备干扰,如正在和Nor flash交易,其他两个设备应该自觉走开不参与,试想如果一起交易,CPU怎么分的清楚谁是谁是不是,所以引入了片选。片选初始是高逻辑电平,拉低谁,谁就被启动(被CPU喊来交易)。
- CPU怎么分清楚是读数据还是要写数据
其实和片选一样,由读信号(nOE)和写信号(nWE),这相当于告诉你一声,我要读/写数据啦,不然CPU和设备怎么知道是别人来捣乱还是干扰。
- 对于不同位宽的设备,CPU是如何操作和读写数据的
以下作了说明。感觉很难说明白,就不做解释了,只做了相关笔记。
mov R0, #3
ldrb R1, [R0] //读一个字节
cpu发送地址 | ROM收到地址 | 读ROM | ROM返回数据 | |
---|---|---|---|---|
8bit | 0b0011 | 0b0011 | 第3个 8bit | 第3个 8bit 中的第0个8bit(就是他本身) |
16bit | 0b0011 | 0b0001 | 第1个 16bit | 第1个 16bit 中的第1个8bit |
32bit | 0b0011 | 0b0000 | 第0个 32bit | 第0个 16bit 中的第3个8bit |
mov R0, #4
ldr R1, [R0] //读四个字节
cpu发送地址 | ROM收到地址 | 读ROM | ROM返回数据 | |
---|---|---|---|---|
8bit | 0b0100 | 0b0100 | 第4、5、6、7个 8bit | 第4、5、6、7个 8bit |
16bit | 0b0100 | 0b0010 | 第2、3个 16bit | 第2、3个 16bit |
32bit | 0b0100 | 0b0001 | 第1个 32bit | 第1个 32bit |