循環指令

循環也是改變指令執行順序的一種方式,循環操作重複的執行,直到滿足條件。我們可以使用條件跳轉指令來創建循環,但事實上彙編語言中有更簡單的循環指令系列。

循環指令使用ECX寄存器作為計數器,隨著循環指令的執行自動遞減它的值,並且不會影響EFLAGS寄存器的標誌位,當ecx寄存器值到達0時,0標誌不會被設置。循環指令有如下:loop(循環直到ecx寄存器為0)、loope/loopz(循環直到ecx寄存器為0或沒有設置ZF標誌)、loopne/loopnz(循環直到ecx寄存器為0或設置了ZF標誌)。

loope/loopz和loopne/loopnz指令提供了監視0標誌的附加功能。指令的使用格式為:

loop addr

addr是要跳轉到的程序代碼位置的標籤名稱。在循環開始之前,必須在ecx寄存器中設置執行迭代的次數值。如下:

#loop.s
.section .text
.globl _start
_start:
    movl $10, %ecx
    movl $0, %eax
here_loop:
    addl %ecx, %eax
    loop here_loop

    movl %eax, %ebx
    movl $1, %eax
    int $0x80</span>

程序簡單循環計算0到10的累加和,然會程序返回累加值。make,運行結果如下:

$ make
as -o loop.o loop.s --gstabs
ld -o loop loop.o
$ ./loop
$ echo $?
55
$