Gloire is an OS built with the Ironclad
kernel and using GNU tools for the userland, along with some original
applications like util-ironclad
. This repository holds scripts and tools to
build the OS from the ground up on a Linux-based system.
Gloire is named after the french ironclad, which was the first ocean-going vessel of its kind.
Gloire running the JWM window manager, a terminal emulator, xeyes, and a game Gloire generating an RSA key and running neofetch in its fallback shell.
One can grab a pre-built Gloire image here.
One can run either the downloaded disk image (uncompressing it first) or a built image with an emulator like QEMU, for using QEMU with an x86_64 image, one can do:
qemu-system-x86_64 -enable-kvm -cpu host -smp 4 -m 2G -M q35 -drive format=raw,file=gloire.img -serial stdio
Where gloire.img
is your image of choice.
To do the same with a riscv64 image, you can do:
qemu-system-riscv64 -M virt,acpi=off -cpu rv64 -smp 4 -device ramfb -device qemu-xhci \
-device usb-kbd -device usb-mouse -drive if=pflash,unit=0,format=raw,file=<firmware path> \
-hda gloire.img -serial stdio -m 2G
For riscv64, firmware can be obtained from the EDK2 project, and must be prepared as per QEMU with a
dd if=/dev/zero of=<firmware path> bs=1 count=0 seek=33554432
Depending on your distribution, to use Linux's KVM, you might need to add your
user to the kvm
usergroup, as such:
usermod -aG kvm <user>
Gloire should run fine on any x86 machine, be it UEFI or BIOS. For running it, one can burn your gloire image (uncompressing it first if downloaded) to a SATA or ATA drive. USB sticks for booting are not supported (for now, stay posted!).
Gloire accepts contributions for new packages or any other kind of changes using the pull request system baked into Github. Please submit PRs here or read our documentation on how to do so and some things to keep in mind porting on the project's wiki.
The project uses jinx
as its build system, which is included in the tree.
The instructions to build an x86_64 system are:
PKGS_TO_INSTALL="*" ./build-support/makeiso.sh # Create the image.
Note: on certain distros, like Ubuntu 24.04, one may get an error like:
.../.jinx-cache/rbrt: failed to open or write to /proc/self/setgroups at line 186: Permission denied
In that case, it likely means apparmor is preventing the use of user namespaces,
causing jinx
to fail to work. One can enable user namespaces by running:
sudo sysctl kernel.apparmor_restrict_unprivileged_userns=0
This is not permanent across reboots. To make it so, one can do:
sudo sh -c 'echo "kernel.apparmor_restrict_unprivileged_userns = 0" >/etc/sysctl.d/99-userns.conf'
To build the very experimental riscv64 port, one can instead use:
PKGS_TO_INSTALL="*" JINX_CONFIG_FILE=jinx-config-riscv64 ./build-support/makeiso.sh # Create the image.
Regardless of architecture, if, instead of building all packages, building
a minimal command-line only environment is desired, instead of "*"
, one
can pass ""
(or a list of desired packages, base
is implied) as PKGS_TO_INSTALL
.
Any of those routes will generate a bootable disk image that can be burned to storage media or be booted by several emulators.
A list of the tools needed for compilation of the OS are:
git
for cloning packages.curl
and a working C compiler (ascc
) for setting up jinx.- Common UNIX tools like
bash
,coreutils
,grep
,find
, etc. sgdisk
from thegptfdisk
package for building the image.qemu
for testing, if wanted.tar
andlzip
for extracting packages.rsync
for building bootable images.
All of said things can be installed in debian-based systems with
sudo apt install lzip git build-essentials rsync
A list of the licenses used by the software ported to Gloire is:
- Mintsuki for the limine bootloader and
jinx
. - The managarm project for help with some
of the recipes and
mlibc
.