日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式教程
[導(dǎo)讀]ARM系統(tǒng)完成I/O功能的標(biāo)準(zhǔn)方法是使用存儲(chǔ)器映射I/O。這種方法使用特定的存儲(chǔ)器地址。當(dāng)從這些地址加載或向這些地址存儲(chǔ)時(shí),它們提供I/O功能。某些ARM系統(tǒng)也可能有直接存儲(chǔ)器訪問(wèn)(DMA,Direct Memory Access)硬件。

2.4 I/O管理

ARM系統(tǒng)完成I/O功能的標(biāo)準(zhǔn)方法是使用存儲(chǔ)器映射I/O。這種方法使用特定的存儲(chǔ)器地址。當(dāng)從這些地址加載或向這些地址存儲(chǔ)時(shí),它們提供I/O功能。某些ARM系統(tǒng)也可能有直接存儲(chǔ)器訪問(wèn)(DMA,Direct Memory Access)硬件。

外圍設(shè)備(如串行線控制器)中包含一些寄存器。在存儲(chǔ)器映射系統(tǒng)中,這些寄存器就像特定地址的存儲(chǔ)器一樣。(在其他的系統(tǒng)組織中,I/O功能可能與存儲(chǔ)器件有不同的尋址空間。)串行線控制器可能有以下5種寄存器。

① 發(fā)送數(shù)據(jù)寄存器(只寫):寫入這個(gè)位置的數(shù)據(jù)被送往串行線。

② 接受數(shù)據(jù)寄存器(只讀):保存從串行線送來(lái)的數(shù)據(jù)。

③ 控制寄存器(讀/寫):設(shè)置數(shù)據(jù)速率,管理RTS(請(qǐng)求發(fā)送)和其他類似信號(hào)。

④ 中斷使能寄存器(讀/寫):控制中斷的硬件事件。

⑤ 狀態(tài)寄存器(讀/寫):指示讀數(shù)據(jù)是否有效、寫緩存是否滿等。

要接受數(shù)據(jù),必須用軟件適當(dāng)?shù)卦O(shè)置器件。通常在接收到有效數(shù)據(jù)或檢測(cè)到錯(cuò)誤時(shí)產(chǎn)生一個(gè)中斷。中斷程序必須將數(shù)據(jù)復(fù)制到緩存器中并進(jìn)行錯(cuò)誤檢測(cè)。

應(yīng)該注意的是,存儲(chǔ)器映射外圍寄存器的行為與存儲(chǔ)器不同。連續(xù)兩次讀數(shù)據(jù)寄存器,即使對(duì)該寄存器沒有寫操作,其結(jié)果也很可能不同。而對(duì)真正存儲(chǔ)器的讀是冪等的(idempotent)(可多次重復(fù)讀,結(jié)果一致)。對(duì)外圍寄存器的讀操作可能清除當(dāng)前值,致使下一次讀結(jié)果不同。這種寄存器稱為讀敏感(read-sensitive)的。

當(dāng)涉及讀敏感寄存器時(shí),編程必須小心。特別是不能將這種寄存器的數(shù)據(jù)復(fù)制到Cache存儲(chǔ)器。

在許多ARM系統(tǒng)中,不能在用戶模式下訪問(wèn)I/O寄存器。要訪問(wèn)這些器件,只能通過(guò)監(jiān)控調(diào)用(SWI)或通過(guò)使用這種調(diào)用的C庫(kù)函數(shù)。

注意

在ARM編程中,通常將存儲(chǔ)器的I/O區(qū)域標(biāo)記為非Cache區(qū)(uncacheable),并繞過(guò)Cache訪問(wèn)。通常Cache與讀敏感(read-sensitive)器件相互排斥。顯示幀緩存器(DisplayFrame Buffers)也需要仔細(xì)考慮,通常也設(shè)為不可Cache的。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關(guān)閉