bookstack

Kernel Barebones

Concepts you may want to Google beforehand: kernel, ELF format, makefile

Goal: Create a simple kernel and a bootsector capable of booting it

The kernel

Our C kernel will just print an ‘X’ on the top left corner of the screen. Go ahead and open kernel.c.

You will notice a dummy function that does nothing. That function will force us to create a kernel entry routine which does not point to byte 0x0 in our kernel, but to an actual label which we know that launches it. In our case, function main().

i386-elf-gcc -ffreestanding -c kernel.c -o kernel.o

That routine is coded on kernel_entry.asm. Read it and you will learn how to use [extern] declarations in assembly. To compile this file, instead of generating a binary, we will generate an elf format file which will be linked with kernel.o

nasm kernel_entry.asm -f elf -o kernel_entry.o

The linker

A linker is a very powerful tool and we only started to benefit from it.

To link both object files into a single binary kernel and resolve label references, run:

i386-elf-ld -o kernel.bin -Ttext 0x1000 kernel_entry.o kernel.o --oformat binary

Notice how our kernel will be placed not at 0x0 in memory, but at 0x1000. The bootsector will need to know this address too.

The bootsector

It is very similar to the one in lesson 10. Open bootsect.asm and examine the code. Actually, if you remove all the lines used to print messages on the screen, it accounts to a couple dozen lines.

Compile it with nasm bootsect.asm -f bin -o bootsect.bin

Putting it all together

Now what? We have two separate files for the bootsector and the kernel?

Can’t we just “link” them together into a single file? Yes, we can, and it’s easy, just concatenate them:

cat bootsect.bin kernel.bin > os-image.bin

Run!

You can now run os-image.bin with qemu.

Remember that if you find disk load errors you may need to play with the disk numbers or qemu parameters (floppy = 0x0, hdd = 0x80). I usually use qemu-system-i386 -fda os-image.bin

You will see four messages:

  • “Started in 16-bit Real Mode”
  • “Loading kernel into memory”
  • (Top left) “Landed in 32-bit Protected Mode”
  • (Top left, overwriting previous message) “X”

Congratulations!

Makefile

As a last step, we will tidy up the compilation process with a Makefile. Open the Makefile script and examine its contents. If you don’t know what a Makefile is, now is a good time to Google and learn it, as this will save us a lot of time in the future.