![基于Linux嵌入式系統(tǒng)的ISA總線(xiàn)DMA的實(shí)現(xiàn)_第1頁(yè)](http://file3.renrendoc.com/fileroot_temp3/2022-3/17/da5edcce-5351-43ec-a74b-957b80a54f5b/da5edcce-5351-43ec-a74b-957b80a54f5b1.gif)
![基于Linux嵌入式系統(tǒng)的ISA總線(xiàn)DMA的實(shí)現(xiàn)_第2頁(yè)](http://file3.renrendoc.com/fileroot_temp3/2022-3/17/da5edcce-5351-43ec-a74b-957b80a54f5b/da5edcce-5351-43ec-a74b-957b80a54f5b2.gif)
![基于Linux嵌入式系統(tǒng)的ISA總線(xiàn)DMA的實(shí)現(xiàn)_第3頁(yè)](http://file3.renrendoc.com/fileroot_temp3/2022-3/17/da5edcce-5351-43ec-a74b-957b80a54f5b/da5edcce-5351-43ec-a74b-957b80a54f5b3.gif)
下載本文檔
版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、基于Linux嵌入式系統(tǒng)的ISA總線(xiàn)DMA的實(shí)現(xiàn) 1.DMA概述DMA是外設(shè)與主存之間的一種數(shù)據(jù)傳輸機(jī)制。一般來(lái)說(shuō),外設(shè)與主存之間存在兩種數(shù)據(jù)傳輸方法:(1)Pragrammed I/O(PIO)方法,也即由CPU通過(guò)內(nèi)存讀寫(xiě)指令或I/O指令來(lái)持續(xù)地讀寫(xiě)外設(shè)的內(nèi)存單元(8位、16位或32位),直到整個(gè)數(shù)據(jù)傳輸過(guò)程完成。 (2)DMA,即由DMA控制器(DMA Controller,簡(jiǎn)稱(chēng)DMAC)來(lái)完成整個(gè)數(shù)據(jù)傳輸過(guò)程。在此期間,CPU可以并發(fā)地執(zhí)行其他任務(wù),當(dāng)DMA結(jié)束后,DMAC通過(guò)中斷通知CPU數(shù) 據(jù)傳輸已經(jīng)結(jié)束,然后由CPU執(zhí)行相應(yīng)的ISR進(jìn)
2、行后處理。DMA技術(shù)產(chǎn)生時(shí)正是ISA總線(xiàn)在PC中流行的時(shí)侯。因此,ISA卡的DMA數(shù)據(jù)傳輸是通過(guò)ISA總線(xiàn)控制芯片組中的兩個(gè)級(jí)聯(lián)8237 DMAC來(lái)實(shí)現(xiàn)的。這種DMA機(jī)制也稱(chēng)為“標(biāo)準(zhǔn)DMA”(standard DMA)。標(biāo)準(zhǔn)DMA有時(shí)也稱(chēng)為“第三方DMA”(third-party DMA),這是因?yàn)椋合到y(tǒng)DMAC完成實(shí)際的傳輸過(guò)程,所以它相對(duì)于傳輸過(guò)程的“前兩方”(傳輸?shù)陌l(fā)送者和接收者)來(lái)說(shuō)是 “第三方”。標(biāo)準(zhǔn)DMA技術(shù)主要有兩個(gè)缺點(diǎn):(1)8237 DMAC的數(shù)據(jù)傳輸速度太慢,不能與更高速的總線(xiàn)(如PCI)配合使用。(2)兩個(gè)8237 DMAC一起只提供了8個(gè)DMA通道,這也成為了限制系統(tǒng)I
3、/O吞吐率提升的瓶頸。鑒于上述兩個(gè)原因,PCI總線(xiàn)體系結(jié)構(gòu)設(shè)計(jì)一種成為“第一方DMA”(first-party DMA)的DMA機(jī)制,也稱(chēng)為“Bus Mastering”(總線(xiàn)主控)。在這種情況下,進(jìn)行傳輸?shù)腜CI卡必須取得系統(tǒng)總線(xiàn)的主控權(quán)后才能進(jìn)行數(shù)據(jù)傳輸。實(shí)際的傳輸也不借助慢速 的ISA DMAC來(lái)進(jìn)行,而是由內(nèi)嵌在PCI卡中的DMA電路(比傳統(tǒng)的ISA DMAC要快)來(lái)完成。Bus Mastering方式的DMA可以讓PCI外設(shè)得到它們想要的傳輸帶寬,因此它比標(biāo)準(zhǔn)DMA功能滿(mǎn)足現(xiàn)代高性能外設(shè)的要求。隨著計(jì)算機(jī)外設(shè)技術(shù)的不斷發(fā)展,現(xiàn)代能提供更快傳輸速率的Ultra DMA(UDMA)也已經(jīng)
4、被廣泛使用了。本為隨后的篇幅只討論ISA總線(xiàn)的標(biāo)準(zhǔn)DMA技術(shù)在Linux中的實(shí)現(xiàn)。記?。篒SA卡幾乎不使用Bus Mastering模式的DMA;而PCI卡只使用Bus Mastering模式的DMA,它從不使用標(biāo)準(zhǔn)DMA。2.Intel 8237 DMAC最初的IBM PC/XT中只有一個(gè)8237 DMAC,它提供了4個(gè)8位的DMA通道(DMA channel 0-3)。從IBM AT開(kāi)始,又增加了一個(gè)8237 DMAC(提供4個(gè)16位的DMA通道,DMA channel 4-7)。兩個(gè)8237 DMAC一起為系統(tǒng)提供8個(gè)DMA通道。與中斷控制器8259的級(jí)聯(lián)方式相反,第一個(gè)DMAC被級(jí)聯(lián)到
5、第二個(gè)DMAC上,通道4被用于DMAC級(jí)聯(lián),因此 它對(duì)外設(shè)來(lái)說(shuō)是不可用的。第一個(gè)DMAC也稱(chēng)為“slave DAMC”,第二個(gè)DMAC也稱(chēng)為“Master DMAC”。下面我們來(lái)詳細(xì)敘述一下Intel 8237這個(gè)DMAC的結(jié)構(gòu)。每個(gè)8237 DMAC都提供4個(gè)DMA通道,每個(gè)DMA通道都有各自的寄存器,而8237本身也有一組控制寄存器,用以控制它所提供的所有DMA通道。2.1 DMA通道的寄存器8237 DMAC中的每個(gè)DMA通道都有5個(gè)寄存器,分別是:當(dāng)前地址寄存器、當(dāng)前計(jì)數(shù)寄存器、地址寄存器(也稱(chēng)為偏移寄存器)、計(jì)數(shù)寄存器和頁(yè)寄存器。其中,前兩個(gè)是8237的內(nèi)部寄存器,對(duì)外部是不可見(jiàn)的。
6、(1)當(dāng)前地址寄存器(Current Address Register):每個(gè)DMA通道都有一個(gè)16位的當(dāng)前地址寄存器,表示一個(gè)DMA傳輸事務(wù)(Transfer Transaction)期間當(dāng)前DMA傳輸操作的DMA物理內(nèi)存地址。在每個(gè)DMA傳輸開(kāi)始前,8237都會(huì)自動(dòng)地用該通道的Address Register中的值來(lái)初始化這個(gè)寄存器;在傳輸事務(wù)期間的每次DMA傳輸操作之后該寄存器的值都會(huì)被自動(dòng)地增加或減小。(2)當(dāng)前計(jì)數(shù)寄存器(Current Count Register):每個(gè)每個(gè)DMA通道都有一個(gè)16位的當(dāng)前計(jì)數(shù)寄存器,表示當(dāng)前DMA傳輸事務(wù)還剩下多少未傳輸?shù)臄?shù)據(jù)。在每個(gè)DMA傳輸事務(wù)
7、開(kāi)始之 前,8237都會(huì)自動(dòng)地用該通道的Count Register中的值來(lái)初始化這個(gè)寄存器。在傳輸事務(wù)期間的每次DMA傳輸操作之后該寄存器的值都會(huì)被自動(dòng)地增加或減小(步長(zhǎng)為1)。(3)地址寄存器(Address Register)或偏移寄存器(Offset Register):每個(gè)DMA通道都有一個(gè)16位的地址寄存器,表示系統(tǒng)RAM中的DMA緩沖區(qū)的起始位置在頁(yè)內(nèi)的偏移。(4)計(jì)數(shù)寄存器(Count Register):每個(gè)DMA通道都有一個(gè)16位的計(jì)數(shù)寄存器,表示DMA緩沖區(qū)的大小。(5)頁(yè)寄存器(Page Register):該寄存器定義了DMA緩沖區(qū)的起始位置所在物理頁(yè)的基地址,即頁(yè)號(hào)
8、。頁(yè)寄存器有點(diǎn)類(lèi)似于PC中的段基址寄存器。2.2 8237 DAMC的控制寄存器(1)命令寄存器(Command Register)這個(gè)8位的寄存器用來(lái)控制8237芯片的操作。其各位的定義如下圖所示:(2)模式寄存器(Mode Register)用于控制各DMA通道的傳輸模式,如下所示:(3)請(qǐng)求寄存器(Request Register)用于向各DMA通道發(fā)出DMA請(qǐng)求。各位的定義如下:(4)屏蔽寄存器(Mask Register)用來(lái)屏蔽某個(gè)DMA通道。當(dāng)一個(gè)DMA通道被屏蔽后,它就不能在服務(wù)于DMA請(qǐng)求,直到通道的屏蔽碼被清除。各位的定義如下:上述屏蔽寄存器也稱(chēng)為“單通道屏蔽寄存器”(Single Channel Mask Register),因?yàn)樗淮沃荒芷帘我粋€(gè)通道。此外含有一個(gè)屏蔽寄存器,可以實(shí)現(xiàn)一次屏蔽所有4個(gè)DMA通道,如下:(5)狀態(tài)寄存器(Status Register)一個(gè)只讀的8位寄存器,表示各DMA通道的當(dāng)前狀態(tài)。比如:DMA通道是否正服務(wù)于一個(gè)DMA請(qǐng)求,或者某個(gè)DMA通道上的DMA傳輸事務(wù)已經(jīng)完成。2.3 8237 DMAC的I/O端口地址主、從8237 DMAC的各個(gè)寄存器都是編址在I/O端口空間的。而且其中有些I/O端口地址對(duì)于I/O讀、寫(xiě)操作有不同的表示含義。如下表示所示:Slave DMACs I/O port Master DMA
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 施工現(xiàn)場(chǎng)閘機(jī)設(shè)置標(biāo)準(zhǔn)
- 施工現(xiàn)場(chǎng)施工防高空墜物制度
- 閱讀啟迪心靈小學(xué)生的成長(zhǎng)之路
- 母嬰用品銷(xiāo)售中的用戶(hù)體驗(yàn)優(yōu)化策略匯報(bào)
- 清明節(jié)掃墓應(yīng)急預(yù)案
- 預(yù)防為主早期小兒肺炎識(shí)別與護(hù)理措施
- DB4415T 55-2025香芋南瓜-紫云英-香芋南瓜輪作生產(chǎn)技術(shù)規(guī)程
- 交通監(jiān)控項(xiàng)目工程合同
- 上海市大數(shù)據(jù)中心計(jì)算機(jī)信息系統(tǒng)集成合同
- 個(gè)人小額信貸合同范本
- 營(yíng)銷(xiāo)策劃 -嘉華鮮花餅「正宗」戰(zhàn)略重塑
- 解剖臺(tái)市場(chǎng)發(fā)展預(yù)測(cè)和趨勢(shì)分析
- DB14∕T 92-2010 M5、M15車(chē)用甲醇汽油
- 2024年醫(yī)師定期考核臨床類(lèi)人文醫(yī)學(xué)知識(shí)考試題庫(kù)及答案(共280題)
- 2024年廣東省公務(wù)員考試《行測(cè)》真題及答案解析
- 上海市2024年中考化學(xué)真題(含答案)
- 油氣儲(chǔ)運(yùn)節(jié)能優(yōu)化方案
- 物流公司員工守則以及管理制度
- 2024人形機(jī)器人產(chǎn)業(yè)半年研究報(bào)告
- 購(gòu)買(mǎi)演唱會(huì)門(mén)票的合同模板
- 燃燒爆炸理論及應(yīng)用 課件 第1-3章 緒論、燃燒及其災(zāi)害、物質(zhì)的燃燒
評(píng)論
0/150
提交評(píng)論