通过使用这两行代码:
cli ; stop all interrupts
hlt ; halt the cpu
您可以停止 x86 电脑的可启动程序:
BITS 16
start:
mov ax, 07C0h ; Set up 4K stack space after this bootloader
add ax, 288 ; (4096 + 512) / 16 bytes per paragraph
mov ss, ax
mov sp, 4096
mov ax, 07C0h ; Set data segment to where we're loaded
mov ds, ax
cld ; clear direction flag
mov si, text_string ; Put string position into SI
call print_string ; Call our string-printing routine
cli ; stop all interrupts
hlt ; halt the cpu
jmp $ ; Jump here - infinite loop!
text_string db 'Hello World!', 0
print_string: ; Routine: output string in SI to screen
mov ah, 0Eh ; int 10h 'print char' function
.repeat:
lodsb ; Get character from string
cmp al, 0
je .done ; If char is zero, end of string
int 10h ; Otherwise, print it
jmp .repeat
.done:
ret
times 510-($-$$) db 0 ; Pad remainder of boot sector with 0s
dw 0xAA55 ; The standard PC boot signature
将其保存为“prog.asm”,然后使用“nasm”创建引导扇区:
nasm -f bin -o boot.img prog.asm
现在你可以使用“qemu”来测试它了:
qemu-system-i386 -drive file=boot.img,index=0,media=disk,format=raw -boot c -net none
注意:删除上面提到的这两行会导致您的虚拟机使用最大的可用 CPU 周期。
编辑:添加了“cld”指令。正如 Michael 所提到的,有必要确保 text_string 从左到右加载。