• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 8  文章 - 26  trackbacks - 0
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(5)

            隨筆檔案

            文章分類

            文章檔案

            相冊

            C++語言

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            轉(zhuǎn)自:http://www.eetop.cn/blog/html/64/64964-2377.html

            早期的8086只有20根地址線,只能訪問1M的地址空間。CPU尋址則按段+偏移的方式進(jìn)行。16位段+16位偏移的可能的范圍是0~0x10FFEF(即0xFFFF0+0xFFFF),即1M+65520字節(jié)的范圍。由于只有20根地址線,所以在對1M~1M+65520范圍進(jìn)行訪問時,會發(fā)生“地址回繞”的現(xiàn)象,就是說實際會訪問到0~65520的地方。據(jù)說某個著名的/臭名昭著的軟件利用了這個特點。在80286,386等CPU上,它會失敗,因為這些CPU有多于20根的地址線,并不產(chǎn)生“地址回繞”現(xiàn)象。為了保持完全的兼容性,IBM決定在PC AT系統(tǒng)上加個邏輯,來模仿以上的回繞特征。他們的方法就是把A20和鍵盤控制器的一個輸出進(jìn)行AND,這樣來控制A20的打開和關(guān)閉。一開始時A20是被屏蔽的(總為0),直到系統(tǒng)軟件去打開它。

             

            A20地址線問題
             1981年8月,IBM公司最初推出的個人計算機(jī)IBM PC使用的CPU是Intel 8088。在該微機(jī)中地址線
            只有20根(A0 – A19)。在當(dāng)時內(nèi)存RAM只有幾百KB或不到1MB時,20根地址線已足夠用來尋址這些
            內(nèi)存。其所能尋址的最高地址是0xffff:0xffff,也即0x10ffef。對于超出0x100000(1MB)的尋址地址將默認(rèn)
            地環(huán)繞到0x0ffef。當(dāng)IBM公司于1985年引入AT機(jī)時,使用的是Intel 80286 CPU,具有24根地址線,最
            高可尋址16MB,并且有一個與8088完全兼容的實模式運行方式。然而,在尋址值超過1MB時它卻不能
            象8088那樣實現(xiàn)地址尋址的環(huán)繞。但是當(dāng)時已經(jīng)有一些程序是利用這種地址環(huán)繞機(jī)制進(jìn)行工作的。為了
            實現(xiàn)完全的兼容性,IBM公司發(fā)明了使用一個開關(guān)來開啟或禁止0x100000地址比特位。由于在當(dāng)時的8042
            鍵盤控制器上恰好有空閑的端口引腳(輸出端口P2,引腳P21),于是便使用了該引腳來作為與門控制這
            個地址比特位。該信號即被稱為A20。如果它為零,則比特20及以上地址都被清除。從而實現(xiàn)了兼容性。
             由于在機(jī)器啟動時,默認(rèn)條件下,A20地址線是禁止的,所以操作系統(tǒng)必須使用適當(dāng)?shù)姆椒▉黹_啟它。
            但是由于各種兼容機(jī)所使用的芯片集不同,要做到這一點卻是非常的麻煩。因此通常要在幾種控制方法中
            選擇。

             
             對A20信號線進(jìn)行控制的常用方法是通過設(shè)置鍵盤控制器的端口值。 有些操作系統(tǒng)將A20的開啟和禁止作

            為實模式與保護(hù)運行模式之間進(jìn)行轉(zhuǎn)換的標(biāo)準(zhǔn)過程中的一部分。
            由于鍵盤的控制器速度很慢,因此就不能使用鍵盤控制器對A20線來進(jìn)行操作。為此引進(jìn)了一個A20快
            速門選項(Fast Gate A20),它使用I/O端口0x92來處理A20信號線,避免了使用慢速的鍵盤控制器操作方
            式。對于不含鍵盤控制器的系統(tǒng)就只能使用0x92端口來控制,但是該端口也有可能被其它兼容微機(jī)上的
            設(shè)備(如顯示芯片)所使用,從而造成系統(tǒng)錯誤的操作。
             還有一種方式是通過讀0xee端口來開啟A20信號線,寫該端口則會禁止A20信號線。

            posted on 2008-10-07 17:51 楊彬彬 閱讀(572) 評論(0)  編輯 收藏 引用 所屬分類: 操作系統(tǒng)
            久久久久久久97| 久久久艹| 国产精品美女久久久| AV无码久久久久不卡蜜桃 | 精品久久久久久中文字幕| 国产精品久久久久影院嫩草 | 亚洲中文字幕伊人久久无码| 国产亚洲精久久久久久无码77777| 亚洲成色www久久网站夜月| 久久婷婷久久一区二区三区| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 亚洲欧美另类日本久久国产真实乱对白| 久久精品国产亚洲AV香蕉| 久久99国产精品久久久| 久久人人爽人人爽人人片AV东京热| 精品久久久中文字幕人妻| 久久精品国产一区二区三区| 区久久AAA片69亚洲| 久久综合欧美成人| 久久香蕉超碰97国产精品 | 久久99精品国产麻豆宅宅| 久久人爽人人爽人人片AV| 久久人人爽人人爽人人片AV东京热| 中文字幕亚洲综合久久2| 亚洲色大成网站www久久九| 久久久国产精品| 亚洲伊人久久综合影院| 久久精品国产黑森林| 一级做a爰片久久毛片人呢| 97久久精品国产精品青草| 久久久精品人妻一区二区三区蜜桃| 日韩AV毛片精品久久久| 93精91精品国产综合久久香蕉 | 久久久久久久精品妇女99| 久久精品无码一区二区app| 狠狠色噜噜狠狠狠狠狠色综合久久 | 久久99精品久久久久久久久久| 亚洲欧美成人综合久久久| 午夜精品久久久久成人| 思思久久好好热精品国产| 久久青青草原精品国产软件|