读书人

请教个nasm中的有关问题

发布时间: 2014-01-17 15:01:00 作者: rapoo

请问个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

读书人网 >汇编语言

热点推荐