Compare commits
2 commits
1cbd918b56
...
master
Author | SHA1 | Date | |
---|---|---|---|
|
e161d14321 | ||
|
48436ef9bd |
3 changed files with 19 additions and 18 deletions
2
Makefile
2
Makefile
|
@ -2,7 +2,7 @@ DOSBOX=dosbox -conf dosbox-build.conf -exit
|
||||||
|
|
||||||
ordos.img: BOOT.BIN IO.SYS ORDOS.SYS COMMAND.COM debug.com edlin.com exe2bin.exe link.exe masm.exe
|
ordos.img: BOOT.BIN IO.SYS ORDOS.SYS COMMAND.COM debug.com edlin.com exe2bin.exe link.exe masm.exe
|
||||||
rm -f ordos.img
|
rm -f ordos.img
|
||||||
mkfs.fat -C $@ 720
|
mkfs.fat -C $@ -M 0xff 320
|
||||||
rw -I 0x7c00 -i BOOT.BIN -o $@ -c 512
|
rw -I 0x7c00 -i BOOT.BIN -o $@ -c 512
|
||||||
mcopy -i $@ IO.SYS ::
|
mcopy -i $@ IO.SYS ::
|
||||||
mcopy -i $@ ORDOS.SYS ::
|
mcopy -i $@ ORDOS.SYS ::
|
||||||
|
|
12
boot.asm
12
boot.asm
|
@ -17,12 +17,12 @@ jmp code
|
||||||
dw 512 ; Bytes per sector
|
dw 512 ; Bytes per sector
|
||||||
db 2 ; Sectors per cluster
|
db 2 ; Sectors per cluster
|
||||||
dw 1 ; Reserved sectors
|
dw 1 ; Reserved sectors
|
||||||
fats db 2 ; FATs
|
db 2 ; FATs
|
||||||
dw 112 ; Root directory entries
|
dw 112 ; Root directory entries
|
||||||
dw 2*720 ; Total sectors
|
dw 2*320 ; Total sectors
|
||||||
db 0f9h ; Media descriptor
|
db 0ffh ; Media descriptor
|
||||||
sectorsperfat dw 3 ; Sectors per fat
|
dw 1 ; Sectors per fat
|
||||||
sectorspertrack dw 9
|
sectorspertrack dw 8
|
||||||
heads dw 2
|
heads dw 2
|
||||||
dd 0 ; Hidden sectors
|
dd 0 ; Hidden sectors
|
||||||
dd 0 ; Total sectors (large)
|
dd 0 ; Total sectors (large)
|
||||||
|
@ -40,7 +40,7 @@ code:
|
||||||
mov drivenumber, dl
|
mov drivenumber, dl
|
||||||
|
|
||||||
; TODO: Check we actually have the OS
|
; TODO: Check we actually have the OS
|
||||||
mov ax, 14
|
mov ax, 10
|
||||||
mov bx, 600h
|
mov bx, 600h
|
||||||
mov cx, 17 ; This is what PC-DOS 1.10's full size ends up at
|
mov cx, 17 ; This is what PC-DOS 1.10's full size ends up at
|
||||||
call loadsectors
|
call loadsectors
|
||||||
|
|
23
io.asm
23
io.asm
|
@ -276,6 +276,16 @@ endif
|
||||||
|
|
||||||
dec di
|
dec di
|
||||||
jz sector_read_fail
|
jz sector_read_fail
|
||||||
|
|
||||||
|
reset_disk:
|
||||||
|
if debug
|
||||||
|
mov al, '"'
|
||||||
|
mov ah, 0eh
|
||||||
|
int 10h
|
||||||
|
endif
|
||||||
|
xor ax, ax
|
||||||
|
int 13h
|
||||||
|
|
||||||
pop cx
|
pop cx
|
||||||
pop ax
|
pop ax
|
||||||
jmp try_sector_read
|
jmp try_sector_read
|
||||||
|
@ -558,15 +568,14 @@ code ends
|
||||||
|
|
||||||
constants segment
|
constants segment
|
||||||
|
|
||||||
sectorspertrack dw 9 ; TODO: Don't hardcode
|
sectorspertrack dw 8 ; TODO: Don't hardcode
|
||||||
heads dw 2 ; TODO: Don't hardcode
|
heads dw 2 ; TODO: Don't hardcode
|
||||||
|
|
||||||
disks_table:
|
disks_table:
|
||||||
db 1 ; 1 drive, TODO: Don't hardcode
|
db 1 ; 1 drive, TODO: Don't hardcode
|
||||||
|
|
||||||
db 0 ; Physical drive 0
|
db 0 ; Physical drive 0
|
||||||
;dw offset iogroup:parameters_320k
|
dw offset iogroup:parameters_320k
|
||||||
dw offset iogroup:parameters_720k
|
|
||||||
|
|
||||||
parameters_320k:
|
parameters_320k:
|
||||||
dw 512 ; Sector size in bytes
|
dw 512 ; Sector size in bytes
|
||||||
|
@ -576,14 +585,6 @@ parameters_320k:
|
||||||
dw 112 ; Number of directory entries
|
dw 112 ; Number of directory entries
|
||||||
dw 320*2 ; Number of sectors
|
dw 320*2 ; Number of sectors
|
||||||
|
|
||||||
parameters_720k:
|
|
||||||
dw 512 ; Sector size in bytes
|
|
||||||
db 2 ; Sectors per cluster
|
|
||||||
dw 1 ; Number of reserved sectors
|
|
||||||
db 2 ; Number of FATs
|
|
||||||
dw 112 ; Number of directory entries
|
|
||||||
dw 720*2 ; Number of sectors
|
|
||||||
|
|
||||||
doubleticks_per_hour dw 32772 ; 1800B0h / 2 / 24
|
doubleticks_per_hour dw 32772 ; 1800B0h / 2 / 24
|
||||||
ticks_per_minute dw 1092 ; 1800B0h / 24 / 60
|
ticks_per_minute dw 1092 ; 1800B0h / 24 / 60
|
||||||
ticks_per_second dw 18 ; 1800B0h / 24 / 60 / 60
|
ticks_per_second dw 18 ; 1800B0h / 24 / 60 / 60
|
||||||
|
|
Loading…
Reference in a new issue