Skip to content

Commit 79ada2c

Browse files
authored
Merge pull request #246 from nicola-lunghi/nicolal/add-gh-ci
TonexOneController: add ci to build the system
2 parents 2660402 + c022811 commit 79ada2c

File tree

3 files changed

+123
-18
lines changed

3 files changed

+123
-18
lines changed

.github/workflows/ci.yaml

Lines changed: 92 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,92 @@
1+
name: ESP-IDF Build
2+
3+
on:
4+
push:
5+
branches:
6+
- main
7+
pull_request:
8+
branches:
9+
- main
10+
workflow_dispatch: # Allows manual triggering from the Actions page
11+
12+
env:
13+
JSON_CONFIG_FILE: "source/esp_idf_project_configuration.json"
14+
15+
jobs:
16+
extract-config:
17+
runs-on: ubuntu-latest
18+
outputs:
19+
platforms: ${{ steps.extract-platforms.outputs.platforms }}
20+
steps:
21+
- run: env | sort
22+
23+
- name: Checkout repository
24+
uses: actions/checkout@v4
25+
with:
26+
sparse-checkout: |
27+
${{ env.JSON_CONFIG_FILE }}
28+
sparse-checkout-cone-mode: false
29+
30+
- run: find . -type f
31+
32+
- run: which jq && jq --version
33+
34+
- name: Extract the keys (platform names) from the JSON file
35+
id: extract-platforms
36+
run: echo "platforms=$(jq -c 'keys' ${{ env.JSON_CONFIG_FILE }})" | tee -a ${GITHUB_OUTPUT}
37+
38+
build:
39+
name: Build ${{ matrix.platform }}
40+
needs: extract-config
41+
runs-on: ubuntu-latest
42+
strategy:
43+
fail-fast: false
44+
matrix:
45+
platform: ${{ fromJson(needs.extract-config.outputs.platforms) }}
46+
47+
steps:
48+
- run: env | sort
49+
50+
- name: Checkout repository
51+
uses: actions/checkout@v4
52+
with:
53+
clean: true
54+
# submodules: 'recursive'
55+
sparse-checkout: |
56+
source/
57+
58+
- name: Setup ccache
59+
uses: hendrikmuhs/ccache-action@v1
60+
with:
61+
key: ${{ github.job }}-${{ matrix.platform }}
62+
evict-old-files: 'job'
63+
64+
- run: find . -type f -and -not -path './.git/*' -not -path './.ccache/*'
65+
66+
- run: which jq && jq --version
67+
68+
- name: Set SDKCONFIG_DEFAULTS for ${{ matrix.platform }}
69+
run: echo "SDKCONFIG_DEFAULTS=$(jq -r '.${{ matrix.platform }}.build.sdkconfigDefaults | join(";")' ${{ env.JSON_CONFIG_FILE }})" | tee -a ${GITHUB_ENV:?}
70+
71+
- run: env | sort
72+
73+
- name: esp-idf build
74+
uses: espressif/esp-idf-ci-action@v1
75+
with:
76+
path: 'source'
77+
# esp_idf_version: v5 # optional, default is latest
78+
target: esp32s3 # optional, default is esp32
79+
extra_docker_args: "-v ./.ccache:/root/.ccache -e CCACHE_DIR=/root/.ccache -e SDKCONFIG_DEFAULTS"
80+
command: "idf.py build"
81+
82+
- run: find ./source/build -type f
83+
84+
- run: ccache --print-stat
85+
86+
- uses: actions/upload-artifact@v4
87+
with:
88+
name: build-${{ matrix.platform }}
89+
path: |
90+
source/build/**/*.bin
91+
source/build/flasher_args.json
92+
if-no-files-found: error

source/esp_idf_project_configuration.json

Lines changed: 18 additions & 18 deletions
Original file line numberDiff line numberDiff line change
@@ -5,8 +5,8 @@
55
"ninjaArgs": [],
66
"buildDirectoryPath": "${workspaceFolder}/build_ws169",
77
"sdkconfigDefaults": [
8-
"sdkconfig.ws169",
9-
"sdkconfig.defaults"
8+
"sdkconfig.defaults",
9+
"sdkconfig.ws169"
1010
],
1111
"sdkconfigFilePath": "${workspaceFolder}/build_ws169"
1212
},
@@ -57,8 +57,8 @@
5757
"ninjaArgs": [],
5858
"buildDirectoryPath": "${workspaceFolder}/build_ws169t",
5959
"sdkconfigDefaults": [
60-
"sdkconfig.ws169t",
61-
"sdkconfig.defaults"
60+
"sdkconfig.defaults",
61+
"sdkconfig.ws169t"
6262
],
6363
"sdkconfigFilePath": "${workspaceFolder}/build_ws169t"
6464
},
@@ -109,8 +109,8 @@
109109
"ninjaArgs": [],
110110
"buildDirectoryPath": "${workspaceFolder}/build_ws43b_as",
111111
"sdkconfigDefaults": [
112-
"sdkconfig.ws43b_as",
113-
"sdkconfig.defaults"
112+
"sdkconfig.defaults",
113+
"sdkconfig.ws43B_as"
114114
],
115115
"sdkconfigFilePath": "${workspaceFolder}/build_ws43b_as"
116116
},
@@ -135,8 +135,8 @@
135135
"ninjaArgs": [],
136136
"buildDirectoryPath": "${workspaceFolder}/build_ws43b_ps",
137137
"sdkconfigDefaults": [
138-
"sdkconfig.ws43b_ps",
139-
"sdkconfig.defaults"
138+
"sdkconfig.defaults",
139+
"sdkconfig.ws43B_ps"
140140
],
141141
"sdkconfigFilePath": "${workspaceFolder}/build_ws43b_ps"
142142
},
@@ -239,8 +239,8 @@
239239
"ninjaArgs": [],
240240
"buildDirectoryPath": "${workspaceFolder}/build_wszero",
241241
"sdkconfigDefaults": [
242-
"sdkconfig.wszero",
243-
"sdkconfig.defaults"
242+
"sdkconfig.defaults",
243+
"sdkconfig.wszero"
244244
],
245245
"sdkconfigFilePath": "${workspaceFolder}/build_wszero"
246246
},
@@ -265,8 +265,8 @@
265265
"ninjaArgs": [],
266266
"buildDirectoryPath": "${workspaceFolder}/build_devkitc_N8R2",
267267
"sdkconfigDefaults": [
268-
"sdkconfig.devkitc_N8R2",
269-
"sdkconfig.defaults"
268+
"sdkconfig.defaults",
269+
"sdkconfig.devkitc_N8R2"
270270
],
271271
"sdkconfigFilePath": "${workspaceFolder}/build_devkitc_N8R2"
272272
},
@@ -291,8 +291,8 @@
291291
"ninjaArgs": [],
292292
"buildDirectoryPath": "${workspaceFolder}/build_devkitc_N16R8",
293293
"sdkconfigDefaults": [
294-
"sdkconfig.devkitc_N16R8",
295-
"sdkconfig.defaults"
294+
"sdkconfig.defaults",
295+
"sdkconfig.devkitc_N16R8"
296296
],
297297
"sdkconfigFilePath": "${workspaceFolder}/build_devkitc_N16R8"
298298
},
@@ -317,8 +317,8 @@
317317
"ninjaArgs": [],
318318
"buildDirectoryPath": "${workspaceFolder}/build_m5atoms3r",
319319
"sdkconfigDefaults": [
320-
"sdkconfig.m5atoms3r",
321-
"sdkconfig.defaults"
320+
"sdkconfig.defaults",
321+
"sdkconfig.m5atoms3r"
322322
],
323323
"sdkconfigFilePath": "${workspaceFolder}/build_m5atoms3r"
324324
},
@@ -395,8 +395,8 @@
395395
"ninjaArgs": [],
396396
"buildDirectoryPath": "${workspaceFolder}/build_ws43devonly",
397397
"sdkconfigDefaults": [
398-
"sdkconfig.defaults",
399-
"sdkconfig .ws43devonly"
398+
"sdkconfig.ws43devonly",
399+
"sdkconfig.defaults"
400400
],
401401
"sdkconfigFilePath": "${workspaceFolder}/build_ws43devonly"
402402
},

source/sdkconfig.ws43devonly

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
# Settings for Waveshare 4.3 (not B) and 7". Also works on B.
2+
CONFIG_PARTITION_TABLE_CUSTOM=y
3+
CONFIG_PARTITION_TABLE_CUSTOM_FILENAME="partitions.csv"
4+
CONFIG_PARTITION_TABLE_FILENAME="partitions.csv"
5+
CONFIG_PARTITION_TABLE_OFFSET=0x8000
6+
CONFIG_PARTITION_TABLE_MD5=y
7+
CONFIG_ESPTOOLPY_FLASHMODE_QIO=y
8+
CONFIG_ESPTOOLPY_FLASHMODE="qio"
9+
CONFIG_ESPTOOLPY_FLASHSIZE_8MB=y
10+
CONFIG_ESPTOOLPY_FLASHSIZE="8MB"
11+
CONFIG_SPIRAM_MODE_OCT=y
12+
CONFIG_ESP_DEFAULT_CPU_FREQ_MHZ_240=y
13+
CONFIG_TONEX_CONTROLLER_HARDWARE_PLATFORM_WAVESHARE_43B=y

0 commit comments

Comments
 (0)