Skip to content

ReturnInfinity/BareMetal-Firecracker

Repository files navigation

BareMetal-Firecracker

This repository contains the source code for BareMetal-Firecracker. This is a custom version of the BareMetal kernel explicitly for execution within a Firecracker microVM. The goal of this project was to achieve a <1ms cold start for the BareMetal kernel and its payload. That goal was achieved.

  • BareMetal, an exokernel written in x86-64 Assembly.
  • Firecracker, a streamlined virtualization environment.

On an AMD Ryzen AI Max+ 395 running Ubuntu Desktop 25.10 execution times are as follows:

  • Init: ~100µs from Firecracker handoff to kernel start.
  • BareMetal: ~700µs with network and disk enabled. ~500µs with only network enabled.

Contents

  • src: Source code for BareMetal init and the BareMetal kernel.
  • payload: Payload for the kernel - Currently a minimal version of BareMetal Monitor.
  • scripts: Scripts for creating/removing bridge and tap networks.
  • img: Screenshot

Firecracker

Overview

What is missing from a "standard" VM:

  • No BIOS or UEFI
  • No PCI/PCIe bus
  • No VGA or LFB
  • No USB
  • Minimal ACPI
  • NO HPET

What you get:

  • VirtIO devices (block, net, and others) addressable via MMIO
  • PS/2 keyboard controller (only used for sending Ctrl-Alt-Del)
  • Serial console

Note: It is possible to enable a PCIe bus for Firecracker but it is not a default.

Memory usage

Firecracker uses the following memory address on startup:

Start AddressDescription
0x000500GDT
0x000520IDT
0x006000PVH
0x007000boot_params
0x008000Stack (starts at 0x8FF0)
0x009000PML4 (CR3 points here)
0x00A000PDPTE
0x00B000PDE
0x020000cmd_line
0x0E0000RSDP
0x100000your software

0xC000-0xFFFF should be free

Startup

Execution starts at 0x100000. RFLAGS is set to 0x2, RSP/RBP to 0x8FF0, and RSI to address of boot_params.

BareMetal Init

Init preps the system for the BareMetal Kernel. It sets the system up in a similar way to Pure64. It is also written in Assembly.

Memory Map

Start AddressEnd AddressSizeDescription
0x00000000000000000x0000000000000FFF4 KiBIDT - 256 descriptors (each descriptor is 16 bytes)
0x00000000000010000x0000000000001FFF4 KiBGDT - 256 descriptors (each descriptor is 16 bytes)
0x00000000000020000x0000000000002FFF4 KiBPML4 - 512 entries, entry 0 points to PDP at 0x3000, entry 256 points to PDP at 0x4000
0x00000000000030000x0000000000003FFF4 KiBPDP Low - 512 entries
0x00000000000040000x0000000000004FFF4 KiBPDP High - 512 entries
0x00000000000050000x0000000000005FFF4 KiBInit data
0x00000000000060000x0000000000006FFF4 KiBStack
0x00000000000070000x0000000000007FFF4 KiBboot_params
0x00000000000080000x000000000000FFFF32 KiBStub
0x00000000000100000x000000000001FFFF64 KiBPD Low - Entries are 8 bytes per 2MiB page
0x00000000000200000x000000000005FFFF256 KiBPD High - Entries are 8 bytes per 2MiB page
0x00000000000600000x000000000009FFFF256 KiBFree
0x00000000000A00000x00000000000FFFFF384 KiBLegacy BIOS ROM Area
   VGA RAM at 0xA0000 (128 KiB) Color text starts at 0xB8000
   Video BIOS at 0xC0000 (64 KiB)
   Motherboard BIOS at F0000 (64 KiB)
0x00000000001000000xFFFFFFFFFFFFFFFF1+ MiBThe software payload is loaded here

Init data

Start AddressEnd AddressSizeDescription
0x00000000000058000x00000000000058FF256 BMMIO devices
0x00000000000059000x00000000000059FF256 Bmemmap
0x0000000000005A000x0000000000005AFF256 Bcmdline

BareMetal

The BareMetal kernel in this repo has been adapted from the general version. VirtIO drivers have been reworked to use MMIO.

Virtio-Block and Virtio-Net drivers are present. Virtio-Vsock, and other Firecracker-supported devices, is yet to be added.

SMP is not included in this version of BareMetal and will be added at a later date. BareMetal uses 2MiB of memory - A microVM should be provisioned with at least 4MiB of memory so 2MiB can be mapped at 0xFFFF800000000000. 2MiB is the minimum if the application runs from kernel memory (there is some room).

The kernel binary is currently ~5500 bytes.

TODO

  • proper parsing of the cmdline string to gather the base addresses and IRQs of the Virtio MMIO devices
  • parse ACPI tables for APIC IDs (SMP removed from this version)
  • unikernel mode for diskless systems (embed app into ELF image)

//EOF

About

BareMetal for Firecracker

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors