程序集INT 0x13:尝试从磁盘读取时未收到错误

时间:2015-07-25 05:25:48

标签: assembly qemu osdev

每当我在QEMU中运行时,我似乎没有出现错误,但屏幕上没有打印消息,所以我不确定我看不到的是什么。这是我的代码:

[org 0x7c00]
mov bp, 0x8000
mov sp, bp

mov si, name
call print_string
mov si, version
call print_string
call rd_dsk
mov si, testmsg
call print_string
jmp $

;Print
print_char:
  mov ah, 0x0e
  int 0x10
  ret
print_string:
  screen:
    lodsb
    cmp al, 0
    je screen_end
    mov ah, 0x0e
    int 0x10
    jmp screen
  screen_end:
  ret
print_hex:
  mov si, hex_temp
  mov bx, dx
  shr bx, 12
  mov bx, [bx+hex_alph]
  mov [hex_temp+2], bl
  mov bx, dx
  shr bx, 8
  and bx, 0x000f
  mov bx, [bx+hex_alph]
  mov [hex_temp+3], bl
  mov bx, dx
  shr bx, 4
  and bx, 0x000f
  mov bx, [bx+hex_alph]
  mov [hex_temp+4], bl
  mov bx, dx
  and bx, 0x000f
  mov bx, [bx+hex_alph]
  mov [hex_temp+5], bl
  call print_string
  ret

;Read
rd_dsk:
  mov ah, 0x02
  mov al, 0x01
  mov ch, 0x00
  mov dh, 0x00
  mov cl, 0x02
  mov bx, 0x00
  mov es, bx
  mov bx, 0x7c00 + 512
  int 0x13
  jc rd_dsk_error
   ret

; Error
rd_dsk_error:
  mov si, rd_dsk_error_msg
  call print_string
  jmp $

;Misc Data
name:
  db 'PurityOS ',0
version:
  db 'v0.0.1.2 ',0
hex_temp:
  db '0x????',0
hex_alph:
  db '0123456789ABCDEF'

; Error Messages
rd_dsk_error_msg:
  db 'Error reading the disk.',0

times 510-($-$$) db 0
dw 0xaa55

;Data beyond BootSector
testmsg:
  db 'Reading Second Sector',0

我希望得到这个输出:

PurityOS v0.0.1.2 Reading Second Sector

然而,我只能得到这个:

PurityOS v0.0.1.2

另外,如果我将“call rd_dsk”放在顶部:

[org 0x7c00]
mov bp, 0x8000
mov sp, bp

call rd_dsk
mov si, name
call print_string
mov si, version
call print_string
mov si, testmsg
call print_string
jmp $

我没有得到任何输出,我只得到闪烁的光标,好像我只有“jmp $”

我使用NASM组装.asm文件,然后用QEMU运行它。 “qemu -fda ...”不起作用。我得到“程序'qemu'可以在以下软件包中找到”,安装后没有任何软件包帮助。我只需运行“qemu-system-x86_64 ./Asm/bootsector.bin”即可打开QEMU。

提前谢谢。

1 个答案:

答案 0 :(得分:0)

您的堆栈指针最初位于0x0000:0x8000。

当你进行"电话"或" int"指令返回地址被压入堆栈(位于内存范围0x7F00-0x8000)。

当您覆盖此内存时,系统将崩溃。

解决方案:

在此行中将0x8000更改为0x7BFC:

mov bp, 0x8000
mov sp, bp