-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
81c9522
commit d9c2694
Showing
210 changed files
with
135 additions
and
155 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,5 @@ | ||
# Editor files | ||
*/.vscode/ | ||
.vscode/ | ||
|
||
|
||
# Object files | ||
|
This file was deleted.
Oops, something went wrong.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,10 +1,137 @@ | ||
# oresat-dxwifi-software | ||
[data:image/s3,"s3://crabby-images/d3ebb/d3ebbee41a0e16c76904244ff622a57cf40de780" alt="Build/Test"](https://github.com/oresat/oresat-dxwifi-software/actions/workflows/build_test.yml) | ||
|
||
This repository contains software to run OreSat's DxWifi transmission system. Each folder contains its own subproject with its own README. | ||
## tx-rx | ||
|
||
- `archive` -- Old work performed by the 2019 ECE Capstone Team. | ||
- `error-simulator` -- Software to simulate bit errors and packet loss. | ||
- `fec` -- Software to apply FEC encoding and decoding using the OpenFEC library. | ||
- `tx-rx` -- Software to construct, transmit, and receive data packets via packet injection and monitor mode using the AR9271 chip. | ||
Software to construct, transmit, and receive data packets via packet injection and monitor mode using the AR9271 chip. | ||
|
||
*[Development in progress.]* | ||
## Prerequisites | ||
|
||
- 2 linux capable devices (Raspberry PI, Beaglebone Black, Your laptop etc.) | ||
- 2 WiFi adapters capable of monitor mode (Only tested on Atheros AR9271 chipset) | ||
- [CMake](https://cmake.org/) | ||
- [`libpcap-dev`](https://www.tcpdump.org/), [`libgpiod-dev`](https://git.kernel.org/pub/scm/libs/libgpiod/libgpiod.git/), [`iw`](https://wireless.wiki.kernel.org/en/users/documentation/iw), [`ip`](https://linux.die.net/man/8/ip) | ||
|
||
## Building | ||
|
||
These programs uses [cmake](https://cmake.org/) to generate the correct build files. If | ||
you need to generate a build for a specific platform then I suggest checking out the docs. | ||
For basic GNU Makefiles the following should get you going: | ||
|
||
First, make sure the submodules are updated: | ||
``` | ||
git submodule update --init --recursive | ||
``` | ||
|
||
Then generate build scripts and make the executables | ||
|
||
```bash | ||
mkdir build | ||
cd build && cmake .. | ||
make | ||
``` | ||
|
||
Alternatively, to make multiple out-of-source builds you can do the following | ||
with any of the default configurations: *Debug, Release, RelWithDebInfo, MinSizeRel* | ||
``` | ||
cmake -S . -B build/Debug -DCMAKE_BUILD_TYPE=Debug | ||
cmake --build build/Debug | ||
``` | ||
|
||
The executables are located in `bin` and libraries in `lib`. You can also build a | ||
specific target with | ||
|
||
``` | ||
cmake --build --target dxwifi | ||
``` | ||
|
||
**Note**: If you're using VSCode I **highly** recommend just using the | ||
[CMake Tools](https://marketplace.visualstudio.com/items?itemName=ms-vscode.cmake-tools) | ||
extension. | ||
|
||
## Installation and Packaging | ||
|
||
With the project built and cmake files present in the `build` directory you do the following: | ||
|
||
``` | ||
make install | ||
``` | ||
|
||
This will install the `rx`, `tx`, and `startmonitor` programs into `/usr/bin` as well as define the `oresat-dxwifi-txd.service` | ||
daemon that you can start with `systemctl start oresat-dxwifi-txd.service`. | ||
|
||
To build debian packages to install you can run the following in the `build` directory: | ||
|
||
``` | ||
cpack # or `make package` | ||
``` | ||
|
||
This will create two debian packages `oresat-dxwifi-rx_<version>_<arch>.deb` and `oresat-dxwifi-tx_<version>_<arch>.deb`. The **RX** package just | ||
installs the `rx` program. The **TX** package installs `tx`, `startmonitor` and the `oresat-dxwifi-txd.service` daemon. | ||
|
||
**Note**: The `oresat-dxwifi-txd.service` daemon is currently configured for testing on OreSat 0, as such all it does is transmit a test sequence of bytes ad infinitum or until stopped. | ||
|
||
## Usage | ||
|
||
On the receiver | ||
``` | ||
sudo ./startMonitor.sh mon0 | ||
sudo ./rx --dev mon0 copy.md | ||
``` | ||
|
||
On the transmitter | ||
``` | ||
sudo ./startMonitor.sh mon0 | ||
sudo ./tx --dev mon0 README.md | ||
``` | ||
|
||
Congratulations you just copied this readme to the receiving device! | ||
(*Note* change `mon0` to the name of *your* network device) | ||
|
||
Both the receiver and transmitter support a variety of different options. You can get a full list | ||
of options with the `--help` option. | ||
|
||
Here's an example where we set the receiver to output received files in the `test/` directory with the file format of `test_n.raw`, | ||
timeout after 10 seconds without receiving a packet, log everything, strictly order the packets and fill in missing packets with noise, and | ||
only capture packets whose addressed to 11:22:33:44:55:66. | ||
``` | ||
sudo ./rx --dev mon0 -v 6 --ordered --add-noise --timeout 10 --extension raw --prefix test --filter="wlan addr1 11:22:33:44:55:66" test/ | ||
``` | ||
|
||
And for the transmitter we set it to transmit everything in the `dxwifi` directory matching the glob pattern `*.md` and listen for new files, timeout after 20 seconds | ||
of no new files, transmit each file into 512 byte blocks, send 5 redundant control frames, and delay 10ms between each tranmission block and 10ms between each file transmission. | ||
``` | ||
sudo ./tx --dev mon0 --blocksize 512 --redundancy 5 --delay 10 --file-delay 10 --filter "*.md" --include-all --watch-timeout 20 dxwifi/ | ||
``` | ||
|
||
**Note**: When doing multi-file transmission like the example above, it's critical to set the `--file-delay` and `--redundancy` parameters | ||
to something reasonable for your channel. If these parameters are not set then file boundaries will not be clearly delimited to the receiver. | ||
|
||
## System Tests | ||
|
||
To run the system tests first you'll need to compile the project with `DXWIFI_TESTS` defined. | ||
The project Cmake file defines two build configurations with this macro enabled, `TestDebug` and `TestRel`. | ||
Building with this macro defined will force `tx`/`rx` to run in *offline* mode causing them to write or read | ||
packetized data from a `savefile`. With the correct binaries built, simply run the following to execute the tests: | ||
|
||
``` | ||
python -m unittest | ||
``` | ||
|
||
## Cross Compilation | ||
|
||
Currently DxWiFi only supports cross-compilation for the `armv7l` architecture. To setup cross-compilation for `armv7l` you'll first | ||
need to setup your toolchain. | ||
|
||
```bash | ||
sudo apt install gcc-arm-linux-gnueabihf g++-arm-linux-gnueabihf qemu-user-static debootstrap -y | ||
sudo qemu-debootstrap --arch armhf buster /mnt/data/armhf http://deb.debian.org/debian/ | ||
sudo chroot /mnt/data/armhf | ||
apt-get install libpcap-dev | ||
``` | ||
|
||
This will install the armhf version of `libpcap-dev` in `mnt/data/armhf/lib/arm-linux-gnueabihf`. Then you can generate the | ||
correct build scripts with: | ||
|
||
``` | ||
cmake -S . -B build -DPLATFORM=armhf | ||
``` |
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes
File renamed without changes.
File renamed without changes
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
This file was deleted.
Oops, something went wrong.
Submodule rscode
deleted from
d18eb0