Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/w84death/smolos
smolOS - a tiny and simple ๐งช research โ๏ธ operating system โจ๏ธ written in ๐ MicroPython for microcontrollers giving user a POSIX-like ๐ environment and ๐งฐ tools to play.
https://github.com/w84death/smolos
esp8266 micropython micropython-esp8266 neopixels operating-system os research-project rp2040 seeeduino-xiao xiao
Last synced: 5 days ago
JSON representation
smolOS - a tiny and simple ๐งช research โ๏ธ operating system โจ๏ธ written in ๐ MicroPython for microcontrollers giving user a POSIX-like ๐ environment and ๐งฐ tools to play.
- Host: GitHub
- URL: https://github.com/w84death/smolos
- Owner: w84death
- License: mit
- Created: 2023-07-09T21:16:34.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-12-29T21:34:46.000Z (22 days ago)
- Last Synced: 2025-01-09T01:36:31.985Z (12 days ago)
- Topics: esp8266, micropython, micropython-esp8266, neopixels, operating-system, os, research-project, rp2040, seeeduino-xiao, xiao
- Language: Python
- Homepage: http://smol.p1x.in/os/
- Size: 1.21 MB
- Stars: 156
- Watchers: 11
- Forks: 13
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# smolOS
## Specialized Microcontroller-Oriented Lightweight Operating System**smolOS** is a tiny (<20KB, <500LOC) and simple ๐งช research โ๏ธ operating system โจ๏ธ written in ๐ MicroPython for microcontrollers giving user a POSIX-like ๐ environment to play. It came with a set of ๐งฐ tools and ๐ช demos.
The system should run on any MicroPython supported board but it's tested and developed on [Seeed Studio XIAO RP2040](https://www.seeedstudio.com/XIAO-RP2040-v1-0-p-5026.html),
### Official homepage:
- [smol.p1x.in/os/ (http)](http://smol.p1x.in/os/)
- [smol.p1x.in/os/ (https)](https://smol.p1x.in/os/)![smolOS XIAO](media/smolos.png)
### Real Life Use cases
* listing and removing unwanted files on board
* checking free space
* easy way to write simple programs and run them from the OS
* quicly iterating parameters for a program
* editing small bugs in programs
* having fun with microcontrollers### smolOS Features
* Changes microcontroller into a small working PC
* Homemade for fun and learning
* Super small and fast
* Easy to use, simillar to MS-DOS, POSIX-like environments
* List and manipulates files
* Text editor included (very basic but capable)
* Basic tools and demos included (for NeoPixels, Buzzers, LEDs)
* Build on MicroPython with clear code
* Stability and simplicity are the main principle behind the code
* Free and open :)### Additoinal Programs
* ansi - Displays ANSI escape codes
* life - Game of Life implementation for smolOS (text)
* buzz - Simple synthezator for 1-bit music (requies a buzzer)
* bytebeat - Implementation of ByteBeat for a buzzerAll of those are for NeoPixel Grid 5x5 BFF:
* duck - Yellow Rubber Duck for programmers
* neolife - Game of Life implementation
* pixel - Tools for playing with one LED
* plasma - Demoscene plasma effect
* font - Font bitmaps (for scroller)
* scroller - Scrolls text## Installation
### Super Quick Quide
* put main system file ```smolos.py``` onto the board flash (that has latest MicroPython firmware)
* (optional) for auto-boot copy ```main.py``` too
* restart device### Detailed Guides
* [XIAO RP2040 Guide](docs/XIAO-RP2040.md)
* [ESP8266 Guide](docs/ESP8266.md)## Connecting
As normal user:```
$ picocom /dev/ttyACM0
```
Press ```ctrl+a+x``` to exit.## Running
First start. Or after flashing new main.py file. Restart the microcontroller:
```
>>> machine.soft_reset()
```### Autoboot
This should restart the device and "boot" you into the smolOS. Like so:![smolOS XIAO](media/smolos.png)
### Manual
If you put ```smolos.py``` then you need to boot the system by hand.
In MicroPython REPL write:
```
>>> from smolos import smolOS
>>> os = smolOS()
>>> os.boot()
```## Using
Write `help` for manual :)
![smolOS list](media/list.png)
![smolOS help](media/help.png)
![smolOS editor](media/edit.png)
## Intresting forks
- [smolOS by rbenrax](https://github.com/rbenrax/smolOS) - very nice, goes as close to the POSIX as you can get!
- [pegasusOS by 047pegasus](https://github.com/047pegasus/pegasusOS) - adds easy networking## Missing Features / ROADMAP
Some kind of a roadmap (from high to low priority)
- os: move/copy files
- (external, threaded programs) check exception for used core instead of class variable
- good manual## Articles
- [hackster.io](https://www.hackster.io/news/krzysztof-jankowski-s-micropython-based-smolos-puts-a-tiny-posix-like-environment-on-your-esp8266-0c776559152b)
- [cnx-software.com](https://www.cnx-software.com/2023/07/12/smolos-brings-a-linux-like-command-line-interface-to-esp8266-microcontroller/)
- [lobste.rs](https://lobste.rs/s/ipztxc/smolos_small_os_for_micropython_on)