Update firmware workflow and README

This commit is contained in:
Dave 2022-09-07 21:56:24 -05:00
parent 51022040f1
commit 69d5d16544
2 changed files with 123 additions and 31 deletions

View File

@ -1,25 +1,37 @@
name: asdf-firmware name: asdf-firmware
on:
push: push:
branches: branches:
asdf-release asdf-release
asdf-build-test asdf-build-test
uses: lukka/get-cmake@latest
jobs: jobs:
build_firmware: build_firmware:
runs-on: ubuntu-latest runs-on: ubuntu-latest
container: { image: alpine }
defaults:
run:
shell: sh
steps: steps:
- run: apt-get install gcc-avr binutils-avr avr-libc - name: install_git_and_bash
- run: snap install cmake run: apk add bash git rsync
- name: checkout
uses: actions/checkout@v2
- run: apk add gcc-avr binutils-avr avr-libc
- run: apk add cmake make
- run: apk add python3 py3-pip
- run: pip install -U sphinx sphinx-rtd-theme sphinx-autodoc-typehints - run: pip install -U sphinx sphinx-rtd-theme sphinx-autodoc-typehints
- run: pip install -U sphinxcontrib-napoleon - run: pip install -U sphinxcontrib-napoleon
- run: pip install -U toml build - run: pip install -U toml
- run: pip install pipenv
# Create the build directories, make all targets, and copy # Create the build directories, make all targets, and copy
# hex files to sphinx source directory for download links # hex files to sphinx source directory for download links
- run: bash ./make-targets.sh -a -p -i -s - run: cd firmware/asdf; /bin/bash ./make-targets.sh -a -i -s
- run: mkdir public - run: mkdir public; touch public/.nojekyll
- run: sphinx-build -b html docs/source public - run: sphinx-build -b html firmware/asdf/docs/source public
- name: Deploy
uses: JamesIves/github-pages-deploy-action@v4
with:
folder: public

View File

@ -1,5 +1,5 @@
ASDF Keyboard scanning firmware # ASDF Keyboard scanning firmware
-
This is a key matrix scanner that can detect and debounce keypress and release This is a key matrix scanner that can detect and debounce keypress and release
events on a key matrix and either send codes or perform actions on keypress or events on a key matrix and either send codes or perform actions on keypress or
release. Keymaps are defined per application and may, for example, generate release. Keymaps are defined per application and may, for example, generate
@ -18,8 +18,12 @@ ASDF supports basic keyboard functionality and is configurable via a few
boolean variables, and via the key maps. The key maps are organized in boolean variables, and via the key maps. The key maps are organized in
row,column format, with separate keymaps shift, capslock, and control-key modes. row,column format, with separate keymaps shift, capslock, and control-key modes.
Features: ## Downloads:
--
Download the latest release of the firmware [here](https://osiweb.github.io/unified_retro_keyboard)
## Features:
--------
* modifiers: A set of modifier keys may be specified. When only a few modifiers * modifiers: A set of modifier keys may be specified. When only a few modifiers
are used, this mechanism is a low-overhead alternative to a keymap overlay for are used, this mechanism is a low-overhead alternative to a keymap overlay for
keyboard states that only change the key codes produced by a keypress, such as keyboard states that only change the key codes produced by a keypress, such as
@ -59,22 +63,98 @@ Features:
* ASCII output - supported via output_value function. * ASCII output - supported via output_value function.
* Virtual Output layer: Indicator LEDs and other direct logic-level hardware controls: supported via * Virtual Output layer: Indicator LEDs and other direct logic-level hardware
a virtual output layer. The keymaps (and certain functions such as shiftlock and capslock) may bind virtual outputs. The keymaps may then specify how the virtual outputs map to the available physical resources. This allows one keymap to place the capslock LED in one position, and another keymap may place the capslock LED elswhere. This simplifies support of multiple keyboards and keymaps. controls: supported via a virtual output layer. The keymaps (and certain
functions such as shiftlock and capslock) may bind virtual outputs. The keymaps
may then specify how the virtual outputs map to the available physical
resources. This allows one keymap to place the capslock LED in one position,
and another keymap may place the capslock LED elswhere. This simplifies support
of multiple keyboards and keymaps.
Compiling and configuration ## Compiling and configuration
--
The source files are in the ./src directory. The final build files go in the ./build directory.
To build, enter the ./src directory. You should be able to build a binary and ### building using github actions:
hex file suitable for programming a microcontroller by typing "Make". You may
edit the Makefile to specify your target platform (default is Atmega328P ASCII
controller). You may also wish to edit your preferences in "asdf_config.h" to
specify repeat timings, optimize the debounce setting (if you have very bounce
keys), and specify the character output buffer size (if you are implementing
macros, etc.)
Porting If you have commit privileges to the repository, or if you have your own fork,
then push a commit to one of the following branches to trigger an automatic build:
- asdf-release
- asdf-build-test
This will generate a github page with downloadable hex files. You will find the
link to the github page in the "Actions" tab of the repository.
### build using the make-build-dirs.sh script.
------------------------------------------
1) Run the make-targets.sh script
Options:
-x Before creating a build directgory or virtual env, remove
any pre-existing version
-t add an architecture directory
-a Add all valid architecture directories
-i Build each specified target and install to dist directory
-p Install pipenv virtual environment for python scripts
-c Clean all artifacts
-s Copy dist files to sphinx directory
Valid targets: atmega640, atmega1280, atmega2560
- To create build directories for all targets and install the python virtual environment:
> bash make-targets.sh -ap
- To create a a build directory for atmega1280, deleting any pre-existing directory:
> bash make-targets.sh -xt atmega280
- To remove and rebuild the python virtual environment:
> bash make-targets.sh -xp
- To copy hex files to sphinx source tree (Requres the hex files
to be installed in ./dist either from make install in each target
directory, or 'bash make-targets.sh -ai')
> bash make-targets.sh -s
- From a fresh checkout, build all targets and install hex files in
sphinx tree for the download links:
> bash make-targets -pais
2) Enter the build directory for the desired architecture and build:
Only needed if working on single target. To make all targets at once,
use the make-targest script described in step 1.
Example: building the atmega2560 binary:
> cd build-atmega2560
> make
3) Build the sphinx documentation:
> cd docs
> pipenv run make html
### build manually (e.g., for development)
==============
1) make and build directories for the desired architectures:
> mkdir build-atmega328p build-atmega640
3) enter each build directory and run cmake for the desired architecture.
This step will also install the resulting hex files to the ./dist subdirectory.
> cd build-atmega2560
> cmake .. -DARCH=atmega2560 -DCMAKE_INSTALL_PRESFIX=.. -DCMAKE_BUILD_TYPE=RELEASE
> make install
## Porting
-- --
This firmware was written in modular, portable C99, to be compiled with GCC This firmware was written in modular, portable C99, to be compiled with GCC
(avr-gcc for the Atmega). The hardware-sepecific files are in Arch/*.[ch]. To (avr-gcc for the Atmega). The hardware-sepecific files are in Arch/*.[ch]. To