0

我只是接近机器级 x86 编码,所以请原谅我的问题的琐碎性。以下代码旨在成为一个简单的引导加载程序。它将软盘的某些扇区转储到内存中,然后跳转到加载的代码。在加载的代码中,我试图从内存变量中读取,但没有成功,如评论中所述。

    [ORG 0]

            jmp 07C0h:start     ; Goto segment 07C0

    start:
            ; Update the segment registers
            mov ax, cs
            mov ds, ax
            mov es, ax


    reset:                      ; Reset the floppy drive
            mov ax, 0          
            mov dl, 0          
            int 13h            
            jc reset         


    read:
            mov ax, 1000h       ; ES:BX = 1000:0000
            mov es, ax          
            mov bx, 0           

            mov ah, 2           ; Load disk data to ES:BX
            mov al, 5           ; Load 5 sectors
            mov ch, 0           ; Cylinder=0
            mov cl, 2           ; Sector=2
            mov dh, 0           ; Head=0
            mov dl, 0           ; Drive=0
            int 13h             ; Read!

            jc read             ; on error


            jmp 1000h:0000      ; Jump to the program


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

       ;     ==  Loaded code from second floppy sector  ==
prog:
        mov     ah,     0x0E       ; Prints a char. This one works: the '-'
        mov     al,     '-'        ;   is printed.
        mov     bx,     0
        int     10h

        mov     bx,     0 
a:                                 
        mov     al,     [L1+bx]    ; Should read from L1 and print out chars.
        inc     bx                 ;   But it prints only white spaces. Why?
        int     10h
        cmp     bx,     10
        jz      h
        jmp a

        cli
        hlt

        L1 db "0123456789"        ; my string

我不明白为什么它不起作用。我非常感谢任何帮助。

4

2 回答 2

2

如果上面是单个汇编文件,则jmp 1000h:0000改为jmp 0FE0h:200h,这将适当补偿ip从一路累积的寄存器偏移量,[ORG 0]并且仍然将控制权转移到物理地址0x10000

除此之外,在代码的第二部分设置dscs(或)。0FE0h

于 2013-03-29T17:30:50.510 回答
2

“从软盘加载”部分编译的基本偏移量与其加载的偏移量不同,您需要重新计算其地址

您也可以使用ORG 7C00h并节省自己的跳跃,不同之处在于您的段将是 0 而不是 07C0h

您可以将新的偏移量计算为 [L1-prog],也可以重新排序代码:

            jmp 1000h:000Ah      ; Jump to the program
....
L1          db "0123456789"        ; my string
prog:
        mov     ah,     0x0E   

...
        mov     al,     cs:[bx]

我没有要测试的汇编程序,但你明白了 - 不需要浮动地址,把它放在开头

我粗略估计您在 1000H 段中的实际偏移量约为 32-ish,这就是您翻译的 L1 大致所在的位置。相反,您的 L1 被计算为大约 550 的编译时间,因此您实际上是在尝试从您读取的第二个扇区加载一些东西。第二个加载扇区的开头是否有一些空白字符或零?

于 2013-03-29T17:31:49.580 回答