Vinix is an effort to write a modern, fast, and useful operating system in the V programming language.
Join the Discord chat.
- Keeping the code as simple and easy to understand as possible, while not sacrificing performance and prioritising code correctness.
- Making a usable OS which can run on real hardware, not just on emulators or virtual machines.
- Targeting modern 64-bit architectures, CPU features, and multi-core computing.
- Maintaining good source-level compatibility with Linux to allow to easily port programs over.
- Exploring V capabilities in bare metal programming and improving the compiler in response to the uncommon needs of bare metal programming.
- Having fun.
Note: Vinix is still pre-alpha software not meant for daily or production usage!
You can grab a pre-built nightly Vinix image at https://github.com/vlang/vinix/releases
Make sure to boot the ISO with enough memory (8+GiB) as, for now, Vinix loads its entire root filesystem in a ramdisk in order to be able to more easily boot on real hardware.
- mlibc
- bash
- gcc/g++
- V
- nano
- storage drivers
- ext2
- X.org
- X window manager
- Networking
- Wayland
- Hypervisor
- V-UI
- Intel HD graphics driver (Linux port)
The following is a distro-agnostic list of packages needed to build Vinix.
Skip to a paragraph for your host distro if there is any.
GNU make, findutils, curl, git, xz, rsync, xorriso, qemu to test it, and a working C compiler (cc) needs to be present.
sudo apt install -y build-essential make findutils curl git xz-utils rsync xorriso qemu-system-x86sudo pacman -S --needed gcc make findutils curl git xz rsync xorriso qemusudo yum install -y gcc make findutils curl git xz rsync xorriso qemusudo xbps-install -Suv gcc make findutils curl git xz rsync xorriso qemuTo build the distro, which includes the cross toolchain necessary to build kernel and ports, as well as the kernel itself, run:
make all # Build the base distro and make filesystem and ISO.This will build a minimal distro image. Setting the PKGS_TO_INSTALL env variable will allow one to specify a custom set of packages to build/install. For example:
PKGS_TO_INSTALL='*' make allThis will build all packages (may take some time). Or:
PKGS_TO_INSTALL='python sqlite' make allThis will build the base system (like make all) plus the python and sqlite packages.
In Linux, if KVM is available, run with
make run-kvm
In macOS, if hvf is available, run with
make run-hvf
To run without any acceleration, run with
make run