Skip to content

update changelog for maia-sdr-v0.4.0 #6

update changelog for maia-sdr-v0.4.0

update changelog for maia-sdr-v0.4.0 #6

name: 'build-firmware'
on:
push:
branches:
- test-build
tags:
- maia-sdr-*
# TODO: refactor this as a workflow_call action
jobs:
build-plutosdr:
name: Build Pluto SDR firmware
runs-on: [self-hosted, vivado]
container:
image: ghcr.io/maia-sdr/maia-sdr-devel:latest
volumes:
- vivado2021_2:/opt/Xilinx
options: --user root
steps:
- uses: actions/checkout@v3
with:
submodules: recursive
- name: Build firmware
# xsct, which is run by the make process, uses Xvfb, which usually needs a
# connection to an X server (even though it is a CLI application). We run
# Xvfb in the container to create a "fake" X session that makes xsct
# happy.
#
# We cannot '.' the main settings.sh file for Vivado, because it uses
# 'source' to run the sub-files, and we are not using bash. Instead, we
# '.' each individual sub-file.
run: |
. /opt/Xilinx/Vitis/2021.2/.settings64-Vitis.sh
. /opt/Xilinx/Vivado/2021.2/.settings64-Vivado.sh
. /opt/Xilinx/Vitis_HLS/2021.2/.settings64-Vitis_HLS.sh
. /opt/rust/env
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin/:/usr/bin:/sbin:/bin:/opt/gcc-arm-linux-gnueabi/bin:$PATH:/opt/oss-cad-suite/bin
export PYTHONPATH=/usr/local/lib/python3.10/dist-packages
apt-get update
DEBIAN_FRONTEND=noninteractive apt-get install -y xvfb
Xvfb :10 &
export DISPLAY=:10
make
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: maia-sdr-pluto-firmware
path: |
build/plutosdr-fw-*.zip
build/plutosdr-jtag-bootstrap-*.zip
build/system_top.xsa
if-no-files-found: error
# The working directory in the self-hosted runner needs be cleaned before
# building. We use if: ${{ always() }} to clean even if the build fails.
- name: Clean up runner working dir
uses: TooMuch4U/actions-clean@v2.1
if: ${{ always() }}
build-plutoplus:
name: Build Pluto+ firmware
runs-on: [self-hosted, vivado]
container:
image: ghcr.io/maia-sdr/maia-sdr-devel:latest
volumes:
- vivado2021_2:/opt/Xilinx
options: --user root
steps:
- uses: actions/checkout@v3
with:
submodules: recursive
- name: Build firmware
# xsct, which is run by the make process, uses Xvfb, which usually needs a
# connection to an X server (even though it is a CLI application). We run
# Xvfb in the container to create a "fake" X session that makes xsct
# happy.
#
# We cannot '.' the main settings.sh file for Vivado, because it uses
# 'source' to run the sub-files, and we are not using bash. Instead, we
# '.' each individual sub-file.
run: |
. /opt/Xilinx/Vitis/2021.2/.settings64-Vitis.sh
. /opt/Xilinx/Vivado/2021.2/.settings64-Vivado.sh
. /opt/Xilinx/Vitis_HLS/2021.2/.settings64-Vitis_HLS.sh
. /opt/rust/env
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin/:/usr/bin:/sbin:/bin:/opt/gcc-arm-linux-gnueabi/bin:$PATH:/opt/oss-cad-suite/bin
export PYTHONPATH=/usr/local/lib/python3.10/dist-packages
apt-get update
DEBIAN_FRONTEND=noninteractive apt-get install -y xvfb
Xvfb :10 &
export DISPLAY=:10
TARGET=plutoplus make
- name: Upload artifacts
uses: actions/upload-artifact@v3
with:
name: maia-sdr-plutoplus-firmware
path: |
build/plutoplus-fw-*.zip
build/plutoplus-jtag-bootstrap-*.zip
build/system_top.xsa
if-no-files-found: error
# The working directory in the self-hosted runner needs be cleaned before
# building. We use if: ${{ always() }} to clean even if the build fails.
- name: Clean up runner working dir
uses: TooMuch4U/actions-clean@v2.1
if: ${{ always() }}