内存地址
1.逻辑地址
包含在机器语言指令中用来指定一个操作数或一条指令的地址。每个逻辑地址都由一个段(segment)和偏移量(offset)组成,偏移量指明了从段开始的地方到实际地址之间的距离。
2.线性地址
是一个32位无符号整数,可以用来表示4GB的地址,也就是高达4294967296个内存单元。线性地址通常用十六进制数字表示,范围从0x00000000到0xffffffff。
3.物理地址
用于内存芯片级内存单元寻址,他们与从微处理器的地址引脚发送到内存总线上的电信号相对应。物理地址由32位或者36位无符号整数表示。
内存控制单元(MMU)通过一种分段单元(segmentation unit)的硬件电路把一个逻辑地址转换成线性地址,接着第二个分页单元(paging unit)的硬件电路把线性地址转换成一个物理地址。
逻辑地址--(分段单元)-->线性地址--(分页单元)-->物理地址
直接内存存取(DMA)
DMA(Direct Memory Access,直接内存存取) 即内存和外设交换数据,它允许不同速度的硬件装置来沟通,而不需要依赖于 CPU 的大量中断负载。否则,CPU 需要从来源把每一片段的资料复制到暂存器,然后把它们再次写回到新的地方。在这个时间中,CPU 对于其他的工作来说就无法使用。
参考书目《深入理解LINUX内核》