请问个nasm中的问题
我想用nasm来改写linux 0.11中的bootsect.s,我只写了一点就出问题了,请看:
;引导程序bootsect.asm
[BITS 16]
[ORG 0x07C00]
jmp start
BOOTSEG EQU 0x07c0
INITSEG EQU 0x9000
start:
;把启动时的引导程序从0x07c0:0复制到0x9000:0,共512个字节
mov ax,BOOTSEG
mov ds,ax
mov ax,INITSEG
mov es,ax
mov cx,20
sub si,si
sub di,di
rep
movsw
nop
nop
jmp INITSEG:go ;跳转到0x9000:go的位置
go: mov ax,cs
mov ds,ax
mov es,ax
mov ss,ax
mov sp,0xFF00
nop
nop
call DispStr
jmp $
DispStr:
mov ax,BootMessage
mov bp,ax
mov cx,16
mov ax,01301h
mov bx,000ch
mov dl,0
int 10h
ret
BootMessage:db"Hello, OS world!"
times 510-($-$$) db 0
dw 0xaa55
我是在linux下用bochs来模拟的,我编译nasm bootsect.asm -o bootsect.bin,然后用bochs来启动,
我调式时,发现jmp INITSEG:go 就出问题了,好像偏移地址不对了,并且mov ax,BootMessage的
偏移地址也不对,它们都不是从0开始计算的,请问有什么办法解决呢?
[解决办法]
1. BOOTSEG EQU 0x07c0 改0x7c00
2. jmp INITSEG:go 改 jmp INITSEG
3. go的地址相对于0x7c00偏移的 即0x7c00+偏移量 。
4. org是伪指令,程序编译好后地址已经是0x7c00了,不即使复制到0x9000都不能正常运行
[解决办法]
mov cx,20 -> mov cx,0x0100