• <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è)

            C++語(yǔ)言

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

             

            關(guān)于80x86處理器保護(hù)模式下存儲(chǔ)段描述符屬性中類型小結(jié)

             

            *1.存儲(chǔ)段描述符

             

            80x86存儲(chǔ)段描述符(8字節(jié))

                                      (1)

            屬性字段(第5,6字節(jié))

             

             

            我們先來(lái)看看這8個(gè)字節(jié)中我感覺(jué)最復(fù)雜的TYPE這四位標(biāo)志吧,然后在看看其他的位

            第五字節(jié)低四位為描述符的類型描述,下面主要將這四位單獨(dú)抽出進(jìn)行說(shuō)明:

            __________________________________

            |      |       |     |     |

            | 3   | 2    | 1 | 0 |

            | E   |       |     | A |

            _________________________________

             

            (1)0指示描述符是否被訪問(wèn)過(guò)(Accessed),用符號(hào)A標(biāo)記。A=0表示尚未被訪問(wèn),A=1 表示段已被訪問(wèn)。當(dāng)把描述符的相應(yīng)選擇子裝入到段寄存器時(shí),80386把該位置為1,表明描述符已被訪問(wèn)。操作系統(tǒng)可測(cè)試訪問(wèn)位,已確定描述符是否被訪問(wèn)過(guò)

            (2)3指示所描述的段是代碼段還是數(shù)據(jù)段,用符號(hào)E標(biāo)記。E=0表示段為數(shù)據(jù)段,相應(yīng)的描述符也就是數(shù)據(jù)段(包括堆棧段)描述符。數(shù)據(jù)段是不可執(zhí)行的,但總是可讀的。 E=1表示段是可執(zhí)行段,即代碼段,相應(yīng)的描述符就是代碼段描述符。代碼段總是不可寫(xiě)的,若需要對(duì)代碼段進(jìn)行寫(xiě)入操作,則必須使用別名技術(shù),即用一個(gè)可寫(xiě)的數(shù)據(jù)段描述符來(lái)描述該代碼段,然后對(duì)此數(shù)據(jù)段進(jìn)行寫(xiě)入。

             

            ___________________________________

            |      |       |     |     |

            | 3   | 2    | 1 | 0 |

            | E=0 | ED   | W |  A |

            _________________________________

            (3)在數(shù)據(jù)段描述符中(E=0的情況, ,如上圖所示),TYPE中的位1指示所描述的數(shù)據(jù)段是否可寫(xiě),用W標(biāo)記。 W=0表示對(duì)應(yīng)的數(shù)據(jù)段不可寫(xiě)。反之,W=1表示數(shù)據(jù)段是可寫(xiě)的。注意,數(shù)據(jù)段總是可讀的。

            TYPE中的位2ED位,指示所描述的數(shù)據(jù)段的擴(kuò)展方向。ED=0表示數(shù)據(jù)段向高端擴(kuò)展,也即段內(nèi)偏移必須小于等于段界限。ED=1表示數(shù)據(jù)段向低擴(kuò)展,段內(nèi)偏移必須大于段界限。

            ___________________________________

            |      |       |     |     |

            | 3   | 2    | 1 | 0 |

            | E=1 | C    | R | A |

            _________________________________

            (4)在代碼段描述符中(E=1的情況,如上圖所示),TYPE中的位1指示所描述的代碼段是否可讀,用符號(hào)R標(biāo)記。R=0表示對(duì)應(yīng)的代碼段不可讀,只能執(zhí)行。R=1表示對(duì)應(yīng)的代碼段可讀可執(zhí)行。注意代碼段總是不可寫(xiě)的,若需要對(duì)代碼段進(jìn)行寫(xiě)入操作,則必須使用別名技術(shù)。

            在代碼段中,TYPE中的位2指示所描述的代碼段是否是一致代碼段,用C標(biāo)記。C=0表示對(duì)應(yīng)的代碼段是非一致代碼段(普通代碼段),C=1表示對(duì)應(yīng)的代碼段是一致代碼段。

             

            小結(jié):(如下圖)

                                                 (2)

             

            上面這些我在初學(xué)保護(hù)模式的時(shí)候感覺(jué)很迷惑,所以先拿出來(lái)說(shuō)說(shuō),下面再看看其他的標(biāo)志位.

             

            一.段基址與段界限

            從圖一我們可以看出基地址長(zhǎng)32位,被安排在234,7字節(jié)中,段界限長(zhǎng)20位,被安排在0,1字節(jié)與第6字節(jié)的低4位中。

            使用兩個(gè)域存放段基地址和段界限的原因與80286有關(guān)。在80286保護(hù)方式下,段基地址只有24位長(zhǎng),而段界限只有16位長(zhǎng)。80286存儲(chǔ)段描述符盡管也是8字節(jié)長(zhǎng),但實(shí)際只使用低 6字節(jié),高2字節(jié)必須置為080386存儲(chǔ)段描述符這樣的安排,可使得80286的存儲(chǔ)段描述符的格式在80386下繼續(xù)有效。

             

            .

            (1)P位稱為存在(Present)位。P=1表示描述符對(duì)地址轉(zhuǎn)換是有效的,或者說(shuō)該描述符所描述的段存在,即在內(nèi)存中;P=0表示描述符對(duì)地址轉(zhuǎn)換無(wú)效,即該段不存在。使用該描述符進(jìn)行內(nèi)存訪問(wèn)時(shí)會(huì)引起異常。

             

            (2)DPL表示描述符特權(quán)級(jí)(Descriptor Privilege level),共2位。它規(guī)定了所描述段的特權(quán)級(jí),用于特權(quán)檢查,以決定對(duì)該段能否訪問(wèn)

             

            (3)DT位說(shuō)明描述符的類型。對(duì)于存儲(chǔ)段描述符而言,DT=1,以區(qū)別與系統(tǒng)段描述符和門描述符(DT=0)。

             

            (4)TYPE標(biāo)志,即開(kāi)篇講得那堆。

             

            (5)G為就是段界限粒度(Granularity)位。G=0表示界限粒度為字節(jié);G=1表示界限粒度為4K 字節(jié)。注意,界限粒度只對(duì)段界限有效,對(duì)段基地址無(wú)效,段基地址總是以字節(jié)為單位。

             

            補(bǔ)充段界限規(guī)定段的大小。在80386保護(hù)模式下,段界限用20位表示,而且段界限可以是以字節(jié)為單位或以4K字節(jié)為單位。段屬性中有一位對(duì)此進(jìn)行定義,把該位成為粒度位,用符號(hào)G標(biāo)記。G=0表示段界限以字節(jié)位位單位,于是20位的界限可表示的范圍是1字節(jié)至1M字節(jié),增量為1字節(jié);G=1表示段界限以4K字節(jié)為單位,于是20位的界限可表示的范圍是4K字節(jié)至4G字節(jié),增量為4K字節(jié)。當(dāng)段界限以4K字節(jié)為單位時(shí),實(shí)際的段界限LIMIT可通過(guò)下面的公式從20 位段界限Limit計(jì)算出來(lái):

            LIMIT=limit*4K+0FFFH=(Limit SHL 12)+0FFFH

            所以當(dāng)粒度為1時(shí),段的界限實(shí)際上就擴(kuò)展成32位。由此可見(jiàn),在80386保護(hù)模式下,段的長(zhǎng)度可大大超過(guò)64K字節(jié)。

             

             

             (6)D位是一個(gè)很特殊的位,在描述可執(zhí)行段、向下擴(kuò)展數(shù)據(jù)段或由SS寄存器尋址的段(通常是堆棧段)的三種描述符中的意義各不相同。

            在描述可執(zhí)行段的描述符中,D位決定了指令使用的地址及操作數(shù)所默認(rèn)的大小。D=1表示默認(rèn)情況下指令使用32位地址及32位或8位操作數(shù),這樣的代碼段也稱為32位代碼段;D=0 表示默認(rèn)情況下,使用16位地址及16位或8位操作數(shù),這樣的代碼段也稱為16位代碼段,它與80286兼容。可以使用地址大小前綴和操作數(shù)大小前綴分別改變默認(rèn)的地址或操作數(shù)的大小。

            在向下擴(kuò)展數(shù)據(jù)段的描述符中,D位決定段的上部邊界。D=1表示段的上部界限為4G;D=0表示段的上部界限為64K,這是為了與80286兼容。

            在描述由SS寄存器尋址的段描述符中,D位決定隱式的堆棧訪問(wèn)指令(PUSHPOP指令)使用何種堆棧指針寄存器。D=1表示使用32位堆棧指針寄存器ESPD=0表示使用16位堆棧指針寄存器SP,這與80286兼容。

             

            (7)AVL位是軟件可利用位。80386對(duì)該位的使用未左規(guī)定,Intel公司也保證今后開(kāi)發(fā)生產(chǎn)的處理器只要與80386兼容,就不會(huì)對(duì)該位的使用做任何定義或規(guī)定。

             

             

             

            三:.存儲(chǔ)段描述符的結(jié)構(gòu)類型表示

             

            ; (注:采用nasm語(yǔ)法)

            ; 描述符

            ; usage: Descriptor Base, Limit, Attr

            ;        Base: dd

            ;        Limit: dd (low 20 bits available)

            ;        Attr: dw (lower 4 bits of higher byte are always 0)

            %macro Descriptor 3

                   dw   %2 & 0FFFFh                            ; 段界限 1                         (2 字節(jié))

                   dw   %1 & 0FFFFh                            ; 段基址 1                         (2 字節(jié))

                   db    (%1 >> 16) & 0FFh                    ; 段基址 2                         (1 字節(jié))

                   dw   ((%2 >> 8) & 0F00h) | (%3 & 0F0FFh)      ; 屬性 1 + 段界限 2 + 屬性 2         (2 字節(jié))

                   db    (%1 >> 24) & 0FFh                    ; 段基址 3                         (1 字節(jié))

            %endmacro ; 8 字節(jié)

             

             

            *2.系統(tǒng)段描述符

            在上面我們講過(guò)對(duì)于存儲(chǔ)段描述符其DT位為1,當(dāng)描述符的DT位為0時(shí),那么這個(gè)描述符所描述的就是一個(gè)系統(tǒng)段描述符了。

             

            系統(tǒng)段是為了實(shí)現(xiàn)存儲(chǔ)管理機(jī)制所使用的一種特別的段。在80386中,有兩種系統(tǒng)段:任務(wù)狀態(tài)段TSS和局部描述符表LDT段。用于描述系統(tǒng)段的描述符稱為系統(tǒng)段描述符。

             

            系統(tǒng)段描述符與存儲(chǔ)段描述符幾乎一模一樣,但也有一定的差別:

            (1)   DT位,DT=1表示存儲(chǔ)段,DT=0表示系統(tǒng)段。

            (2)   D位,D位在系統(tǒng)段中不使用。

            (3)   與存儲(chǔ)段最不相同的是TYPE段。系統(tǒng)段描述符的類型字段TYPE仍是4位,其其含義與存儲(chǔ)段描述符的類型卻完全不同。只有類型編碼為2、13、9B的描述符才是真正的系統(tǒng)段描述符,它們用于描述系統(tǒng)段LDT和任務(wù)狀態(tài)段TSS,其它類型的描述符是門描述符。具體見(jiàn)下表:

                                    圖3

             

            **LDT段描述符

            LDT段描述符描述任務(wù)的局部描述符表段。LDT段描述符必須安排在全局描述符表中才有效。在裝載LDTR寄存器時(shí),描述符中的LDT段基地址和段界限等信息被裝入LDT段描述符高速緩沖寄存器中。

             

            **.任務(wù)狀態(tài)段描述符

            任務(wù)狀態(tài)段TSS用于保存任務(wù)的各種狀態(tài)信息。任務(wù)狀態(tài)段描述符描述某個(gè)任務(wù)狀態(tài)段TSS描述符分為286TSS386TSS兩類。TSS描述符規(guī)定了任務(wù)狀態(tài)段的基地址和任務(wù)狀態(tài)段的大小等信息。在裝載任務(wù)狀態(tài)段寄存器TR時(shí),描述符中的段基地址和段界限等信息被裝入到TR的高速緩沖寄存器中。在任務(wù)切換或執(zhí)行LTR指令時(shí),要裝載TR寄存器。

             

            參考:

            80X86匯編語(yǔ)言程序設(shè)計(jì)教程》清華大學(xué)出版社 揚(yáng)季文主編

            《自己動(dòng)手編寫(xiě)操作系統(tǒng)》 于淵著

             

             

             

             

            posted on 2008-09-25 10:09 楊彬彬 閱讀(2365) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 操作系統(tǒng)
            九九精品99久久久香蕉| 久久精品亚洲乱码伦伦中文 | 狠狠色伊人久久精品综合网| 久久久亚洲欧洲日产国码是AV| 久久久久久亚洲精品不卡| 欧美精品一区二区精品久久| 97久久久久人妻精品专区| 欧美熟妇另类久久久久久不卡| 热99RE久久精品这里都是精品免费 | 香蕉久久av一区二区三区| 亚洲天堂久久久| 精品一二三区久久aaa片| 亚洲乱码精品久久久久..| 精品国产乱码久久久久软件| 亚洲精品国产美女久久久| 人妻少妇久久中文字幕一区二区| 久久九九精品99国产精品| 国产成人精品白浆久久69| 亚洲乱亚洲乱淫久久| 精品久久久久国产免费| 亚洲精品乱码久久久久久不卡| 国产精品久久久久久五月尺| 国产美女亚洲精品久久久综合 | 久久发布国产伦子伦精品| 国产精品美女久久久久| 国产亚洲美女精品久久久| 久久久久久久久66精品片| 久久婷婷五月综合国产尤物app| 国产精品久久久久无码av| 久久国产一片免费观看| 久久人人添人人爽添人人片牛牛| 国产Av激情久久无码天堂| 久久电影网| 精品久久久久久久无码| 久久国产成人午夜AV影院| 97久久国产综合精品女不卡| 久久免费小视频| 久久亚洲精品成人AV| 亚洲精品无码久久不卡| 久久精品国产精品青草| 久久久久99这里有精品10|