DMA:
一是 动态内存分配:dynamic memory allocate. 就是程序在执行过程中分配内存.
这就是我们在c/c++中经常用到的new, delete, alloc(函数)等等.

[[
memory::[ˈmɛməri] 发音中是e, 不是en.
有多种意思: 一是记忆, 记忆力, 记性: his phone number has slipped(滑动, 滑走了)my memory.
二是存储器(外部存储器和内部存储器都可以), 内存.]]

另外一种意思是: 直接存储器存取. direct memory access
就是 电脑主板上的 DMA控制器(芯片), 取代cpu, 来控制数据的传送(存取).

如果没有DMA, 要将数据 在 适配卡(适配器: 包括硬盘/U盘/光盘/卡式磁带等等的统称) 和 内存之间传送(包括适配卡到内存的双向传送, 内存到内存分段之间的传送, 适配卡和适配卡之间的传送), 都要在cpu的参与下来动作, 这就包括两个动作:
1. 将data transfer to register
2. register -> destination
这样动作多了, 效率慢了, 同时还要占用cpu的工作时间. 划不来!
那么, 就用 在电脑启动 初始化的时候, 由cpu给主板上 的DMA控制器 编程, 以后 内存和存储器之间的数据传输, 就直接由 DMA 控制器来做, 这样:一是解放了cpu, 让它专心控制核心的OS的管理工作, 二是简化了数据传送的线路和过程, 没有中间步骤.

---------------- DMA就相当于 cpu对数据传送的 放权!

------------- 网上的参考摘要
http://wenku.baidu.com/view/9e507f8bd0d233d4b14e69cd.html
电脑上有很多总线, 各完成各个的功能.
对数据总线, 有读数据总线和写的数据总线.
控制总线, 接收/传达控制命令(控制信号中就包括 读/写动作, 目的/源地址, 字节数 的多少等等.

DMA(Direct Memory Access) ,即直接存储器存取,是一种快速传送数据的机制。数据传递可以从适配卡到内存,从内存到适配卡或从一段内存到另一段内存。DMA技术的重要性在于,利用它进行数据传送时不需要CPU的参与。每台电脑主机板上都有DMA控制器,通常计算机对其编程,并用一个适配器上的ROM(如软盘驱动控制器上的ROM)来储存程序,这些程序控制DMA传送数据。一旦控制器初始化完成,数据开始传送,DMA就可以脱离CPU,
独立完成数据传送。  
在DMA传送开始的短暂时间内,基本上有两个处理器为它工作,一个执行程序代码,一个传送数据。利用DMA传送数据的另一个好处是,数据直接在源地址和目的地址之间传送,不需要中间媒介。如果通过CPU把一个字节从适配卡传送至内存,需要两步操作。首先,CPU把这个字节从适配卡读到内部寄存器中,然后再从寄存器传送到内存的适当地址。DMA控制器将这些操作简化为一步,它操作总线上的控制信号,使写字节一次完成。这样大大提高了计
算机运行速度和工作效率。  
计算机发展到今天,DMA已不再用于内存到内存的数据传送,因为CPU速度非常快,做这件事,比用DMA控制还要快,但要在适配卡和内存之间传送数据,仍然是非DMA莫属。要从适配卡到内存传送数据,DMA同时触发从适配卡读数据总线(即I/O读操作)和向内存写数据的总线。激活I/O读操作就是让适配卡把一个数据单位(通常是一个字节或一个字)放到PC数据总线上,因为此时内存写总线也被激活,数据就被同时从PC总线上拷贝到内存中。  对于每一次写操作,DMA控制器都控制地址总线,通知应将数据写到哪段内存中去。 DMA控制数据从内存传送到适配卡的方法与上面类似。对每一个要传送的单位数据,DMA控制器激活读内存和I/O写操作的总线。内存地址被放到地址总线上,像从适配卡到内存传送数据一样,以数据总线为通道,数据从源地址直接传送到目的地址。 DMA从DMA请求线(DREQ)
上接收DMA请求,正像中断控制器从中断请求线(IRQ)上接收中断请求一样。  
一个典型的从适配卡到内存的数据传送是这样进行的.........

cpu通过请求线和外围的控制器相连, 传送各种控制/请求信号, 如通过IRQ请求线传送 中断信号给中断控制器, 然后ICTR去执行中断, 执行完后, 将控制器通过IRQ还给cpu, 同样DMA通过DREQ请求线从cpu取得DMA请求, 得到总线控制权....

.........
DMA(Direct Memory Access) ,即直接存储器存取,是一种快速传送数据的机制。数据传递可以从适配卡到内存,从内存到适配卡或从一段内存到另一段内存。DMA技术的重要性在于,利用它进行数据传送时不需要CPU的参与。每台电脑主机板上都有DMA控制器,通常计算机对其编程,并用一个适配器上的ROM(如软盘驱动控制器上的ROM)来储存程序,这些程序控制DMA传送数据。一旦控制器初始化完成,数据开始传送,DMA就可以脱离CPU,
独立完成数据传送。  
在DMA传送开始的短暂时间内,基本上有两个处理器为它工作,一个执行程序代码,一个传送数据。利用DMA传送数据的另一个好处是,数据直接在源地址和目的地址之间传送,不需要中间媒介。如果通过CPU把一个字节从适配卡传送至内存,需要两步操作。首先,CPU把这个字节从适配卡读到内部寄存器中,然后再从寄存器传送到内存的适当地址。DMA控制器将这些操作简化为一步,它操作总线上的控制信号,使写字节一次完成。这样大大提高了计
算机运行速度和工作效率。  
计算机发展到今天,DMA已不再用于内存到内存的数据传送,因为CPU速度非常快,做这件事,比用DMA控制还要快,但要在适配卡和内存之间传送数据,仍然是非DMA莫属。要从适配卡到内存传送数据,DMA同时触发从适配卡读数据总线(即I/O读操作)和向内存写数据的总线。激活I/O读操作就是让适配卡把一个数据单位(通常是一个字节或一个字)放到PC数据总线上,因为此时内存写总线也被激活,数据就被同时从PC总线上拷贝到内存中。  对于每一次写操作,DMA控制器都控制地址总线,通知应将数据写到哪段内存中去。 DMA控制数据从内存传送到适配卡的方法与上面类似。对每一个要传送的单位数据,DMA控制器激活读内存和I/O写操作的总线。内存地址被放到地址总线上,像从适配卡到内存传送数据一样,以数据总线为通道,数据从源地址直接传送到目的地址。 DMA从DMA请求线(DREQ)
上接收DMA请求,正像中断控制器从中断请求线(IRQ)上接收中断请求一样。  
一个典型的从适配卡到内存的数据传送是这样进行的

------------- 网上的参考摘要(完)

05-11 16:14
查看更多