gpt4 book ai didi

assembly - 在 QEmu 中使用简单引导扇区从磁盘读取不正确的字节

转载 作者:行者123 更新时间:2023-12-01 13:32:56 25 4
gpt4 key购买 nike

所以我正在尝试学习如何制作一个小操作系统,主要使用 this教程的东西。

我在那个教程的第 28 页,试图做这个小磁盘加载器。

但是,当我运行 qemu-system-i386 boot_sector.bin 时,适用于之前的引导扇区示例,我得到的十六进制输出是 0xDADA 0xZRWV ,第一个正确,第二个不正确。

我的代码如下。

引导扇区.asm

; Very simple boot sector to read sectors from disk

jmp main ; ensures that we start where we want to

%include "disk_load.asm"

BOOT_DRIVE:
db 0

[org 0x7c00] ; tell the assembler where this code will be loaded

main:
mov bp, 0x8000 ; Make sure the stack is out of our way
mov sp, bp

mov bx, 0x9000
mov dh, 2 ; Want to read 2 sectors
call disk_load

mov dx, [0x9000]
call hex_print ; Should output 0xDADA

mov dx, [0x9000 + 512]; Should output 0xFACE
call hex_print

hang:
jmp hang ; Continually jump to current location

; Add padding and magic BIOS number (to let BIOS know this is a boot sector)

times 510-($-$$) db 0 ; pad with zeroes
dw 0xaa55 ; magic number

times 256 dw 0xdada ; second sector
times 256 dw 0xface ; third sector

disk_load.asm:
%include "bios_print.asm"

ERROR_MSG:
db "Disk read error!", 0

SECTOR_ERROR_MSG:
db "Wrong number of sectors read!", 0

disk_load:
push dx ; Store the number of sectors we wanted to read
mov ah, 0x02 ; BIOS read sector function
mov al, dh ; Number of sectors to be read

mov ch, 0x00 ; Cylinder 0
mov dh, 0x00 ; Head 0
mov cl, 0x02 ; Sector 2 (just after the boot sector)

int 0x13

jc disk_error ; if carry flag is set, report an error

pop dx
cmp dh, al
jne sector_error ; if we didn't read as many sectors as we wanted.
ret

disk_error:
mov bx, ERROR_MSG
call bios_print
jmp $

sector_error:
mov bx, SECTOR_ERROR_MSG
call bios_print
jmp $

然后 bios_print.asm 只有打印十六进制等的功能:
bios_print:
pusha
mov si, bx

loop:
lodsb
or al, al
jz done
mov ah, 0x0e
int 0x10
jmp loop

done:
popa
ret

HEX_OUT:
db '0x0000', 0

hex_print:
pusha
mov cx, 4 ; Counter

char_loop:
dec cx
mov ax, dx
shr dx, 4
and ax, 0xf ; Mask to get the last part of ax
mov bx, HEX_OUT
add bx, 2 ; Skip the '0x' in HEX_OUT
add bx, cx

; If the character is a number, we just plop that out, but if it
; is a letter, we have to convert it to ASCII by adding 7 (because
; ASCII starts at 17, and the numbers end at 10)
cmp ax, 0xa
jl set_char
add byte [bx], 7
jl set_char

set_char:
add byte [bx], al ; Add the value of the byte to the char stored at bx
cmp cx, 0
je finished
jmp char_loop

finished:
mov bx, HEX_OUT
call bios_print

popa
ret

我也尝试过使用 -fda 标志运行 QEmu,这是在一些地方建议的,但没有运气。此外,如果我将要读取的扇区数更改为 5(如教程中所示),则会出现驱动器读取错误(由 disk_load 函数引发)。

这让我非常恼火。在此先感谢您的帮助。

最佳答案

-_- 我刚刚弄清楚问题是什么。

调用后hex_print ,我没有重置HEX_STRING .

我通过简单地复制 HEX_STRING 的位置来解决这个问题回退到BX,然后遍历BX,间接设置HEX_STRING的每个字节到 ASCII 0。

这已经解决了这个问题。

关于assembly - 在 QEmu 中使用简单引导扇区从磁盘读取不正确的字节,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44850097/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com