x86 LES指令解析
阿新 • • 發佈:2019-02-12
1. SDM指令功能描述(LES)
總體描述:用32位或48位的資料載入16位ES段選擇符和16或32位的通用暫存器值,其中通用暫存器在目的運算元中。LES (16or32)通用暫存器, (32or48)記憶體變數的地址
注意:LES指令不支援64位模式
2. 虛擬碼:
64位模式:
#UD
32位模式:
if(selector is not NULL)
{
if((selector指向gdt或者ldt超出了gdt或ldt的limit) or (描述符的意義說明不是資料段也不是可讀的程式碼段) or (在(RPL>DPL 或 CPL>DPL)的前提下,段不是資料段也不是非一致性程式碼段))
{
#GP
}
else
{
ES選擇符賦值ES段描述符(對軟體不可見)賦值}}else(selector is NULL){ES=0ES段描述符(對軟體不可見)=0
}
DEST=*(SRC)
16位真實模式
ES=*(SRC+2)DEST=*(SRC)
測試程式碼
struct lseg_st{ long a; int16_t b; }; void test() { struct lseg_st les; les.a = 0xffffffff; les.b = 0x08; __asm__ volatile ( "lesl %0, %%eax\t\n" ::"m"(les) ); }
bochs執行效果