]> git.ipfire.org Git - thirdparty/u-boot.git/blame - .gitlab-ci.yml
sunxi: define SYS_MONITOR_LEN in Kconfig, not _defconfig
[thirdparty/u-boot.git] / .gitlab-ci.yml
CommitLineData
1a62a722
TR
1# SPDX-License-Identifier: GPL-2.0+
2
cb735173
JS
3# Grab our configured image. The source for this is found
4# in the u-boot tree at tools/docker/Dockerfile
17196e44 5image: trini/u-boot-gitlab-ci-runner:jammy-20221003-17Oct2022
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
bd181a24 17 - git config --global --add safe.directory "${CI_PROJECT_DIR}"
85ae52b9 18 - git clone --depth=1 https://source.denx.de/u-boot/u-boot-test-hooks /tmp/uboot-test-hooks
1a62a722
TR
19 - ln -s travis-ci /tmp/uboot-test-hooks/bin/`hostname`
20 - ln -s travis-ci /tmp/uboot-test-hooks/py/`hostname`
28a51234
TR
21 - grub-mkimage --prefix="" -o ~/grub_x86.efi -O i386-efi normal echo lsefimmap lsefi lsefisystab efinet tftp minicmd
22 - grub-mkimage --prefix="" -o ~/grub_x64.efi -O x86_64-efi normal echo lsefimmap lsefi lsefisystab efinet tftp minicmd
49fb28a4 23 - if [[ "${TEST_PY_BD}" == "qemu-riscv32_spl" ]]; then
b6b35fd2
HS
24 wget -O - https://github.com/riscv/opensbi/releases/download/v0.9/opensbi-0.9-rv-bin.tar.xz | tar -C /tmp -xJ;
25 export OPENSBI=/tmp/opensbi-0.9-rv-bin/share/opensbi/ilp32/generic/firmware/fw_dynamic.bin;
49fb28a4 26 fi
0e60b3a7 27 - if [[ "${TEST_PY_BD}" == "qemu-riscv64_spl" ]] || [[ "${TEST_PY_BD}" == "sifive_unleashed" ]]; then
b6b35fd2
HS
28 wget -O - https://github.com/riscv/opensbi/releases/download/v0.9/opensbi-0.9-rv-bin.tar.xz | tar -C /tmp -xJ;
29 export OPENSBI=/tmp/opensbi-0.9-rv-bin/share/opensbi/lp64/generic/firmware/fw_dynamic.bin;
49fb28a4 30 fi
b29cb058 31
1a62a722 32 after_script:
24df1b14 33 - rm -rf /tmp/uboot-test-hooks /tmp/venv
1a62a722 34 script:
dd5c954e 35 # If we've been asked to use clang only do one configuration.
4e32fed4 36 - export UBOOT_TRAVIS_BUILD_DIR=/tmp/${TEST_PY_BD}
1aa168ca 37 - echo BUILD_ENV ${BUILD_ENV}
7ec1255c
SG
38 - tools/buildman/buildman -o ${UBOOT_TRAVIS_BUILD_DIR} -w -E -W -e
39 --board ${TEST_PY_BD} ${OVERRIDE}
82560ae2
HS
40 - cp ~/grub_x86.efi $UBOOT_TRAVIS_BUILD_DIR/
41 - cp ~/grub_x64.efi $UBOOT_TRAVIS_BUILD_DIR/
42 - cp /opt/grub/grubriscv64.efi $UBOOT_TRAVIS_BUILD_DIR/grub_riscv64.efi
82560ae2
HS
43 - cp /opt/grub/grubaa64.efi $UBOOT_TRAVIS_BUILD_DIR/grub_arm64.efi
44 - cp /opt/grub/grubarm.efi $UBOOT_TRAVIS_BUILD_DIR/grub_arm.efi
0e60b3a7
BM
45 # create sdcard / spi-nor images for sifive unleashed using genimage
46 - if [[ "${TEST_PY_BD}" == "sifive_unleashed" ]]; then
47 mkdir -p root;
48 cp ${UBOOT_TRAVIS_BUILD_DIR}/spl/u-boot-spl.bin .;
49 cp ${UBOOT_TRAVIS_BUILD_DIR}/u-boot.itb .;
50 rm -rf tmp;
51 genimage --inputpath . --config board/sifive/unleashed/genimage_sdcard.cfg;
52 cp images/sdcard.img ${UBOOT_TRAVIS_BUILD_DIR}/;
53 rm -rf tmp;
54 genimage --inputpath . --config board/sifive/unleashed/genimage_spi-nor.cfg;
55 cp images/spi-nor.img ${UBOOT_TRAVIS_BUILD_DIR}/;
56 fi
bfb2a7fb
SG
57 - if [[ "${TEST_PY_BD}" == "coreboot" ]]; then
58 wget -O -
59 "https://drive.google.com/uc?id=1x6nrtWIyIRPLS2cQBwYTnT2TbOI8UjmM&export=download" |
60 xz -dc >${UBOOT_TRAVIS_BUILD_DIR}/coreboot.rom;
61 wget -O -
62 "https://drive.google.com/uc?id=149Cz-5SZXHNKpi9xg6R_5XITWohu348y&export=download" >
63 cbfstool;
64 chmod a+x cbfstool;
65 ./cbfstool ${UBOOT_TRAVIS_BUILD_DIR}/coreboot.rom add-flat-binary -f ${UBOOT_TRAVIS_BUILD_DIR}/u-boot.bin -n fallback/payload -c LZMA -l 0x1110000 -e 0x1110000;
66 fi
085b8978
TR
67 - virtualenv -p /usr/bin/python3 /tmp/venv
68 - . /tmp/venv/bin/activate
69 - pip install -r test/py/requirements.txt
4080d097 70 # "${var:+"-k $var"}" expands to "" if $var is empty, "-k $var" if not
4e32fed4 71 - export PATH=/opt/qemu/bin:/tmp/uboot-test-hooks/bin:${PATH};
1a62a722 72 export PYTHONPATH=/tmp/uboot-test-hooks/py/travis-ci;
f3092473 73 ./test/py/test.py -ra --bd ${TEST_PY_BD} ${TEST_PY_ID}
4080d097 74 ${TEST_PY_TEST_SPEC:+"-k ${TEST_PY_TEST_SPEC}"}
cec1e856 75 --build-dir "$UBOOT_TRAVIS_BUILD_DIR"
bfb2a7fb
SG
76 # It seems that the files in /tmp go away, so copy out what we need
77 - if [[ "${TEST_PY_BD}" == "coreboot" ]]; then
78 cp -v /tmp/coreboot/*.{html,css} .;
79 fi
1a62a722 80
a11cb57d 81build all 32bit ARM platforms:
1a62a722
TR
82 stage: world build
83 script:
84 - ret=0;
bd181a24 85 git config --global --add safe.directory "${CI_PROJECT_DIR}";
d7713ad3 86 ./tools/buildman/buildman -o /tmp -PEWM arm -x aarch64 || ret=$?;
dd5c954e 87 if [[ $ret -ne 0 ]]; then
b52f5a19 88 ./tools/buildman/buildman -o /tmp -seP;
4c749971
TR
89 exit $ret;
90 fi;
9f7bda10 91
a11cb57d 92build all 64bit ARM platforms:
9f7bda10
TR
93 stage: world build
94 script:
26a426a1 95 - virtualenv -p /usr/bin/python3 /tmp/venv
f0db8395 96 - . /tmp/venv/bin/activate
9f7bda10 97 - ret=0;
bd181a24 98 git config --global --add safe.directory "${CI_PROJECT_DIR}";
d7713ad3 99 ./tools/buildman/buildman -o /tmp -PEWM aarch64 || ret=$?;
dd5c954e 100 if [[ $ret -ne 0 ]]; then
b52f5a19 101 ./tools/buildman/buildman -o /tmp -seP;
4c749971
TR
102 exit $ret;
103 fi;
9f7bda10 104
a11cb57d 105build all PowerPC platforms:
9f7bda10
TR
106 stage: world build
107 script:
108 - ret=0;
bd181a24 109 git config --global --add safe.directory "${CI_PROJECT_DIR}";
dd5c954e
SG
110 ./tools/buildman/buildman -o /tmp -P -E -W powerpc || ret=$?;
111 if [[ $ret -ne 0 ]]; then
b52f5a19 112 ./tools/buildman/buildman -o /tmp -seP;
4c749971
TR
113 exit $ret;
114 fi;
9f7bda10 115
a11cb57d 116build all other platforms:
9f7bda10
TR
117 stage: world build
118 script:
119 - ret=0;
bd181a24 120 git config --global --add safe.directory "${CI_PROJECT_DIR}";
d7713ad3 121 ./tools/buildman/buildman -o /tmp -PEWM -x arm,powerpc || ret=$?;
dd5c954e 122 if [[ $ret -ne 0 ]]; then
b52f5a19 123 ./tools/buildman/buildman -o /tmp -seP;
4c749971
TR
124 exit $ret;
125 fi;
1a62a722 126
c1a7de57
TR
127check for migrated symbols in board header:
128 stage: testsuites
129 script:
130 - KSYMLST=`mktemp`;
131 KUSEDLST=`mktemp`;
239fe55a 132 RET=0;
c1a7de57
TR
133 cat `find . -name "Kconfig*"` |
134 sed -n -e 's/^\s*config *\([A-Za-z0-9_]*\).*$/CONFIG_\1/p'
135 -e 's/^\s*menuconfig *\([A-Za-z0-9_]*\).*$/CONFIG_\1/p'
136 | sort -u > $KSYMLST;
137 for CFG in `find include/configs -name "*.h"`; do
694943cf
TR
138 (grep '#define[[:blank:]]CONFIG_' $CFG |
139 sed -n 's/#define.\(CONFIG_[A-Za-z0-9_]*\).*/\1/p' ;
140 grep '#undef[[:blank:]]CONFIG_' $CFG |
141 sed -n 's/#undef.\(CONFIG_[A-Za-z0-9_]*\).*/\1/p') |
c1a7de57 142 sort -u > ${KUSEDLST} || true;
576eac85 143 NUM=`comm -123 --total --output-delimiter=, ${KSYMLST} ${KUSEDLST} |
c1a7de57
TR
144 cut -d , -f 3`;
145 if [[ $NUM -ne 0 ]]; then
239fe55a
TR
146 echo "Unmigrated symbols found in $CFG:";
147 comm -12 ${KSYMLST} ${KUSEDLST};
148 RET=1;
c1a7de57 149 fi;
239fe55a
TR
150 done;
151 exit $RET
c1a7de57 152
1a62a722
TR
153# QA jobs for code analytics
154# static code analysis with cppcheck (we can add --enable=all later)
155cppcheck:
1a62a722
TR
156 stage: testsuites
157 script:
4ee7f527 158 - cppcheck -j$(nproc) --force --quiet --inline-suppr .
1a62a722
TR
159
160# search for TODO within source tree
161grep TODO/FIXME/HACK:
1a62a722
TR
162 stage: testsuites
163 script:
164 - grep -r TODO .
165 - grep -r FIXME .
166 # search for HACK within source tree and ignore HACKKIT board
167 - grep -r HACK . | grep -v HACKKIT
168
3eb7b78b
HS
169# build HTML documentation
170htmldocs:
3eb7b78b
HS
171 stage: testsuites
172 script:
836049d6
HS
173 - virtualenv -p /usr/bin/python3 /tmp/venvhtml
174 - . /tmp/venvhtml/bin/activate
175 - pip install -r doc/sphinx/requirements.txt
3eb7b78b
HS
176 - make htmldocs
177
1a62a722
TR
178# some statistics about the code base
179sloccount:
1a62a722
TR
180 stage: testsuites
181 script:
182 - sloccount .
183
184# ensure all configs have MAINTAINERS entries
185Check for configs without MAINTAINERS entry:
1a62a722
TR
186 stage: testsuites
187 script:
7ae8a527 188 - ./tools/buildman/buildman -R
1a62a722
TR
189
190# Ensure host tools build
191Build tools-only:
1a62a722
TR
192 stage: testsuites
193 script:
194 - make tools-only_config tools-only -j$(nproc)
195
1f3910da
PJT
196# Ensure env tools build
197Build envtools:
1f3910da
PJT
198 stage: testsuites
199 script:
200 - make tools-only_config envtools -j$(nproc)
201
7261833f 202Run binman, buildman, dtoc, Kconfig and patman testsuites:
1a62a722
TR
203 stage: testsuites
204 script:
d7ae9321
TR
205 - git config --global user.name "GitLab CI Runner";
206 git config --global user.email trini@konsulko.com;
b6d4e085 207 git config --global --add safe.directory "${CI_PROJECT_DIR}";
d7ae9321 208 export USER=gitlab;
26a426a1 209 virtualenv -p /usr/bin/python3 /tmp/venv;
d7ae9321 210 . /tmp/venv/bin/activate;
38229b55 211 pip install -r test/py/requirements.txt;
bf0a8133 212 export UBOOT_TRAVIS_BUILD_DIR=/tmp/sandbox_spl;
d7ae9321
TR
213 export PYTHONPATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc/pylibfdt";
214 export PATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc:${PATH}";
b6d4e085 215 set +e;
6c914e42
SG
216 ./tools/buildman/buildman -T0 -o ${UBOOT_TRAVIS_BUILD_DIR} -w
217 --board sandbox_spl;
b6d4e085 218 set -e;
d7ae9321
TR
219 ./tools/binman/binman --toolpath ${UBOOT_TRAVIS_BUILD_DIR}/tools test;
220 ./tools/buildman/buildman -t;
221 ./tools/dtoc/dtoc -t;
6bb74de7 222 ./tools/patman/patman test;
7261833f 223 make testconfig
1a62a722 224
6cfd09d4 225Run tests for Nokia RX-51 (aka N900):
6cfd09d4
T
226 stage: testsuites
227 script:
e2d6a77a 228 - export PATH=/opt/gcc-11.1.0-nolibc/arm-linux-gnueabi/bin:$PATH;
6cfd09d4
T
229 test/nokia_rx51_test.sh
230
642e51ad
SG
231# Check for any pylint regressions
232Run pylint:
233 stage: testsuites
234 script:
b6d4e085 235 - git config --global --add safe.directory "${CI_PROJECT_DIR}"
642e51ad 236 - pip install -r test/py/requirements.txt
e47bbf7e 237 - pip install asteval pylint==2.12.2 pyopenssl
642e51ad
SG
238 - export PATH=${PATH}:~/.local/bin
239 - echo "[MASTER]" >> .pylintrc
240 - echo "load-plugins=pylint.extensions.docparams" >> .pylintrc
241 - export UBOOT_TRAVIS_BUILD_DIR=/tmp/sandbox_spl
b6d4e085 242 - set +e
642e51ad
SG
243 - ./tools/buildman/buildman -T0 -o ${UBOOT_TRAVIS_BUILD_DIR} -w
244 --board sandbox_spl
b6d4e085 245 - set -e
642e51ad
SG
246 - pylint --version
247 - export PYTHONPATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc/pylibfdt"
248 - make pylint_err
249
1a62a722
TR
250# Test sandbox with test.py
251sandbox test.py:
1a62a722
TR
252 variables:
253 TEST_PY_BD: "sandbox"
1a62a722
TR
254 <<: *buildman_and_testpy_dfn
255
0219d014 256sandbox with clang test.py:
0219d014
TR
257 variables:
258 TEST_PY_BD: "sandbox"
927e0eed 259 OVERRIDE: "-O clang-13"
0219d014
TR
260 <<: *buildman_and_testpy_dfn
261
1aa168ca
SG
262sandbox without LTO test.py:
263 variables:
264 TEST_PY_BD: "sandbox"
265 BUILD_ENV: "NO_LTO=1"
266 <<: *buildman_and_testpy_dfn
267
1a62a722 268sandbox_spl test.py:
1a62a722
TR
269 variables:
270 TEST_PY_BD: "sandbox_spl"
afb26ba9 271 TEST_PY_TEST_SPEC: "test_ofplatdata or test_handoff or test_spl"
1a62a722
TR
272 <<: *buildman_and_testpy_dfn
273
6c914e42 274sandbox_noinst_test.py:
6c914e42
SG
275 variables:
276 TEST_PY_BD: "sandbox_noinst"
277 TEST_PY_TEST_SPEC: "test_ofplatdata or test_handoff or test_spl"
278 <<: *buildman_and_testpy_dfn
279
a31eff30
SG
280sandbox_vpl test.py:
281 variables:
282 TEST_PY_BD: "sandbox_vpl"
283 TEST_PY_TEST_SPEC: "test_vpl_help or test_spl"
284 <<: *buildman_and_testpy_dfn
285
699c0b93 286evb-ast2500 test.py:
699c0b93
TR
287 variables:
288 TEST_PY_BD: "evb-ast2500"
289 TEST_PY_ID: "--id qemu"
699c0b93
TR
290 <<: *buildman_and_testpy_dfn
291
b24087ae
JS
292evb-ast2600 test.py:
293 variables:
294 TEST_PY_BD: "evb-ast2600"
295 TEST_PY_ID: "--id qemu"
296 <<: *buildman_and_testpy_dfn
297
1a62a722 298sandbox_flattree test.py:
1a62a722
TR
299 variables:
300 TEST_PY_BD: "sandbox_flattree"
1a62a722
TR
301 <<: *buildman_and_testpy_dfn
302
15e30106
KA
303vexpress_ca9x4 test.py:
304 variables:
305 TEST_PY_BD: "vexpress_ca9x4"
306 TEST_PY_ID: "--id qemu"
307 <<: *buildman_and_testpy_dfn
308
1a62a722 309integratorcp_cm926ejs test.py:
1a62a722
TR
310 variables:
311 TEST_PY_BD: "integratorcp_cm926ejs"
312 TEST_PY_TEST_SPEC: "not sleep"
313 TEST_PY_ID: "--id qemu"
1a62a722
TR
314 <<: *buildman_and_testpy_dfn
315
316qemu_arm test.py:
1a62a722
TR
317 variables:
318 TEST_PY_BD: "qemu_arm"
319 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
320 <<: *buildman_and_testpy_dfn
321
322qemu_arm64 test.py:
1a62a722
TR
323 variables:
324 TEST_PY_BD: "qemu_arm64"
325 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
326 <<: *buildman_and_testpy_dfn
327
d8533167 328qemu_malta test.py:
d8533167
DS
329 variables:
330 TEST_PY_BD: "malta"
331 TEST_PY_TEST_SPEC: "not sleep and not efi"
332 TEST_PY_ID: "--id qemu"
333 <<: *buildman_and_testpy_dfn
334
335qemu_maltael test.py:
d8533167
DS
336 variables:
337 TEST_PY_BD: "maltael"
338 TEST_PY_TEST_SPEC: "not sleep and not efi"
339 TEST_PY_ID: "--id qemu"
340 <<: *buildman_and_testpy_dfn
341
342qemu_malta64 test.py:
d8533167
DS
343 variables:
344 TEST_PY_BD: "malta64"
345 TEST_PY_TEST_SPEC: "not sleep and not efi"
346 TEST_PY_ID: "--id qemu"
347 <<: *buildman_and_testpy_dfn
348
349qemu_malta64el test.py:
d8533167
DS
350 variables:
351 TEST_PY_BD: "malta64el"
352 TEST_PY_TEST_SPEC: "not sleep and not efi"
353 TEST_PY_ID: "--id qemu"
354 <<: *buildman_and_testpy_dfn
355
1a62a722 356qemu-ppce500 test.py:
1a62a722
TR
357 variables:
358 TEST_PY_BD: "qemu-ppce500"
359 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
360 <<: *buildman_and_testpy_dfn
361
a379d330 362qemu-riscv32 test.py:
a379d330
BM
363 variables:
364 TEST_PY_BD: "qemu-riscv32"
365 TEST_PY_TEST_SPEC: "not sleep"
a379d330
BM
366 <<: *buildman_and_testpy_dfn
367
7298d82d 368qemu-riscv64 test.py:
7298d82d
TR
369 variables:
370 TEST_PY_BD: "qemu-riscv64"
371 TEST_PY_TEST_SPEC: "not sleep"
49fb28a4
BM
372 <<: *buildman_and_testpy_dfn
373
374qemu-riscv32_spl test.py:
49fb28a4
BM
375 variables:
376 TEST_PY_BD: "qemu-riscv32_spl"
377 TEST_PY_TEST_SPEC: "not sleep"
49fb28a4
BM
378 <<: *buildman_and_testpy_dfn
379
380qemu-riscv64_spl test.py:
49fb28a4
BM
381 variables:
382 TEST_PY_BD: "qemu-riscv64_spl"
383 TEST_PY_TEST_SPEC: "not sleep"
7298d82d
TR
384 <<: *buildman_and_testpy_dfn
385
1a62a722 386qemu-x86 test.py:
1a62a722
TR
387 variables:
388 TEST_PY_BD: "qemu-x86"
389 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
390 <<: *buildman_and_testpy_dfn
391
392qemu-x86_64 test.py:
1a62a722
TR
393 variables:
394 TEST_PY_BD: "qemu-x86_64"
395 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
396 <<: *buildman_and_testpy_dfn
397
0e125756 398r2dplus_i82557c test.py:
0e125756
MV
399 variables:
400 TEST_PY_BD: "r2dplus"
401 TEST_PY_ID: "--id i82557c_qemu"
402 <<: *buildman_and_testpy_dfn
403
404r2dplus_pcnet test.py:
0e125756
MV
405 variables:
406 TEST_PY_BD: "r2dplus"
407 TEST_PY_ID: "--id pcnet_qemu"
408 <<: *buildman_and_testpy_dfn
409
410r2dplus_rtl8139 test.py:
0e125756
MV
411 variables:
412 TEST_PY_BD: "r2dplus"
413 TEST_PY_ID: "--id rtl8139_qemu"
414 <<: *buildman_and_testpy_dfn
415
416r2dplus_tulip test.py:
0e125756
MV
417 variables:
418 TEST_PY_BD: "r2dplus"
419 TEST_PY_ID: "--id tulip_qemu"
420 <<: *buildman_and_testpy_dfn
421
0e60b3a7
BM
422sifive_unleashed_sdcard test.py:
423 variables:
424 TEST_PY_BD: "sifive_unleashed"
425 TEST_PY_ID: "--id sdcard_qemu"
426 <<: *buildman_and_testpy_dfn
427
428sifive_unleashed_spi-nor test.py:
429 variables:
430 TEST_PY_BD: "sifive_unleashed"
431 TEST_PY_ID: "--id spi-nor_qemu"
432 <<: *buildman_and_testpy_dfn
433
f7c6ee7f 434xilinx_zynq_virt test.py:
1a62a722 435 variables:
f7c6ee7f 436 TEST_PY_BD: "xilinx_zynq_virt"
1a62a722 437 TEST_PY_TEST_SPEC: "not sleep"
1a62a722 438 TEST_PY_ID: "--id qemu"
1a62a722
TR
439 <<: *buildman_and_testpy_dfn
440
441xilinx_versal_virt test.py:
1a62a722
TR
442 variables:
443 TEST_PY_BD: "xilinx_versal_virt"
444 TEST_PY_TEST_SPEC: "not sleep"
1a62a722 445 TEST_PY_ID: "--id qemu"
1a62a722
TR
446 <<: *buildman_and_testpy_dfn
447
448xtfpga test.py:
1a62a722
TR
449 variables:
450 TEST_PY_BD: "xtfpga"
451 TEST_PY_TEST_SPEC: "not sleep"
1a62a722 452 TEST_PY_ID: "--id qemu"
1a62a722 453 <<: *buildman_and_testpy_dfn
bfb2a7fb
SG
454
455coreboot test.py:
456 variables:
457 TEST_PY_BD: "coreboot"
458 TEST_PY_TEST_SPEC: "not sleep"
459 TEST_PY_ID: "--id qemu"
460 artifacts:
461 paths:
462 - "*.html"
463 - "*.css"
464 expire_in: 1 week
465 <<: *buildman_and_testpy_dfn