我正在尝试使用NASM Assembler自己编写一个bootloader。我正在尝试打印两行文本,等待按键,如果按下的键是'r'则重新启动,如果按下的键是'b'则继续启动。但是,这不是我的问题的主题(我将在稍后实现这些函数,因此目前代码中的nop
指令)。相反,我想问一下为什么我的换行符0xA
以这种奇怪的方式打印?我已经在我的TODO中完成了所有三个项目,但我认为这很重要,因为加载器一定不会看起来很糟糕。
这是我的代码:
BITS 16 ; tell nasm we're working in 16 bit real mode
start: ; entry symbol for the os
mov ax, 0x07C0 ; 4 kilobyte stack space set up
add ax, 288 ; (4096+512) / 16 bytes per paragraph
mov ss, ax
mov sp, 4096
mov ax, 0x07C0 ; set data segment to where we've loaded
mov ds, ax
mov si, text_string ; put our string position into SI
call write_string ; call our string-printing function
mov si, text_string_tutorial
cli ; jump here for an infinite loop
hlt
text_string db 'Mao Mao Loader 0.01 written by Safal Aryal', 0xA
text_string_tutorial db 'Press r to reboot or b to continue booting', 0x9
write_string: ; output string located in si
mov ah, 0xE ; the 'print char' function of int 0x10
.repeat:
lodsb ; get character from the string
cmp al, 0 ; check if it is zero
je .done ; if it is, jump to .done and finish the function
int 10h ; call interrupt 10h
jmp .repeat ; repeat for every char in the string
.done:
ret
read_input:
mov ah, 0x00
int 16h
cmp al, 'r'
nop
cmp al, 'b'
nop
times 510-($-$$) db 0 ; pad boot sector with zeroes
dw 0xAA55 ; standard bootsig
;TODO: read key pressed, change background colour and start writing kernel
答案 0 :(得分:5)
在我看来,换行符(0xa
)完全正如我所期望的那样 - 打印换行符。但是,您还没有打印回车符(0xd
),因此您的下一句话将从屏幕中间开始。添加回车符,您应该得到您正在寻找的结果。
答案 1 :(得分:2)
指令cmp al,0检查工作字符是否为0.在这种情况下 - 结束例行程序。你的字符串必须以0结尾。如例:
... Aryal', 0x0D, 0xA, 0
...booting', 0x0D, 0xA, 0