昨天,把8088单板机的rom boot进行了一次升级改写,实现了rom boot可以加载Dos下com类程序的加载。当时匆忙的把这个实现了,今天想把实现的构想再总结一下。
这款8088单板机板上有一片64k的rom,32k的ram,64K的rom设计在内存的高端地址,ram设计在内存的地址,boot没烧录到rom中,通过串口可以加载程序到RAM中,并进行执行。原设计把程序加载到0000:2000H起始的地址了(也就是使用了RAM的8K-32K这段地址,0-7K这段闲置未用),原来需要加载的程序,没编译成了二进制块文件,段内偏移地址为2000H。
//led 闪烁程序
//nasm 编译 生成 bin文件
;-------------------------------------------------------------------------------------
led_port equ 800h
;-------------------------------------------------------------------------------------
org 2000h ;程序将由监控bios下载到内存RAM的地址(0000:2000)
start:
;------------------------------------------------------
;init part
;------------------------------------------------------
;mov ax,0
mov ax,1f0h
mov ds,ax
mov ss,ax
mov sp,3fffh
st001:
nop
;-----------------------------------------------------
;点亮系统板上的LED
;-----------------------------------------------------
;MOV DX,800H ;800H是板子上8个LED的端口地址号
mov dx,led_port
MOV AL,0aaH ;一亮一灭间隔点亮
OUT DX,AL
call DELAY
;MOV DX,800H ;800H是板子上8个LED的端口地址号
mov dx,led_port
MOV AL,00H ;一亮一灭间隔点亮
OUT DX,AL
call DELAY
;mov al,01010101b
;mov al,0f0h;
;out 25H,al
;hlt
jmp st001
jmp start
;------------------------------------------------------------
; DELAY PROC NEAR
;------------------------------------------------------------
;push
DELAY:
PUSH CX
PUSH BX
NOP
NOP
mov bx,10
del1:
mov cx,5882
del2:
loop del2
dec bx
jnz del1
;pop cx
;pop bx
POP BX
POP CX
RET
db 55h,55h,55h,55h,55h,55h ;程序结束标志,监控bios程序,收到后自动跳转到内存0000:2000处执行
后来,想把这个二进制块文件,改成DOS系统下的COM文件 ,这样在理论上就是说,这个单板机可以加载DOS格式下的通用com文件了,并且可以用emu8086来生成测试程序,并可以在emu8086上进行模拟仿真。
要想解决这个问题,就要解决Boot加载程序后的跳转问题,原来boot跳转地址是0000:2000H,那么要想对boot作出最小的修改,即物理加载地址不变,逻辑地址上实现
0000:2000H=?:0100H ;
那么这个?段地址求出来就行了,答案是01F0H。
那么理解了这个修改原理,生下来的就好办了。
这就是一个纯个人爱好的项目,闲的时候做一做,看到自己的构想得以实现和验证,感觉总是很开心。还是那句话,Just for fun!