DMA --- Direct Memory Access
实现 内存----外设 外设----外设 内存----内存 之间的数据快速批量传输
一般的用于进行DMA传输数据的内存需要专门申请,且一般认为需要物理地址连续,并且内存是不可cache的。
以Linux系统平台为例,有两种方式引发DMA数据传输:
*第一种情况:软件对数据的请求
1. 当进程调用read,驱动程序函数分配一个DMA缓冲区,并让硬件将数据传输到这个缓冲区中。进程处于睡眠状态。
2. 硬件将数据写入到DMA缓冲区中,当写入完毕,产生一个中断
3. 中断处理程序获取输入的数据,应答中断,并唤起进程,该进程现在即可读取数据
*第二种情况发生在异步使用DMA时。
1. 硬件产生中断,宣告新数据的到来
2. 中断处理程序分配一个缓冲区,并且告诉硬件向哪里传输数据
3. 外围设备将数据写入数据区,完成后,产生另外一个中断
4.处理程序分发新数据,唤醒任何相关进程,然后执行清理工作
注:在DMA方式中,一批数据传送前的准备工作,以及传送结束后的处理工作,均由管理程序承担,而DMA控制器仅负责数据传送的工作。
参考与引用:
http://wlzy.aynu.edu.cn/jsj/wlkc/jsjzcyl/jsjzcyl/Chap08/8.3.1.htm (DMA传输原理)
http://www.cnblogs.com/jikexianfeng/p/6413262.html(芯片级8237DMA控制器的使用)