CSP Shell or csh
pronounced seashell is a command line interpreter for running CSP and libparam
based applications.
satctl
was originally a piece of software under license from 'Satlab A/S'. Since the current
version of 'spaceinventor/satctl' has nothing to do with satlab or the original satctl
we are changing the name of both the software and the repository to avoid any misunderstanding.
The process will be gradual to avoid too many broken links so the old repo will remain in place for a while still.
But the software will be called csh
(pronounced 'seashell') from now on.
Requirements: libcurl4-openssl-dev build-essential, libsocketcan-dev, can-utils, libzmq3-dev, libyaml-dev, meson, ninja, pkg-config, fonts-powerline, python3-pip, libelf-dev, libbsd-dev libprotobuf-c-dev
sudo apt install libcurl4-openssl-dev git build-essential libsocketcan-dev can-utils libzmq3-dev libyaml-dev pkg-config fonts-powerline python3-pip libelf-dev libbsd-dev libprotobuf-c-dev
sudo pip3 install meson ninja
Sometimes needed:
link /usr/sbin/ninja /usr/local/lib/python3.5/dist-packages/ninja
export PATH=~/.local/bin:$PATH
Build:
git clone --recurse-submodules https://github.com/discosat/csh.git
cd csh
./configure
./install
Prerequisistes:
- you will need to install the ARM gcc package that matches the one used on the targetted RaspberryPI
gcc-12-arm-linux-gnueabihf
for the Debian bookworm based Raspberry Linux'es (32-bit)gcc-aarch64-linux-gnu
for the Debian bookworm based Raspberry Linux'es (64-bit)
- you need a fairly recent version of Docker as well as the
qemu-user-static
package installed on the build PC
Overview:
- build a
sysroot
containing whatever dependencies are needed to build CSH (as of now, this amounts to thelibcurl4-openssl-dev
andlibzmq3-dev
packages) - Configure a Rapsberry-Meson build directory
- Build
Details:
- There are Dockerfiles in
cross/raspberrypi/Dockerfile
that do that for you:
- run
docker build --platform linux/arm/v7 -t sysroot-build-gnueabihf -f Dockerfile_gnueabihf .
to build the image (ARM 32-bit) - run
docker build --platform linux/aarch64 -t sysroot-build-aarch64 -f Dockerfile_aarch64 .
to build the image (ARM 64-bit)
docker run -v /<path>/to/csh/sysroot:/sysroot -e LIST_OF_PACKAGES="libcurl4-openssl-dev libzmq3-dev" --platform linux/arm/v7 -it sysroot-build-gnueabihf
or
docker run -v /<path>/to/csh/sysroot:/sysroot -e LIST_OF_PACKAGES="libcurl4-openssl-dev libzmq3-dev" --platform linux/aarch64 -it sysroot-build-aarch64
to create a usable, shared sysroot located in this example here /<path>/to/csh/sysroot
- run
meson setup --cross-file cross/raspberrypi/cross_raspberrypi_aarch64.txt build-aarch64
ormeson setup --cross-file cross/raspberrypi/cross_raspberrypi_gnueabihf.txt build-gnueabihf
- run
ninja -C build-aarch64
orninja -C build-gnueabihf
To setup CAN sudo is required:
caninit
Then launch two instances
csh -i conf1.csh
and
csh -i conf2.csh
Then on instance 1 type ping 2
Note: you need to setup the two different configuration files, so they can speak to each other, e.g.
csp init
csp add can -d 1
If change of baudrate is requred, give permission for 'csh' to access network configuration in order to setup the CAN interface. When the file is deleted (rebuild) setcap needs to be run again
sudo setcap cap_net_raw,cap_net_admin+ep ./builddir/csh
CSH does not have native support for running in Windows, but it is possible to use Microsoft WSL, to enable support for Windows based machines.
In a powershell, run the following command
wsl --install
After a reboot, you can then start the application WSL to get a virtual Ubuntu environment and follow the guidelines for installing CSH in Linux as above. Windows by default does not forward USB devices to WSL entities. To enable USB forwarding, follow the guide in https://learn.microsoft.com/en-us/windows/wsl/connect-usb.
src/slash_apm.c defines a command, apm load, for loading a shared library as an APM, and a command, ap, info, for listing loaded APMs.
An APM optionally defines the following functions
libmain(int argc, char ** argv)
If defined, this is called once after having loaded the APM. The function is intended to initialize the APM after which it must return, as the CSH command line interface that is calling the function will otherwise hang.
libinfo()
If defined, this is called by the APM info call. The intention is to provide a means of providing information on the state of the APM, like statistics.
See https://github.com/spaceinventor/csh_example for example usage.
The following APMs were implemented as a more thorough test of the APM implementation.
csh_hk
: hk retrieve
For retrieving historical telemetry stored on an OBC.
csh_cortex
: csp add cortex
cortex CSP interface implementation.
csh_cspftp
: FTP client over CSP.
cping
: Concurrent, hence faster, ping and scan in one command cping
.
Observe that hk retrieve and cortex implementation is removed from plain CSH and must be added by addin load command.