Chinaunix

标题: Linux DMA问题 请教? [打印本页]

作者: 我的小伙伴    时间: 2013-07-10 19:41
标题: Linux DMA问题 请教?
今天看了DMA的知识,一直没搞明白,数据是怎么从内存传输到外设的,或者从外设传输到内存的。
DMA控制器8237只设置了一个DMA缓冲区的首地址与长度,然后就开启了DMA。网上能查到的最多的一段代码就是:
   flags = claim_dma_lock();
    disable_dma(chan);
    clear_dma_ff(chan);
    set_dma_mode(chan, DMA_MODE_WRITE);
    set_dma_addr(chan, virt_to_bus(page));
    set_dma_count(chan, 32);
    enable_dma(chan);
    release_dma_lock(flags);
那我想问题,那数据传送到哪个外设去了呢?
这里只设置了一个DMA写缓冲地址,那目的地址呢?数据被传送到哪去了?哪个设备接受数据?
要有两个地址才能传输的吧?只有一个地址,怎么传输数据啊?具体是怎么工作的?
数据传输,总待有个源地址与目的地址吧?这里怎么传输?

在PC机上做实验,内存到内存之间,用DMA传输数据?
    flags = claim_dma_lock();
    disable_dma(0);
    clear_dma_ff(0);
    set_dma_mode(0, DMA_MODE_WRITE);
    set_dma_addr(0, virt_to_bus(page0));
    set_dma_count(0, 32);
    enable_dma(0);
    release_dma_lock(flags);
//////////////////////////////////////////
    flags = claim_dma_lock();
    disable_dma(1);
    clear_dma_ff(1);
    set_dma_mode(1, DMA_MODE_WRITE);
    set_dma_addr(1, virt_to_bus(page1));
    set_dma_count(1, 32);
    enable_dma(1);
    release_dma_lock(flags);
这样能将缓冲区page0的数据传送到缓冲区page1中吗?不然,怎么传送?帮忙看看啊?

作者: 问枫    时间: 2013-07-12 09:49
为DMA指定的内存地址,应该是在内核中提前申请好的、物理地址上连续的一片内存,当外设向CPU传输数据时,DMA控制器会将数据直接写入到你指定给它的那段连续的地址中,数据传输完成后,外设会向CPU产生一次中断,在中断处理函数中,你的软件要去之前指定的内存中获取数据。向外设发数据时,过程类似。
作者: 我的小伙伴    时间: 2013-07-12 11:37
回复 2# 问枫


你说的,我明白。我不解的是:

当外设向CPU传输数据时,DMA控制器会将数据直接写入到你指定给它的那段连续的地址中?

外设怎么和DMA是怎么沟通的?外设只要向这段缓冲区中写数据?实际就是通过DMA传输了?不是通过CPU的?

我不明白的是,外设怎么将数据通过DMA传输到缓冲区中?
作者: zjjsky1211    时间: 2013-07-17 13:12
可以把DMA控制器想象成一个搬运工,当需要使用时,先CPU先配置它,让它知道将数据从哪里搬到哪里,并设置触发条件。配置好后就它就可以独立工作了,只要它检测到触发条件,那它就启动一次DMA传输,这个过程无需CPU的参与。
作者: lelee007    时间: 2013-07-21 21:41
LZ知道啥叫DMA不?DMA搬运数据的时候(搬运过程)是不需要CPU参合的,DMA搬完之后按配置的方式让CPU感知搬完即可




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2