MOS ist das von von Grund auf entwickelte Unix-ähnliche Betriebssystem und zielt darauf ab, posix-konform zu sein.
? Optionale Funktionen
Macos
Pakete installieren
$ brew install qemu nasm gdb i386-elf-gcc i386-elf-grub bochs e2fsprogs xorriso
Öffnen Sie Ihre Bash -Konfiguration und fügen Sie unten Zeilen hinzu. Abhängig von Ihrer Bash -Konfiguration kann die Datei unterschiedlich sein. Ich benutze ohmyzsh , also ist es .zshrc
# .zshrc
alias grub-file=i386-elf-grub-file
alias grub-mkrescue=i386-elf-grub-mkrescue
Emulator ausführen
$ cd src && mkdir logs
$ ./create_image.sh && ./build.sh qemu iso
ein anderes Terminal öffnen
$ cd src
$ gdb isodir/boot/mos.bin
# in gdb
(gdb) target remote localhost:1234
(gdb) c
✍? Wenn Sie diesen Fehler erhalten hdiutil: attach failed - no mountable file systems , kann die Installation von Extfs für Mac helfen
Ubuntu
Installieren Sie Packakges
$ sudo apt install build-essential autopoint bison gperf texi2html texinfo qemu automake-1.15 nasm xorriso qemu-system-i386Installieren Sie GCC Cross Compilier über https://wiki.osdev.org/gcc_cross-compiler#the_build
Installieren Sie GCC (Version 9.1.0) & Binutils (Version 2.32).
Öffnen Sie SRC/Toolchain/Build.sh und ändern
PREFIX="$HOME/opt/cross"
TARGET=i386-pc-mos
# SYSROOT cannot locate inside PREFIX
SYSROOT="$HOME/Projects/mos/src/toolchain/sysroot"
JOBCOUNT=$(nproc)
Installieren Sie MOS Toolchain
$ cd src/toolchain
$ ./build.sh
Emulator ausführen
$ cd src && mkdir logs
$ ./create_image.sh
$ cd ports/figlet && ./package.sh && cd ../..
$ cd ports/bash && ./package.sh make && cd ../..
$ cd ports/coreutils && ./package.sh make && cd ../..
$ ./build.sh qemu iso
Ein anderes Terminal öffnen
$ cd src
$ gdb isodir/boot/mos.bin
# in gdb
(gdb) target remote localhost:1234
(gdb) c
✍️ Um die Benutzerspace -Adresse zum Debuggen zu erhalten
$ i386-mos-readelf -e program
# find the line below and copy Addr
# [Nr] Name Type Addr Off Size ES Flg Lk Inf Al
# [ x] .text PROGBITS xxx xxx xxx 00 AX 0 0 4
Einheitstest
$ cd test && git clone https://github.com/ThrowTheSwitch/Unity.git unity
$ make clean && make
Debuggen
In build.sh addieren Sie -s -S direkt nach qemu , um in den Debug -Modus zu wechseln. Derzeit verwende ich VSCODE + Native Debugug -> Klicken Sie ausführen -> Wählen Sie "an Qemu anhängen".
Überwachung
Standardmäßig geben MOS -Protokolle an Terminal aus. Wenn Sie über Datei überwachen möchten, machen Sie folgende Schritte aus
# src/build.sh#L71
-serial stdio
↓
-serial file:logs/uart1.log
$ tail -f serial.log | while read line ; do echo $line ; done
✍? Die Verwendung von tail in Rohr, um die Ausgabe (wie oben) zu färben