]> git.ipfire.org Git - thirdparty/u-boot.git/blob - .gitlab-ci.yml
Merge tag 'u-boot-amlogic-20230131' of https://source.denx.de/u-boot/custodians/u...
[thirdparty/u-boot.git] / .gitlab-ci.yml
1 # SPDX-License-Identifier: GPL-2.0+
2
3 # Grab our configured image. The source for this is found
4 # in the u-boot tree at tools/docker/Dockerfile
5 image: trini/u-boot-gitlab-ci-runner:jammy-20221130-11Jan2023
6
7 # We run some tests in different order, to catch some failures quicker.
8 stages:
9 - testsuites
10 - test.py
11 - world build
12
13 .buildman_and_testpy_template: &buildman_and_testpy_dfn
14 stage: test.py
15 before_script:
16 # Clone uboot-test-hooks
17 - git config --global --add safe.directory "${CI_PROJECT_DIR}"
18 - git clone --depth=1 https://source.denx.de/u-boot/u-boot-test-hooks /tmp/uboot-test-hooks
19 - ln -s travis-ci /tmp/uboot-test-hooks/bin/`hostname`
20 - ln -s travis-ci /tmp/uboot-test-hooks/py/`hostname`
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
23 - if [[ "${TEST_PY_BD}" == "qemu-riscv32_spl" ]]; then
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;
26 fi
27 - if [[ "${TEST_PY_BD}" == "qemu-riscv64_spl" ]] || [[ "${TEST_PY_BD}" == "sifive_unleashed" ]]; then
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;
30 fi
31
32 after_script:
33 - rm -rf /tmp/uboot-test-hooks /tmp/venv
34 script:
35 # If we've been asked to use clang only do one configuration.
36 - export UBOOT_TRAVIS_BUILD_DIR=/tmp/${TEST_PY_BD}
37 - echo BUILD_ENV ${BUILD_ENV}
38 - tools/buildman/buildman -o ${UBOOT_TRAVIS_BUILD_DIR} -w -E -W -e
39 --board ${TEST_PY_BD} ${OVERRIDE}
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
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
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
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
67 - virtualenv -p /usr/bin/python3 /tmp/venv
68 - . /tmp/venv/bin/activate
69 - pip install -r test/py/requirements.txt
70 # "${var:+"-k $var"}" expands to "" if $var is empty, "-k $var" if not
71 - export PATH=/opt/qemu/bin:/tmp/uboot-test-hooks/bin:${PATH};
72 export PYTHONPATH=/tmp/uboot-test-hooks/py/travis-ci;
73 ./test/py/test.py -ra --bd ${TEST_PY_BD} ${TEST_PY_ID}
74 ${TEST_PY_TEST_SPEC:+"-k ${TEST_PY_TEST_SPEC}"}
75 --build-dir "$UBOOT_TRAVIS_BUILD_DIR"
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
80
81 build all 32bit ARM platforms:
82 stage: world build
83 script:
84 - ret=0;
85 git config --global --add safe.directory "${CI_PROJECT_DIR}";
86 ./tools/buildman/buildman -o /tmp -PEWM arm -x aarch64 || ret=$?;
87 if [[ $ret -ne 0 ]]; then
88 ./tools/buildman/buildman -o /tmp -seP;
89 exit $ret;
90 fi;
91
92 build all 64bit ARM platforms:
93 stage: world build
94 script:
95 - virtualenv -p /usr/bin/python3 /tmp/venv
96 - . /tmp/venv/bin/activate
97 - ret=0;
98 git config --global --add safe.directory "${CI_PROJECT_DIR}";
99 ./tools/buildman/buildman -o /tmp -PEWM aarch64 || ret=$?;
100 if [[ $ret -ne 0 ]]; then
101 ./tools/buildman/buildman -o /tmp -seP;
102 exit $ret;
103 fi;
104
105 build all PowerPC platforms:
106 stage: world build
107 script:
108 - ret=0;
109 git config --global --add safe.directory "${CI_PROJECT_DIR}";
110 ./tools/buildman/buildman -o /tmp -P -E -W powerpc || ret=$?;
111 if [[ $ret -ne 0 ]]; then
112 ./tools/buildman/buildman -o /tmp -seP;
113 exit $ret;
114 fi;
115
116 build all other platforms:
117 stage: world build
118 script:
119 - ret=0;
120 git config --global --add safe.directory "${CI_PROJECT_DIR}";
121 ./tools/buildman/buildman -o /tmp -PEWM -x arm,powerpc || ret=$?;
122 if [[ $ret -ne 0 ]]; then
123 ./tools/buildman/buildman -o /tmp -seP;
124 exit $ret;
125 fi;
126
127 check for new CONFIG symbols outside Kconfig:
128 stage: testsuites
129 script:
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_'
134 :^doc/ :^arch/arm/dts/ :^scripts/kconfig/lkc.h
135 :^include/linux/kconfig.h :^tools/ && exit 1 || exit 0
136
137 # QA jobs for code analytics
138 # static code analysis with cppcheck (we can add --enable=all later)
139 cppcheck:
140 stage: testsuites
141 script:
142 - cppcheck -j$(nproc) --force --quiet --inline-suppr .
143
144 # search for TODO within source tree
145 grep TODO/FIXME/HACK:
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
153 # build documentation
154 docs:
155 stage: testsuites
156 script:
157 - virtualenv -p /usr/bin/python3 /tmp/venvhtml
158 - . /tmp/venvhtml/bin/activate
159 - pip install -r doc/sphinx/requirements.txt
160 - make htmldocs
161 - make infodocs
162
163 # some statistics about the code base
164 sloccount:
165 stage: testsuites
166 script:
167 - sloccount .
168
169 # ensure all configs have MAINTAINERS entries
170 Check for configs without MAINTAINERS entry:
171 stage: testsuites
172 script:
173 - ./tools/buildman/buildman -R
174
175 # Ensure host tools build
176 Build tools-only:
177 stage: testsuites
178 script:
179 - make tools-only_config tools-only -j$(nproc)
180
181 # Ensure env tools build
182 Build envtools:
183 stage: testsuites
184 script:
185 - make tools-only_config envtools -j$(nproc)
186
187 Run binman, buildman, dtoc, Kconfig and patman testsuites:
188 stage: testsuites
189 script:
190 - git config --global user.name "GitLab CI Runner";
191 git config --global user.email trini@konsulko.com;
192 git config --global --add safe.directory "${CI_PROJECT_DIR}";
193 export USER=gitlab;
194 virtualenv -p /usr/bin/python3 /tmp/venv;
195 . /tmp/venv/bin/activate;
196 pip install -r test/py/requirements.txt;
197 export UBOOT_TRAVIS_BUILD_DIR=/tmp/sandbox_spl;
198 export PYTHONPATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc/pylibfdt";
199 export PATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc:${PATH}";
200 set +e;
201 ./tools/buildman/buildman -T0 -o ${UBOOT_TRAVIS_BUILD_DIR} -w
202 --board sandbox_spl;
203 set -e;
204 ./tools/binman/binman --toolpath ${UBOOT_TRAVIS_BUILD_DIR}/tools test;
205 ./tools/buildman/buildman -t;
206 ./tools/dtoc/dtoc -t;
207 ./tools/patman/patman test;
208 make testconfig
209
210 Run tests for Nokia RX-51 (aka N900):
211 stage: testsuites
212 script:
213 - export PATH=/opt/gcc-12.2.0-nolibc/arm-linux-gnueabi/bin:$PATH;
214 test/nokia_rx51_test.sh
215
216 # Check for any pylint regressions
217 Run pylint:
218 stage: testsuites
219 script:
220 - git config --global --add safe.directory "${CI_PROJECT_DIR}"
221 - pip install -r test/py/requirements.txt
222 - pip install asteval pylint==2.12.2 pyopenssl
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
227 - set +e
228 - ./tools/buildman/buildman -T0 -o ${UBOOT_TRAVIS_BUILD_DIR} -w
229 --board sandbox_spl
230 - set -e
231 - pylint --version
232 - export PYTHONPATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc/pylibfdt"
233 - make pylint_err
234
235 # Test sandbox with test.py
236 sandbox test.py:
237 variables:
238 TEST_PY_BD: "sandbox"
239 <<: *buildman_and_testpy_dfn
240
241 sandbox with clang test.py:
242 variables:
243 TEST_PY_BD: "sandbox"
244 OVERRIDE: "-O clang-14"
245 <<: *buildman_and_testpy_dfn
246
247 sandbox without LTO test.py:
248 variables:
249 TEST_PY_BD: "sandbox"
250 BUILD_ENV: "NO_LTO=1"
251 <<: *buildman_and_testpy_dfn
252
253 sandbox_spl test.py:
254 variables:
255 TEST_PY_BD: "sandbox_spl"
256 TEST_PY_TEST_SPEC: "test_ofplatdata or test_handoff or test_spl"
257 <<: *buildman_and_testpy_dfn
258
259 sandbox_noinst_test.py:
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
265 sandbox_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
271 evb-ast2500 test.py:
272 variables:
273 TEST_PY_BD: "evb-ast2500"
274 TEST_PY_ID: "--id qemu"
275 <<: *buildman_and_testpy_dfn
276
277 evb-ast2600 test.py:
278 variables:
279 TEST_PY_BD: "evb-ast2600"
280 TEST_PY_ID: "--id qemu"
281 <<: *buildman_and_testpy_dfn
282
283 sandbox_flattree test.py:
284 variables:
285 TEST_PY_BD: "sandbox_flattree"
286 <<: *buildman_and_testpy_dfn
287
288 vexpress_ca9x4 test.py:
289 variables:
290 TEST_PY_BD: "vexpress_ca9x4"
291 TEST_PY_ID: "--id qemu"
292 <<: *buildman_and_testpy_dfn
293
294 integratorcp_cm926ejs test.py:
295 variables:
296 TEST_PY_BD: "integratorcp_cm926ejs"
297 TEST_PY_TEST_SPEC: "not sleep"
298 TEST_PY_ID: "--id qemu"
299 <<: *buildman_and_testpy_dfn
300
301 qemu_arm test.py:
302 variables:
303 TEST_PY_BD: "qemu_arm"
304 TEST_PY_TEST_SPEC: "not sleep"
305 <<: *buildman_and_testpy_dfn
306
307 qemu_arm64 test.py:
308 variables:
309 TEST_PY_BD: "qemu_arm64"
310 TEST_PY_TEST_SPEC: "not sleep"
311 <<: *buildman_and_testpy_dfn
312
313 qemu_malta test.py:
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
320 qemu_maltael test.py:
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
327 qemu_malta64 test.py:
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
334 qemu_malta64el test.py:
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
341 qemu-ppce500 test.py:
342 variables:
343 TEST_PY_BD: "qemu-ppce500"
344 TEST_PY_TEST_SPEC: "not sleep"
345 <<: *buildman_and_testpy_dfn
346
347 qemu-riscv32 test.py:
348 variables:
349 TEST_PY_BD: "qemu-riscv32"
350 TEST_PY_TEST_SPEC: "not sleep"
351 <<: *buildman_and_testpy_dfn
352
353 qemu-riscv64 test.py:
354 variables:
355 TEST_PY_BD: "qemu-riscv64"
356 TEST_PY_TEST_SPEC: "not sleep"
357 <<: *buildman_and_testpy_dfn
358
359 qemu-riscv32_spl test.py:
360 variables:
361 TEST_PY_BD: "qemu-riscv32_spl"
362 TEST_PY_TEST_SPEC: "not sleep"
363 <<: *buildman_and_testpy_dfn
364
365 qemu-riscv64_spl test.py:
366 variables:
367 TEST_PY_BD: "qemu-riscv64_spl"
368 TEST_PY_TEST_SPEC: "not sleep"
369 <<: *buildman_and_testpy_dfn
370
371 qemu-x86 test.py:
372 variables:
373 TEST_PY_BD: "qemu-x86"
374 TEST_PY_TEST_SPEC: "not sleep"
375 <<: *buildman_and_testpy_dfn
376
377 qemu-x86_64 test.py:
378 variables:
379 TEST_PY_BD: "qemu-x86_64"
380 TEST_PY_TEST_SPEC: "not sleep"
381 <<: *buildman_and_testpy_dfn
382
383 r2dplus_i82557c test.py:
384 variables:
385 TEST_PY_BD: "r2dplus"
386 TEST_PY_ID: "--id i82557c_qemu"
387 <<: *buildman_and_testpy_dfn
388
389 r2dplus_pcnet test.py:
390 variables:
391 TEST_PY_BD: "r2dplus"
392 TEST_PY_ID: "--id pcnet_qemu"
393 <<: *buildman_and_testpy_dfn
394
395 r2dplus_rtl8139 test.py:
396 variables:
397 TEST_PY_BD: "r2dplus"
398 TEST_PY_ID: "--id rtl8139_qemu"
399 <<: *buildman_and_testpy_dfn
400
401 r2dplus_tulip test.py:
402 variables:
403 TEST_PY_BD: "r2dplus"
404 TEST_PY_ID: "--id tulip_qemu"
405 <<: *buildman_and_testpy_dfn
406
407 sifive_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
413 sifive_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
419 xilinx_zynq_virt test.py:
420 variables:
421 TEST_PY_BD: "xilinx_zynq_virt"
422 TEST_PY_TEST_SPEC: "not sleep"
423 TEST_PY_ID: "--id qemu"
424 <<: *buildman_and_testpy_dfn
425
426 xilinx_versal_virt test.py:
427 variables:
428 TEST_PY_BD: "xilinx_versal_virt"
429 TEST_PY_TEST_SPEC: "not sleep"
430 TEST_PY_ID: "--id qemu"
431 <<: *buildman_and_testpy_dfn
432
433 xtfpga test.py:
434 variables:
435 TEST_PY_BD: "xtfpga"
436 TEST_PY_TEST_SPEC: "not sleep"
437 TEST_PY_ID: "--id qemu"
438 <<: *buildman_and_testpy_dfn
439
440 coreboot 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