DMA(Direct Memory Access)控制器是一種在系統內部轉移數據的獨特外設,可以將其視為一種能夠通過一組專用總線將內部和外部存儲器與每個具有DMA能力的外設連接起來的控制器。它之所以屬于外設,是因為它是在處理器的編程控制下來 執行傳輸的。
一般而言,DMA控制器將包括一條地址總線、一條數據總線和控制寄存器。高效率的DMA控制器將具有訪問其所需要的任意資源的能力,而無須處理器本身的介入,它必須能產生中斷。最后,它必須能在控制器內部計算出地址。[2]
一個處理器可以包含多個DMA控制器。每個控制器有多個DMA通道,以及多條直接與存儲器站(memory bank)和外設連接的總線,如圖1所示。在很多高性能處理器中集成了兩種類型的DMA控制器。第一類通常稱為“系統DMA控制器”,可以實現對任何資源(外設和存儲器)的訪問,對于這種類型的控制器來說,信號周期數是以系統時鐘(SCLK)來計數的,以ADI的Blackfin處理器為 例,頻率最高可達133MHz。第二類稱為內部存儲器DMA控制器(IMDMA),專門用于內部存儲器所處位置之間的相互存取操作。因為存取都發生在內部 (L1-L1、L1-L2,或者L2-L2),周期數的計數則以內核時鐘(CCLK)為基準來進行,該時鐘的速度可以超過600MHz。
圖1:系統和存儲器DMA架構。
每個DMA控制器有一組FIFO,起到DMA子系統和外設或存儲器之間的緩沖器的作用。對于MemDMA(Memory DMA)來說,傳輸的源端和目標端都有一組FIFO存在。當資源緊張而不能完成數據傳輸的話,則FIFO可以提供數據的暫存區,從而提高性能。
因為你通常會在代碼初始化過程中對DMA控制器進行配置,內核就只需要在數據傳輸完成后對中斷做出響應即可。你可以對DMA控制進行編程,讓其與內核并行地移動數據,而同時讓內核執行其基本的處理任務—那些應該讓它專注完成的工作。
DMA寄存器怎樣配置
這東西說明書也沒有說的,是狀態代碼。
1、特殊代碼“00”和“FF”及其它起始碼有三種情況出現:
①已由一系列其它代碼之后再出現:“00”或“FF”,則主板OK。
②如果將CMOS中設置無錯誤,則不嚴重的故障不會影響BIOS自檢的繼續,而最終出現“00”或“FF”。
③一開機就出現“00”或“FF”或其它起始代碼并且不變化則為板沒有運行起來。
2、本表是按代碼值從小到大排序,卡中出碼順序不定。
3、未定義的代碼表中未列出。
4、對于不同BIOS(常用的AMI、Award、Phoenix)用同一代碼所代表的意義有所不同,因此應弄清您所檢測的電腦是屬于哪一種類型的BIOS,您可查問你的電腦使用手冊,或從主板上的BIOS芯片上直接查看,也可以在啟動屏幕時直接看到。
5、有少數主板的PCI槽只有前一部分代碼出現,但ISA槽則有完整自檢代碼輸出。且目前已發現有極個別原裝機主板的ISA槽無代碼輸出,而PCI槽則有完整代碼輸出,故建議您在查看代碼不成功時,將本雙槽卡換到另一種插槽試一下。另外,同一塊主板的不同PCI槽,有的槽有完整《代碼送出,如DELL810主板只有靠近CPU的一個PCI槽有完整的代碼顯示,一直變化到“00”或“FF”,而其它槽走到“38”則不繼續變化。
6、復位信號所需時間ISA與PCI不一定同步,故有可能ISA開始出代碼,但PCI的復位燈還不熄,故PCI代碼停在起始碼上。
代碼 Award BIOS Ami BIOS Phoenix BIOS或Tandy 3000 BIOS
00 。 已顯示系統的配置;即將控制INI19引導裝入。 。
01 處理器測試1,處理器狀態核實,如果測試失敗,循環是無限的。 處理器寄存器的測試即將開始,不可屏蔽中斷即將停用。 CPU寄存器測試正在進行或者失敗。
02 確定診斷的類型(正常或者制造)。如果鍵盤緩沖器含有數據就會失效。 停用不可屏蔽中斷;通過延遲開始。 CMOS寫入/讀出正在進行或者失靈。
03 清除8042鍵盤控制器,發出TESTKBRD命令(AAH) 通電延遲已完成。 ROM BIOS檢查部件正在進行或失靈。
04 使8042鍵盤控制器復位,核實TESTKBRD。 鍵盤控制器軟復位/通電測試。 可編程間隔計時器的測試正在進行或失靈。
05 如果不斷重復制造測試1至5,可獲得8042控制狀態。 已確定軟復位/通電;即將啟動ROM。 DMA初如準備正在進行或者失靈。
06 使電路片作初始準備,停用視頻、奇偶性、DMA電路片,以及清除DMA電路片,所有頁面寄存器和CMOS停機字節。 已啟動ROM計算ROM BIOS檢查總和,以及檢查鍵盤緩沖器是否清除。 DMA初始頁面寄存器讀/寫測試正在進行或失靈。
07 處理器測試2,核實CPU寄存器的工作。 ROM BIOS檢查總和正常,鍵盤緩沖器已清除,向鍵盤發出BAT(基本保證測試)命令。 。
08 使CMOS計時器作初始準備,正常的更新計時器的循環。 已向鍵盤發出BAT命令,即將寫入BAT命令。 RAM更新檢驗正在進行或失靈。
09 EPROM檢查總和且必須等于零才通過。 核實鍵盤的基本保證測試,接著核實鍵盤命令字節。 第一個64K RAM測試正在進行。
0A 使視頻接口作初始準備。 發出鍵盤命令字節代碼,即將寫入命令字節數據。 第一個64K RAM芯片或數據線失靈,移位。
0B 測試8254通道0。 寫入鍵盤控制器命令字節,即將發出引腳23和24的封鎖/解鎖命令。 第一個64K RAM奇/偶邏輯失靈。
0C 測試8254通道1。 鍵盤控制器引腳23、24已封鎖/解鎖;已發出NOP命令。 第一個64K RAN的地址線故障。
0D 1、檢查CPU速度是否與系統時鐘相匹配。2、檢查控制芯片已編程值是否符合初設置。3、視頻通道測試,如果失敗,則鳴喇叭。 已處理NOP命令;接著測試CMOS停開寄存器。 第一個64K RAM的奇偶性失靈
0E 測試CMOS停機字節。 CMOS停開寄存器讀/寫測試;將計算CMOS檢查總和。 初始化輸入/輸出端口地址。
0F 測試擴展的CMOS。 已計算CMOS檢查總和寫入診斷字節;CMOS開始初始準備。 。
10 測試DMA通道0。 CMOS已作初始準備,CMOS狀態寄存器即將為日期和時間作初始準備。 第一個64K RAM第0位故障。
11 測試DMA通道1。 CMOS狀態寄存器已作初始準備,即將停用DMA和中斷控制器。 第一個64DK RAM第1位故障。
12 測試DMA頁面寄存器。 停用DMA控制器1以及中斷控制器1和2;即將視頻顯示器并使端口B作初始準備。 第一個64DK RAM第2位故障。
13 測試8741鍵盤控制器接口。 視頻顯示器已停用,端口B已作初始準備;即將開始電路片初始化/存儲器自動檢測。 第一個64DK RAM第3位故障。
14 測試存儲器更新觸發電路。 電路片初始化/存儲器處自動檢測結束;8254計時器測試即將開始。 第一個64DK RAM第4位故障。
15 測試開頭64K的系統存儲器。 第2通道計時器測試了一半;8254第2通道計時器即將完成測試。 第一個64DK RAM第5位故障。
16 建立8259所用的中斷矢量表。 第2通道計時器測試結束;8254第1通道計時器即將完成測試。 第一個64DK RAM第6位故障。
17 調準視頻輸入/輸出工作,若裝有視頻BIOS則啟用。 第1通道計時器測試結束;8254第0通道計時器即將完成測試。 第一個64DK RAM第7位故障。
18 測試視頻存儲器,如果安裝選用的視頻BIOS通過,由可繞過。 第0通道計時器測試結束;即將開始更新存儲器。 第一個64DK RAM第8位故障。
19 測試第1通道的中斷控制器(8259)屏蔽位。 已開始更新存儲器,接著將完成存儲器的更新。 第一個64DK RAM第9位故障。
1A 測試第2通道的中斷控制器(8259)屏蔽位。 正在觸發存儲器更新線路,即將檢查15微秒通/斷時間。 第一個64DK RAM第10位故障。
1B 測試CMOS電池電平。 完成存儲器更新時間30微秒測試;即將開始基本的64K存儲器測試。 第一個64DK RAM第11位故障。
1C 測試CMOS檢查總和。 。 第一個64DK RAM第12位故障。
1D 調定CMOS配置。 。 第一個64DK RAM第13位故障。
1E 測定系統存儲器的大小,并且把它和CMOS值比較。 。 第一個64DK RAM第14位故障。
1F 測試64K存儲器至最高640K。 。 第一個64DK RAM第15位故障。
20 測量固定的8259中斷位。 開始基本的64K存儲器測試;即將測試地址線。 從屬DMA寄存器測試正在進行或失靈。
21 維持不可屏蔽中斷(NMI)位(奇偶性或輸入/輸出通道的檢查)。 通過地址線測試;即將觸發奇偶性。 主DMA寄存器測試正在進行或失靈。
22 測試8259的中斷功能。 結束觸發奇偶性;將開始串行數據讀/寫測試。 主中斷屏蔽寄存器測試正在進行或失靈。
23 測試保護方式8086虛擬方式和8086頁面方式。 基本的64K串行數據讀/寫測試正常;即將開始中斷矢量初始化之前的任何調節。 從屬中斷屏蔽存器測試正在進行或失靈。
24 測定1MB以上的擴展存儲器。 矢量初始化之前的任何調節完成,即將開始中斷矢量的初始準備。 設置ES段地址寄存器注冊表到內存高端。
25 測試除頭一個64K之后的所有存儲器。 完成中斷矢量初始準備;將為旋轉式斷續開始讀出8042的輸入/輸出端口。 裝入中斷矢量正在進行或失靈。
26 測試保護方式的例外情況。 讀出8042的輸入/輸出端口;即將為旋轉式斷續開始使全局數據作初始準備。 開啟A20地址線;使之參入尋址。
27 確定超高速緩沖存儲器的控制或屏蔽RAM。 全1數據初始準備結束;接著將進行中斷矢量之后的任何初始準備。 鍵盤控制器測試正在進行或失靈。
28 確定超高速緩沖存儲器的控制或者特別的8042鍵盤控制器。 完成中斷矢量之后的初始準備;即將調定單色方式。 CMOS電源故障/檢查總和計算正在進行。
29 。 已調定單色方式,即將調定彩色方式。 CMOS配置有效性的檢查正在進行。
2A 使鍵盤控制器作初始準備。 已調定彩色方式,即將進行ROM測試前的觸發奇偶性。 置空64K基本內存。
2B 使磁碟驅動器和控制器作初始準備。 觸發奇偶性結束;即將控制任選的視頻ROM檢查前所需的任何調節。 屏幕存儲器測試正在進行或失靈。
2C 檢查串行端口,并使之作初始準備。 完成視頻ROM控制之前的處理;即將查看任選的視頻ROM并加以控制。 屏幕初始準備正在進行或失靈。
2D 檢測并行端口,并使之作初始準備。 已完成任選的視頻ROM控制,即將進行視頻ROM回復控制之后任何其他處理的控制。 屏幕回掃測試正在進行或失靈。
2E 使硬磁盤驅動器和控制器作初始準備。 從視頻ROM控制之后的處理復原;如果沒有發現EGA/VGA就要進行顯示器存儲器讀/寫測試。 檢測視頻ROM正在進行。
2F 檢測數學協處理器,并使之作初始準備。 沒發現EGA/VGA;即將開始顯示器存儲器讀/寫測試。 。
30 建立基本內存和擴展內存。 通過顯示器存儲器讀/寫測試;即將進行掃描檢查。 認為屏幕是可以工作的。
31 檢測從C800:0至EFFF:0的選用ROM,并使之作初始準備。 顯示器存儲器讀/寫測試或掃描檢查失敗,即將進行另一種顯示器存儲器讀/寫測試。 單色監視器是可以工作的。
32 對主板上COM/LTP/FDD/聲音設備等I/O芯片編程使之適合設置值。 通過另一種顯示器存儲器讀/寫測試;卻將進行另一種顯示器掃描檢查。 彩色監視器(40列)是可以工作的。
33 。 視頻顯示器檢查結束;將開始利用調節開關和實際插卡檢驗顯示器的關型。 彩色監視器(80列)是可以工作的。
34 。 已檢驗顯示器適配器;接著將調定顯示方式。 計時器滴答聲中斷測試正在進行或失靈。
35 。 完成調定顯示方式;即將檢查BIOS ROM的數據區。 停機測試正在進行或失靈。
36 。 已檢查BIOS ROM數據區;即將調定通電信息的游標。 門電路中A-20失靈。
37 。 識別通電信息的游標調定已完成;即將顯示通電信息。 保護方式中的意外中斷。
38 。 完成顯示通電信息;即將讀出新的游標位置。 RAM測試正在進行或者地址故障>FFFFH。
39 。 已讀出保存游標位置,即將顯示引用信息串。 。
3A 。 引用信息串顯示結束;即將顯示發現信息。 間隔計時器通道2測試或失靈。
3B 用OPTI電路片(只是486)使輔助超高速緩沖存儲器作初始準備。 已顯示發現<ESC>信息;虛擬方式,存儲器測試即
將開始。 按日計算的日歷時鐘測試正在進行或失靈。
3C 建立允許進入CMOS設置的標志。 。 串行端口測試正在進行或失靈。
3D 初始化鍵盤/PS2鼠標/PNP設備及總內存節點。 。 并行端口測試正在進行或失靈。
3E 嘗試打開L2高速緩存。 。 數學協處理器測試正在進行或失靈。
40 。 已開始準備虛擬方式的測試;即將從視頻存儲器來檢驗。 調整CPU速度,使之與外圍時鐘精確匹配。
41 中斷已打開,將初始化數據以便于0:0檢測內存變換(中斷控制器或內存不良) 從視頻存儲器檢驗之后復原;即將準
備描述符表。 系統插件板選擇失靈。
42 顯示窗口進入SETUP。 描述符表已準備好;即將進行虛擬方式作存儲器測試。 擴展CMOS RAM故障。
43 若是即插即用BIOS,則串口、并口初始化。 進入虛擬方式;即將為診斷方式實現中斷。 。
44 。 已實現中斷(如已接通診斷開關;即將使數據作初始準備以檢查存儲器在0:0返轉。) BIOS中斷進行初始化。
45 初始化數學協處理器。 數據已作初始準備;即將檢查存儲器在0:0返轉以及找出系統存儲器的規模。 。
46 。 測試存儲器已返回;存儲器大小計算完畢,即將寫入頁面來測試存儲器。 檢查只讀存儲器ROM版本。
47 。 即將在擴展的存儲器試寫頁面;即將基本640K存儲器寫入頁面。 。
48 。 已將基本存儲器寫入頁面;即將確定1MB以上的存儲器。 視頻檢查,CMOS重新配置。
49 。 找出1BM以下的存儲器并檢驗;即將確定1MB以上的存儲器。 。
4A 。 找出1MB以上的存儲器并檢驗;即將檢查BIOS ROM數據區。 進行視頻的初始化。
4B 。 BIOS ROM數據區的檢驗結束,即將檢查<ESC>和為軟復位清除1MB以上的存儲器。 。
4C 。 清除1MB以上的存儲器(軟復位)即將清除1MB以上的存儲器。 屏蔽視頻BIOS ROM。。
4D 已清除1MB以上的存儲器(軟復位);將保存存儲器的大小。 。
4E 若檢測到有錯誤;在顯示器上顯示錯誤信息,并等待客戶按<F1>鍵繼續。 開始存儲器的測試:(無軟復位);即將顯示第一個64K存儲器的測試。 顯示版權信息。
4F 讀寫軟、硬盤數據,進行DOS引導。 開始顯示存儲器的大小,正在測試存儲器將使之更新;將進行串行和隨機的存儲器測試。 。
50 將當前BIOS監時區內的CMOS值存到CMOS中。 完成1MB以下的存儲器測試;即將高速存儲器的大小以便再定位和掩蔽。 將CPU類型和速度送到屏幕。
51 。 測試1MB以上的存儲器。 。
52 所有ISA只讀存儲器ROM進行初始化,最終給PCI分配IRQ號等初始化工作。 已完成1MB以上的存儲器測試;即將準備回到實址方式。 進入鍵盤檢測。
53 如果不是即插即用BIOS,則初始化串口、并口和設置時種值。 保存CPU寄存器和存儲器的大小,將進入實址方式。 。
54 。 成功地開啟實址方式;即將復原準備停機時保存的寄存器。 掃描“打擊鍵”
55 。 寄存器已復原,將停用門電路A-20的地址線。 。
56 。 成功地停用A-20的地址線;即將檢查BIOS ROM數據區。 鍵盤測試結束。
57 。 BIOS ROM數據區檢查了一半;繼續進行。 。
58 。 BIOS ROM的數據區檢查結束;將清除發現<ESC>信息。 非設置中斷測試。
59 。 已清除<ESC>信息;信息已顯示;即將開始DMA和中斷控制器的測試。 。
5A 。 。 顯示按“F2”鍵進行設置。
5B 。 。 測試基本內存地址。
5C 。 。 測試640K基本內存。
60 設置硬盤引導扇區病毒保護功能。 通過DMA頁面寄存器的測試;即將檢驗視頻存儲器。 測試擴展內存。
61 顯示系統配置表。 視頻存儲器檢驗結束;即將進行DMA#1基本寄存器的測試。 。
62 開始用中斷19H進行系統引導。 通過DMA#1基本寄存器的測試;即將進行DMA#2寄存器的測試。 測試擴展內存地址線。
63 。 通過DMA#2基本寄存器的測試;即將檢查BIOS ROM數據區。 。
64 。 BIOS ROM數據區檢查了一半,繼續進行。 。
65 。 BIOS ROM數據區檢查結束;將把DMA裝置1和2編程。 。
66 。 DMA裝置1和2編程結束;即將使用59號中斷控制器作初始準備。 Cache注冊表進行優化配置。
67 。 8259初始準備已結束;即將開始鍵盤測試。 。
68 。 。 使外部Cache和CPU內部Cache都工作。
6A 。 。 測試并顯示外部Cache值。
6C 。 。 顯示被屏蔽內容。
6E 。 。 顯示附屬配置信息。
70 。 。 檢測到的錯誤代碼送到屏幕顯示。
72 。 。 檢測配置有否錯誤。
74 。 。 測試實時時鐘。
76 。 。 掃查鍵盤錯誤。
7A 。 。 鎖鍵盤。
7C 。 。 設置硬件中斷矢量。
7E 。 。 測試有否安裝數學處理器。
80 。 鍵盤測試開始,正在清除和檢查有沒有鍵卡住,即將使鍵盤復原。 關閉可編程輸入/輸出設備。
81 。 找出鍵盤復原的錯誤卡住的鍵;即將發出鍵盤控制端口的測試命令。 。
82 。 鍵盤控制器接口測試結束,即將寫入命令字節和使循環緩沖器作初始準備。 檢測和安裝固定RS232接口(串口)。
83 。 已寫入命令字節,已完成全局數據的初始準備;即將檢查有沒有鍵鎖住。 。
84 。 已檢查有沒有鎖住的鍵,即將檢查存儲器是否與CMOS失配。 檢測和安裝固定并行口。
85 。 已檢查存儲器的大小;即將顯示軟錯誤和口令或旁通安排。 。
86 。 已檢查口令;即將進行旁通安排前的編程。 重新打開可編程I/O設備和檢測固定I/O是否有沖突。
87 。 完成安排前的編程;將進行CMOS安排的編程。 。
88 。 從CMOS安排程序復原清除屏幕;即將進行后面的編程。 初始化BIOS數據區。
89 。 完成安排后的編程;即將顯示通電屏幕信息。 。
8A 。 顯示頭一個屏幕信息。 進行擴展BIOS數據區初始化。
8B 。 顯示了信息:即將屏蔽主要和視頻BIOS。 。
8C 。 成功地屏蔽主要和視頻BIOS,將開始CMOS后的安排任選項的編程。 進行軟驅控制器初始化。
8D 。 已經安排任選項編程,接著檢查滑了鼠和進行初始準備。 。
8E 。 檢測了滑鼠以及完成初始準備;即將把硬、軟磁盤復位。 。
8F 。 軟磁盤已檢查,該磁碟將作初始準備,隨后配備軟磁碟。 。
90 。 軟磁碟配置結束;將測試硬磁碟的存在。 硬盤控制器進行初始化。
91 。 硬磁碟存在測試結束;隨后配置硬磁碟。 局部總線硬盤控制器初始化。
92 。 硬磁碟配置完成;即將檢查BIOS ROM的數據區。 跳轉到用戶路徑2。
93 。 BIOS ROM的數據區已檢查一半;繼續進行。 。
94 。 BIOS ROM的數據區檢查完畢,即調定基本和擴展存儲器的大小。 關閉A-20地址線。
95 。 因應滑鼠和硬磁碟47型支持而調節好存儲器的大小;即將檢驗顯示存儲器。 。
96 。 檢驗顯示存儲器后復原;即將進行C800:0任選ROM控制之前的初始準備。 “ES段”注冊表清除。
97 。 C800:0任選ROM控制之前的任何初始準備結束,接著進行任選ROM的檢查及控制。 。
98 。 任選ROM的控制完成;即將進行任選ROM回復控制之后所需的任何處理。 查找ROM選擇。
99 。 任選ROM測試之后所需的任何初始準備結束;即將建立計時器的數據區或打印機基本地址。 。
9A 。 調定計時器和打印機基本地址后的返回操作;即調定RS-232基本地址。 屏蔽ROM選擇。
9B 。 在RS-232基本地址之后返回;即將進行協處理器測試之初始準備。 。
9C 。 協處理器測試之前所需初始準備結束;接著使協處理器作初始準備。 建立電源節能管理。
9D 。 協處理器作好初始準備,即將進行協處理器測試之后的任何初始準備。 。
9E 。 完成協。。.
評論
查看更多