Merge branch 'master' into AoC

This commit is contained in:
Robbe Van Herck 2020-01-03 11:31:57 +01:00
commit 5d3f60377e
No known key found for this signature in database
GPG key ID: A66F76F7B81BD784
2 changed files with 16 additions and 18 deletions

View file

@ -1,4 +1,4 @@
DISK_ID EQU 0x80
; DISK_ID EQU 0x80
KERNEL_START EQU 0x100000
ELF_START EQU 0x8000
@ -73,14 +73,14 @@ ret
puthex:
; Print high bits
mov dl, bl
shr dl, 4
mov cl, bl
shr cl, 4
cmp dl, 9
cmp cl, 9
jg .puthex_high_alpha
; It's < 10, print as digit
mov al, dl
mov al, cl
add al, 0x30
mov ah, 0x0e
int 0x10
@ -88,21 +88,21 @@ jmp .puthex_low
.puthex_high_alpha:
; It's >= 10, print as letter
mov al, dl
mov al, cl
add al, 0x57 ; 0x57 = (0x61 - 10)
mov ah, 0x0e
int 0x10
.puthex_low:
; Print low bits
mov dl, bl
and dl, 0b1111
mov cl, bl
and cl, 0b1111
cmp dl, 9
cmp cl, 9
jg .puthex_low_alpha
; It's < 10, print as digit
mov al, dl
mov al, cl
add al, 0x30
mov ah, 0x0e
int 0x10
@ -110,7 +110,7 @@ jmp .puthex_end
.puthex_low_alpha:
; It's >= 10, print as letter
mov al, dl
mov al, cl
add al, 0x57 ; 0x57 = (0x61 - 10)
mov ah, 0x0e
int 0x10
@ -136,10 +136,12 @@ mov ch, 0b00100000
mov cl, 0b00000000
int 0x10
mov bl, dl
call puthex
; reset disk system
mov ah, 0x00
mov dl, DISK_ID
; mov dl, DISK_ID
int 0x13
; print result on error
@ -158,7 +160,7 @@ mov al, 0x01 ; number of sectors
mov ch, 0x00 ; cylinder number, low 8 bits
; mov cl, 0x01 ; cylinder number, high 2 bits + sector number (6 bits)
mov dh, 0x00 ; head number
mov dl, DISK_ID ; drive number
; mov dl, DISK_ID ; drive number
int 0x13
; exit on error

View file

@ -20,10 +20,6 @@ The first 512 bytes are the bootloader, right after that the 32-bit kernel ELF-f
## Known issues
### USB Boot
It doesn't boot the kernel from USB, as BIOS does not recognize USB as valid hard drive for int 13, only hard drives and floppies. Thus it loads sectors 2-65 from the hard drive. If this is written on a hard drive, it could work if DRIVE_ID is set correctly.
### Stack setup
As I don't quite get how segments work in real mode, there are most likely errors in the way I set up my stack. I'm going on a _it works on my qemu_ approach currently.
As I don't quite get how segments work in real mode, there are most likely errors in the way I set up my stack. I'm going on a _it works on my machine_ approach currently.