Skip to main content

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 card specific configs are are named <card_name>.yaml format. They contain all card specific objects and PDOs.
    • NOTE: The cards YAML are similar to CANopen's .eds files; they are for a device type, not a unique device on a CAN network (if you add an object to solar.yaml, all solar cards will have that object).
  • The sw_common.yaml defines all CANopen standard objects, common objects, and common PDOs for all Octavo A8-based cards.
  • The fw_common.yaml defines all CANopen standard objects, common objects, and common PDOs for all STM32-based cards.
  • A standard_object.yaml contains some CANopen standard objects that any <card_name>.yaml or *_common.yaml can flag to include.
  • The beacon.yaml file 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.yaml file 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

oresat_configs-0.8.0.tar.gz (122.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

oresat_configs-0.8.0-py3-none-any.whl (76.8 kB view details)

Uploaded Python 3

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

Hashes for oresat_configs-0.8.0.tar.gz
Algorithm Hash digest
SHA256 6369867cb187191c178ed4014ecd79a35a1afd5efdbb82fb155f3a76951c82b6
MD5 9cea2104de0e663f1c6d3ee382a77d6e
BLAKE2b-256 a4d8d16d990092b25ea6bbadc3959bff21b30e4f45a43d29075b727f35a27fa5

See more details on using hashes here.

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

Hashes for oresat_configs-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 05e8bd645e2e65b63777d4d8e44698134c781f1b36405afeb9b59ad318bf7b00
MD5 7012081f99392222f40d8ed53229b8a1
BLAKE2b-256 bcd40fc0e790efbfcec47d22d144479931cf45326618fbffb88a5ca37a20c368

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page