Direct Memory Access,直接内存存取
允许不同速度的硬件装置来沟通,而不需要依赖于 CPU 的大量中断负载。DMA 传输对于高效能嵌入式系统算法和网络很重要

传输过程

  1. DMA请求
    CPU对DMA控制器初始化,并向I/O接口发出操作命令,I/O接口提出DMA请求
  2. DMA响应
    CPU执行完当前总线周期即释放总线控制权。DMA控制器通知I/O接口开始DMA传输
  3. DMA传输
    DMA控制器获得总线控制权后,CPU即刻挂起或只执行内部操作。存储器和外部设备之间直接进行数据传送,不需要中央处理器的参与
  4. DMA结束
    DMA控制器即释放总线控制权,并向I/O接口发出结束信号。当I/O接口收到结束信号后,一方面停止I/O设备的工作,另一方面向CPU提出中断请求