]> Git Repo - u-boot.git/blame - .gitlab-ci.yml
drivers: spi: sh_qspi.c: Use log_warning() instead of printf()
[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
85fd4898 5image: trini/u-boot-gitlab-ci-runner:jammy-20221130-11Jan2023
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
bb9b9c1e 127check for new CONFIG symbols outside Kconfig:
c1a7de57
TR
128 stage: testsuites
129 script:
bb9b9c1e
TR
130 - git config --global --add safe.directory "${CI_PROJECT_DIR}"
131 # If grep succeeds and finds a match the test fails as we should
132 # have no matches.
133 - git grep -E '^#[[:blank:]]*(define|undef)[[:blank:]]*CONFIG_'
a03efb6f
TR
134 :^doc/ :^arch/arm/dts/ :^scripts/kconfig/lkc.h
135 :^include/linux/kconfig.h :^tools/ && exit 1 || exit 0
c1a7de57 136
1a62a722
TR
137# QA jobs for code analytics
138# static code analysis with cppcheck (we can add --enable=all later)
139cppcheck:
1a62a722
TR
140 stage: testsuites
141 script:
4ee7f527 142 - cppcheck -j$(nproc) --force --quiet --inline-suppr .
1a62a722
TR
143
144# search for TODO within source tree
145grep TODO/FIXME/HACK:
1a62a722
TR
146 stage: testsuites
147 script:
148 - grep -r TODO .
149 - grep -r FIXME .
150 # search for HACK within source tree and ignore HACKKIT board
151 - grep -r HACK . | grep -v HACKKIT
152
e9cc7029
HS
153# build documentation
154docs:
3eb7b78b
HS
155 stage: testsuites
156 script:
836049d6
HS
157 - virtualenv -p /usr/bin/python3 /tmp/venvhtml
158 - . /tmp/venvhtml/bin/activate
159 - pip install -r doc/sphinx/requirements.txt
3eb7b78b 160 - make htmldocs
e9cc7029 161 - make infodocs
3eb7b78b 162
1a62a722
TR
163# some statistics about the code base
164sloccount:
1a62a722
TR
165 stage: testsuites
166 script:
167 - sloccount .
168
169# ensure all configs have MAINTAINERS entries
170Check for configs without MAINTAINERS entry:
1a62a722
TR
171 stage: testsuites
172 script:
7ae8a527 173 - ./tools/buildman/buildman -R
1a62a722
TR
174
175# Ensure host tools build
176Build tools-only:
1a62a722
TR
177 stage: testsuites
178 script:
179 - make tools-only_config tools-only -j$(nproc)
180
1f3910da
PJT
181# Ensure env tools build
182Build envtools:
1f3910da
PJT
183 stage: testsuites
184 script:
185 - make tools-only_config envtools -j$(nproc)
186
7261833f 187Run binman, buildman, dtoc, Kconfig and patman testsuites:
1a62a722
TR
188 stage: testsuites
189 script:
d7ae9321
TR
190 - git config --global user.name "GitLab CI Runner";
191 git config --global user.email [email protected];
b6d4e085 192 git config --global --add safe.directory "${CI_PROJECT_DIR}";
d7ae9321 193 export USER=gitlab;
26a426a1 194 virtualenv -p /usr/bin/python3 /tmp/venv;
d7ae9321 195 . /tmp/venv/bin/activate;
38229b55 196 pip install -r test/py/requirements.txt;
bf0a8133 197 export UBOOT_TRAVIS_BUILD_DIR=/tmp/sandbox_spl;
d7ae9321
TR
198 export PYTHONPATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc/pylibfdt";
199 export PATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc:${PATH}";
b6d4e085 200 set +e;
6c914e42
SG
201 ./tools/buildman/buildman -T0 -o ${UBOOT_TRAVIS_BUILD_DIR} -w
202 --board sandbox_spl;
b6d4e085 203 set -e;
d7ae9321
TR
204 ./tools/binman/binman --toolpath ${UBOOT_TRAVIS_BUILD_DIR}/tools test;
205 ./tools/buildman/buildman -t;
206 ./tools/dtoc/dtoc -t;
6bb74de7 207 ./tools/patman/patman test;
7261833f 208 make testconfig
1a62a722 209
6cfd09d4 210Run tests for Nokia RX-51 (aka N900):
6cfd09d4
T
211 stage: testsuites
212 script:
09ed7e62 213 - export PATH=/opt/gcc-12.2.0-nolibc/arm-linux-gnueabi/bin:$PATH;
6cfd09d4
T
214 test/nokia_rx51_test.sh
215
642e51ad
SG
216# Check for any pylint regressions
217Run pylint:
218 stage: testsuites
219 script:
b6d4e085 220 - git config --global --add safe.directory "${CI_PROJECT_DIR}"
642e51ad 221 - pip install -r test/py/requirements.txt
e47bbf7e 222 - pip install asteval pylint==2.12.2 pyopenssl
642e51ad
SG
223 - export PATH=${PATH}:~/.local/bin
224 - echo "[MASTER]" >> .pylintrc
225 - echo "load-plugins=pylint.extensions.docparams" >> .pylintrc
226 - export UBOOT_TRAVIS_BUILD_DIR=/tmp/sandbox_spl
b6d4e085 227 - set +e
642e51ad
SG
228 - ./tools/buildman/buildman -T0 -o ${UBOOT_TRAVIS_BUILD_DIR} -w
229 --board sandbox_spl
b6d4e085 230 - set -e
642e51ad
SG
231 - pylint --version
232 - export PYTHONPATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc/pylibfdt"
233 - make pylint_err
234
1a62a722
TR
235# Test sandbox with test.py
236sandbox test.py:
1a62a722
TR
237 variables:
238 TEST_PY_BD: "sandbox"
1a62a722
TR
239 <<: *buildman_and_testpy_dfn
240
0219d014 241sandbox with clang test.py:
0219d014
TR
242 variables:
243 TEST_PY_BD: "sandbox"
09ed7e62 244 OVERRIDE: "-O clang-14"
0219d014
TR
245 <<: *buildman_and_testpy_dfn
246
1aa168ca
SG
247sandbox without LTO test.py:
248 variables:
249 TEST_PY_BD: "sandbox"
250 BUILD_ENV: "NO_LTO=1"
251 <<: *buildman_and_testpy_dfn
252
1a62a722 253sandbox_spl test.py:
1a62a722
TR
254 variables:
255 TEST_PY_BD: "sandbox_spl"
afb26ba9 256 TEST_PY_TEST_SPEC: "test_ofplatdata or test_handoff or test_spl"
1a62a722
TR
257 <<: *buildman_and_testpy_dfn
258
6c914e42 259sandbox_noinst_test.py:
6c914e42
SG
260 variables:
261 TEST_PY_BD: "sandbox_noinst"
262 TEST_PY_TEST_SPEC: "test_ofplatdata or test_handoff or test_spl"
263 <<: *buildman_and_testpy_dfn
264
a31eff30
SG
265sandbox_vpl test.py:
266 variables:
267 TEST_PY_BD: "sandbox_vpl"
268 TEST_PY_TEST_SPEC: "test_vpl_help or test_spl"
269 <<: *buildman_and_testpy_dfn
270
699c0b93 271evb-ast2500 test.py:
699c0b93
TR
272 variables:
273 TEST_PY_BD: "evb-ast2500"
274 TEST_PY_ID: "--id qemu"
699c0b93
TR
275 <<: *buildman_and_testpy_dfn
276
b24087ae
JS
277evb-ast2600 test.py:
278 variables:
279 TEST_PY_BD: "evb-ast2600"
280 TEST_PY_ID: "--id qemu"
281 <<: *buildman_and_testpy_dfn
282
1a62a722 283sandbox_flattree test.py:
1a62a722
TR
284 variables:
285 TEST_PY_BD: "sandbox_flattree"
1a62a722
TR
286 <<: *buildman_and_testpy_dfn
287
15e30106
KA
288vexpress_ca9x4 test.py:
289 variables:
290 TEST_PY_BD: "vexpress_ca9x4"
291 TEST_PY_ID: "--id qemu"
292 <<: *buildman_and_testpy_dfn
293
1a62a722 294integratorcp_cm926ejs test.py:
1a62a722
TR
295 variables:
296 TEST_PY_BD: "integratorcp_cm926ejs"
297 TEST_PY_TEST_SPEC: "not sleep"
298 TEST_PY_ID: "--id qemu"
1a62a722
TR
299 <<: *buildman_and_testpy_dfn
300
301qemu_arm test.py:
1a62a722
TR
302 variables:
303 TEST_PY_BD: "qemu_arm"
304 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
305 <<: *buildman_and_testpy_dfn
306
307qemu_arm64 test.py:
1a62a722
TR
308 variables:
309 TEST_PY_BD: "qemu_arm64"
310 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
311 <<: *buildman_and_testpy_dfn
312
d8533167 313qemu_malta test.py:
d8533167
DS
314 variables:
315 TEST_PY_BD: "malta"
316 TEST_PY_TEST_SPEC: "not sleep and not efi"
317 TEST_PY_ID: "--id qemu"
318 <<: *buildman_and_testpy_dfn
319
320qemu_maltael test.py:
d8533167
DS
321 variables:
322 TEST_PY_BD: "maltael"
323 TEST_PY_TEST_SPEC: "not sleep and not efi"
324 TEST_PY_ID: "--id qemu"
325 <<: *buildman_and_testpy_dfn
326
327qemu_malta64 test.py:
d8533167
DS
328 variables:
329 TEST_PY_BD: "malta64"
330 TEST_PY_TEST_SPEC: "not sleep and not efi"
331 TEST_PY_ID: "--id qemu"
332 <<: *buildman_and_testpy_dfn
333
334qemu_malta64el test.py:
d8533167
DS
335 variables:
336 TEST_PY_BD: "malta64el"
337 TEST_PY_TEST_SPEC: "not sleep and not efi"
338 TEST_PY_ID: "--id qemu"
339 <<: *buildman_and_testpy_dfn
340
1a62a722 341qemu-ppce500 test.py:
1a62a722
TR
342 variables:
343 TEST_PY_BD: "qemu-ppce500"
344 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
345 <<: *buildman_and_testpy_dfn
346
a379d330 347qemu-riscv32 test.py:
a379d330
BM
348 variables:
349 TEST_PY_BD: "qemu-riscv32"
350 TEST_PY_TEST_SPEC: "not sleep"
a379d330
BM
351 <<: *buildman_and_testpy_dfn
352
7298d82d 353qemu-riscv64 test.py:
7298d82d
TR
354 variables:
355 TEST_PY_BD: "qemu-riscv64"
356 TEST_PY_TEST_SPEC: "not sleep"
49fb28a4
BM
357 <<: *buildman_and_testpy_dfn
358
359qemu-riscv32_spl test.py:
49fb28a4
BM
360 variables:
361 TEST_PY_BD: "qemu-riscv32_spl"
362 TEST_PY_TEST_SPEC: "not sleep"
49fb28a4
BM
363 <<: *buildman_and_testpy_dfn
364
365qemu-riscv64_spl test.py:
49fb28a4
BM
366 variables:
367 TEST_PY_BD: "qemu-riscv64_spl"
368 TEST_PY_TEST_SPEC: "not sleep"
7298d82d
TR
369 <<: *buildman_and_testpy_dfn
370
1a62a722 371qemu-x86 test.py:
1a62a722
TR
372 variables:
373 TEST_PY_BD: "qemu-x86"
374 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
375 <<: *buildman_and_testpy_dfn
376
377qemu-x86_64 test.py:
1a62a722
TR
378 variables:
379 TEST_PY_BD: "qemu-x86_64"
380 TEST_PY_TEST_SPEC: "not sleep"
1a62a722
TR
381 <<: *buildman_and_testpy_dfn
382
0e125756 383r2dplus_i82557c test.py:
0e125756
MV
384 variables:
385 TEST_PY_BD: "r2dplus"
386 TEST_PY_ID: "--id i82557c_qemu"
387 <<: *buildman_and_testpy_dfn
388
389r2dplus_pcnet test.py:
0e125756
MV
390 variables:
391 TEST_PY_BD: "r2dplus"
392 TEST_PY_ID: "--id pcnet_qemu"
393 <<: *buildman_and_testpy_dfn
394
395r2dplus_rtl8139 test.py:
0e125756
MV
396 variables:
397 TEST_PY_BD: "r2dplus"
398 TEST_PY_ID: "--id rtl8139_qemu"
399 <<: *buildman_and_testpy_dfn
400
401r2dplus_tulip test.py:
0e125756
MV
402 variables:
403 TEST_PY_BD: "r2dplus"
404 TEST_PY_ID: "--id tulip_qemu"
405 <<: *buildman_and_testpy_dfn
406
0e60b3a7
BM
407sifive_unleashed_sdcard test.py:
408 variables:
409 TEST_PY_BD: "sifive_unleashed"
410 TEST_PY_ID: "--id sdcard_qemu"
411 <<: *buildman_and_testpy_dfn
412
413sifive_unleashed_spi-nor test.py:
414 variables:
415 TEST_PY_BD: "sifive_unleashed"
416 TEST_PY_ID: "--id spi-nor_qemu"
417 <<: *buildman_and_testpy_dfn
418
f7c6ee7f 419xilinx_zynq_virt test.py:
1a62a722 420 variables:
f7c6ee7f 421 TEST_PY_BD: "xilinx_zynq_virt"
1a62a722 422 TEST_PY_TEST_SPEC: "not sleep"
1a62a722 423 TEST_PY_ID: "--id qemu"
1a62a722
TR
424 <<: *buildman_and_testpy_dfn
425
426xilinx_versal_virt test.py:
1a62a722
TR
427 variables:
428 TEST_PY_BD: "xilinx_versal_virt"
429 TEST_PY_TEST_SPEC: "not sleep"
1a62a722 430 TEST_PY_ID: "--id qemu"
1a62a722
TR
431 <<: *buildman_and_testpy_dfn
432
433xtfpga test.py:
1a62a722
TR
434 variables:
435 TEST_PY_BD: "xtfpga"
436 TEST_PY_TEST_SPEC: "not sleep"
1a62a722 437 TEST_PY_ID: "--id qemu"
1a62a722 438 <<: *buildman_and_testpy_dfn
bfb2a7fb
SG
439
440coreboot test.py:
441 variables:
442 TEST_PY_BD: "coreboot"
443 TEST_PY_TEST_SPEC: "not sleep"
444 TEST_PY_ID: "--id qemu"
445 artifacts:
446 paths:
447 - "*.html"
448 - "*.css"
449 expire_in: 1 week
450 <<: *buildman_and_testpy_dfn
This page took 0.126016 seconds and 4 git commands to generate.