新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 基于Linux嵌入式系統的ISA總線DMA的實現

        基于Linux嵌入式系統的ISA總線DMA的實現

        作者: 時間:2010-09-08 來源:網絡 收藏

          0x003 0x0c3 Channel 1/5的Count Register

          0x004 0x0c4 Channel 2/6的Address Register

          0x005 0x0c5 Channel 2/6的Count Register

          0x006 0x0c6 Channel 3/7的Address Register

          0x007 0x0c7 Channel 3/7的Count Register

          0x008 0x0d0 Status Register Command Register

          0x009 0x0d2 Request Register

          0x00a 0x0d4 Single Channel Mask Register

          0x00b 0x0d6 Mode Register

          0x00c 0x0d8 Clear Flip-Flop Register

          0x00d 0x0da Temporary Register Reset controller

          0x00e 0x0dc Reset all channel masks

          0x00f 0x0de all-channels Mask Register

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

           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指令開中斷。

        linux操作系統文章專題:linux操作系統詳解(linux不再難懂)

        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 静乐县| 罗江县| 乐山市| 磐安县| 崇州市| 沙雅县| 晋城| 香格里拉县| 綦江县| 南皮县| 陕西省| 定西市| 武冈市| 辽宁省| 黄陵县| 灌云县| 芒康县| 颍上县| 井研县| 绥芬河市| 左贡县| 宜兴市| 全州县| 疏勒县| 阿巴嘎旗| 望江县| 都昌县| 武汉市| 常德市| 仁布县| 工布江达县| 铁岭县| 滦平县| 锡林郭勒盟| 屏南县| 义乌市| 班玛县| 灵宝市| 东乌珠穆沁旗| 通榆县| 镇坪县|