彙編語言無效指令錯誤概述

此錯誤僅適用於奔騰 處理器、奔騰處理器與MMX技術、奔騰OverDrive處理器 和奔騰OverDrive處理器帶有MMX技術。 奔騰Pro處理器, 奔騰II處理器和i486及更早版本處理器不受影響 問題:cmpxchg8b 指令比較一個8字節值edx和EAX帶有8字節值內存( 目的地操作數)。 只有有效目標操作數用於此指令是內存 操作數。 如果目標操作數是一個寄存器處理器應產生一個 無效OpCode例外,執行的指令cmpxchg8b應當停止和 處理器應該執行無效OpCode異常處理程序。 此錯誤發生是 鎖定前綴爲使用cmpxchg8b指令與一個(無效)寄存器目的地 操作數。 在這種情況下,處理器可能無法啓動執行無效OpCode 異常處理程序,因爲總線已鎖定。 這將導致系統掛起。

提示:如果(無效)寄存器目的地 操作使用cmpxchg8b指令和鎖定前綴,系統可能掛起。 沒有內存數據已損壞,用戶可以執行系統重置以返回到正常 操作。 請注意,特定無效代碼序列必要此錯誤 發生通常不能被生成,該課程的編程也不這樣的序列 可可由此商業軟件。

此錯誤僅適用於奔騰 處理器、奔騰處理器與MMX技術、奔騰OverDrive處理器 和奔騰OverDrive處理器帶有MMX技術。 奔騰Pro處理器, 奔騰II處理器和i486及更早版本處理器不受影響。

變通辦法:有兩種變通方法此錯誤以 保護模式操作系統。 變通辦法二者生成一個頁面錯誤當無效 OpCode例外情況。 在以上兩例中,頁錯誤將維修前無效 OpCode例外,從而防止鎖定狀態的發生。 實施 細節將有所不同取決於操作系統。 使用以下方法之一:
第一部分的該解決辦法集的第一個7條目(0-6)中斷 描述信息表(IDT)在非寫頁。 當無效OpCode異常 (異常6)出現的原因是鎖定cmpxchg8b指令帶無效註冊 目的地,然後才),處理器將生成一個頁面錯誤如果沒有有 寫訪問該頁面包含條目6的IDT。 的第二部分該解決辦法 修改頁面錯誤處理程序認識和正確地調度"無效OpCode 例外情況,現在佈線通過頁面錯誤處理程序。

部件I、IDT頁面訪問

標記頁面包含的第一個七個條目(0-6)的IDT爲只讀通過 設置位1的頁面表條目爲零。 也可以設置cr0.wp(16位)爲1。 現在,當" 無效OpCode異常發生鎖定cmpxchg8b指令,處理器將 會觸發頁面錯誤由於它沒有寫訪問該頁面包含條目6的 IDT。 此頁面錯誤阻止了總線鎖定狀態並給操作系統完全控制 過程"無效操作異常。 請注意,例外6是 無效OpCode例外,因此與此圖式的OS有完全控制的任何程序 執行一個無效cmpxchg8b指令。
可選:如果更新條目7-255的IDT發生在課程正常 操作,頁面錯誤應避免在寫入這些IDT條目。 這些頁面錯誤 可避免對齊IDT跨越一個4KB頁面邊界(例如,可在第一個七個 條目(0-6)的IDT在第一個只讀"頁和"剩餘的條目在 讀/寫頁。

第II、頁面錯誤 處理程序修改

修改尋呼容處理程序來計算哪種異常導致該頁面錯誤使用 容地址以cr2。 如果錯誤代碼堆棧上表示產生異常 從震鈴0和如果地址對應於無效OpCode例外,然後彈出的 錯誤代碼關閉堆棧和跳轉到"無效OpCode異常處理程序。 否則 繼續正常頁面錯誤處理程序。

該解決辦法有兩部分。 首先,中斷描述信息表(IDT)對齊 (例如,任何無效OpCode異常會導致頁面錯誤(由於頁不 存在)。 其次,頁面錯誤處理程序日期認識和正確地調度 "無效OpCode異常和其他一些例外情況,現在佈線通過 頁面錯誤處理程序。

部件I、IDT校準:

對齊中斷描述信息表(IDT)這樣的,其跨越4KB頁面邊界, 把第一項啓動56字節來自最終的第一個4KB"頁。 這將 該第一個七個條目(0-6)在第一個4KB"頁和剩餘的條目在 第二個頁面。
該頁面包含的頭7條目IDT不能有映射在OS 頁面表。 這將導致任何例外0-6生成一份頁不存在故障。 一個 頁面錯誤阻止了總線鎖定狀態並給操作系統完全控制過程 這些異常。 請注意,例外6是無效OpCode例外,因此 與此圖式的OS有完全控制的任何程序執行一個無效cmpxchg8b 指令。

第II、頁面錯誤處理程序修改:

識別訪問指向的第一頁IDT通過測試的容地址cr2中。 頁面不存在故障在其他地址可處理正常。
頁不存在故障第一頁上的IDT,操作系統必須識別和 發送異常造成該頁面不存在故障。 繼續之前,測試 故障地址以cr2以確定其是否被在地址範圍相應 例外情況0-6。
計算哪種異常導致該頁不存在故障從容地址 cr2中。
取決於操作系統,某些權限級別檢查可能會要求,以及 調整中斷堆棧。
跳轉到正常處理程序爲適當異常。

兩個變通辦法僅應上實現英特爾處理器返回family=5 通過CPUID指令。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章