MOROS: Obscure Rust Operating System 🦉
Go to file
Vincent Ollivier 60ab58c292 Update changelog 2020-11-15 10:38:30 +01:00
.cargo Remove dependency on rlibc (#115) 2020-11-12 23:07:02 +01:00
doc Add a web server (#114) 2020-11-15 09:44:10 +01:00
dsk Improve console (#74) 2020-07-10 08:18:34 +02:00
run Update ATA driver (#41) 2020-04-13 11:36:04 +02:00
src Disable rand_chacha with debug_assertions (#120) 2020-11-15 10:37:01 +01:00
.gitignore Update gitignore 2020-07-03 23:49:58 +02:00
.travis.yml Add tests (#118) 2020-11-14 21:52:07 +01:00
CHANGELOG.md Update changelog 2020-11-15 10:38:30 +01:00
Cargo.lock Bump version to 0.5.0 2020-11-15 10:07:46 +01:00
Cargo.toml Bump version to 0.5.0 2020-11-15 10:07:46 +01:00
LICENSE Add license 2019-12-29 11:19:29 +01:00
Makefile Add a web server (#114) 2020-11-15 09:44:10 +01:00
README.md Add badges to readme 2020-11-14 22:09:08 +01:00
moros.png Rename screenshot 2020-07-27 07:23:23 +02:00
rust-toolchain Start MOROS project 2019-12-28 18:37:49 +01:00
x86_64-moros.json Add password hashing 2020-01-03 22:01:48 +01:00

README.md

MOROS: Obscure Rust Operating System

Travis Crates.io

MOROS is a toy operating system written in Rust for the x86 architecture.

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.

screenshot

Features

  • External bootloader (using bootloader)
  • x86 CPU support (using x86_64)
  • Hardware interrupts (using pic8259_simple)
  • PS/2 Keyboard (using pc-keyboard)
  • VGA Text mode output
  • Serial output (using uart_16550)
  • Paging
  • Heap allocation (using linked_list_allocator)
  • ACPI shutdown (using acpi and aml)
  • RTC clock
  • PCI enumeration
  • ATA PIO mode
  • Random number generator (using rand_chacha)
  • RTL8139 network card
  • AMD PCNET network card
  • DHCP/IP/TCP/UDP/DNS/HTTP protocols (using smoltcp)
  • Basic filesystem
  • Basic shell
  • Basic text editor
  • Basic file and network commands
  • A LOT OF UGLY SHORTCUTS TO GET EVERYTHING WORKING
  • Processes
  • Multitasking
  • A real userspace

Setup

Install the required tools:

$ curl https://sh.rustup.rs -sSf | sh
$ rustup install nightly
$ rustup default nightly
$ rustup component add rust-src
$ rustup component add llvm-tools-preview
$ cargo install bootimage

Clone the repo:

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

Usage

Build the image to disk.img:

$ make image output=vga keyboard=qwerty nic=rtl8139

Run MOROS in QEMU:

$ make qemu output=vga 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):

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

In both cases, MOROS will open a console in diskless mode after boot if no filesystem is detected. The following command will setup the filesystem on the first hard drive of the first ATA bus, 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.

Tests

Run the test suite in QEMU:

$ make test

LICENSE

MOROS is released under MIT.