mov sreg, r/m16 在16位和32位编程中的区别
生活随笔
收集整理的這篇文章主要介紹了
mov sreg, r/m16 在16位和32位编程中的区别
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
總結于《X86匯編語言 從實模式到保護模式》
僅適用于X86系列處理器
1. 兩者的區別:
例:mov ds, ax
A.在指定16位編譯模式下,產生的二進制碼是 8E D8
B.在指定32位編譯模式下(在某些老式的編譯器中才會出現的),產生的二進制碼是 66 8E D8
2. 影響:
A.加上0x66的前綴是為了反轉默認的操作數大小。因為32位模式下,默認的操作數大小是4字節的,而指令中的源操作數是16位的AX。
B.有前綴和沒前綴相比,CPU在執行時會多花一個額外的時鐘周期。
3. 解決
A. 使用32位的源操作數,但是高地址部分會被截斷。也讓人難以理解。如:
mov ds, eax
編譯出來的二進制指令是:8E D8
B. 使用NASM編譯器,NASM編譯器無論在什么樣的處理器模式下,編譯出來的指令都是一樣的。
?
轉載于:https://www.cnblogs.com/Jer-/p/3176551.html
總結
以上是生活随笔為你收集整理的mov sreg, r/m16 在16位和32位编程中的区别的全部內容,希望文章能夠幫你解決所遇到的問題。