From ed0f77e1c70c3e3e9765edfe6a6718813a501c3a Mon Sep 17 00:00:00 2001 From: Ryan Howard Date: Wed, 10 Apr 2024 13:39:34 -0400 Subject: [PATCH] chore(cmake): Add sensor variant firmware ci (#766) * add a configure and build preset for the special sensor firmware * add a build task that builds just the applications, we don't need the images, and we don't need the release * make the workflow task have a better name * ignore the dist-sensor directory * guess we gotta build the images for install to run * use the other preset in the test gitub workflow --- .github/workflows/build_sensor_fw.yaml | 44 +++++++++++++++++++ .../cross-compile-special-sensors.yaml | 14 +++--- .gitignore | 2 + CMakePresets.json | 22 ++++++++++ 4 files changed, 75 insertions(+), 7 deletions(-) create mode 100644 .github/workflows/build_sensor_fw.yaml diff --git a/.github/workflows/build_sensor_fw.yaml b/.github/workflows/build_sensor_fw.yaml new file mode 100644 index 000000000..d6e4e6d52 --- /dev/null +++ b/.github/workflows/build_sensor_fw.yaml @@ -0,0 +1,44 @@ +name: "Build firmware sensor variant bundles" +on: + push: + branches: + - '*' + tags: + - 'v*' + workflow_dispatch: + +env: + ci: 1 + +defaults: + run: + shell: bash + +jobs: + build: + name: "Build" + runs-on: "ubuntu-latest" + timeout-minutes: 20 + steps: + - uses: "actions/checkout@v2" + with: + fetch-depth: 0 + - uses: "actions/cache@v3" + with: + path: "./stm32-tools" + key: ${{ runner.os }}-${{ hashFiles('**/cmake/*') }}-${{ secrets.CACHE_VERSION }} + - name: 'CMake configure' + run: | + cmake --preset=cross-sensor-buffer . -DCMAKE_BUILD_TYPE=RelWithDebInfo + - name: 'Build images' + run: | + cmake --build --preset=firmware-g4-sensors --target firmware-applications firmware-images + - name: 'Prep images for upload' + run: | + cmake --install ./build-cross-sensor + - name: 'Upload application artifact' + uses: actions/upload-artifact@v3 + with: + name: 'firmware-applications-${{github.ref_name}}' + path: | + dist-sensor/applications/* diff --git a/.github/workflows/cross-compile-special-sensors.yaml b/.github/workflows/cross-compile-special-sensors.yaml index f4ab712f2..ff1038851 100644 --- a/.github/workflows/cross-compile-special-sensors.yaml +++ b/.github/workflows/cross-compile-special-sensors.yaml @@ -1,4 +1,4 @@ -name: "cross-compile/format/lint all targets" +name: "cross-compile-sensors/format/lint all targets" on: push: branches: @@ -47,10 +47,10 @@ jobs: cache-version: ${{ secrets.CACHE_VERSION }} - name: Configure - run: cmake --preset=cross . -DUSE_PRESSURE_MOVE=true + run: cmake --preset=cross-sensor-buffer . - name: Build all STM32G4 applications - run: cmake --build --preset=${{ matrix.target }} --target ${{ matrix.target }}-images ${{ matrix.target }}-applications + run: cmake --build ./build-cross-sensor --target ${{ matrix.target }}-images ${{ matrix.target }}-applications format: runs-on: "ubuntu-20.04" @@ -76,10 +76,10 @@ jobs: cache-version: ${{ secrets.CACHE_VERSION }} - name: Configure - run: cmake --preset=cross . -DUSE_PRESSURE_MOVE=true + run: cmake --preset=cross-sensor-buffer . - name: Format - run: cmake --build ./build-cross --target format-ci + run: cmake --build ./build-cross-sensor --target format-ci lint: runs-on: "ubuntu-20.04" @@ -110,7 +110,7 @@ jobs: cache-version: ${{ secrets.CACHE_VERSION }} - name: Configure - run: cmake --preset=cross . -DUSE_PRESSURE_MOVE=true + run: cmake --preset=cross-sensor-buffer . - name: Format - run: cmake --build ./build-cross --target ${{ matrix.target }}-lint + run: cmake --build ./build-cross-sensor --target ${{ matrix.target }}-lint diff --git a/.gitignore b/.gitignore index f550a95a5..19900ef61 100644 --- a/.gitignore +++ b/.gitignore @@ -5,6 +5,7 @@ CMakeUserPresets.json *.pyc build-cross/ build-cross-pipettes/ +build-cross-sensor/ stm32-tools/ build-host/ cmake-build-debug/ @@ -17,3 +18,4 @@ state_manager/coverage.xml state_manager/dist/ state_manager/poetry.toml dist/ +dist-sensor/ diff --git a/CMakePresets.json b/CMakePresets.json index de644b8f5..6dbf1c62d 100644 --- a/CMakePresets.json +++ b/CMakePresets.json @@ -35,6 +35,17 @@ "binaryDir": "${sourceDir}/build-cross", "inherits": "cross-no-directory-reqs" }, + { + "name": "cross-sensor-buffer", + "displayName": "STM32 G4 OT-3 cross-compilation with sensor data buffers", + "description": "Build application firmware for OT-3 systems that use STM32, for flashing onto boards", + "installDir": "${sourceDir}/dist-sensor", + "binaryDir": "${sourceDir}/build-cross-sensor", + "cacheVariables": { + "USE_PRESSURE_MOVE": true + }, + "inherits": "cross" + }, { "name": "host", "displayName": "STM32 OT-3 host compilation for tests", @@ -88,6 +99,17 @@ "firmware-images" ] }, + { + "name": "firmware-g4-sensors", + "displayName": "All G4 Firmwares With Sensor Data Buffers", + "description": "Environment to build all g4 firmware - see firmware-l5", + "configurePreset": "cross-sensor-buffer", + "jobs": 4, + "targets": [ + "firmware-applications", + "firmware-images" + ] + }, { "name": "pipettes", "displayName": "pipettes binaries",