OreSat mission configurations
Project description
OreSat Configs
Firmware/software configurations for OreSat missions.
Includes:
- A centralize "database" for all OreSat card object dictionaries (OD)
- Beacon definition for each OreSat mission
- The C3 F-RAM data definition (object values to be saved to the F-RAM chip)
Having all the OD defined in one place makes it much easier to update OD definitions without having to go to each repo to update each cards OD. Also, the C3 can easily import all the OD definitions to be used for SDO transfers.
How This Works
- All object dictionaries for a specific OreSat mission are defined by YAML
files.
- All the OD configs are in
oresat_configs/base/ - All the beacon configs (
beacon.yaml)are in their mission directories:oresat_configs/oresat<mission_num>/
- All the OD configs are in
- All card specific configs are are named
<card_name>.yamlformat. They contain all card specific objects and PDOs.- NOTE: The cards YAML are similar to CANopen's
.edsfiles; they are for a device type, not a unique device on a CAN network (if you add an object tosolar.yaml, all solar cards will have that object).
- NOTE: The cards YAML are similar to CANopen's
- The
sw_common.yamldefines all CANopen standard objects, common objects, and common PDOs for all Octavo A8-based cards. - The
fw_common.yamldefines all CANopen standard objects, common objects, and common PDOs for all STM32-based cards. - A
standard_object.yamlcontains some CANopen standard objects that any<card_name>.yamlor*_common.yamlcan flag to include. - The
beacon.yamlfile defines the beacon definition as all the data is pulled strait out the C3's OD, which is mostly build from all other ODs. - The
c3.yamlfile also defines what objects have their values periodically saved to the C3's F-RAM chip.
Setup
Install project dev dependencies. libyaml should be installed by default on
reasonable systems, but it never hurts to make sure.
$ sudo apt install libyaml-0-2
$ pip install -r requirements.txt
If installing on ARM (e.g. Octavo cards like the C3) special work is needed to
ensure that pyyaml uses the libyaml C bindings. The binary wheels from PyPI
aren't built with them so we need to install from the source package:
Installing the first time:
$ sudo apt install libyaml-dev
$ pip install --no-binary pyyaml -r requirements.txt
Fixing an already installed pyyaml: (see here if you get "ImportError: pyyaml missing/installed without libyaml bindings.")
$ sudo apt install libyaml-dev
$ pip install --force-reinstall --no-cache-dir --no-binary pyyaml pyyaml
Updating a Config
After updating configs for card(s), run the unit tests to validate all the configs.
$ python3 -m unittest
If there are no errors, the configs are valid.
Build and install the new version of oresat-configs to build, test, and/or import with.
Once the change have been tested with firmware/software, open a Pull Request to this repo to get all changes into the next release.
Build and Install Local Package
Just run the build_and_install.sh script.
$ ./build_and_install.sh
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file oresat_configs-0.8.0.tar.gz.
File metadata
- Download URL: oresat_configs-0.8.0.tar.gz
- Upload date:
- Size: 122.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.9.22
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6369867cb187191c178ed4014ecd79a35a1afd5efdbb82fb155f3a76951c82b6
|
|
| MD5 |
9cea2104de0e663f1c6d3ee382a77d6e
|
|
| BLAKE2b-256 |
a4d8d16d990092b25ea6bbadc3959bff21b30e4f45a43d29075b727f35a27fa5
|
File details
Details for the file oresat_configs-0.8.0-py3-none-any.whl.
File metadata
- Download URL: oresat_configs-0.8.0-py3-none-any.whl
- Upload date:
- Size: 76.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.9.22
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
05e8bd645e2e65b63777d4d8e44698134c781f1b36405afeb9b59ad318bf7b00
|
|
| MD5 |
7012081f99392222f40d8ed53229b8a1
|
|
| BLAKE2b-256 |
bcd40fc0e790efbfcec47d22d144479931cf45326618fbffb88a5ca37a20c368
|