A simple OS microkernel written in Rust, and designed for security and modularity.
.cargo | ||
.vscode | ||
linker-scripts | ||
src | ||
.envrc | ||
.gitignore | ||
build.rs | ||
Cargo.lock | ||
Cargo.toml | ||
Dockerfile | ||
LICENSE | ||
limine.conf | ||
Makefile | ||
README.md | ||
rust-toolchain.toml | ||
shell.nix |
Gila v0.2.2 - a Rust Microkernel
Gila is a Rust microkernel OS, inspired by the Xinu embedded OS. It will hopefully be capable of multitasking some day. I do not intend for Gila to be POSIX-like or compatible.
Work In Progress
Gila does nothing at all right now. Check back later. Or contribute.
Licensing
Licensed under the GNU Public License v3. See LICENSE for details.
Navigating
- boot.rs: Handles bootloader handoff. Gila uses Limine. Other bootloaders are NOT supported.
- display.rs: Handles text-mode display via the VGA buffer.
- lib.rs: Glue to make all files accessible from main.rs.
- log.rs: Logging structures and singletons for logging to serial or the display.
- main.rs: The entry point that gets called by the bootloader.
- memory.rs: Types relating to memory regions and allocation.
- panic.rs: The panic handler and associated functionality.
- params.rs: Kernel parameter handler code.
- process.rs: Process types and functions.
- resources.rs: Resources that are accessible from multiple parts of the code.
Building and running
To build an ISO image that you can boot, there are several prerequisites:
rustup
command installedlimine
command installedxorriso
command installedmake
command installedqemu-system-x86_64
command installed (for running)
Then run make
to invoke the Makefile.
make prepare
: Installs needed Rust toolchain.make clean
: Cleans all built files.make gila
: Builds the kernel ELF file.make iso
: Builds the bootable ISO with Limine installed.make run
: Builds the ISO and boots it in QEMU.
You can install all these dependencies automatically by using nix-shell
and
supplying shell.nix as an argument.
TODO: The dockerfile is kinda broken and display forwarding does not work.
Credits
The linker script stuff is from limine-rust-template, which is available under the BSD 0-Clause License.