btc匯編
『壹』 求匯編高人.....
1、操作碼F0是lock(鎖定匯流排前綴),它只能用在ADD,ADC,AND,
BTC,BTR,BTS,CMPXCHG,CMPXCH8B,DEC,INC,NEG,NOT,或,SBB,SUB,Xor,
XADD,XCHG.指令前,不使用在以上指令前,將產生未定義操作碼異常(見06版intel手冊卷2第586頁)。
2、windows處理這個未定義操作碼異常,生成以上對話框,供用戶選擇,只能選擇關閉,修改程序。
3、假如程序沒有其他錯誤,只簡單把程序中的F0nop(90h)掉即可。
『貳』 匯編:每一句前的mov ax,data是什麼意思
這句話的作用就是使DS的值為DATA.其中DATA為你定義的數據段,它的作用就是把數據段寄存器DS的值賦為DATA,就是讓數據段指向正確的位置
data賦給AX只是起一個過渡作用,實際上是為了將值賦給DS
DATA指DATA做的地址,應該是隨機分配的
將AX的值賦給DS是一個過渡作用
(2)btc匯編擴展閱讀:
語言組成
由於匯編指令系統龐大,因而需構建指令系統體系,其指令數量龐大,格式復雜,可記憶性差等。指令中最難的是指令所支持的定址方式,其實質就是指令中操作數如何獲取。對於處理器而言,就是如何找到他所需的數據。
但對於計算機底層的匯編語言而言,這種定址方式將涉及大量的計算存儲格式,與 復雜的存儲管理方式緊密相關,因而難以理解。最後,匯編指令還關繫到如何影響標志位,但處理器標志位非常復雜,因而對其機制掌握就比較困難。
傳送指令
包括通用數據傳送指令MOV、條件傳送指令CMOVcc、堆棧操作指令PUSH/PUSHA/PUSHAD/POP/POPA/POPAD、交換指令XCHG/XLAT/BSWAP、地址或段描述符選擇子傳送指令LEA/LDS/LES/LFS/LGS/LSS等。
邏輯運算
這部分指令用於執行算術和邏輯運算,包括加法指令ADD/ADC、減法指令SUB/SBB、加一指令INC、減一指令DEC
比較操作指令CMP、乘法指令MUL/IMUL、除法指令DIV/IDIV、符號擴展指令CBW/CWDE/CDQE、十進制調整指令DAA/DAS/AAA/AAS、邏輯運算指令NOT/AND/OR/XOR/TEST等。
移位指令
這部分指令用於將寄存器或內存操作數移動指定的次數。包括邏輯左移指令SHL、邏輯右移指令SHR、算術左移指令SAL、算術右移指令SAR、循環左移指令ROL、循環右移指令ROR等。
位操作
這部分指令包括位測試指令BT、位測試並置位指令BTS、位測試並復位指令BTR、位測試並取反指令BTC、位向前掃描指令BSF、位向後掃描指令BSR等。
控制轉移
這部分包括無條件轉移指令JMP、條件轉移指令Jcc/JCXZ、循環指令LOOP/LOOPE/LOOPNE、過程調用指令CALL、子過程返回指令RET、中斷指令INTn、INT3、INTO、IRET等。
串操作
這部分指令用於對數據串進行操作,包括串傳送指令MOVS、串比較指令CMPS、串掃描指令SCANS、串載入指令LODS、串保存指令STOS,這些指令可以有選擇地使用REP/REPE/REPZ/REPNE和REPNZ的前綴以連續操作。
輸入輸出
這部分指令用於同外圍設備交換數據,包括埠輸入指令IN/INS、埠輸出指令OUT/OUTS
『叄』 gcc at&t匯編語法 立即數 沒有
一 基本語法
1 寄存器引用
引用寄存器要在寄存器號前加百分號%,如「movl %eax, %ebx」。
80386有如下寄存器:
1、8個32-bit寄存器 %eax,%ebx,%ecx,%edx,%edi,%esi,%ebp,%esp;
2、8個16-bit寄存器,它們事實上是上面8個32-bit寄存器的低16位:%ax,%bx,%cx,%dx,%di,%si,%bp,%sp;
3、8個8-bit寄存器:%ah,%al,%bh,%bl,%ch,%cl,%dh,%dl。它們事實上是寄存器%ax,%bx,%cx,%dx的高8位和低8位;
4、6個段寄存器:%cs(code),%ds(data),%ss(stack), %es,%fs,%gs;
5、3個控制寄存器:%cr0,%cr2,%cr3;
6、6個debug寄存器:%db0,%db1,%db2,%db3,%db6,%db7;
7、2個測試寄存器:%tr6,%tr7;
8、8個浮點寄存器棧:%st(0),%st(1),%st(2),%st(3),%st(4),%st(5),%st(6),%st(7)。
2 操作數順序
操作數排列是從源(左)到目的(右),如「movl %eax(源), %ebx(目的)」
3 立即數
使用立即數,要在數前面加符號$, 如「movl $0x04, %ebx」
或者:
para = 0x04
movl $para, %ebx
指令執行的結果是將立即數04h裝入寄存器ebx。
4 符號常數
符號常數直接引用 如
value : .long 0x12a3f2de
movl value , %ebx
指令執行的結果是將常數0x12a3f2de裝入寄存器ebx。
5 操作數的長度
操作數的長度用加在指令後的符號表示b(byte, 8-bit), w(word, 16-bits), l(long, 32-bits),如「movb %al, %bl」,「movw %ax, %bx」,「movl %eax, %ebx 」。
如果沒有指定操作數長度的話,編譯器將按照目標操作數的長度來設置。比如指令「mov %ax, %bx」,由於目標操作數bx的長度為word,那麼編譯器將把此指令等同於「movw %ax, %bx」。同樣道理,指令「mov $4, %ebx」等同於指令「movl $4, %ebx」,「push %al」等同於「pushb %al」。對於沒有指定操作數長度,但編譯器又無法猜測的指令,編譯器將會報錯,比如指令「push $4」。
引用符號地址在符號前加符號$, 如「movl $value, %ebx」則是將符號value的地址裝入寄存器ebx。
6 符號擴展和零擴展指令
絕大多數面向80386的AT&T匯編指令與Intel格式的匯編指令都是相同的,符號擴展指令和零擴展指令則是僅有的不同格式指令。符號擴展指令和零擴展指令需要指定源操作數長度和目的操作數長度,即使在某些指令中這些操作數是隱含的。
在AT&T語法中,符號擴展和零擴展指令的格式為,基本部分"movs"和"movz"(對應Intel語法的movsx和movzx),後面跟上源操作數長度和 目的操作數長度。movsbl意味著movs (from)byte (to)long;movbw意味著movs (from)byte (to)word;movswl意味著movs (from)word (to)long。對於movz指令也一樣。比如指令「movsbl %al, %edx」意味著將al寄存器的內容進行符號擴展後放置到edx寄存器中。
其它的Intel格式的符號擴展指令還有:
cbw -- sign-extend byte in %al to word in %ax;
cwde -- sign-extend word in %ax to long in %eax;
cwd -- sign-extend word in %ax to long in %dx:%ax;
cdq -- sign-extend dword in %eax to quad in %edx:%eax;
對應的AT&T語法的指令為cbtw,cwtl,cwtd,cltd。
7 調用和跳轉指令
段內調用和跳轉指令為"call","ret"和"jmp",段間調用和跳轉指令為"lcall","lret"和"ljmp"。
段間調用和跳轉指令的格式為「lcall/ljmp $SECTION, $OFFSET」,而段間返回指令則為「lret $STACK-ADJUST」。
8 前綴
操作碼前綴被用在下列的情況:
1、字元串重復操作指令(rep,repne);
2、指定被操作的段(cs,ds,ss,es,fs,gs);
3、進行匯流排加鎖(lock);
4、指定地址和操作的大小(data16,addr16);
在AT&T匯編語法中,操作碼前綴通常被單獨放在一行,後面不跟任何操作數。例如,對於重復scas指令,其寫法為:
repne
scas
上述操作碼前綴的意義和用法如下:
指定被操作的段前綴為cs,ds,ss,es,fs,和gs。在AT&T語法中,只需要按照section:memory-operand的格式就指定了相應的段前綴。比如:lcall %cs:realmode_swtch
操作數/地址大小前綴是「data16」和"addr16",它們被用來在32-bit操作數/地址代碼中指定16-bit的操作數/地址。
匯流排加鎖前綴「lock」,它是為了在多處理器環境中,保證在當前指令執行期間禁止一切中斷。這個前綴僅僅對ADD, ADC, AND, BTC, BTR, BTS, CMPXCHG,DEC, INC, NEG, NOT, OR, SBB, SUB, XOR, XADD,XCHG指令有效,如果將Lock前綴用在其它指令之前,將會引起異常。
字元串重復操作前綴"rep","repe","repne"用來讓字元串操作重復「%ecx」次。
9 內存引用
Intel語法的間接內存引用的格式為:
section:[base+index*scale+displacement]
而在AT&T語法中對應的形式為:
section:displacement(base,index,scale)
其中,base和index是任意的32-bit base和index寄存器。scale可以取值1,2,4,8。如果不指定scale值,則默認值為1。section可以指定任意的段寄存器作為段前綴,默認的段寄存器在不同的情況下不一樣。如果你在指令中指定了默認的段前綴,則編譯器在目標代碼中不會產生此段前綴代碼。
下面是一些例子:
-4(%ebp):base=%ebp,displacement=-4,section沒有指定,由於base=%ebp,所以默認的section=%ss,index,scale沒有指定,則index為0。
foo(,%eax,4):index=%eax,scale=4,displacement=foo。其它域沒有指定。這里默認的section=%ds。
foo(,1):這個表達式引用的是指針foo指向的地址所存放的值。注意這個表達式中沒有base和index,並且只有一個逗號,這是一種異常語法,但卻合法。
%gs:foo:這個表達式引用的是放置於%gs段里變數foo的值。
如果call和jump操作在操作數前指定前綴「*」,則表示是一個絕對地址調用/跳轉,也就是說jmp/call指令指定的是一個絕對地址。如果沒有指定"*",則操作數是一個相對地址。
任何指令如果其操作數是一個內存操作,則指令必須指定它的操作尺寸(byte,word,long),也就是說必須帶有指令後綴(b,w,l)。
『肆』 匯編語言中的DEC是什麼意思
DEC( DECrement ) 減1指令
格式:DEC OPR //Byte/Word
執行操作:(OPR)<-(OPR-1) //除CF標志位,其餘標志位都受影響。
指令使操作數的內容減1,然後再送回該操作數。該操作數可以是寄存器操作數、存儲器操作數。
例如:一、dec自減函數
1.dec(i,n);//i,n:integer;n為自減量
相當於i:=i-n;
2.dec(i);//i:integer;
相當於i:=i-1;
例如:二、Dec是遞減函數
i:=100;
dec(i);
i就變成99了,
如果是dec(i,30)的話,
那麼i=100-30=70
(4)btc匯編擴展閱讀:
數據傳送指令
這部分指令包括通用數據傳送指令MOV、條件傳送指令CMOVcc、堆棧操作指令
PUSH/PUSHA/PUSHAD/POP/POPA/POPAD、交換指令XCHG/XLAT/BSWAP、地址或段描述符選擇子傳送指令LEA/LDS/LES/LFS/LGS/LSS等。
注意,CMOVcc不是一條具體的指令,而是一個指令簇,包括大量的指令,用於根據EFLAGS寄存器的某些位狀態來決定是否執行指定的傳送操作。
整數和邏輯運算指令
這部分指令用於執行算術和邏輯運算,包括加法指令ADD/ADC、減法指令SUB/SBB、加一指令INC、減一指令DEC、比較操作指令CMP、乘法指令MUL/IMUL、
除法指令DIV/IDIV、符號擴展指令CBW/CWDE/CDQE、十進制調整指令DAA/DAS/AAA/AAS、邏輯運算指令NOT/AND/OR/XOR/TEST等。
移位指令
這部分指令用於將寄存器或內存操作數移動指定的次數。包括邏輯左移指令SHL、邏輯右移指令SHR、算術左移指令SAL、算術右移指令SAR、循環左移指令ROL、循環右移指令ROR等。
位操作指令
這部分指令包括位測試指令BT、位測試並置位指令BTS、位測試並復位指令BTR、位測試並取反指令BTC、位向前掃描指令BSF、位向後掃描指令BSR等。
條件設置指令
這不是一條具體的指令,而是一個指令簇,包括大約30條指令,用於根據EFLAGS寄存器的某些位狀態來設置一個8位的寄存器或者內存操作數。比如SETE/SETNE/SETGE等等。
控制轉移指令
這部分包括無條件轉移指令JMP、條件轉移指令Jcc/JCXZ、循環指令LOOP/LOOPE/LOOPNE、過程調用指令CALL、子過程返回指令RET、中斷指令INTn、INT3、INTO、IRET等。
注意,Jcc是一個指令簇,包含了很多指令,用於根據EFLAGS寄存器的某些位狀態來決定是否轉移;INT n是軟中斷指令,n可以是0到255之間的數,用於指示中斷向量號。
串操作指令
這部分指令用於對數據串進行操作,包括串傳送指令MOVS、串比較指令CMPS、串掃描指令SCANS、串載入指令LODS、串保存指令STOS,這些指令可以有選擇地使用REP/REPE/REPZ/REPNE和REPNZ的前綴以連續操作。
輸入輸出指令
這部分指令用於同外圍設備交換數據,包括埠輸入指令IN/INS、埠輸出指令OUT/OUTS。
高級語言輔助指令
這部分指令為高級語言的編譯器提供方便,包括創建棧幀的指令ENTER和釋放棧幀的指令LEAVE。
控制和特權指令
這部分包括無操作指令NOP、停機指令HLT、等待指令WAIT/MWAIT、換碼指令ESC、匯流排封鎖指令LOCK、內存范圍檢查指令BOUND、全局描述符表操作指令LGDT/SGDT、中斷描述符表操作指令LIDT/SIDT、局部描述符表操作指令LLDT/SLDT、
描述符段界限值載入指令LSR、描述符訪問權讀取指令LAR、任務寄存器操作指令LTR/STR、請求特權級調整指令ARPL、任務切換標志清零指令CLTS、控制寄存器和調試寄存器數據傳送指令MOV、
高速緩存控制指令INVD/WBINVD/INVLPG、型號相關寄存器讀取和寫入指令RDMSR/WRMSR、處理器信息獲取指令CPUID、時間戳讀取指令RDTSC等。
浮點和多媒體指令
這部分指令用於加速浮點數據的運算,以及用於加速多媒體數據處理的單指令多數據(SIMD及其擴展SSEx)指令。這部分指令數據非常龐大,無法一一列舉,請自行參考INTEL手冊。
虛擬機擴展指令
這部分指令包括INVEPT/INVVPID/VMCALL/VMCLEAR/VMLAUNCH/VMRESUME/VMPTRLD/VMPTRST/VMREAD/VMWRITE/VMXOFF/VMON等。
網路——匯編語言(面向機器的程序設計語言)
『伍』 求匯編裡面幾個命令的英文全稱
掃描指令
1.
順向掃描指令
BSF(Bit
Scan
Forward)
格式:BSF
DST,RSC
功能:從右向左掃描RSC操作數中第一個含1的位,並把掃描到的第一個含1的位號送DST操作數。若RSC=0,則DST值不確定。
說明:DST和RSC可以是16位或32位的,但長度要相同。DST只能是通用寄存器,RSC不能是立即數。
標志:若RSC為0,則置ZF=1;否則清0
ZF,其它標志位不確定。
2.
逆向掃描指令
BSR(Bit
Scan
Reverse)
格式:BSR
DST,RSC
功能:從左向右掃描RSC操作數中第一個含1的位,並把掃描到的第一個含1的位號送DST操作數。
說明:同BSF。
標志:對標志影響同BSF。
位測試指令
位測試(Bit
Test)
BT
DST,SRC
->cf
位測試並置位(Bit
Test
and
Set)
BTS
DST,SRC
->cf
位測試並復位(Bit
Test
and
Rest)BTR
DST,SRC
->cf
為測試並取反(Bit
Test
and
Complement)BTC
DST,SRC
->cf
說明:目標可以是16或32位的寄存器或存儲器操作數,源可以是8位的立即數、寄存器或存儲器操作數,若源操作數是立即數,則其值不應超過目標操作數的長度。若不是立即數,其長度一定要和目標的長度相同。目標操作數的位偏移從最右邊位開始、從0開始計數。
『陸』 匯編指令集…要具體詳細!
1. 通用數據傳送指令.
MOV 傳送字或位元組.
MOVSX 先符號擴展,再傳送.
MOVZX 先零擴展,再傳送.
MOVSX reg16,r/m8 ; o16 0F BE /r [386]
MOVSX reg32,r/m8 ; o32 0F BE /r [386]
MOVSX reg32,r/m16 ; o32 0F BF /r [386]
MOVZX reg16,r/m8 ; o16 0F B6 /r [386]
MOVZX reg32,r/m8 ; o32 0F B6 /r [386]
MOVZX reg32,r/m16 ; o32 0F B7 /r [386]
PUSH 把字壓入堆棧.
POP 把字彈出堆棧.
PUSHA 把AX,CX,DX,BX,SP,BP,SI,DI依次壓入堆棧.
POPA 把DI,SI,BP,SP,BX,DX,CX,AX依次彈出堆棧.
PUSHAD 把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次壓入堆棧.
POPAD 把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次彈出堆棧.
BSWAP 交換32位寄存器里位元組的順序
XCHG 交換字或位元組.( 至少有一個操作數為寄存器,段寄存器不可作為操作數)
CMPXCHG 比較並交換操作數.( 第二個操作數必須為累加器AL/AX/EAX )
XADD 先交換再累加.( 結果在第一個操作數里 )
XLAT 位元組查表轉換.
── BX 指向一張 256 位元組的表的起點, AL 為表的索引值 (0-255,即
0-FFH); 返回 AL 為查表結果. ( [BX+AL]->AL )
2. 輸入輸出埠傳送指令.
IN I/O埠輸入. ( 語法: IN 累加器, {埠號│DX} )
OUT I/O埠輸出. ( 語法: OUT {埠號│DX},累加器 )
輸入輸出埠由立即方式指定時, 其范圍是 0-255; 由寄存器 DX 指定時,
其范圍是 0-65535.
3. 目的地址傳送指令.
LEA 裝入有效地址.
例: LEA DX,string ;把偏移地址存到DX.
LDS 傳送目標指針,把指針內容裝入DS.
例: LDS SI,string ;把段地址:偏移地址存到DS:SI.
LES 傳送目標指針,把指針內容裝入ES.
例: LES DI,string ;把段地址:偏移地址存到ES:DI.
LFS 傳送目標指針,把指針內容裝入FS.
例: LFS DI,string ;把段地址:偏移地址存到FS:DI.
LGS 傳送目標指針,把指針內容裝入GS.
例: LGS DI,string ;把段地址:偏移地址存到GS:DI.
LSS 傳送目標指針,把指針內容裝入SS.
例: LSS DI,string ;把段地址:偏移地址存到SS:DI.
4. 標志傳送指令.
LAHF 標志寄存器傳送,把標志裝入AH.
SAHF 標志寄存器傳送,把AH內容裝入標志寄存器.
PUSHF 標志入棧.
POPF 標志出棧.
PUSHD 32位標志入棧.
POPD 32位標志出棧.
二、算術運算指令
ADD 加法.
ADC 帶進位加法.
INC 加 1.
AAA 加法的ASCII碼調整.
DAA 加法的十進制調整.
SUB 減法.
SBB 帶借位減法.
DEC 減 1.
NEC 求反(以 0 減之).
CMP 比較.(兩操作數作減法,僅修改標志位,不回送結果).
AAS 減法的ASCII碼調整.
DAS 減法的十進制調整.
MUL 無符號乘法.
IMUL 整數乘法.
以上兩條,結果回送AH和AL(位元組運算),或DX和AX(字運算),
AAM 乘法的ASCII碼調整.
DIV 無符號除法.
IDIV 整數除法.
以上兩條,結果回送:
商回送AL,余數回送AH, (位元組運算);
或 商回送AX,余數回送DX, (字運算).
AAD 除法的ASCII碼調整.
CBW 位元組轉換為字. (把AL中位元組的符號擴展到AH中去)
CWD 字轉換為雙字. (把AX中的字的符號擴展到DX中去)
CWDE 字轉換為雙字. (把AX中的字元號擴展到EAX中去)
CDQ 雙字擴展. (把EAX中的字的符號擴展到EDX中去)
三、邏輯運算指令
AND 與運算.
OR 或運算.
XOR 異或運算.
NOT 取反.
TEST 測試.(兩操作數作與運算,僅修改標志位,不回送結果).
SHL 邏輯左移.
SAL 算術左移.(=SHL)
SHR 邏輯右移.
SAR 算術右移.(=SHR)
ROL 循環左移.
ROR 循環右移.
RCL 通過進位的循環左移.
RCR 通過進位的循環右移.
以上八種移位指令,其移位次數可達255次.
移位一次時, 可直接用操作碼. 如 SHL AX,1.
移位>1次時, 則由寄存器CL給出移位次數.
如 MOV CL,04
SHL AX,CL
四、串指令
DS:SI 源串段寄存器 :源串變址.
ES:DI 目標串段寄存器:目標串變址.
CX 重復次數計數器.
AL/AX 掃描值.
D標志 0表示重復操作中SI和DI應自動增量; 1表示應自動減量.
Z標志 用來控制掃描或比較操作的結束.
MOVS 串傳送.
( MOVSB 傳送字元. MOVSW 傳送字. MOVSD 傳送雙字. )
CMPS 串比較.
( CMPSB 比較字元. CMPSW 比較字. )
SCAS 串掃描.
把AL或AX的內容與目標串作比較,比較結果反映在標志位.
LODS 裝入串.
把源串中的元素(字或位元組)逐一裝入AL或AX中.
( LODSB 傳送字元. LODSW 傳送字. LODSD 傳送雙字. )
STOS 保存串.
是LODS的逆過程.
REP 當CX/ECX<>0時重復.
REPE/REPZ 當ZF=1或比較結果相等,且CX/ECX<>0時重復.
REPNE/REPNZ 當ZF=0或比較結果不相等,且CX/ECX<>0時重復.
REPC 當CF=1且CX/ECX<>0時重復.
REPNC 當CF=0且CX/ECX<>0時重復.
五、程序轉移指令
1>無條件轉移指令 (長轉移)
JMP 無條件轉移指令
CALL 過程調用
RET/RETF過程返回.
2>條件轉移指令 (短轉移,-128到+127的距離內)
( 當且僅當(SF XOR OF)=1時,OP1 JA/JNBE 不小於或不等於時轉移.
JAE/JNB 大於或等於轉移.
JB/JNAE 小於轉移.
JBE/JNA 小於或等於轉移.
以上四條,測試無符號整數運算的結果(標志C和Z).
JG/JNLE 大於轉移.
JGE/JNL 大於或等於轉移.
JL/JNGE 小於轉移.
JLE/JNG 小於或等於轉移.
以上四條,測試帶符號整數運算的結果(標志S,O和Z).
JE/JZ 等於轉移.
JNE/JNZ 不等於時轉移.
JC 有進位時轉移.
JNC 無進位時轉移.
JNO 不溢出時轉移.
JNP/JPO 奇偶性為奇數時轉移.
JNS 符號位為 "0" 時轉移.
JO 溢出轉移.
JP/JPE 奇偶性為偶數時轉移.
JS 符號位為 "1" 時轉移.
3>循環控制指令(短轉移)
LOOP CX不為零時循環.
LOOPE/LOOPZ CX不為零且標志Z=1時循環.
LOOPNE/LOOPNZ CX不為零且標志Z=0時循環.
JCXZ CX為零時轉移.
JECXZ ECX為零時轉移.
4>中斷指令
INT 中斷指令
INTO 溢出中斷
IRET 中斷返回
5>處理器控制指令
HLT 處理器暫停, 直到出現中斷或復位信號才繼續.
WAIT 當晶元引線TEST為高電平時使CPU進入等待狀態.
ESC 轉換到外處理器.
LOCK 封鎖匯流排.
NOP 空操作.
STC 置進位標志位.
CLC 清進位標志位.
CMC 進位標志取反.
STD 置方向標志位.
CLD 清方向標志位.
STI 置中斷允許位.
CLI 清中斷允許位.
六、偽指令
DW 定義字(2位元組).
PROC 定義過程.
ENDP 過程結束.
SEGMENT 定義段.
ASSUME 建立段寄存器定址.
ENDS 段結束.
END 程序結束.
七、位操作指令,處理器控制指令
1.位操作指令,8086新增的一組指令,包括位測試,位掃描。BT,BTC,BTR,BTS,BSF,BSR
1.1 BT(Bit Test),位測試指令,指令格式:
BT OPRD1,OPRD2,規則:操作作OPRD1可以是16位或32位的通用寄存器或者存儲單元。操作數OPRD2必須是8位立即數或者是與OPRD1操作數長度相等的通用寄存器。如果用OPRD2除以OPRD1,假設商存放在Divd中,余數存放在Mod中,那麼對OPRD1操作數要進行測試的位號就是Mod,它的主要功能就是把要測試位的值送往CF,看幾個簡單的例子:
1.2 BTC(Bit Test And Complement),測試並取反用法和規則與BT是一樣,但在功能有些不同,它不但將要測試位的值送往CF,並且還將該位取反。
1.3 BTR(Bit Test And Reset),測試並復位,用法和規則與BT是一樣,但在功能有些不同,它不但將要測試位的值送往CF,並且還將該位復位(即清0)。
1.4 BTS(Bit Test And Set),測試並置位,用法和規則與BT是一樣,但在功能有些不同,它不但將要測試位的值送往CF,並且還將該位置位(即置1)。
1.5 BSF(Bit Scan Forward),順向位掃描,指令格式:BSF OPRD1,OPRD2,功能:將從右向左(從最低位到最高位)對OPRD2操作數進行掃描,並將第一個為1的位號送給操作數OPRD1。操作數OPRD1,OPRD2可以是16位或32位通用寄存器或者存儲單元,但OPRD1和OPRD2操作數的長度必須相等。
1.6 BSR(Bit Scan Reverse),逆向位掃描,指令格式:BSR OPRD1,OPRD2,功能:將從左向右(從最高位到最低位)對OPRD2操作數進行掃描,並將第一個為1的位號送給操作數OPRD1。操作數OPRD1,OPRD2可以是16位或32位通用寄存器或存儲單元,但OPRD1和OPRD2操作數的長度必須相等。
1.7 舉個簡單的例子來說明這6條指令:
AA DW 1234H,5678H
BB DW 9999H,7777H
MOV EAX,12345678H
MOV BX,9999H
BT EAX,8;CF=0,EAX保持不變
BTC EAX,8;CF=0,EAX=12345778H
BTR EAX,8;CF=0,EAX=12345678H
BTS EAX,8;CF=0,EAX=12345778H
BSF AX,BX;AX=0
BSR AX,BX;AX=15
BT WORD PTR [AA],4;CF=1,[AA]的內容不變
BTC WORD PTR [AA],4;CF=1,[AA]=1223H
BTR WORD PTR [AA],4;CF=1,[AA]=1223H
BTS WORD PTR [AA],4;CF=1,[AA]=1234H
BSF WORD PTR [AA],BX;[AA]=0;
BSR WORD PTR [AA],BX;[AA]=15(十進制)
BT DWORD PTR [BB],12;CF=1,[BB]的內容保持不變
BTC DWORD PTR [BB],12;CF=1,[BB]=76779999H
BTR DWORD PTR [BB],12;CF=1,[BB]=76779999H
BTS DWORD PTR [BB],12;CF=1,[BB]=77779999H
BSF DWORD PTR [BB],12;[BB]=0
BSR DWORD PTR [BB],12;[BB]=31(十進制)
2.處理器控制指令
處理器控制指令主要是用來設置/清除標志,空操作以及與外部事件同步等。
2.1 CLC,將CF標志位清0。
2.2 STC,將CF標志位置1。
2.3 CLI,關中斷。
2.4 STI,開中斷。
2.5 CLD,清DF=0。
2.6 STD,置DF=1。
2.7 NOP,空操作,填補程序中的空白區,空操作本身不執行任何操作,主要是為了保持程序的連續性。
2.8 WAIT,等待BUSY引腳為高。
2.9 LOCK,封鎖前綴可以鎖定其後指令的操作數的存儲單元,該指令在指令執行期間一直有效。在多任務環境中,可以用它來保證獨占其享內存,只有以下指令才可以用LOCK前綴:
『柒』 匯編語言 bt語句
BT 指令
格式: BT OPD,OPS
----
功能: 目的操作數OPD中由源操作數OPS指定的位送CF標志
說明: 1. 在指令中,目的操作數OPD只能是16/32位通用寄存器或存儲單元,用於指定要測試的數據;源操作數OPS必須是8位立即數或者是與目的操作數等長的16/32位通用寄存器,用於指定要測試的位. 如果目的操作數是寄存器,則源操作數 除以 16/32的余數就是要測試的位,它在0-15/31之間.
2. 舉例: MOV EAX 12345678H ;EAX=12345678H
BT EAX,5 ;EAX的D5位=1-->CF,EAX=12345678H
注意: 如果目的操作數是存儲單元, 則該單元的最低位為0.從這個最低位向地 址高端每位依次增量,向地址代低端每位依次減量,這部分存儲器數據作 為一個2G-1~-2G長的位串.此時,有符號源操作數就指示要測試的位.
『捌』 匯編程序中BTRSC什麼意思
格式:BT DEST,SRC
BTC DEST,SRC
BTR DEST,SRC
BTS DEST,SRC
功能:按照源操作指定的位號,測試目的操作數,當指令執行時,被測試位的狀態被復制到進位標志CF。
BT將SRC指定的DEST中一位的數值復制到CF。BTC將SRC指定的DEST中一位的數值復制到CF,且將DEST中該位取反。BTR將SRC 指定的DEST中一位的數值復制到CF,且將DEST中該位復位。BTS將SRC指定的DEST中一位的數值復制到CF,且將DEST中該位置位。
目的操作數為16位或32位通用寄存器或存儲器,源操作數為16位或32位通用寄存器,以及8位立即數,當源操作數為通用寄存器時,必須同目的操作數類型一致。源操作數SRC以兩種方式給出目的操作數的位號,即
· SRC為8位立即數,以二進制形式直接給出要操作的位號;
· SRC為通用寄存器,如果DEST為通用寄存器,則SRC中二進制值直接給出要操作的位號。如果DEST為存儲器操作數,通用寄存器SRC為帶符號整數, SRC的值除以DEST的長度所得到的商作為DEST的相對偏移量,余數直接作為要操作的位號。DEST的有效地址為DEST給出的偏移地址和DEST相 對偏移量之和。
BT,BTC,BTR,BTS指令影響CF標志位,其它標志位無定義。
『玖』 匯編語言中,LOCK指令是否可放在任何指令前面
不可以,LOCK指令前綴只能用於以下這些指令:
ADD, ADC, AND, BTC, BTR, BTS, CMPXCHG, CMPXCH8B, DEC, INC, NEG, NOT, OR, SBB, SUB, XOR, XADD, XCHG
LOCK指令只有在目標操作數為內存地址時LOCK指令才會將該指令變為原子指令;如果目標操作數不為內存則會產生UD(Undefined Opcode,未定義的指令)錯誤。
另外值得注意的是,部分編譯器會將LOCK指令合法的編譯在非前面提到的指令前(例如:LOCK MOV [DATA],EAX),但是在運行程序時會同樣產生UD錯誤。
題外話:XCHG的其中一個操作數為內存時會自動插入LOCK指令,使其所需要的周期變得很長。
『拾』 X86指令集的內容有哪些
CPU擴展指令集CPU依靠指令來計算和控制系統,每款CPU在設計時就規定了一系列與其硬體電路相配合的指令系統。指令的強弱也是CPU的重要指標,指令集是提高微處理器效率的最有效工具之一。從現階段的主流體系結構講,指令集可分為復雜指令集和精簡指令集兩部分,而從具體運用看,如Intel的MMX(Multi Media Extended)、SSE、 SSE2(Streaming-Single instruction multiple data-Extensions 2)、SEE3和AMD的3DNow!等都是CPU的擴展指令集,分別增強了CPU的多媒體、圖形圖象和Internet等的處理能力。我們通常會把CPU的擴展指令集稱為CPU的指令集。SSE3指令集也是目前規模最小的指令集,此前MMX包含有57條命令,SSE包含有50條命令,SSE2包含有144條命令,SSE3包含有13條命令。目前SSE3也是最先進的指令集,英特爾Prescott處理器已經支持SSE3指令集,AMD會在未來雙核心處理器當中加入對SSE3指令集的支持,全美達的處理器也將支持這一指令集。
指令集:
(1) X86指令集要知道什麼是指令集還要從當今的X86架構的CPU說起。X86指令集是Intel為其第一塊16位CPU(i8086)專門開發的,IBM1981年推出的世界第一台PC機中的CPU—i8088(i8086簡化版)使用的也是X86指令,同時電腦中為提高浮點數據處理能力而增加的X87晶元系列數學協處理器則另外使用X87指令,以後就將X86指令集和X87指令集統稱為X86指令集。雖然隨著CPU技術的不斷發展,Intel陸續研製出更新型的i80386、i80486直到今天,但為了保證電腦能繼續運行以往開發的各類應用程序以保護和繼承豐富的軟體資源,所以Intel公司所生產的所有CPU仍然繼續使用X86指令集,所以它的CPU仍屬於X86系列。由於Intel X86系列及其兼容CPU都使用X86指令集,所以就形成了今天龐大的X86系列及兼容CPU陣容。
(2) RISC指令集RISC指令集是以後高性能CPU的發展方向。它與傳統的CISC(復雜指令集)相對。相比而言,RISC的指令格式統一,種類比較少,定址方式也比復雜指令集少。當然處理速度就提高很多了。而且RISC指令集還兼容原來的X86指令集。