sat-rs: A library to build on-board software for remote systems
Go to file
Robin Mueller 2ef3057771
Some checks are pending
Rust/sat-rs/pipeline/head Build started...
extracted event handling
2024-02-05 17:48:53 +01:00
.idea/runConfigurations remove spacepackets run configs 2023-01-25 23:04:32 +01:00
automation remove those trailing slashes 2023-12-11 15:12:50 +01:00
images single source event manager graph, fix doc build 2024-01-30 23:27:22 +01:00
misc lets try this out 2023-09-06 21:56:48 +02:00
satrs-book need a copy of that image here 2024-01-31 14:34:50 +01:00
satrs-core extracted event handling 2024-02-05 17:48:53 +01:00
satrs-example extracted event handling 2024-02-05 17:48:53 +01:00
satrs-example-stm32f3-disco add license file 2023-01-25 22:20:12 +01:00
satrs-mib the check finally works again 2023-12-13 15:49:26 +01:00
.gitignore ignore Cargo.lock 2023-01-25 21:41:33 +01:00
.gitmodules remove spacepackets submodule 2023-01-25 20:37:28 +01:00
Cargo.toml added more tests 2023-09-21 16:34:18 +02:00
coverage.py add coverage 2023-12-01 22:21:12 +01:00
LICENSE-APACHE add license files 2022-06-18 22:47:10 +02:00
NOTICE add credit 2023-09-06 21:58:56 +02:00
README.md add coverage 2023-12-01 22:21:12 +01:00

sat-rs

This is the repository of the sat-rs framework. Its primary goal is to provide re-usable components to write on-board software for remote systems like rovers or satellites. It is specifically written for the special requirements for these systems. You can find an overview of the project and the link to the more high-level sat-rs book at the IRS documentation website.

A lot of the architecture and general design considerations are based on the FSFW C++ framework which has flight heritage through the 2 missions FLP and EIVE.

Overview

This project currently contains following crates:

  • satrs-book: Primary information resource in addition to the API documentation, hosted here. It can be useful to read this first before delving into the example application and the API documentation.
  • satrs-core: Core components of sat-rs.
  • satrs-example: Example of a simple example on-board software using various sat-rs components which can be run on a host computer or on any system with a standard runtime like a Raspberry Pi.
  • satrs-mib: Components to build a mission information base from the on-board software directly.
  • satrs-example-stm32f3-disco: Example of a simple example on-board software using sat-rs components on a bare-metal system with constrained resources.

Each project has its own CHANGELOG.md.

Related projects

In addition to the crates in this repository, the sat-rs project also maintains other libraries.

  • spacepackets: Basic ECSS and CCSDS packet protocol implementations. This repository is re-exported in the satrs-core crate.

Coverage

Coverage was generated using grcov. If you have not done so already, install the llvm-tools-preview:

rustup component add llvm-tools-preview
cargo install grcov --locked

After that, you can simply run coverage.py to test the satrs-core crate with coverage. You can optionally supply the --open flag to open the coverage report in your webbrowser.