fox32+fox32rom: Use DMA for the disk controller
Instead of accessing one byte at a time, use a DMA-like system to read/write a whole sector at a time directly to/from memory.
This commit is contained in:
parent
e332558e21
commit
4fc5324f2a
39
boot.asm
39
boot.asm
|
@ -2,16 +2,11 @@
|
||||||
; these are only used during booting, they are not exposed via the jump table
|
; these are only used during booting, they are not exposed via the jump table
|
||||||
|
|
||||||
; read disk 0 and attempt to figure out what type of disk it is, and load the correct binary into memory
|
; read disk 0 and attempt to figure out what type of disk it is, and load the correct binary into memory
|
||||||
; currently this only supports booting raw binaries
|
|
||||||
; inputs:
|
; inputs:
|
||||||
; r0: disk size (bytes)
|
; r0: disk size (bytes)
|
||||||
; outputs:
|
; outputs:
|
||||||
; none (doesn't return)
|
; none (doesn't return)
|
||||||
start_boot_process:
|
start_boot_process:
|
||||||
; in the future, this will check the header for various different types of disk types
|
|
||||||
; but for now, just assume the user inserted a raw binary
|
|
||||||
; load it to 0x00000800 (immediately after the interrupt vectors) and jump
|
|
||||||
|
|
||||||
; r0 contains the size of the disk in bytes
|
; r0 contains the size of the disk in bytes
|
||||||
; divide the size by 512 and add 1 to get the size in sectors
|
; divide the size by 512 and add 1 to get the size in sectors
|
||||||
div r0, 512
|
div r0, 512
|
||||||
|
@ -20,22 +15,26 @@ start_boot_process:
|
||||||
mov r31, r0
|
mov r31, r0
|
||||||
mov r0, 0 ; sector counter
|
mov r0, 0 ; sector counter
|
||||||
mov r2, 0x00000800 ; destination pointer
|
mov r2, 0x00000800 ; destination pointer
|
||||||
mov r3, 0x80003000 ; command to read a sector from disk 0 into the sector buffer
|
mov r3, 0x80003000 ; command to read a sector from disk 0 into memory
|
||||||
mov r4, 0x80002000 ; command to read a byte from the sector buffer
|
mov r4, 0x80002000 ; command to set the location of the buffer
|
||||||
start_boot_process_sector_loop:
|
|
||||||
out r3, r0 ; read the current sector into the sector buffer
|
|
||||||
mov r1, 0 ; byte counter
|
|
||||||
start_boot_process_byte_loop:
|
|
||||||
mov r5, r4
|
|
||||||
or r5, r1 ; or the byte read command with the current byte counter
|
|
||||||
in r5, r5 ; read the current byte into r5
|
|
||||||
mov.8 [r2], r5 ; write the byte
|
|
||||||
inc r2 ; increment the destination pointer
|
|
||||||
inc r1 ; increment the byte counter
|
|
||||||
cmp r1, 512
|
|
||||||
ifnz jmp start_boot_process_byte_loop
|
|
||||||
loop start_boot_process_sector_loop
|
|
||||||
|
|
||||||
|
; first, check to see if this is a FAT-formatted disk
|
||||||
|
out r4, r2 ; set the memory buffer location
|
||||||
|
out r3, 0 ; read sector 0 into the buffer
|
||||||
|
cmp.8 [r2], 0xEB ; check for an x86 jmp instruction, indicating a possible FAT volume
|
||||||
|
ifz jmp start_boot_process_fat
|
||||||
|
cmp.8 [r2], 0xE9 ; check for an x86 jmp instruction, indicating a possible FAT volume
|
||||||
|
ifz jmp start_boot_process_fat
|
||||||
|
start_boot_process_raw_binary_sector_loop:
|
||||||
|
out r4, r2 ; set the memory buffer location
|
||||||
|
out r3, r0 ; read the current sector into memory
|
||||||
|
inc r0 ; increment sector counter
|
||||||
|
add r2, 512 ; increment the destination pointer
|
||||||
|
loop start_boot_process_raw_binary_sector_loop
|
||||||
|
jmp start_boot_process_done
|
||||||
|
start_boot_process_fat:
|
||||||
|
;
|
||||||
|
start_boot_process_done:
|
||||||
; done loading !!!
|
; done loading !!!
|
||||||
; now clean up and jump to the loaded binary
|
; now clean up and jump to the loaded binary
|
||||||
call boot_cleanup
|
call boot_cleanup
|
||||||
|
|
Loading…
Reference in New Issue
Block a user