Learning about the miracle of boot
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
pantonshire 121e13165b enable a20 in stage 2 prelude 1 year ago
boot1 enable a20 in stage 2 prelude 1 year ago
elf fix hexdump alignment for non-multiple-of-16 size 1 year ago
include move defines.s to include directory 1 year ago
patches add seabios as submodule 1 year ago
seabios@e5f2e4c696 add seabios as submodule 1 year ago
.gitignore start elf parser 1 year ago
.gitmodules add seabios as submodule 1 year ago
boot0.s use e820 to get available memory 1 year ago
boot1.s enter unreal mode 1 year ago
justfile enable a20 in stage 2 prelude 1 year ago
readme.md enable a20 1 year ago
resources.md update resources 1 year ago

readme.md

Overview

Currently we boot from BIOS on a GPT-partitioned disk.

boot0.s is the first-stage bootloader. It lives in the MBR bootstrap field, and must therefore fit into 440 bytes. Its tasks are:

  • Set up a stack etc.
  • Get the boot drive geometry
  • Load and parse the GPT
  • Find the partition of the second stage
  • Load and jump to the first sector of the second stage

boot1.s is the second-stage bootloader. Its tasks are:

  • Load its own sectors not loaded by the first stage
  • Enable A20
  • Detect available memory
  • Enter unreal mode
  • Read the kernel ELF from disk (don't have to parse the ELF just yet)
  • Get all the useful information we can from the BIOS before we leave unreal mode
  • Enter long mode (possibly via protected mode?)
  • Load the kernel ELF
  • Initialise stack etc. for the kernel
  • Jump to kernel