]> git.ipfire.org Git - thirdparty/u-boot.git/blame - .gitlab-ci.yml
Convert CONFIG_SYS_I2C_EEPROM_ADDR_LEN to Kconfig
[thirdparty/u-boot.git] / .gitlab-ci.yml
CommitLineData
1a62a722
TR
1# SPDX-License-Identifier: GPL-2.0+
2
3# Grab our configured image. The source for this is found at:
a3bbd0b9 4# https://source.denx.de/u-boot/gitlab-ci-runner
99cffa23 5image: trini/u-boot-gitlab-ci-runner:focal-20211006-14Nov2021
1a62a722
TR
6
7# We run some tests in different order, to catch some failures quicker.
8stages:
1a62a722 9 - testsuites
b29cb058 10 - test.py
1a62a722
TR
11 - world build
12
13.buildman_and_testpy_template: &buildman_and_testpy_dfn
1a62a722
TR
14 stage: test.py
15 before_script:
16 # Clone uboot-test-hooks
85ae52b9 17 - git clone --depth=1 https://source.denx.de/u-boot/u-boot-test-hooks /tmp/uboot-test-hooks
1a62a722
TR
18 - ln -s travis-ci /tmp/uboot-test-hooks/bin/`hostname`
19 - ln -s travis-ci /tmp/uboot-test-hooks/py/`hostname`
28a51234
TR
20 - grub-mkimage --prefix="" -o ~/grub_x86.efi -O i386-efi normal echo lsefimmap lsefi lsefisystab efinet tftp minicmd
21 - grub-mkimage --prefix="" -o ~/grub_x64.efi -O x86_64-efi normal echo lsefimmap lsefi lsefisystab efinet tftp minicmd
49fb28a4 22 - if [[ "${TEST_PY_BD}" == "qemu-riscv32_spl" ]]; then
b6b35fd2
HS
23 wget -O - https://github.com/riscv/opensbi/releases/download/v0.9/opensbi-0.9-rv-bin.tar.xz | tar -C /tmp -xJ;
24 export OPENSBI=/tmp/opensbi-0.9-rv-bin/share/opensbi/ilp32/generic/firmware/fw_dynamic.bin;
49fb28a4 25 fi
0e60b3a7 26 - if [[ "${TEST_PY_BD}" == "qemu-riscv64_spl" ]] || [[ "${TEST_PY_BD}" == "sifive_unleashed" ]]; then
b6b35fd2
HS
27 wget -O - https://github.com/riscv/opensbi/releases/download/v0.9/opensbi-0.9-rv-bin.tar.xz | tar -C /tmp -xJ;
28 export OPENSBI=/tmp/opensbi-0.9-rv-bin/share/opensbi/lp64/generic/firmware/fw_dynamic.bin;
49fb28a4 29 fi
b29cb058 30
1a62a722 31 after_script:
24df1b14 32 - rm -rf /tmp/uboot-test-hooks /tmp/venv
1a62a722 33 script:
dd5c954e 34 # If we've been asked to use clang only do one configuration.
4e32fed4 35 - export UBOOT_TRAVIS_BUILD_DIR=/tmp/${TEST_PY_BD}
7ec1255c
SG
36 - tools/buildman/buildman -o ${UBOOT_TRAVIS_BUILD_DIR} -w -E -W -e
37 --board ${TEST_PY_BD} ${OVERRIDE}
82560ae2
HS
38 - cp ~/grub_x86.efi $UBOOT_TRAVIS_BUILD_DIR/
39 - cp ~/grub_x64.efi $UBOOT_TRAVIS_BUILD_DIR/
40 - cp /opt/grub/grubriscv64.efi $UBOOT_TRAVIS_BUILD_DIR/grub_riscv64.efi
82560ae2
HS
41 - cp /opt/grub/grubaa64.efi $UBOOT_TRAVIS_BUILD_DIR/grub_arm64.efi
42 - cp /opt/grub/grubarm.efi $UBOOT_TRAVIS_BUILD_DIR/grub_arm.efi
0e60b3a7
BM
43 # create sdcard / spi-nor images for sifive unleashed using genimage
44 - if [[ "${TEST_PY_BD}" == "sifive_unleashed" ]]; then
45 mkdir -p root;
46 cp ${UBOOT_TRAVIS_BUILD_DIR}/spl/u-boot-spl.bin .;
47 cp ${UBOOT_TRAVIS_BUILD_DIR}/u-boot.itb .;
48 rm -rf tmp;
49 genimage --inputpath . --config board/sifive/unleashed/genimage_sdcard.cfg;
50 cp images/sdcard.img ${UBOOT_TRAVIS_BUILD_DIR}/;
51 rm -rf tmp;
52 genimage --inputpath . --config board/sifive/unleashed/genimage_spi-nor.cfg;
53 cp images/spi-nor.img ${UBOOT_TRAVIS_BUILD_DIR}/;
54 fi
085b8978
TR
55 - virtualenv -p /usr/bin/python3 /tmp/venv
56 - . /tmp/venv/bin/activate
57 - pip install -r test/py/requirements.txt
4080d097 58 # "${var:+"-k $var"}" expands to "" if $var is empty, "-k $var" if not
4e32fed4 59 - export PATH=/opt/qemu/bin:/tmp/uboot-test-hooks/bin:${PATH};
1a62a722 60 export PYTHONPATH=/tmp/uboot-test-hooks/py/travis-ci;
f3092473 61 ./test/py/test.py -ra --bd ${TEST_PY_BD} ${TEST_PY_ID}
4080d097 62 ${TEST_PY_TEST_SPEC:+"-k ${TEST_PY_TEST_SPEC}"}
cec1e856 63 --build-dir "$UBOOT_TRAVIS_BUILD_DIR"
1a62a722 64
a11cb57d 65build all 32bit ARM platforms:
1a62a722
TR
66 stage: world build
67 script:
68 - ret=0;
dd5c954e
SG
69 ./tools/buildman/buildman -o /tmp -P -E -W arm -x aarch64 || ret=$?;
70 if [[ $ret -ne 0 ]]; then
b52f5a19 71 ./tools/buildman/buildman -o /tmp -seP;
4c749971
TR
72 exit $ret;
73 fi;
9f7bda10 74
a11cb57d 75build all 64bit ARM platforms:
9f7bda10
TR
76 stage: world build
77 script:
26a426a1 78 - virtualenv -p /usr/bin/python3 /tmp/venv
f0db8395
TR
79 - . /tmp/venv/bin/activate
80 - pip install pyelftools
9f7bda10 81 - ret=0;
dd5c954e
SG
82 ./tools/buildman/buildman -o /tmp -P -E -W aarch64 || ret=$?;
83 if [[ $ret -ne 0 ]]; then
b52f5a19 84 ./tools/buildman/buildman -o /tmp -seP;
4c749971
TR
85 exit $ret;
86 fi;
9f7bda10 87
a11cb57d 88build all PowerPC platforms:
9f7bda10
TR
89 stage: world build
90 script:
91 - ret=0;
dd5c954e
SG
92 ./tools/buildman/buildman -o /tmp -P -E -W powerpc || ret=$?;
93 if [[ $ret -ne 0 ]]; then
b52f5a19 94 ./tools/buildman/buildman -o /tmp -seP;
4c749971
TR
95 exit $ret;
96 fi;
9f7bda10 97
a11cb57d 98build all other platforms:
9f7bda10
TR
99 stage: world build
100 script:
101 - ret=0;
dd5c954e
SG
102 ./tools/buildman/buildman -o /tmp -P -E -W -x arm,powerpc || ret=$?;
103 if [[ $ret -ne 0 ]]; then
b52f5a19 104 ./tools/buildman/buildman -o /tmp -seP;
4c749971
TR
105 exit $ret;
106 fi;
1a62a722
TR
107
108# QA jobs for code analytics
109# static code analysis with cppcheck (we can add --enable=all later)
110cppcheck:
1a62a722
TR
111 stage: testsuites
112 script:
4ee7f527 113 - cppcheck -j$(nproc) --force --quiet --inline-suppr .
1a62a722
TR
114
115# search for TODO within source tree
116grep TODO/FIXME/HACK:
1a62a722
TR
117 stage: testsuites
118 script:
119 - grep -r TODO .
120 - grep -r FIXME .
121 # search for HACK within source tree and ignore HACKKIT board
122 - grep -r HACK . | grep -v HACKKIT
123
3eb7b78b
HS
124# build HTML documentation
125htmldocs:
3eb7b78b
HS
126 stage: testsuites
127 script:
836049d6
HS
128 - virtualenv -p /usr/bin/python3 /tmp/venvhtml
129 - . /tmp/venvhtml/bin/activate
130 - pip install -r doc/sphinx/requirements.txt
3eb7b78b
HS
131 - make htmldocs
132
1a62a722
TR
133# some statistics about the code base
134sloccount:
1a62a722
TR
135 stage: testsuites
136 script:
137 - sloccount .
138
139# ensure all configs have MAINTAINERS entries
140Check for configs without MAINTAINERS entry:
1a62a722
TR
141 stage: testsuites
142 script:
143 - if [ `./tools/genboardscfg.py -f 2>&1 | wc -l` -ne 0 ]; then exit 1; fi
144
145# Ensure host tools build
146Build tools-only:
1a62a722
TR
147 stage: testsuites
148 script:
149 - make tools-only_config tools-only -j$(nproc)
150
1f3910da
PJT
151# Ensure env tools build
152Build envtools:
1f3910da
PJT
153 stage: testsuites
154 script:
155 - make tools-only_config envtools -j$(nproc)
156
7261833f 157Run binman, buildman, dtoc, Kconfig and patman testsuites:
1a62a722
TR
158 stage: testsuites
159 script:
d7ae9321
TR
160 - git config --global user.name "GitLab CI Runner";
161 git config --global user.email trini@konsulko.com;
162 export USER=gitlab;
26a426a1 163 virtualenv -p /usr/bin/python3 /tmp/venv;
d7ae9321 164 . /tmp/venv/bin/activate;
38229b55 165 pip install -r test/py/requirements.txt;
bf0a8133 166 export UBOOT_TRAVIS_BUILD_DIR=/tmp/sandbox_spl;
d7ae9321
TR
167 export PYTHONPATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc/pylibfdt";
168 export PATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc:${PATH}";
6c914e42
SG
169 ./tools/buildman/buildman -T0 -o ${UBOOT_TRAVIS_BUILD_DIR} -w
170 --board sandbox_spl;
d7ae9321
TR
171 ./tools/binman/binman --toolpath ${UBOOT_TRAVIS_BUILD_DIR}/tools test;
172 ./tools/buildman/buildman -t;
173 ./tools/dtoc/dtoc -t;
6bb74de7 174 ./tools/patman/patman test;
7261833f 175 make testconfig
1a62a722 176
6cfd09d4 177Run tests for Nokia RX-51 (aka N900):
6cfd09d4
T
178 stage: testsuites
179 script:
e2d6a77a 180 - export PATH=/opt/gcc-11.1.0-nolibc/arm-linux-gnueabi/bin:$PATH;
6cfd09d4
T
181 test/nokia_rx51_test.sh
182
1a62a722
TR
183# Test sandbox with test.py
184sandbox test.py:
1a62a722
TR
185 variables:
186 TEST_PY_BD: "sandbox"
1a62a722
TR
187 <<: *buildman_and_testpy_dfn
188
0219d014 189sandbox with clang test.py:
0219d014
TR
190 variables:
191 TEST_PY_BD: "sandbox"
927e0eed 192 OVERRIDE: "-O clang-13"
0219d014
TR
193 <<: *buildman_and_testpy_dfn
194
1a62a722 195sandbox_spl test.py:
1a62a722
TR
196 variables:
197 TEST_PY_BD: "sandbox_spl"
afb26ba9 198 TEST_PY_TEST_SPEC: "test_ofplatdata or test_handoff or test_spl"
1a62a722
TR
199 <<: *buildman_and_testpy_dfn
200
6c914e42 201sandbox_noinst_test.py:
6c914e42
SG
202 variables:
203 TEST_PY_BD: "sandbox_noinst"
204 TEST_PY_TEST_SPEC: "test_ofplatdata or test_handoff or test_spl"
205 <<: *buildman_and_testpy_dfn
206
699c0b93 207evb-ast2500 test.py:
699c0b93
TR
208 variables:
209 TEST_PY_BD: "evb-ast2500"
210 TEST_PY_ID: "--id qemu"
699c0b93
TR
211 <<: *buildman_and_testpy_dfn
212
1a62a722 213sandbox_flattree test.py:
1a62a722
TR
214 variables:
215 TEST_PY_BD: "sandbox_flattree"
1a62a722
TR
216 <<: *buildman_and_testpy_dfn
217
15e30106
KA
218vexpress_ca9x4 test.py:
219 variables:
220 TEST_PY_BD: "vexpress_ca9x4"
221 TEST_PY_ID: "--id qemu"
222 <<: *buildman_and_testpy_dfn
223
1a62a722 224integratorcp_cm926ejs test.py:
1a62a722
TR
225 variables:
226 TEST_PY_BD: "integratorcp_cm926ejs"
227 TEST_PY_TEST_SPEC: "not sleep"
228 TEST_PY_ID: "--id qemu"
1a62a722
TR
229 <<: *buildman_and_testpy_dfn
230
231qemu_arm test.py:
1a62a722
TR
232 variables:
233 TEST_PY_BD: "qemu_arm"
234 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
235 <<: *buildman_and_testpy_dfn
236
237qemu_arm64 test.py:
1a62a722
TR
238 variables:
239 TEST_PY_BD: "qemu_arm64"
240 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
241 <<: *buildman_and_testpy_dfn
242
d8533167 243qemu_malta test.py:
d8533167
DS
244 variables:
245 TEST_PY_BD: "malta"
246 TEST_PY_TEST_SPEC: "not sleep and not efi"
247 TEST_PY_ID: "--id qemu"
248 <<: *buildman_and_testpy_dfn
249
250qemu_maltael test.py:
d8533167
DS
251 variables:
252 TEST_PY_BD: "maltael"
253 TEST_PY_TEST_SPEC: "not sleep and not efi"
254 TEST_PY_ID: "--id qemu"
255 <<: *buildman_and_testpy_dfn
256
257qemu_malta64 test.py:
d8533167
DS
258 variables:
259 TEST_PY_BD: "malta64"
260 TEST_PY_TEST_SPEC: "not sleep and not efi"
261 TEST_PY_ID: "--id qemu"
262 <<: *buildman_and_testpy_dfn
263
264qemu_malta64el test.py:
d8533167
DS
265 variables:
266 TEST_PY_BD: "malta64el"
267 TEST_PY_TEST_SPEC: "not sleep and not efi"
268 TEST_PY_ID: "--id qemu"
269 <<: *buildman_and_testpy_dfn
270
1a62a722 271qemu-ppce500 test.py:
1a62a722
TR
272 variables:
273 TEST_PY_BD: "qemu-ppce500"
274 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
275 <<: *buildman_and_testpy_dfn
276
a379d330 277qemu-riscv32 test.py:
a379d330
BM
278 variables:
279 TEST_PY_BD: "qemu-riscv32"
280 TEST_PY_TEST_SPEC: "not sleep"
a379d330
BM
281 <<: *buildman_and_testpy_dfn
282
7298d82d 283qemu-riscv64 test.py:
7298d82d
TR
284 variables:
285 TEST_PY_BD: "qemu-riscv64"
286 TEST_PY_TEST_SPEC: "not sleep"
49fb28a4
BM
287 <<: *buildman_and_testpy_dfn
288
289qemu-riscv32_spl test.py:
49fb28a4
BM
290 variables:
291 TEST_PY_BD: "qemu-riscv32_spl"
292 TEST_PY_TEST_SPEC: "not sleep"
49fb28a4
BM
293 <<: *buildman_and_testpy_dfn
294
295qemu-riscv64_spl test.py:
49fb28a4
BM
296 variables:
297 TEST_PY_BD: "qemu-riscv64_spl"
298 TEST_PY_TEST_SPEC: "not sleep"
7298d82d
TR
299 <<: *buildman_and_testpy_dfn
300
1a62a722 301qemu-x86 test.py:
1a62a722
TR
302 variables:
303 TEST_PY_BD: "qemu-x86"
304 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
305 <<: *buildman_and_testpy_dfn
306
307qemu-x86_64 test.py:
1a62a722
TR
308 variables:
309 TEST_PY_BD: "qemu-x86_64"
310 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
311 <<: *buildman_and_testpy_dfn
312
0e125756 313r2dplus_i82557c test.py:
0e125756
MV
314 variables:
315 TEST_PY_BD: "r2dplus"
316 TEST_PY_ID: "--id i82557c_qemu"
317 <<: *buildman_and_testpy_dfn
318
319r2dplus_pcnet test.py:
0e125756
MV
320 variables:
321 TEST_PY_BD: "r2dplus"
322 TEST_PY_ID: "--id pcnet_qemu"
323 <<: *buildman_and_testpy_dfn
324
325r2dplus_rtl8139 test.py:
0e125756
MV
326 variables:
327 TEST_PY_BD: "r2dplus"
328 TEST_PY_ID: "--id rtl8139_qemu"
329 <<: *buildman_and_testpy_dfn
330
331r2dplus_tulip test.py:
0e125756
MV
332 variables:
333 TEST_PY_BD: "r2dplus"
334 TEST_PY_ID: "--id tulip_qemu"
335 <<: *buildman_and_testpy_dfn
336
0e60b3a7
BM
337sifive_unleashed_sdcard test.py:
338 variables:
339 TEST_PY_BD: "sifive_unleashed"
340 TEST_PY_ID: "--id sdcard_qemu"
341 <<: *buildman_and_testpy_dfn
342
343sifive_unleashed_spi-nor test.py:
344 variables:
345 TEST_PY_BD: "sifive_unleashed"
346 TEST_PY_ID: "--id spi-nor_qemu"
347 <<: *buildman_and_testpy_dfn
348
f7c6ee7f 349xilinx_zynq_virt test.py:
1a62a722 350 variables:
f7c6ee7f 351 TEST_PY_BD: "xilinx_zynq_virt"
1a62a722 352 TEST_PY_TEST_SPEC: "not sleep"
1a62a722 353 TEST_PY_ID: "--id qemu"
1a62a722
TR
354 <<: *buildman_and_testpy_dfn
355
356xilinx_versal_virt test.py:
1a62a722
TR
357 variables:
358 TEST_PY_BD: "xilinx_versal_virt"
359 TEST_PY_TEST_SPEC: "not sleep"
1a62a722 360 TEST_PY_ID: "--id qemu"
1a62a722
TR
361 <<: *buildman_and_testpy_dfn
362
363xtfpga test.py:
1a62a722
TR
364 variables:
365 TEST_PY_BD: "xtfpga"
366 TEST_PY_TEST_SPEC: "not sleep"
1a62a722 367 TEST_PY_ID: "--id qemu"
1a62a722 368 <<: *buildman_and_testpy_dfn