Compare commits
No commits in common. "0d16e3e35a8175e21fe8085010be92f794f7acf3" and "94e5e703052c02946b6206ab2303d714fbfb6333" have entirely different histories.
0d16e3e35a
...
94e5e70305
|
@ -26,41 +26,13 @@ setup_drivers:
|
||||||
mov [esi + (64 - 16)], edx
|
mov [esi + (64 - 16)], edx
|
||||||
mov [esi + (64 - 20)], edi
|
mov [esi + (64 - 20)], edi
|
||||||
|
|
||||||
; [esi + 8]: Pointer to the current driver init function
|
|
||||||
; [esi + 12]L Pointer to current driver slot
|
|
||||||
; ecx: Driver slot index
|
|
||||||
|
|
||||||
xor ecx, ecx
|
|
||||||
|
|
||||||
.driver_setup_loop:
|
|
||||||
cmp ecx, DRIVER_SLOT_COUNT
|
|
||||||
jae .epilog
|
|
||||||
|
|
||||||
mov ebx, ecx
|
|
||||||
shl ebx, 2
|
|
||||||
add ebx, driver_init_functions
|
|
||||||
mov eax, [ebx]
|
|
||||||
mov [esi + 8], eax
|
|
||||||
|
|
||||||
cmp eax, 0
|
|
||||||
je .epilog
|
|
||||||
|
|
||||||
mov eax, ecx
|
|
||||||
mov edx, DRIVER_SLOT_SIZE
|
|
||||||
mul edx
|
|
||||||
mov [esi + 12], eax
|
|
||||||
|
|
||||||
push ebp
|
push ebp
|
||||||
mov ebp, esp
|
mov ebp, esp
|
||||||
push dword [esi + 12]
|
push dword DRIVER_MEMORY_AREA
|
||||||
mov eax, [esi + 8]
|
call initialize_pci_driver
|
||||||
call eax
|
|
||||||
mov esp, ebp
|
mov esp, ebp
|
||||||
pop ebp
|
pop ebp
|
||||||
|
|
||||||
inc ecx
|
|
||||||
jmp .driver_setup_loop
|
|
||||||
|
|
||||||
.epilog:
|
.epilog:
|
||||||
mov eax, [esi + (64 - 4)]
|
mov eax, [esi + (64 - 4)]
|
||||||
mov ebx, [esi + (64 - 8)]
|
mov ebx, [esi + (64 - 8)]
|
||||||
|
@ -73,4 +45,3 @@ setup_drivers:
|
||||||
ret
|
ret
|
||||||
|
|
||||||
%include "drivers/pci/driver.asm"
|
%include "drivers/pci/driver.asm"
|
||||||
%include "drivers/acpi/driver.asm"
|
|
||||||
|
|
|
@ -46,6 +46,9 @@ stage_2_setup_entry:
|
||||||
cli
|
cli
|
||||||
hlt
|
hlt
|
||||||
|
|
||||||
|
some_text:
|
||||||
|
db "This is some text.", 0x00
|
||||||
|
|
||||||
; Utilities
|
; Utilities
|
||||||
; Memory Management
|
; Memory Management
|
||||||
%include "memory/a20.asm"
|
%include "memory/a20.asm"
|
||||||
|
@ -55,18 +58,13 @@ stage_2_setup_entry:
|
||||||
|
|
||||||
bits 32
|
bits 32
|
||||||
stage2_true_entry:
|
stage2_true_entry:
|
||||||
push ebp
|
mov [dword 0xb8000], byte 'X'
|
||||||
mov ebp, esp
|
mov [dword 0xb8000 + 1], byte 0x31
|
||||||
call setup_drivers
|
|
||||||
mov esp, ebp
|
|
||||||
pop ebp
|
|
||||||
|
|
||||||
cli
|
cli
|
||||||
hlt
|
hlt
|
||||||
|
|
||||||
%include "utility/math.asm"
|
%include "utility/math.asm"
|
||||||
%include "utility/memory.asm"
|
%include "utility/memory.asm"
|
||||||
%include "utility/display.asm"
|
|
||||||
|
|
||||||
; Driver Manager
|
; Driver Manager
|
||||||
%include "drivers/manager.asm"
|
; %include "drivers/manager.asm"
|
||||||
|
|
Loading…
Reference in New Issue