欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

微處理器標(biāo)記寄存器屏蔽移入彈出裝置和方法

文檔序號(hào):6381243閱讀:187來源:國知局
專利名稱:微處理器標(biāo)記寄存器屏蔽移入彈出裝置和方法
技術(shù)領(lǐng)域
本發(fā)明涉及計(jì)算機(jī)系統(tǒng)之內(nèi)的指令執(zhí)行,且特別涉及一種降低執(zhí)行標(biāo)記(EFLAGS)寄存器寫入及讀出所需指令周期次數(shù)的裝置和方法。
背景技術(shù)
在x86管道式微處理器內(nèi),完成一個(gè)EFLAGS寄存器彈出指令(例如POPF/POPFD、CLI/STI、CLD/STD、CLC/STC)需要多個(gè)執(zhí)行周期。原因是寫入到EFLAGS寄存器的操作取決于當(dāng)前的I/O優(yōu)先等級(jí)(IOPL)和寫入時(shí)EFLAGS寄存器內(nèi)的特定位的狀態(tài)。在Micfosoft Windows操作系統(tǒng)內(nèi),當(dāng)每次從一調(diào)用子程序返回時(shí),EFLAGS寄存器都從堆棧內(nèi)彈出,從而導(dǎo)致明顯的操作系統(tǒng)延遲現(xiàn)象。
因此,現(xiàn)在需要一種運(yùn)行微處理器的技術(shù),該技術(shù)可減輕延遲現(xiàn)象,此延遲現(xiàn)象相關(guān)于完成寫入到EFLAGS寄存器的指令,例如彈出指令。
同樣地,在x86管道式微處理器內(nèi),EFLAGS寄存器的堆棧的移入指令(PUSHF/PUSHFD)也需要相當(dāng)多個(gè)執(zhí)行周期。原因是從EFLAGS寄存器讀出時(shí)位的狀態(tài)和微處理器的執(zhí)行狀態(tài)取決于當(dāng)前I/O優(yōu)先等級(jí)(IOPL)和堆棧移入時(shí)EFLAGS寄存器內(nèi)的特定位的狀態(tài)。在Microsoft Windows操作系統(tǒng)內(nèi),每次子程序的調(diào)用均導(dǎo)致EFLAGS寄存器移入至堆棧內(nèi),從而導(dǎo)致明顯的操作系統(tǒng)延遲現(xiàn)象。
因此,現(xiàn)在需要一種運(yùn)行微處理器的技術(shù),該技術(shù)可減輕延遲現(xiàn)象,此延遲現(xiàn)象相關(guān)于這些完成從EFLAGS讀出操作的EFLAGS堆棧移入指令。

發(fā)明內(nèi)容
依照本發(fā)明的一實(shí)施例,本發(fā)明提供一種執(zhí)行寫入操作到微處理器內(nèi)多位標(biāo)記寄存器的方法。該方法包括通過微處理器的翻譯級(jí)來接收一請求寫入到多位標(biāo)記寄存器的宏指令。該方法還包括通過翻譯級(jí)來生成一用于在單個(gè)寫入周期內(nèi)寫入到多位標(biāo)記寄存器的微指令。該方法還進(jìn)一步包括生成一個(gè)標(biāo)記屏蔽,并將該標(biāo)記屏蔽與一規(guī)定操作數(shù)加以邏輯乘運(yùn)算后生成一結(jié)果。隨后,該結(jié)果存儲(chǔ)到多位標(biāo)記寄存器內(nèi),在特定實(shí)施例的中,多位標(biāo)記寄存器系為執(zhí)行標(biāo)記(EFLAGS)寄存器。
本發(fā)明有助于在單個(gè)指令周期之內(nèi),通過完成一寫入操作,而執(zhí)行寫入到EFLAGS寄存器時(shí),減少微處理器的延遲現(xiàn)象。
依照本發(fā)明的另一實(shí)施例,本發(fā)明提供一種從多位標(biāo)記寄存器執(zhí)行讀取操作的方法。該方法包括通過微處理器的翻譯級(jí)來接收一請求從多位標(biāo)記寄存器讀出的宏指令。該方法還包括通過翻譯級(jí)來生成一用于在單個(gè)寫入周期內(nèi)從多位標(biāo)記寄存器讀出的微指令。該方法還包括生成一個(gè)標(biāo)記屏蔽,該標(biāo)記屏蔽包含根據(jù)當(dāng)前優(yōu)先級(jí)信息在讀取操作過程中與更新多位標(biāo)記寄存器的那些字節(jié)有關(guān)的優(yōu)先級(jí)信息。該方法還可進(jìn)一步包括將該標(biāo)記屏蔽與該多位標(biāo)記寄存器加以邏輯乘運(yùn)算后生成一結(jié)果的步驟。另外,該方法還可進(jìn)一步包括存儲(chǔ)該結(jié)果在存儲(chǔ)器堆棧內(nèi)。
本發(fā)明有助于減少發(fā)生在微處理器內(nèi)于EFLAGS寄存器堆棧移入過程中與EFLAGS寄存器讀取有關(guān)的延遲現(xiàn)象。本發(fā)明所述的方法和裝置可在單個(gè)指令周期之內(nèi)完成執(zhí)行標(biāo)記堆棧移入的操作。
為使本發(fā)明的上述目的、特征和優(yōu)點(diǎn)能更明顯易懂,下文特舉一較佳實(shí)施例,并結(jié)合附圖詳細(xì)說明如下。


圖1表示已知的微處理器的管道等級(jí)的方塊圖。
圖2表示本發(fā)明的微處理器的一實(shí)施例的方塊圖。
圖3表示圖2所示微處理器運(yùn)行的流程圖。
圖4表示本發(fā)明的微處理器的另一實(shí)施例的方塊圖。
圖5表示圖4所示微處理器運(yùn)行的流程圖。
附圖標(biāo)記說明105讀取級(jí)110翻譯級(jí)115寄存級(jí)
120地址級(jí)125數(shù)據(jù)/算術(shù)邏輯單元級(jí)(執(zhí)行級(jí))130反寫級(jí)132EFLAGS寄存器(執(zhí)行標(biāo)記寄存器)202讀取級(jí)204指令讀取邏輯器206指令存儲(chǔ)器208指令指針210翻譯器212翻譯級(jí)216數(shù)據(jù)/算術(shù)邏輯單元-執(zhí)行級(jí)218XIQ(翻譯指令隊(duì)列)220MTEF指令222寄存級(jí)224寄存器文件226ESP(擴(kuò)展子庫)228OP1寄存器230OP2寄存器232載入級(jí)234MTEF寄存器236加載/對位邏輯器238數(shù)據(jù)存儲(chǔ)器240OP3寄存器242OP1寄存器244OP2寄存器246TVAL寄存器(新值寄存器)248TMASK寄存器(屏蔽寄存器)250AND門252PRIV寄存器(優(yōu)先級(jí)寄存器)254結(jié)果寄存器256執(zhí)行邏輯器
402讀取級(jí)404指令讀取邏輯器406指令存儲(chǔ)器408指令指針410翻譯器412翻譯級(jí)414EFLAGS寄存器(執(zhí)行標(biāo)記寄存器)416執(zhí)行邏輯器418數(shù)據(jù)/算術(shù)邏輯單元-執(zhí)行級(jí)419XIQ(翻譯指令隊(duì)列)420MTEF指令422寄存級(jí)424寄存器文件426ESP(擴(kuò)展子庫)428OP1寄存器430OP2寄存器431地址級(jí)432MTEF寄存器434載入級(jí)436加載/對位邏輯器438數(shù)據(jù)存儲(chǔ)器440OP3寄存器442OP1寄存器444OP2寄存器445存儲(chǔ)器內(nèi)堆棧446PRIV寄存器(優(yōu)先級(jí)寄存器)448FMASK寄存器450AND門452結(jié)果寄存器454存儲(chǔ)邏輯器456存儲(chǔ)級(jí)
具體實(shí)施例方式
以下描述是為了使本領(lǐng)域的技術(shù)人員能夠根據(jù)特定應(yīng)用領(lǐng)域及其要求來順利地應(yīng)用本發(fā)明。然而,對于本領(lǐng)域技術(shù)人員來說,很明顯的情況是,可對所提供的幾個(gè)較佳實(shí)施例實(shí)施加以修改,并且此處所定義的一般原理也適用于其它實(shí)施例。因此,本發(fā)明并非僅局限于此處所述的特定實(shí)施例,而是適用于與本發(fā)明所述原理和新特征相關(guān)的一個(gè)較廣的領(lǐng)域。
圖1表示已知的管道式微處理器100的管道等級(jí)的方塊圖。微處理器100包括讀取級(jí)105、翻譯級(jí)110、寄存級(jí)115、地址級(jí)120、數(shù)據(jù)/算術(shù)邏輯部件或執(zhí)行級(jí)125和反寫級(jí)130。
在運(yùn)作時(shí),讀取級(jí)105從存儲(chǔ)器(未標(biāo)出)讀取微處理器100所需執(zhí)行的宏指令。翻譯級(jí)110將所讀取的宏指令翻譯成相關(guān)的微指令。
每一微指令命令微處理器100完成一與讀取宏指令規(guī)定操作相關(guān)的具體子任務(wù)。寄存級(jí)115從一在管道內(nèi)的后續(xù)等級(jí)所使用的寄存器文件(未標(biāo)出)中,檢索這些微指令所規(guī)定的操作數(shù)。地址級(jí)120計(jì)算這些由微指令所指定的存儲(chǔ)器地址,以使用于數(shù)據(jù)存儲(chǔ)和檢索操作。數(shù)據(jù)/算術(shù)邏輯部件級(jí)125要么完成從寄存器文件中檢索數(shù)據(jù)的算術(shù)邏輯單元運(yùn)算,要么使用地址級(jí)120計(jì)算所得存儲(chǔ)器地址來將數(shù)據(jù)寫入到存儲(chǔ)器或從存儲(chǔ)器讀取數(shù)據(jù)。反寫級(jí)130將數(shù)據(jù)讀取操作的結(jié)果或算術(shù)邏輯單元運(yùn)算的結(jié)果寫入到寄存器文件。因此,總結(jié)如下,宏指令通過讀取級(jí)105讀取,并通過翻譯級(jí)110譯碼翻譯成微指令。經(jīng)翻譯后的微指令通過等級(jí)115-130來執(zhí)行。微處理器100就是這樣提供管道操作。
為更好理解本發(fā)明所披露的技術(shù),下面所描述的內(nèi)容將采用x86微處理器術(shù)語。然而,本領(lǐng)域技術(shù)人員將認(rèn)同x86寄存器和宏指令的使用僅是作為例證性說明的目的。同樣可輕易地采用其它微處理器或結(jié)構(gòu)形式來完成本發(fā)明的例證性說明。
數(shù)據(jù)/算術(shù)邏輯單元級(jí)125包括EFLAGS寄存器132,該寄存器132記錄有微處理器的狀態(tài)。EFLAGS寄存器132可被很多指令所修改,且用于進(jìn)行參數(shù)比較、條件循環(huán)和條件跳躍。EFLAGS寄存器的每一位都含有一個(gè)上一指令特定參數(shù)的狀態(tài)。下述表1所示32位與每一位的功能合在一起就組成EFLAGS寄存器。
表1

在當(dāng)今管道式的微處理器內(nèi),例如在微處理器100內(nèi),執(zhí)行任何一個(gè)寫入到EFLAGS寄存器(即POPF/POPFD、CLI/STI、CLD/STD、CLC/STC)的指令都需要運(yùn)行很多次機(jī)器周期。原因是寫入到EFLAGS寄存器132的操作取決于寫入時(shí)當(dāng)前I/O優(yōu)先級(jí)和EFLAGS寄存器內(nèi)特定位的狀態(tài)。更具體地說,位1、3、5、15和22-31均為保留位,它們的具體狀態(tài)并不能被更改。另外,當(dāng)微處理器運(yùn)行在受保護(hù)模式的優(yōu)先級(jí)為0(或?qū)嵉刂纺J?,其等同于?yōu)先級(jí)0)時(shí),除了VIP、VIF、VM位以外,所有非保留位均可更改。VIP、VIF標(biāo)記必須清除掉,而VM標(biāo)記則必須保持其當(dāng)前狀態(tài)。
執(zhí)行任何將數(shù)據(jù)寫入到EFLAGS寄存器132的前述宏指令都會(huì)產(chǎn)生幾個(gè)微指令。更詳細(xì)地說,首先執(zhí)行一個(gè)微指令以確定當(dāng)前I/O優(yōu)先級(jí)(IOPL)。后續(xù)微指令讀取例如VM、PF、IOPL、VIP、IF等特定EFLAGS寄存器位的狀態(tài),并為將要寫入到EFLAGS寄存器的新數(shù)據(jù)建立多個(gè)位狀態(tài)。最后執(zhí)行一微指令以將新數(shù)據(jù)寫入到EFLAGS寄存器132。
上述EFLAGS寄存器更新的傳統(tǒng)方法的明顯缺點(diǎn)是為完成一寫入到EFLAGS寄存器的操作必須執(zhí)行很多微指令。由于要生成并處理多個(gè)微指令,故EFLAGS寄存器的每次更新所需有效時(shí)間就會(huì)延長。這會(huì)對微處理器的效率產(chǎn)生不良影響。
本申請的發(fā)明人已經(jīng)認(rèn)知到在Microsoft Windows操作系統(tǒng)中,當(dāng)從子程序返回時(shí),EFLAGS寄存器每次都會(huì)從堆棧彈出。他們同樣也注意到該情況同樣也發(fā)生在寫入到當(dāng)今常用桌上型計(jì)算機(jī)應(yīng)用程序執(zhí)行標(biāo)記寄存器的其它微指令。由于這些指令屬于常規(guī)使用指令類型,故希望能最大限度地縮減與它們相關(guān)的執(zhí)行時(shí)間。
本發(fā)明的微處理器技術(shù)披露于此的目的是減少完成寫入到執(zhí)行標(biāo)記寄存器所需指令周期的數(shù)目。為達(dá)到該目的,本發(fā)明提供了一種動(dòng)態(tài)產(chǎn)生執(zhí)行標(biāo)記屏蔽的裝置和方法。該屏蔽與規(guī)定操作數(shù)(即彈出執(zhí)行標(biāo)記寄存器或選定的執(zhí)行標(biāo)記位狀態(tài))進(jìn)行邏輯乘的操作,所得結(jié)果寫入到執(zhí)行標(biāo)記寄存器。此處所述的新的微處理器有助于使用單一微指令,其名為移動(dòng)到執(zhí)行標(biāo)記寄存器(MTEF)指令,搭配執(zhí)行級(jí)的專用邏輯器,可在單一指令周期之內(nèi)完成寫入到執(zhí)行標(biāo)記寄存器的操作。
圖2所示為使用單個(gè)微指令MTEF在單個(gè)指令周期內(nèi)完成寫入到執(zhí)行標(biāo)記寄存器的操作的微處理器200方塊圖。微處理器200包括讀取級(jí)202,其包含一與指令存儲(chǔ)器206相連接的指令讀取邏輯器204。指令指針208連接到讀取邏輯器204,以便命令讀取邏輯器204到存儲(chǔ)器206的特定位置,且當(dāng)前指令就從該特定位置讀取。
當(dāng)讀取邏輯器204讀取例如POPF/POPFD、CLI/STI、CLD/STD或CLC/STC等宏指令時(shí),翻譯級(jí)212的翻譯器210作為響應(yīng)會(huì)生成一MTEF D,S微指令,該指令在數(shù)據(jù)/算術(shù)邏輯單元-執(zhí)行級(jí)216內(nèi)執(zhí)行一移動(dòng)到執(zhí)行標(biāo)記寄存器214的操作。在MTEF D,S微指令之內(nèi),S表示一信息源,其表示信息源將傳送到執(zhí)行標(biāo)記寄存器214。D表示在執(zhí)行標(biāo)記寄存器之內(nèi)將要進(jìn)行寫入操作的這些位。
在介紹MTEF微指令之前,先介紹微處理器200的其它結(jié)構(gòu)。如圖所示,MTEF D,S微指令提供到翻譯指令隊(duì)列(XIQ)218。然后,微指令MTEF D,S繼續(xù)行進(jìn)到寄存級(jí)222的MTEF寄存器220。寄存級(jí)222包括一存儲(chǔ)微處理器200的結(jié)構(gòu)狀態(tài)的寄存器文件224。寄存器文件224還包括擴(kuò)展子庫(ESP)寄存器226。如圖所示,寄存級(jí)222還包括OP1寄存器228和OP2寄存器230。
寄存級(jí)222通過一地址級(jí)(在圖中并未標(biāo)出)而連接到載入級(jí)232。該微處理器使用一傳統(tǒng)地址級(jí)來計(jì)算這些微處理器200進(jìn)行指令處理的地址。MTEF寄存器的內(nèi)容傳送并存儲(chǔ)到載入級(jí)232的相應(yīng)MTEF寄存器234內(nèi)。加載級(jí)232包括加載/對位邏輯器236,如圖所示,其連接到寄存級(jí)222的OP1寄存器228和OP2寄存器230。加載對位邏輯器236連接到數(shù)據(jù)存儲(chǔ)器238。加載對位邏輯器236的輸出端連接到OP3寄存器240。如圖所示,寄存級(jí)222的OP1寄存器228和OP2寄存器230的內(nèi)容分別提供到加載級(jí)232的OP1寄存器242和OP2寄存器244。
微處理器200還包括一含有前述的執(zhí)行標(biāo)記寄存器214的數(shù)據(jù)/算術(shù)邏輯單元或執(zhí)行級(jí)216。數(shù)據(jù)/算術(shù)邏輯單元級(jí)216包括TVAL寄存器246和TMASK寄存器248,其內(nèi)容借助于AND門250而邏輯乘到一起。該邏輯乘操作的結(jié)果存儲(chǔ)到執(zhí)行標(biāo)記寄存器214之內(nèi)。該邏輯乘操作和TMASK寄存器248所提供的屏蔽的操作將在隨后討論。數(shù)據(jù)/算術(shù)邏輯單元級(jí)216包括優(yōu)先級(jí)寄存器PRIV 252,該優(yōu)先級(jí)寄存器提供與當(dāng)前執(zhí)行到TMASK寄存器248指令相關(guān)的優(yōu)先級(jí)信息。指令執(zhí)行結(jié)果提供到結(jié)果寄存器254。該結(jié)果通過結(jié)果總線(圖中未標(biāo)出)反寫到寄存器文件224內(nèi)。
如同前面簡述過的情況,為響應(yīng)讀取邏輯器204所提供到翻譯器210的讀取宏指令POPF/POPFD、CLI/STI、CLD/STD、CLC/STC,翻譯器210生成單個(gè)微指令MTEF D,S,該微指令隨后提供到翻譯隊(duì)列(XIQ)216和連接到該位置的寄存級(jí)222。MTEF微指令包括一信息源S和一目標(biāo)區(qū)D。目標(biāo)區(qū)D規(guī)定要寫入的執(zhí)行標(biāo)記寄存器214的這些位。例如若目標(biāo)區(qū)D=0,則表示寫入到表1所示執(zhí)行標(biāo)記寄存器214內(nèi)0位的進(jìn)位標(biāo)記CF。再比如,若目標(biāo)區(qū)D=9,則表示寫入到執(zhí)行標(biāo)記寄存器內(nèi)的IF位,若目標(biāo)區(qū)D=10,則表示寫入到執(zhí)行標(biāo)記寄存器內(nèi)的DF位。若將翻譯器210生成的微指令MTEF D,S中的D設(shè)置成D=31就表示執(zhí)行標(biāo)記寄存器214從堆棧彈出。
微指令MTEF D,S的信息源S規(guī)定這些寫入到執(zhí)行標(biāo)記寄存器214位的狀態(tài)。例如若D=10,S=0表示命令微處理器200清除DF。若D=0,S=1表示命令微處理器200設(shè)置進(jìn)位標(biāo)記。換句話說,在微指令MTEF D,S內(nèi),S=0表示清除目標(biāo)位,S=1表示目標(biāo)位的一種設(shè)置。對于POP EFLAGS指令來說,可忽略S字段。
數(shù)據(jù)/算術(shù)邏輯單元執(zhí)行級(jí)216內(nèi)的執(zhí)行邏輯器256在寫入到執(zhí)行標(biāo)記寄存器時(shí)提供一屏蔽,以便保證僅寫入到正確的位位置。TMASK寄存器248的內(nèi)容在執(zhí)行MTEF微指令時(shí)動(dòng)態(tài)生成。數(shù)據(jù)/算術(shù)邏輯單元執(zhí)行級(jí)216的執(zhí)行邏輯器256從優(yōu)先級(jí)寄存器PRIV 252存取當(dāng)前運(yùn)行模式,并從執(zhí)行標(biāo)記寄存器214存取其它位的狀態(tài)。S字段的值或從加載級(jí)232堆棧內(nèi)所讀取的執(zhí)行標(biāo)記寄存器被提供到新值寄存器TVAL 246。如圖2所示,TVAL借助于AND門250與TMASK進(jìn)行邏輯乘運(yùn)算,所得結(jié)果寫入到執(zhí)行標(biāo)記寄存器214。該方法的優(yōu)點(diǎn)是,TMASK僅用于更改從PRIV寄存器252獲得的特定當(dāng)前運(yùn)行模式函數(shù)允許的那些位。根據(jù)該實(shí)施例,指令所能具有的最高優(yōu)先等級(jí)數(shù)為3,在更新執(zhí)行標(biāo)記寄存器內(nèi)具體位時(shí),該最高優(yōu)先級(jí)為3的指令具有最大更改范圍。具有較低優(yōu)先級(jí)的指令根據(jù)它們更新執(zhí)行標(biāo)記的能力,具有嚴(yán)格限制的更改范圍。最低優(yōu)先級(jí)數(shù)值為0。作為一實(shí)施例,屏蔽包括與執(zhí)行標(biāo)記寄存器相同數(shù)量的位。根據(jù)PRIV寄存器446提供的當(dāng)前優(yōu)先級(jí),若設(shè)定一個(gè)特定屏蔽位,這表示它可被更新,而若沒有設(shè)定一個(gè)特定屏蔽位,則表示它不能被更新。簡而言之,TVAL提供了要寫入到執(zhí)行標(biāo)記的特定值,TMASK根據(jù)存儲(chǔ)在PRIV寄存器252特定指令相關(guān)的優(yōu)先級(jí)信息,以確定是否允許實(shí)施這樣一個(gè)寫入操作。
本發(fā)明所提供技術(shù)的優(yōu)點(diǎn)是可以在單個(gè)指令周期之內(nèi)執(zhí)行寫入到執(zhí)行標(biāo)記寄存器指令,從而可顯著地增加微處理器的處理能力。
圖3表示微處理器200根據(jù)本發(fā)明的先進(jìn)方法執(zhí)行寫入到執(zhí)行標(biāo)記寄存器的操作時(shí)高度簡化的處理過程流程圖。例如POPF/POPFD、CLI/STI、CLC/STC或CLD/STD等宏指令可依照方塊300從存儲(chǔ)器讀取。當(dāng)翻譯器210依照方塊305翻譯該宏指令時(shí),該宏指令就會(huì)產(chǎn)生一個(gè)寫入到執(zhí)行標(biāo)記寄存器214的請求。EFLAGS屏蔽就會(huì)依照方塊310在EFLAGS屏蔽寄存器TMASK 248內(nèi)產(chǎn)生。此時(shí),如同前述,執(zhí)行宏指令產(chǎn)生的要寫入到EFLAGS的新值就會(huì)載入到方塊315內(nèi)的TVAL寄存器246。依照步驟320將目標(biāo)信息提供到TMASK寄存器。同時(shí)也將當(dāng)前優(yōu)先級(jí)提供到TMASK寄存器,以便為TMASK寄存器配置一個(gè)值,假設(shè)依照方塊325優(yōu)先級(jí)信息允許更改該單個(gè)位或多個(gè)位的話,該值允許更改目標(biāo)信息指定的特定EFLAGS位。依照方塊330,TMASK寄存器內(nèi)容與新值TVAL寄存器內(nèi)容進(jìn)行邏輯乘的操作,以便確保只有當(dāng)前優(yōu)先級(jí)允許的應(yīng)該更新的那些EFLAGS位依照方塊335在EFLAGS內(nèi)獲得更新。
前述已經(jīng)注意到,在傳統(tǒng)管道式微處理器之內(nèi),執(zhí)行將EFLAGS寄存器移入至堆棧的命令PUSHF/PUSHFD時(shí),需要運(yùn)行相當(dāng)多個(gè)微處理器周期。原因是從EFLAGS寄存器的讀取操作取決于當(dāng)前I/O優(yōu)先級(jí)(IOPL)和寫入時(shí)EFLAGS內(nèi)特定位狀態(tài)。更具體地說,位1、5、15和22-31為保留位,其具體狀態(tài)不能更改。另外,不能拷貝EFLAGS寄存器的VM和RF標(biāo)記(位16和17)。反倒是,在存儲(chǔ)到堆棧的EFLAGS寄存器圖像內(nèi)要清除這些標(biāo)記值。
當(dāng)x86微處理器運(yùn)行在虛擬8086模式且I/O優(yōu)先級(jí)(IOPL)小于3時(shí),執(zhí)行PUSHF/PUSHFD指令肯定會(huì)引起通用保護(hù)故障或異常。然而,在真實(shí)地址模式之下,若在執(zhí)行指令PUSHF/PUSHFD時(shí),ESP寄存器或SP寄存器為1、3或5,則會(huì)由于堆??臻g不足而導(dǎo)致微處理器關(guān)閉。
在例如微處理器100等當(dāng)今管道式微處理器之內(nèi),執(zhí)行任何PUSHF/PUSHFD指令都會(huì)導(dǎo)致生成多個(gè)微指令。首先,執(zhí)行一微指令將EFLAGS內(nèi)容移動(dòng)到臨時(shí)寄存器。然后執(zhí)行一微指令清除VM、PF位。隨后,執(zhí)行一微指令確定當(dāng)前I/O優(yōu)先級(jí)IOPL,目的是讓微處理器清楚是否應(yīng)生成異?;蜿P(guān)閉微處理器。最后,執(zhí)行一微指令將EFLAGS圖像存儲(chǔ)回堆棧。
上面所討論的傳統(tǒng)微處理器的一個(gè)明顯缺點(diǎn)是為了完成一EFLAGS移入到堆棧的操作,必須執(zhí)行很多微指令。其中某些微指令是必須的,原因是在將EFLAGS移動(dòng)到堆棧之前,必須詢問當(dāng)前I/O優(yōu)先級(jí)(IOPL)。其中還有某些微指令的所以必須的原因是在移入之前要清除EFLAGS內(nèi)的特定位。另外,由于當(dāng)前管道式微處理器結(jié)構(gòu)不適合同時(shí)執(zhí)行包括算術(shù)邏輯單元操作和存儲(chǔ)操作的指令,如此則必須生成更多微指令。當(dāng)前所知的執(zhí)行級(jí)邏輯器僅允許執(zhí)行算術(shù)邏輯單元和存儲(chǔ)器存取操作中的某一單一功能。因此,任何后續(xù)含有存儲(chǔ)類型操作的規(guī)定算術(shù)邏輯單元類型操作指令都必須生成兩個(gè)連續(xù)微指令,以便在連續(xù)的單個(gè)機(jī)器周期內(nèi)完成這兩個(gè)操作。發(fā)明人注意到在例如Microsoft Windows等操作系統(tǒng)中,EFLAGS寄存器在每次調(diào)用子程序時(shí)均移入至堆棧。由于調(diào)用現(xiàn)象很頻繁,因此非常希望能降低與EFLAGS移入到堆棧相關(guān)的執(zhí)行時(shí)間。
圖4所示微處理器400的優(yōu)點(diǎn)是提供了一種單個(gè)微指令,從EFLAGS移動(dòng)指令(MFEF),將EFLAGS寄存器414的內(nèi)容移動(dòng)到堆棧。數(shù)據(jù)/算術(shù)邏輯單元或執(zhí)行級(jí)418的執(zhí)行邏輯器416和加載-算術(shù)邏輯單元存儲(chǔ)管線式結(jié)構(gòu)使得EFLAGS移入的操作可在單個(gè)指令周期內(nèi)完成。因此也就顯著地改善了微處理器的效率。
微處理器400包括讀取級(jí)402,其將命令讀取邏輯器404連接到指令存儲(chǔ)器406。指令指針408系連接到讀取邏輯器404,以命令讀取邏輯器404指定到指令存儲(chǔ)器406的特定位置,且可從該位置讀取當(dāng)前指令。
當(dāng)讀取邏輯器404讀取例如PUSHF/PUSHFD等宏指令時(shí),翻譯級(jí)412的翻譯器410響應(yīng)生成MFEF微指令,該微指令完成從EFLAGS寄存器414移動(dòng)到數(shù)據(jù)/算術(shù)邏輯單元-執(zhí)行級(jí)418的操作。
如圖所示,MFEF微指令提供到翻譯指令隊(duì)列(XIQ)419。該MFEF微指令行進(jìn)到寄存級(jí)422的MFEF寄存器420。寄存級(jí)422包括存儲(chǔ)微處理器400的結(jié)構(gòu)狀態(tài)的寄存器文件424。寄存器文件424包括堆棧指針寄存器ESP 426。如圖所示,寄存級(jí)222包括OP1寄存器428和OP2寄存器430。地址級(jí)431緊鄰寄存級(jí)422。地址級(jí)431計(jì)算存儲(chǔ)值地址,以便可從存儲(chǔ)器檢索它們并將它們寫入到存儲(chǔ)器。
提供MFEF寄存器420內(nèi)容,并將它們存儲(chǔ)在載入級(jí)434的相應(yīng)MFEF寄存器432內(nèi)。加載級(jí)434包括加載/對位邏輯器436,如圖所示,該邏輯器436連接到寄存級(jí)422的OP1寄存器428和OP2寄存器430。加載對位邏輯器436連接到數(shù)據(jù)存儲(chǔ)器438。加載對位邏輯器436的輸出端連接到OP3寄存器440。如圖所示,寄存級(jí)422的OP1寄存器428和OP2寄存器430的內(nèi)容提供到加載級(jí)232的OP1寄存器442和OP2寄存器444。
MFEF寄存器432、OP1寄存器442、OP2寄存器444和OP3寄存器440連接到數(shù)據(jù)/算術(shù)邏輯單元級(jí)418的執(zhí)行邏輯器416,以便將這些寄存器中每一寄存器數(shù)值提供到執(zhí)行邏輯器416。
現(xiàn)在描述MFEF微指令從翻譯級(jí)412到數(shù)據(jù)/算術(shù)邏輯單元執(zhí)行級(jí)418的過程。當(dāng)翻譯器410接收到一個(gè)PUSHF或PUSHFD指令時(shí),翻譯器410會(huì)在其輸出端響應(yīng)生成一個(gè)MFEF微指令。該MFEF微指令命令微處理器400執(zhí)行遞減和讀取的操作,并進(jìn)一步命令堆棧指針寄存器ESP 426讀取EFLAGS寄存器414,并依照當(dāng)前操作狀態(tài)函數(shù)對EFLAGS圖像進(jìn)行動(dòng)態(tài)修正。然后將該EFLAGS圖像存儲(chǔ)到存儲(chǔ)器445的堆棧內(nèi)。
數(shù)據(jù)/算術(shù)邏輯單元執(zhí)行級(jí)418的執(zhí)行邏輯器416包括存儲(chǔ)當(dāng)前執(zhí)行指令優(yōu)先級(jí)信息或IOPL的優(yōu)先級(jí)寄存器PRIV 446。優(yōu)先級(jí)寄存器PRIV 446連接到FMASK寄存器448。EFLAGS寄存器414連接到FMASK寄存器448,以便向FMASK寄存器448提供第二個(gè)輸入端。執(zhí)行邏輯器416提供了一個(gè)屏蔽,名為FMASK,該屏蔽在執(zhí)行MFEF微指令時(shí)動(dòng)態(tài)產(chǎn)生。作為一實(shí)施例,該屏蔽含有與EFLAGS寄存器數(shù)量相同的位。根據(jù)PRIV寄存器446提供的當(dāng)前優(yōu)先級(jí),若設(shè)定一個(gè)特定屏蔽位,這表示它可被更新,而若一個(gè)特定屏蔽位沒有設(shè)定,則表示它不能被更新。執(zhí)行邏輯器416從優(yōu)先級(jí)寄存器PRIV 446存取當(dāng)前操作模式,從EFLAGS寄存器414存取其它位狀態(tài)。然后,讀取EFLAGS寄存器內(nèi)容,并將其與FMASK邏輯乘生成一結(jié)果,該結(jié)果存儲(chǔ)到結(jié)果寄存器452。更詳細(xì)地說,F(xiàn)MASK寄存器448的輸出端連接到AND門450的一個(gè)輸入端。AND門450的其它輸入端連接到EFLAGS寄存器414。
在下一機(jī)器周期,存儲(chǔ)在結(jié)果寄存器452內(nèi)的結(jié)果寫入到存儲(chǔ)器堆棧內(nèi),寫入地址由ESP寄存器426指定。由于在緊接著的下個(gè)機(jī)器周期,該結(jié)果將提供到寄存級(jí)456的存儲(chǔ)邏輯器454,故不需要對EFLAGS圖像進(jìn)行臨時(shí)存儲(chǔ)。存儲(chǔ)邏輯器454發(fā)送該結(jié)果,以便將其存儲(chǔ)在存儲(chǔ)器458堆棧內(nèi)。
微處理器400的優(yōu)點(diǎn)是可在單個(gè)指令周期內(nèi)運(yùn)行PUSHF PUSHFD指令,這顯著地增加了微處理器的效率。
圖5表示根據(jù)本發(fā)明所述先進(jìn)技術(shù)微處理器400執(zhí)行從EFLAGS讀取操作以便進(jìn)行堆棧移入時(shí)微處理器工作流程圖。作為一實(shí)施例,讀取器404從指令存儲(chǔ)器檢索PUSHF或PUSHFD宏指令。根據(jù)該種方式,在微指令傳送到堆棧之前,就已經(jīng)讀取了依據(jù)方塊500需要從EFLAGS寄存器414讀取的微指令。方塊505表示翻譯器410將宏指令翻譯成一用于在單個(gè)微指令周期內(nèi)從EFLAGS寄存器讀取操作的MFEF微指令。依照方塊510,在FMASK寄存器448內(nèi)生成一個(gè)EFLAGS屏蔽。作為一實(shí)施例,該EFLAGS屏蔽具有與EFLAGS本身數(shù)目相等的位。因此,在FMASK寄存器內(nèi)EFLAGS屏蔽位與EFLAGS寄存器位之間存在一一對應(yīng)關(guān)系。為在方塊515內(nèi)生成EFLAGS屏蔽,執(zhí)行邏輯器416檢查優(yōu)先級(jí)情況,并設(shè)置與根據(jù)特定當(dāng)前優(yōu)先級(jí)允許更改的特定EFLAGS位相關(guān)的屏蔽位。相應(yīng)于不能被更改EFLAGS位的其它屏蔽位則處于未設(shè)置狀態(tài)或等于零狀態(tài)。然后,該屏蔽依照方塊520與EFLAGS寄存器的內(nèi)容進(jìn)行邏輯乘的操作,所得結(jié)果依照方塊525寫入到堆棧。
上面結(jié)合圖2及圖3所示內(nèi)容描述了一種增加寫入到EFLAGS寄存器的操作微處理器效率的裝置和方法。結(jié)合圖4及圖5所示內(nèi)容描述了一種增加執(zhí)行從EFLAGS寄存器讀取操作微處理器效率的裝置和方法。該方法的優(yōu)點(diǎn)是寫入到EFLAGS的操作和從EFLAGS讀取的操作均可在單個(gè)指令周期內(nèi)完成,而不像過去所用微處理器那樣需要多個(gè)周期。
盡管在此已詳細(xì)描述了本發(fā)明及其目標(biāo)、特征和優(yōu)點(diǎn),但本發(fā)明還包括其它實(shí)施例。除了采用硬件來實(shí)施本發(fā)明以外,本發(fā)明還可適用于可處理計(jì)算機(jī)程序代碼(例如軟件),例如可應(yīng)用于存儲(chǔ)該代碼的計(jì)算機(jī)可用(可讀)介質(zhì)。該代碼實(shí)現(xiàn)本發(fā)明的功能、制造、建模、模擬和/或測試。例如可通過形式為通用編程語言(例如C、C++等),GDSII,包括VERILOG HDL、VHDL、AHDL(Altera硬件描述語言)等硬件描述語言(HDL)等,或其它數(shù)據(jù)庫,本技術(shù)領(lǐng)域編程和/或電路(圖解)捕獲工具之類計(jì)算機(jī)可讀程序編碼來完成。該編碼可在任何可知計(jì)算機(jī)可用介質(zhì)上處理,這些介質(zhì)包括半導(dǎo)體存儲(chǔ)器、磁盤、光盤(如CD-ROM、DVD-ROM等)、實(shí)施在計(jì)算機(jī)可用(可讀)傳輸介質(zhì)(如載波或包括數(shù)字、光學(xué)或類似介質(zhì)的任何其它介質(zhì))的計(jì)算機(jī)數(shù)據(jù)信號(hào)。這樣,該代碼就可在包括因特網(wǎng)和局域網(wǎng)絡(luò)的通信網(wǎng)路上傳播。在此可認(rèn)為上述本發(fā)明的功能和/或結(jié)構(gòu)可適用于實(shí)施為編碼(如HDL、GDSII等)、并可轉(zhuǎn)變?yōu)榧呻娐凡糠钟布奈⑻幚砥?。同樣該發(fā)明可實(shí)施為硬件與編碼組合態(tài)的形式。
雖然本發(fā)明已以二個(gè)較佳實(shí)施例披露如上,然其并非用以限定本發(fā)明,本領(lǐng)域技術(shù)人員在不脫離本發(fā)明的精神和范圍內(nèi),可作若干的更動(dòng)與潤飾,因此本發(fā)明的保護(hù)范圍視后附的權(quán)利要求為準(zhǔn)。
權(quán)利要求
1.一種完成寫入到微處理器中一多位標(biāo)記寄存器操作的方法,該方法包括在一翻譯級(jí)接收一請求寫入到該多位標(biāo)記寄存器的一宏指令;以及在該翻譯級(jí)生成一寫入周期之內(nèi)可寫入到該多位標(biāo)記寄存器的一微指令。
2.如權(quán)利要求1所述的完成寫入到微處理器多位標(biāo)記寄存器操作的方法,還包括生成一標(biāo)記屏蔽。
3.如權(quán)利要求2所述的完成寫入到微處理器多位標(biāo)記寄存器操作的方法,還包括將該標(biāo)記屏蔽與一規(guī)定操作數(shù)進(jìn)行邏輯乘的操作生成一結(jié)果。
4.如權(quán)利要求3所述的完成寫入到微處理器多位標(biāo)記寄存器操作的方法,還包括將該結(jié)果存儲(chǔ)到該多位標(biāo)記寄存器。
5.如權(quán)利要求4所述的完成寫入到微處理器多位標(biāo)記寄存器操作的方法,其中該多位標(biāo)記寄存器為一執(zhí)行標(biāo)記寄存器。
6.如權(quán)利要求1所述的完成寫入到微處理器多位標(biāo)記寄存器操作的方法,其中該宏指令為下列類型之一POPF、POPFD、CLI、STI、CLC、STC、CLD和STD。
7.一種從一多位標(biāo)記寄存器完成一讀取操作的方法,該方法包括在一翻譯級(jí)接收一請求從一多位標(biāo)記寄存器讀出的一宏指令;以及在該翻譯級(jí)生成一寫入周期內(nèi)可從該多位標(biāo)記寄存器讀出的一微指令。
8.如權(quán)利要求7所述的完成從多位標(biāo)記寄存器讀取操作的方法,還包括生成一個(gè)標(biāo)記屏蔽,該標(biāo)記屏蔽包含根據(jù)當(dāng)前優(yōu)先級(jí)信息的一讀取操作過程中與更新該多位標(biāo)記寄存器的那些字節(jié)有關(guān)的優(yōu)先級(jí)信息。
9.如權(quán)利要求8所述的完成從多位標(biāo)記寄存器讀取操作的方法,還包括將該標(biāo)記屏蔽與該多位標(biāo)記寄存器邏輯乘運(yùn)算后生成一結(jié)果。
10.如權(quán)利要求7所述的完成從多位標(biāo)記寄存器讀取操作的方法,其中該多位標(biāo)記寄存器為一EFLAGS寄存器。
全文摘要
一種寫入到微處理器內(nèi)EFLAGS寄存器或從該寄存器讀出的方法和裝置。對于特定寫入到EFLAGS請求,采用寫入操作目標(biāo)信息和寫入操作優(yōu)先級(jí)信息生成一屏蔽。隨后,該屏蔽與EFLAGS的新值信息進(jìn)行邏輯乘的操作,所得結(jié)果在單個(gè)指令周期內(nèi)寫入到EFLAGS寄存器。對于特定從EFLAGS讀出請求,采用根據(jù)當(dāng)前優(yōu)先級(jí)信息讀取操作過程中與更新多位標(biāo)記寄存器那些字節(jié)有關(guān)的優(yōu)先級(jí)信息生成一屏蔽。隨后,該屏蔽與EFLAGS寄存器內(nèi)容進(jìn)行邏輯乘的操作,所得結(jié)果存儲(chǔ)到存儲(chǔ)器堆棧內(nèi)。
文檔編號(hào)G06F9/06GK1497432SQ0315978
公開日2004年5月19日 申請日期2003年9月25日 優(yōu)先權(quán)日2002年10月22日
發(fā)明者杰勒德·M·科爾, G·格倫·亨利, 特里·帕克斯, 住ず嗬, 帕克斯, 杰勒德 M 科爾 申請人:智權(quán)第一公司
網(wǎng)友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會(huì)獲得點(diǎn)贊!
1
文登市| 黎城县| 商河县| 海门市| 监利县| 金山区| 南川市| 广东省| 凉山| 翁牛特旗| 抚州市| 海淀区| 苏尼特左旗| 永川市| 兰西县| 沾益县| 庆元县| 灵寿县| 建宁县| 卓资县| 犍为县| 砀山县| 蒙城县| 师宗县| 万州区| 嘉禾县| 鹤壁市| 浮梁县| 阿拉善盟| 余干县| 宝鸡市| 綦江县| 金坛市| 太谷县| 成都市| 伊吾县| 秦安县| 洛隆县| 扶绥县| 温州市| 崇左市|