A UNIX-like OS with functional configuration and scripting support.
Important
This project is purely meant for educational purposes. There is no effort to produce production-ready code. Expect many features to be buggy, broken or even unimplemented.
This Project consists of three main pieces of software:
The Amethyst kernel is a UNIX-like monolithic kernel built completely from scratch in C23
and Assembly
.
This is the main part of this project. The code can be found in the init/
, kernel/
, drivers/
and include/
directories. Platform-specific code is located in the arch/
directory.
Features:
- Booting using the limine boot loader
- Paging, physical and virtual memory management
- Kernel heap
- UNIX-like VFS (including pseudo-filesystems like
devfs
(/dev
) andtmpfs
(/tmp
)) - proper file systems like
FAT32
,ext2
, ... - NVMe driver
- SMP-enabled preemptive multitasking and process management
- Syscalls
- Kernel stack switching
- User mode
- PCI device identifictation & interaction
- Keyboard input
- Mouse input
- ...
Supported Architectures:
-
x86_64
-
riscv64
(planned)
Shard is a functional programming language designed for declarative builds and configuration of the Amethyst Operatiing system.
See ./shard and ./shard/README.md for more information.
Geode is the package manager and build system of the Amethyst Operating System.
See its source in ./shard/geode and the package store in ./store.
Features:
-
bootstrap
: Build a new fully functioning system from a single configuration file [in progress] -
rebuild
: Rebuild the system root on the go -
update
: Pull store updates from the internet and do a full rebuild - ...
Warning
geode
is in especially early development state. Expect crashes and cryptic error messages.
- GNU binutils
- GNU make
gcc
version >=13
(withC23
support)libarchive
python3
(versions tested:3.11
-3.13
)
qemu
- Clone this repository:
$ git clone https://github.com/spydr06/amethyst --recursive
$ cd amethyst
- Bootstrap the OS with the following command:
$ ./bootstrap.sh
Note
When compiling for the first time, bootstrapping the system can take several minutes.
You can speed up the process by utilizing more cpu cores using the -jN
flag.
To run amethyst in qemu
, use either the run
or run-kvm
make targets in order to run with or without KVM enabled.
$ ./run.sh
or (with KVM):
$ ./run.sh -K
or (for debugging with gdb
):
$ ./run.sh -d
Pull requests are welcome. For major changes, please open an issue first for discussion. Make sure to update unit tests as appropriate.
Please note that this is a toy OS. Hardware support and system stability are not guaranteed.
Amethyst, Shard and Geode are licensed under the MIT License. See ./LICENSE for more information.
The C standard library (store/libc
) uses partially (e.g. mallocng
) code from musl libc.
See musl's COPYRIGHT file for more information.
I do not take credit for these segments of the code.
For all other parts (pci.ids
, limine
, libarchive
, ...), their respective licenses apply. I take no credit at these projects.