title: DMA设计
tags: linux
date: 2019年1月5日 17:27:08
toc: true
---
DMA设计
DMA框架
一个简单的DMA框图如下DREQ→HOLD→HLDA→DACK
DMAC的一些必备特性:
- 能发出地址信息,对存储器寻址,并修改地址指针,DMAC内部必须有能自动加1或减1的地址寄存
- 能决定传送的字节数,并能判断DMA传送是否结束。DMA内部必须有能自动减1的字计数寄存器,计数结束产生终止计数信号;
- 能发出DMA结束信号,释放总线,使CPU恢复总线控制权;
- 能发出读、写控制信号,包括存储器访问信号和I/O访问信号。DMAC内部必须有时序和读写控制逻辑。
信号线如下
- DRQ:DMA请求信号。是外设向DMA控制器提出要求DMA操作的申请信号。
- DACK:DMA响应信号。是DMA控制器向提出DMA请求的外设表示已收到请求和正进行处理的信号。
- HOLD:总线请求信号。是DMA控制器向CPU要求让出总线的请求信号。
- HLDA:总线响应信号,是CPU向DMA控制器表示允许总线请求的应答信号。
流程顺序
- 当外设有DMA需求,并且准备就绪,就向DMAC控制器发出DMA请求信号DREQ
- DMAC接到DMA请求信号后向CPU发出总线请求信号HRQ。该信号连接到CPU的HOLD信号。
- CPU接到总线请求信号以后,如果允许DMA传输,则会在当前总线周期结束后,发出DMA响应信号HLDA。一方面CPU将控制总线、数据总线和地址总线置高阻态,即放弃对总线的控制权;另一方面CPU将有效的HLDA信号送给DMAC,通知DMAC,CPU已经放弃了对总线的控制权。
- DMAC获得对总线的控制权,并且向外设送出DMAC的应答信号DACK,通知外设可以开始进行DMA传输了。
- DMAC向存储器发送地址信号和向存储器及外设发出读/写控制信号