MOROS: Obscure Rust Operating System 🦉
Go to file
Vincent Ollivier dd5899a74d
Read command line args from userspace programs (#351)
* Read command line args from userspace programs

* Use Stop syscall to debug pointers from userpace

* Fix address translation system

* Update binaries

* Move print to bin

* Add hardcoded alias system

* Strip debug from binaries

* Build userspace binaries before running tests

* Save all the args in args including the command invocation name

* Move sleep command to /bin

* Rebuild binaries
2022-06-14 22:43:33 +02:00
.cargo Remove dependency on rlibc (#115) 2020-11-12 23:07:02 +01:00
.github Read command line args from userspace programs (#351) 2022-06-14 22:43:33 +02:00
doc Add shell variables (#348) 2022-06-08 20:51:02 +02:00
dsk Read command line args from userspace programs (#351) 2022-06-14 22:43:33 +02:00
run Improve FUSE driver with write and delete (#292) 2022-04-15 13:00:54 +02:00
src Read command line args from userspace programs (#351) 2022-06-14 22:43:33 +02:00
www Add socket command (#341) 2022-05-21 10:46:16 +02:00
.gitignore Update gitignore 2020-07-03 23:49:58 +02:00
.static Add website (#261) 2021-11-01 08:58:22 +01:00
CHANGELOG.md Update changelog 2022-06-06 16:03:50 +02:00
Cargo.lock Bump smoltcp from 0.8.0 to 0.8.1 (#342) 2022-05-21 08:46:41 +00:00
Cargo.toml Bump smoltcp from 0.8.0 to 0.8.1 (#342) 2022-05-21 08:46:41 +00:00
LICENSE Update copyright year 2022-04-05 15:02:39 +02:00
Makefile Read command line args from userspace programs (#351) 2022-06-14 22:43:33 +02:00
README.md Rewrite network interface (#334) 2022-05-05 23:05:39 +02:00
rust-toolchain.toml Refactor code (#330) 2022-04-19 22:42:15 +02:00
x86_64-moros.json Add password hashing 2020-01-03 22:01:48 +01:00

README.md

MOROS: Obscure Rust Operating System

screenshot

MOROS is a hobby operating system written in Rust by Vincent Ollivier.

It targets computers with a x86-64 architecture and a BIOS, so mostly from 2005 to 2020, but it also runs well on most emulators (Bochs, QEMU, and VirtualBox).

This project started from the seventh post of the second edition of Writing an OS in Rust by Philipp Oppermann and by reading the OSDev wiki along with many open source kernels.

Travis Crates.io

Features

  • External bootloader (using bootloader)
  • x86 CPU support (using x86_64)
  • Hardware interrupts (using pic8259)
  • PS/2 Keyboard with customizable layout (using pc-keyboard)
  • VGA Text mode with customizable font and color palette
  • Serial output (using uart_16550)
  • Paging
  • Heap allocation (using linked_list_allocator)
  • ACPI shutdown (using acpi and aml)
  • RTC clock
  • PCI devices
  • ATA PIO mode
  • Random number generator (using rand_chacha)
  • RTL8139 network card
  • AMD PCNET network card
  • DHCP/IP/TCP/UDP/DNS/HTTP network protocols (using smoltcp)
  • Basic filesystem
  • Basic shell
  • Basic text editor
  • Basic lisp interpreter
  • Basic file and network commands
  • Basic userspace for nasm binaries
  • Support for Rust binaries
  • Support for multitasking
  • C standard library port

Documentation

Documentation is available here

Setup

Clone the repo:

$ git clone https://github.com/vinc/moros
$ cd moros

Install the required tools with make setup or the following commands:

$ curl https://sh.rustup.rs -sSf | sh
$ rustup install nightly
$ rustup default nightly
$ cargo install bootimage

Usage

Build the image to disk.img:

$ make image output=video keyboard=qwerty

Run MOROS in QEMU:

$ make qemu output=video nic=rtl8139

Run natively on a x86 computer by copying the bootloader and the kernel to a hard drive or USB stick (but there is currently no USB driver so the filesystem will not be available in that case):

$ sudo dd if=target/x86_64-moros/release/bootimage-moros.bin of=/dev/sdx && sync

MOROS will open a console in diskless mode after boot if no filesystem is detected. The following command will setup the filesystem on a hard drive, allowing you to exit the diskless mode and log in as a normal user:

> install

Be careful not to overwrite the hard drive of your OS when using dd inside your OS, and install or disk format inside MOROS if you don't use an emulator.

Tests

Run the test suite in QEMU:

$ make test

LICENSE

MOROS is released under MIT.