Mirror of CollapseOS
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Virgil Dupras 44bcdd4327 Document 8086 asm instructions list 3 anni fa
blk Document 8086 asm instructions list 3 anni fa
cvm Add word TICKS 3 anni fa
doc Document 8086 asm instructions list 3 anni fa
emul emul/rc2014: add support for Zilog SIO 3 anni fa
recipes Add word TICKS 3 anni fa
tests Move z80a from B200 to B5 3 anni fa
tools tools/blkpack: support multiple dirname arguments 3 anni fa
.build.yml Replace Travis CI with Sourcehut CI 4 anni fa
.gitignore recipes/ti84: move recipe blocks into local overlay 3 anni fa
.gitmodules Move "emul" folder to root 4 anni fa
CONTRIBUTING.md Update CONTRIBUTING with instructions for sending patches 4 anni fa
COPYING Re-license to GPLv3 5 anni fa
README.md doc: move usage documention out of the system 3 anni fa
runtests.sh tests: separate tests that need to run on z80 vs those that don't 4 anni fa

README.md

Collapse OS

Bootstrap post-collapse technology

Collapse OS is a Forth operating system and a collection of tools and documentation with a single purpose: preserve the ability to program micro- controllers through civilizational collapse.

It it designed to:

  1. Run on minimal and improvised machines.
  2. Interface through improvised means (serial, keyboard, display).
  3. Edit text files.
  4. Compile assembler source files for a wide range of MCUs and CPUs.
  5. Read and write from a wide range of storage devices.
  6. Assemble itself and deploy to another machine.

Additionally, the goal of this project is to be as self-contained as possible. With a copy of this project, a capable and creative person should be able to manage to build and install Collapse OS without external resources (i.e. internet) on a machine of her design, built from scavenged parts with low-tech tools.

Getting started

Documentation is in text files in doc/. Begin with intro.txt.

Collapse OS can run on any POSIX platform and builds easily. See /cvm/README.md for instructions.

Alternatively, there's also Michael Schierl's JS Collapse OS emulator which is awesome and allows you to run Collapse OS from your browser, but it isn't always up to date. The “Javascript Forth” version is especially awesome: it's not a z80 emulator, but a javascript port of Collapse OS!

Organisation of this repository

  • blk: Collapse OS filesystem's content. That's actually where Collapse OS’ source code is located. Everything else is peripheral.
  • cvm: A C implementation of Collapse OS, allowing it to run natively on any POSIX platform.
  • doc: Documentation.
  • recipes: collection of recipes that assemble Collapse OS on a specific machine.
  • tools: Tools for working with Collapse OS from “modern” environments. For example, tools for facilitating data upload to a Collapse OS machine through a serial port.
  • emul: Tools for running Collapse OS in an emulated environment.
  • tests: Automated test suite for the whole project.

Status

The project unfinished but is progressing well! See Collapse OS’ website for more information.

Looking for the assembler version?

The Forth-based Collapse OS is the second incarnation of the concept. The first one was entirely written in z80 assembly. If you're interested in that incarnation, checkout the z80asm branch.