linux内核 dma,Linux内核DMA机制

《Linux内核DMA机制》由会员分享,可在线阅读,更多相关《Linux内核DMA机制(3页珍藏版)》请在人人文库网上搜索。

1、DMA控制器硬件结构 1DMA 通道使用的地址 3DMA操作函数4DMA映射6(1 )建立一致 DMA映射7(2 )建立流式 DMA映射8(3)分散/集中映射10DMA 池11一个简单的使用 DMA例子15DMA空制器硬件结构DMA允许外围设备和主内存之间直接传输I/O数据,DMA依赖于系统。每一种 体系结构DMA专输不同,编程接口也不同。数据传输可以以两种方式触发:一种软件请求数据,另一种由硬件异步传输。在第一种情况下,调用的步骤可以概括如下(以 read为例):(1) 在进程调用read时,驱动程序的方法分配一个 DMA缓冲区,随后指示硬 件传送它的数据。进程进入睡眠。(2) 硬件将数据写。

2、入DMA缓冲区并在完成时产生一个中断。(3) 中断处理程序获得输入数据,应答中断,最后唤醒进程,该进程现在可以 读取数据了。第二种情形是在DMA被异步使用时发生的。以数据采集设备为例:(1) 硬件发出中断来通知新的数据已经到达。(2) 中断处理程序分配一个 DMAg冲区。(3) 外围设备将数据写入缓冲区,然后在完成时发出另一个中断。(4) 处理程序利用DMA发新的数据,唤醒任何相关进程。网卡传输也是如此,网卡有一个循环缓冲区(通常叫做DMA环形缓冲区)建立在与处理器共享的内存中。每一个输入数据包被放置在环形缓冲区中下一个可用缓冲区,并且发出中断。然后驱动程序将网络数据包传给内核的其它部分处理,。

3、 并在环形缓冲区中放置一个新的 DMA缓冲区。驱动程序在初始化时分配 DMAS冲区,并使用它们直到停止运行。DMA空制器依赖于平台硬件,这里只对i386的8237 DMA控控制器做简单的说明, 它有两个控制器,8个通道,具体说明如下:控制器1:通道0-3,字节操作,端口为00-仆控制器2:通道4-7,字操作,端口咪C0-DF-所有寄存器是8 bit,与传输大小无关。-通道4被用来将控制器1与控制器2级联起来。-通道0-3是字节操作,地址/计数都是字节的。-通道5-7是字操作,地址/计数都是以字为单位的。-传输器对于(0-3通道)必须不超过64K的物理边界,对于5-7必须不超过128K 边界。-。

4、对于5-7通道page registers不用数据bit 0, 代表128K页-对于0-3通道page registers 使用bit 0, 表示64K页DMA传输器限制在低于16M物理内存里。装入寄存器的地址必须是物理地址,而不是逻辑地址。A23 . A16 A15 . A8 A7 . A0 (1物理地址)| Page | Addr MSB | Addr LSB | (DMA地址寄存器)1 . 1 1 . 1 1 . 1P7 . P0 A7 . A0 A7 . A0|.|.|.|.|.|.|对于0-3通道来说地址对寄存器的映射如下:物理地址)对于5-7通道来说地址对寄存器的映射如下:A23 . A17 A16 A15 . A9 A8 A7 . A1 A0。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值