2

私は教育用のブートローダーを書いていますが、うまくいきます。しかし、実際のマシンで起動しようとすると、ディスク読み取りコードがいくつかのセクターのロードに失敗します。エラーコードは表示されず、CF も設定されません。また、1 in al を返します。これは、1 セクターが読み取られたことを意味します (これは正しいはずです)。しかし、ロードされたセクターにジャンプしようとすると、ハングして何もしません..最初の段階では A が出力され、2 番目の段階では F で上書きされます。実際のハードウェアで起動すると、A のみが表示されます。したがって、セクターはメモリ内にあるべき場所にありません..

これは私の MBR です:

LOADOFF equ 0x7C00
BUFFER equ 0x600

[bits 16]
[org 0x7c00]

jmp _start
nop 
    bootdisk db 0

_start: ; entry point
    jmp 0x0:.flush
.flush:
    xor ax, ax
    mov ds, ax
    mov es, ax
    cli
    mov ss, ax
    mov sp, LOADOFF     ; stack setup
    sti

    mov [bootdisk], dl ; boot drive number given by the bios in dl

    mov si, migrate ; move the code below to the buffer
    mov di, BUFFER
    mov cx, 256
    cld
    rep
    movsw

    jmp 0x0:BUFFER ;get my ass in the buffer
migrate:

.reset:
    xor ax, ax      ; reset the disk
    mov dl, [bootdisk]
    int 0x13
    jc .reset

.read:
    mov ah, 0x2
    mov al, 1 ; read 1 sector
    xor cx, cx ; cylinder 0
    mov cl, 2 ; sector 2
    mov dl, [bootdisk]
    xor dh, dh ; head 0


    ; setup buffer
    xor bx, bx
    mov es, bx
    mov bx, 0x7c00 ; chain load it
    int 0x13
    jc .read

    test ah, ah
    jnz .reset

    cmp al, 0x1 ; is there one and only one sector loaded?
    jne .reset

    mov ax, 0xb800
    mov es, ax
    xor di, di
    mov al, 65 ; capital A
    mov ah, 0xc 
    stosw

;   mov ax, 0x7c0
;   mov es, ax
;   xor di, di
;   
;   mov [es:di], byte 191          ; this code proves that my far jump does its work
;   mov [es:di+1], byte 160       ; if you would like to test, comment it out.
;   mov [es:di+2], byte 128
;   mov [es:di+3], byte 184
;   mov [es:di+4], byte 0
;   mov [es:di+5], byte 176
;   mov [es:di+6], byte  142
;   mov [es:di+7], byte 192
;   mov [es:di+8], byte 184
;   mov [es:di+9], byte 88
;   mov [es:di+10], byte 14
;   mov [es:di+11], byte 171

    jmp 0x0:0x7c00      ; execute the loaded sector

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

ORG 0x7C00
[BITS 16]

ステージ 2:

    stage2:
    mov ax, 0xb800
    mov es, ax
    xor di, di
    mov al, 70
    mov ah, 0xc
    stosw
    jmp $

times 512 - ($ - $$) db 0

kvm では完全に動作しますが、実際の BIOS を備えた実際のハードウェアでは動作しません。USB フラッシュ ドライブを使用して、実際のハードウェアでの起動をテストします。

問題は、mbr の最初のバイトで定義していない BPB でしょうか? 生のセクターを読んだだけなので、そうは思いません..間違っている場合は修正してください。

誰でもそれが何であるかの手がかりはありますか?

ありがとう

4

1 に答える 1

2

コードは、「最初のフロッピー ドライブ」であるディスク 0 からロードしようとします。最近の HDD (および USB フラッシュ ディスク) は通常、ディスクとしてアクセスされます0x80。だから試してみてください

bootdisk db 0x80

あなたのコードで。

于 2011-05-20T15:30:59.313 に答える