A 64bit hobby operating system written in C++
Explore the docs »
View Demo
·
Report Bug
·
Request Feature

!-- CURRENTLY IMPLEMENTING 64BIT SUPPORT, OS IS IN A BROKEN STATE --!
Max OS is a hobby operating system developed for the 64bit platform using C++ and Assembly. The project is currently in the early stages of development and is not yet ready for use. The project is being developed as a learning experience and is not intended to be used as a production operating system.
Max OS supports device drivers, memory management, multitasking, a GUI, and more. The project is being developed with the goal of being able to run on real hardware, however, it is currently only able to run on a virtual machine.
(back to top)
This is how to build the Max OS operating system from source. (Alternatively, you can download the latest built kernel from the workflow artifacts)
This is the list of required packages to build the operating system from source. (Note the build scripts should install these automatically)
sudo apt update
sudo apt install -y build-essential bison flex libgmp3-dev libmpc-dev libmpfr-dev texinfo libisl-dev cmakeNote: If you want to run the operating system in a virtual machine, you will need to install QEMU. (If in WSL the script will look for a Windows installation of QEMU)
Clone the repo
git clone https://github.com/maxtyson123/MaxOS.git
cd MaxOSCreate the cross compiler (This will take a while)
cd toolchain
./make_cross_compiler.sh
cd ../Generate makefiles
cd cmake-build
cmake .. -DCMAKE_TOOLCHAIN_FILE=toolchain/CMakeToolchain.txtClean the build directory
make cleanBuild the operating system & Run it in QEMU
make install image run(back to top)
No user usage so far (userland will be added in the future)


See the open issues for a full list of proposed features (and known issues).
(back to top)
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.
If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!
git checkout -b feature/AmazingFeature)git commit -m 'Add some AmazingFeature')git push origin feature/AmazingFeature)(back to top)
Distributed under the BSD 3-Clause License. See LICENSE for more information.
(back to top)
(back to top)