1.最容易访问的设备是什么?
是内存!
要读写内存,知道它的地址就可以了,不需要什么驱动程序;
volatile unsigned int *p = 0xffff8811;
unsigned int val;
*p = val;
val = *p;
只有内存能这样简单、方便的使用吗?
不是的,所有的“ram-like”接口设备都可以这样操作;
什么叫“ram-like”接口?
- 要发出地址:有地址线
- 要读写地址:有数据线
由上图可知,cpu访问某个设备,数据线,地址线,读写信号线都是共用的,怎样保证cpu在访问某个设备的时候其他设备不会来干扰我呢?这里就引入了一个新的设备——内存控制器。
cpu发出地址addr,会先到达内存控制器,内存控制器会判断属于哪一个设备的地址范围,如果是在flash的范围,内存控制器就会选中flash的片选信号cs1,没有被选中的就不会访问。
对内存来说可以直接读写,但是对flash来说,要发一些命令,先擦除它,解锁它,才能写。对GPIO来说,是去操作他的寄存器;读写寄存器,输出输入寄存器等。
对于cpu来说可以发出命令直接控制emmc控制器,但不能直接访问emmc flash。要访问emmc flash就要编写复杂的驱动程序,因为emmc falsh的和cpu是隔离开的。如果cpu发出的地址可以直接到达emmc flash这不就简单多了,这就是PCI的做法!
我们只需要关心红线左边就可以了,就像访问内存一样访问PCI/PCIe设备。