• 易迪拓培训,专注于微波、射频、天线设计工程师的培养
首页 > 无线通信 > 技术文章 > 基于Linux嵌入式系统的ISA总线DMA的实现

基于Linux嵌入式系统的ISA总线DMA的实现

录入:edatop.com     点击:

各DMA通道的Page Register在I/O端口空间中的地址如下:

DMA channel Page Register’sI/O port address

0 0x087

1 0x083

2 0x081

3 0x082

4 0x08f

5 0x08b

6 0x089

7 0x08a

注意两点:

1. 各DMA通道的Address Register是一个16位的寄存器,但其对应的I/O端口是8位宽,因此对这个寄存器的读写就需要两次连续的I/O端口读写操作,低8位首先被发送,然后紧接着发送高8位。

2. 各DMA通道的Count Register:这也是一个16位宽的寄存器(无论对于8位DMA还是16位DMA),但相对应的I/O端口也是8位宽,因此读写这个寄存器同样需要两 次连续的I/O端口读写操作,而且同样是先发送低8位,再发送高8位。往这个寄存器中写入的值应该是实际要传输的数据长度减1后的值。在DMA传输事务期 间,这个寄存器中的值在每次DMA传输操作后都会被减1,因此读取这个寄存器所得到的值将是当前DMA事务所剩余的未传输数据长度减1后的值。当DMA传 输事务结束时,该寄存器中的值应该被置为0。

2.4 DMA通道的典型使用

在一个典型的PC机中,某些DMA通道通常被固定地用于一些PC机中的标准外设,如下所示:

Channel Size Usage

0 8-bit Memory Refresh

1 8-bit Free

2 8-bit Floppy Disk Controller

3 8-bit Free

4 16-bit Cascading

5 16-bit Fr ee

6 16-bit Free

7 16-bit Free

2.5 启动一个DMA传输事务的步骤

要启动一个DMA传输事务必须对8237进行编程,其典型步骤如下:

1.通过CLI指令关闭中断。

2.Disable那个将被用于此次DMA传输事务的DMA通道。

3.向Flip-Flop寄存器中写入0值,以重置它。

4.设置Mode Register。

5.设置Page Register。

6.设置Address Register。

7.设置Count Register。

8.Enable那个将被用于此次DMA传输事务的DMA通道。

9.用STI指令开中断。

 

来源:维库开发网

上一篇:三电平有源电力滤波器技术详解
下一篇:布线经验:要选整体的6类

手机天线设计培训教程详情>>

手机天线设计培训教程 国内最全面、系统、专业的手机天线设计培训课程,没有之一;是您学习手机天线设计的最佳选择...【More..

射频和天线工程师培训课程详情>>

  网站地图