-
Notifications
You must be signed in to change notification settings - Fork 3
94 lines (91 loc) · 3.62 KB
/
main.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
name: build & test
on: [push]
jobs:
build-application:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- run: git submodule update --init
- run: cd deps/pythondata-software-picolibc && git submodule update --init
- run: cd deps/eurorack-pmod && git submodule update --init gateware/external/no2misc
- uses: YosysHQ/setup-oss-cad-suite@v2
- uses: actions-rs/toolchain@v1
with:
toolchain: stable
override: True
components: rustfmt, clippy
target: riscv32imac-unknown-none-elf
- run: cargo install svd2rust
- run: svd2rust --version
- uses: gregdavill/setup-riscv-gnu-toolchain@v2
- run: riscv-none-elf-gcc --version
- name: Install python packages
run: |
python3 -m pip install setuptools
python3 -m pip install pycrc
python3 -m pip install wheel
python3 -m pip install construct
python3 -m pip install Sphinx sphinxcontrib-wavedrom meson ninja setuptools_scm Jinja2
- run: mkdir -p build
# User bitstream
- run: python3 example-colorlight-i5.py --ecppack-compress --flash-boot=0x3E0000 --ecppack-bootaddr 0x100000 --cpu-type vexriscv --cpu-variant imac --csr-svd build/colorlight_i5/csr.svd --uart-baudrate=1000000 --timer-uptime --build
# User firmware
- name: Build firmware (rust)
run: |
cd firmware
BOARD=colorlight_i5 ./build.sh
- name: Firmware FBI
run: |
./bin/crcfbigen.py build/colorlight_i5/rust-fw.bin -f -l -o rust-fw.fbi
- uses: actions/upload-artifact@v3
with:
name: application-artifacts
path: |
build/colorlight_i5/gateware/colorlight_i5.bit
build/colorlight_i5/csr.svd
build/colorlight_i5/rust-fw.bin
rust-fw.fbi
build-bootloader:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- run: git submodule update --init
- run: cd deps/pythondata-software-picolibc && git submodule update --init
- run: cd deps/eurorack-pmod && git submodule update --init gateware/external/no2misc
- uses: YosysHQ/setup-oss-cad-suite@v2
- uses: actions-rs/toolchain@v1
with:
toolchain: stable
override: True
components: rustfmt, clippy
target: riscv32imac-unknown-none-elf
- run: cargo install svd2rust
- run: svd2rust --version
- uses: gregdavill/setup-riscv-gnu-toolchain@v2
- run: riscv-none-elf-gcc --version
- name: Install python packages
run: |
python3 -m pip install setuptools
python3 -m pip install pycrc
python3 -m pip install wheel
python3 -m pip install construct
python3 -m pip install Sphinx sphinxcontrib-wavedrom meson ninja setuptools_scm Jinja2
- run: mkdir -p build
# Bootloader bitstream
- run: python3 example-colorlight-i5.py --ecppack-compress --flash-boot=0x2E0000 --ecppack-bootaddr 0x100000 --cpu-type vexriscv --cpu-variant imac --csr-svd build/colorlight_i5/csr.svd --uart-baudrate=1000000 --timer-uptime --build
# Bootloader firmware
- name: Build firmware (rust)
run: |
cd bootloader
make
- name: Firmware FBI
run: |
./bin/crcfbigen.py bootloader/oc-fw.bin -f -l -o oc-fw.fbi
- uses: actions/upload-artifact@v3
with:
name: bootloader-artifacts
path: |
build/colorlight_i5/gateware/colorlight_i5.bit
build/colorlight_i5/csr.svd
bootloader/oc-fw.bin
oc-fw.fbi