BITS伪指令的作用

(以下ax和eax可同理换成bx,ebx等)

mov ax, mem和mov eax mem的机器码是一样的,处理器为了区分这两条指令,要求在指令前面加前缀加以区分

即,如果程序是32位的话,则mov ax, mem对应的机器码要加前缀,mov eax, mem对应的机器码不用加前缀

反之,如果程序是16位的话,则mov ax, mem对应的机器码不用加前缀, mov eax, mem对应的机器码要加前缀

 

另一方面,16位的程序的段长是64K,32位则是4G,这一点可通过jmp指令来演示

 

我们要告诉汇编器我们的程序要被当作16位的程序还是32位的程序来运行,好让它汇编出正确的机器码,BITS伪指令的作用就在于此

看一个简单的程序

;[bits 16] [bits 32] mov ax, 1 mov eax, 1 jmp $

注释掉第一行,启用第二行(32位),得到的文件是

abcd@ubuntu:~$ nasm -f bin 16-31bits.asm -o 32.asm abcd@ubuntu:~$ hexdump -C 32.asm 00000000 66 b8 01 00 b8 01 00 00 00 e9 fb ff ff ff |f.............| 0000000e 

 

注释掉第二行,启用第一行(16位),得到的文件是

abcd@ubuntu:~$ nasm -f bin 16-31bits.asm -o 16.asm abcd@ubuntu:~$ hexdump -C 16.asm 00000000 b8 01 00 66 b8 01 00 00 00 e9 fd ff |...f........| 0000000c

 

从机器码里可明显看出不同

你可能感兴趣的:(汇编,Linux)