/SalernOS-EFI-Bootloader

A Bootloader for my Operating System

Primary LanguageCApache License 2.0Apache-2.0

SalernOS

SalernOS is a small Toy OS I'm working on.

SalernOS EFI Bootloader (SEB)

The SalernOS EFI Bootloader is a free and open source GNU-EFI bootloader built on top of https://github.com/Absurdponcho/gnu-efi

Naming Conventions

  • _variablename and _variable_name are stack-allocated variables
  • _VariableName is a struct member variable
  • variablename and variable_name are global variables
  • __variablename and __variable_name are function arguments

Compiling SEB

Compiling SEB is quite eaasy, just follow these steps

  • Make sure you're running a GNU/Linux system. If you're running Windows 10/11 or macOS, use WSL or Docker
  • Install the build-essentials package via your package manager (apt-get/pacman etc)
  • Open a terminal in the SEB directory
  • If it's the first time you compile SEB, Type make and wait for a few seconds
  • Type make bootloader and wait for a few seconds
  • The resulting main.efi file will be in the x86_64/bootloader directory

Editing SEB's source code

All of SEB's source code is in the bootloader directory. NOTE: Remember to change something in main.c before compiling, otherwise it won't work!

Using SEB as bootloader for an Operating System

This is a little trickier, but you should be able to do it, otherwise, open an issue on this Github page.

The Simple Boot Specification

The SalernOS EFI Bootlaoder uses the Simple Boot Specification to hand information over to the Kernel.

Making a SEB Compatible File System

Currently the SEB Specification requires the following directories

  • EFI
  • EFI/BOOT
  • openbit
  • openbit/bin
  • openbit/assets

The EFI/BOOTdirectory must contain a bootx64.efi file. This file is the SEB binary, you can get it by renaming the main.efi file. The openbit/assets directory must contain a PSF1 Font named kernelfont.psf. The openbit/bin directory must contain the kernel executable, named kernel.elf