Merge tag 'tpm-030822' of https://source.denx.de/u-boot/custodians/u-boot-tpm
[platform/kernel/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 at:
4 # https://source.denx.de/u-boot/gitlab-ci-runner
5 image: trini/u-boot-gitlab-ci-runner:focal-20220302-15Mar2022
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 clone --depth=1 https://source.denx.de/u-boot/u-boot-test-hooks /tmp/uboot-test-hooks
18     - ln -s travis-ci /tmp/uboot-test-hooks/bin/`hostname`
19     - ln -s travis-ci /tmp/uboot-test-hooks/py/`hostname`
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
22     - if [[ "${TEST_PY_BD}" == "qemu-riscv32_spl" ]]; then
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;
25       fi
26     - if [[ "${TEST_PY_BD}" == "qemu-riscv64_spl" ]] || [[ "${TEST_PY_BD}" == "sifive_unleashed" ]]; then
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;
29       fi
30
31   after_script:
32     - rm -rf /tmp/uboot-test-hooks /tmp/venv
33   script:
34     # If we've been asked to use clang only do one configuration.
35     - export UBOOT_TRAVIS_BUILD_DIR=/tmp/${TEST_PY_BD}
36     - tools/buildman/buildman -o ${UBOOT_TRAVIS_BUILD_DIR} -w -E -W -e
37         --board ${TEST_PY_BD} ${OVERRIDE}
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
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
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
55     - if [[ "${TEST_PY_BD}" == "coreboot" ]]; then
56         wget -O -
57           "https://drive.google.com/uc?id=1x6nrtWIyIRPLS2cQBwYTnT2TbOI8UjmM&export=download" |
58           xz -dc >${UBOOT_TRAVIS_BUILD_DIR}/coreboot.rom;
59         wget -O -
60           "https://drive.google.com/uc?id=149Cz-5SZXHNKpi9xg6R_5XITWohu348y&export=download" >
61           cbfstool;
62         chmod a+x cbfstool;
63         ./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;
64       fi
65     - virtualenv -p /usr/bin/python3 /tmp/venv
66     - . /tmp/venv/bin/activate
67     - pip install -r test/py/requirements.txt
68     # "${var:+"-k $var"}" expands to "" if $var is empty, "-k $var" if not
69     - export PATH=/opt/qemu/bin:/tmp/uboot-test-hooks/bin:${PATH};
70       export PYTHONPATH=/tmp/uboot-test-hooks/py/travis-ci;
71       ./test/py/test.py -ra --bd ${TEST_PY_BD} ${TEST_PY_ID}
72         ${TEST_PY_TEST_SPEC:+"-k ${TEST_PY_TEST_SPEC}"}
73         --build-dir "$UBOOT_TRAVIS_BUILD_DIR"
74     # It seems that the files in /tmp go away, so copy out what we need
75     - if [[ "${TEST_PY_BD}" == "coreboot" ]]; then
76         cp -v /tmp/coreboot/*.{html,css} .;
77       fi
78
79 build all 32bit ARM platforms:
80   stage: world build
81   script:
82     - ret=0;
83       ./tools/buildman/buildman -o /tmp -P -E -W arm -x aarch64 || ret=$?;
84       if [[ $ret -ne 0 ]]; then
85         ./tools/buildman/buildman -o /tmp -seP;
86         exit $ret;
87       fi;
88
89 build all 64bit ARM platforms:
90   stage: world build
91   script:
92     - virtualenv -p /usr/bin/python3 /tmp/venv
93     - . /tmp/venv/bin/activate
94     - pip install pyelftools
95     - ret=0;
96       ./tools/buildman/buildman -o /tmp -P -E -W aarch64 || ret=$?;
97       if [[ $ret -ne 0 ]]; then
98         ./tools/buildman/buildman -o /tmp -seP;
99         exit $ret;
100       fi;
101
102 build all PowerPC platforms:
103   stage: world build
104   script:
105     - ret=0;
106       ./tools/buildman/buildman -o /tmp -P -E -W powerpc || ret=$?;
107       if [[ $ret -ne 0 ]]; then
108         ./tools/buildman/buildman -o /tmp -seP;
109         exit $ret;
110       fi;
111
112 build all other platforms:
113   stage: world build
114   script:
115     - ret=0;
116       ./tools/buildman/buildman -o /tmp -P -E -W -x arm,powerpc || ret=$?;
117       if [[ $ret -ne 0 ]]; then
118         ./tools/buildman/buildman -o /tmp -seP;
119         exit $ret;
120       fi;
121
122 check for migrated symbols in board header:
123   stage: testsuites
124   script:
125     - KSYMLST=`mktemp`;
126       KUSEDLST=`mktemp`;
127       RET=0;
128       cat `find . -name "Kconfig*"` |
129          sed -n -e 's/^\s*config *\([A-Za-z0-9_]*\).*$/CONFIG_\1/p'
130          -e 's/^\s*menuconfig *\([A-Za-z0-9_]*\).*$/CONFIG_\1/p'
131          | sort -u > $KSYMLST;
132       for CFG in `find include/configs -name "*.h"`; do
133          (grep '#define[[:blank:]]CONFIG_' $CFG |
134             sed -n 's/#define.\(CONFIG_[A-Za-z0-9_]*\).*/\1/p' ;
135             grep '#undef[[:blank:]]CONFIG_' $CFG |
136             sed -n 's/#undef.\(CONFIG_[A-Za-z0-9_]*\).*/\1/p') |
137             sort -u > ${KUSEDLST} || true;
138          NUM=`comm -123 --total --output-delimiter=, ${KSYMLST} ${KUSEDLST} |
139             cut -d , -f 3`;
140          if [[ $NUM -ne 0 ]]; then
141             echo "Unmigrated symbols found in $CFG:";
142             comm -12 ${KSYMLST} ${KUSEDLST};
143             RET=1;
144          fi;
145       done;
146       exit $RET
147
148 # QA jobs for code analytics
149 # static code analysis with cppcheck (we can add --enable=all later)
150 cppcheck:
151   stage: testsuites
152   script:
153     - cppcheck -j$(nproc) --force --quiet --inline-suppr .
154
155 # search for TODO within source tree
156 grep TODO/FIXME/HACK:
157   stage: testsuites
158   script:
159     - grep -r TODO .
160     - grep -r FIXME .
161     # search for HACK within source tree and ignore HACKKIT board
162     - grep -r HACK . | grep -v HACKKIT
163
164 # build HTML documentation
165 htmldocs:
166   stage: testsuites
167   script:
168     - virtualenv -p /usr/bin/python3 /tmp/venvhtml
169     - . /tmp/venvhtml/bin/activate
170     - pip install -r doc/sphinx/requirements.txt
171     - make htmldocs
172
173 # some statistics about the code base
174 sloccount:
175   stage: testsuites
176   script:
177     - sloccount .
178
179 # ensure all configs have MAINTAINERS entries
180 Check for configs without MAINTAINERS entry:
181   stage: testsuites
182   script:
183     - if [ `./tools/genboardscfg.py -f 2>&1 | wc -l` -ne 0 ]; then exit 1; fi
184
185 # Ensure host tools build
186 Build tools-only:
187   stage: testsuites
188   script:
189     - make tools-only_config tools-only -j$(nproc)
190
191 # Ensure env tools build
192 Build envtools:
193   stage: testsuites
194   script:
195     - make tools-only_config envtools -j$(nproc)
196
197 Run binman, buildman, dtoc, Kconfig and patman testsuites:
198   stage: testsuites
199   script:
200     - git config --global user.name "GitLab CI Runner";
201       git config --global user.email trini@konsulko.com;
202       export USER=gitlab;
203       virtualenv -p /usr/bin/python3 /tmp/venv;
204       . /tmp/venv/bin/activate;
205       pip install -r test/py/requirements.txt;
206       export UBOOT_TRAVIS_BUILD_DIR=/tmp/sandbox_spl;
207       export PYTHONPATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc/pylibfdt";
208       export PATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc:${PATH}";
209       ./tools/buildman/buildman -T0 -o ${UBOOT_TRAVIS_BUILD_DIR} -w
210         --board sandbox_spl;
211       ./tools/binman/binman --toolpath ${UBOOT_TRAVIS_BUILD_DIR}/tools test;
212       ./tools/buildman/buildman -t;
213       ./tools/dtoc/dtoc -t;
214       ./tools/patman/patman test;
215       make testconfig
216
217 Run tests for Nokia RX-51 (aka N900):
218   stage: testsuites
219   script:
220     - export PATH=/opt/gcc-11.1.0-nolibc/arm-linux-gnueabi/bin:$PATH;
221       test/nokia_rx51_test.sh
222
223 # Check for any pylint regressions
224 Run pylint:
225   stage: testsuites
226   script:
227     - pip install -r test/py/requirements.txt
228     - pip install asteval pylint==2.12.2 pyopenssl
229     - export PATH=${PATH}:~/.local/bin
230     - echo "[MASTER]" >> .pylintrc
231     - echo "load-plugins=pylint.extensions.docparams" >> .pylintrc
232     - export UBOOT_TRAVIS_BUILD_DIR=/tmp/sandbox_spl
233     - ./tools/buildman/buildman -T0 -o ${UBOOT_TRAVIS_BUILD_DIR} -w
234         --board sandbox_spl
235     - pylint --version
236     - export PYTHONPATH="${UBOOT_TRAVIS_BUILD_DIR}/scripts/dtc/pylibfdt"
237     - make pylint_err
238
239 # Test sandbox with test.py
240 sandbox test.py:
241   variables:
242     TEST_PY_BD: "sandbox"
243   <<: *buildman_and_testpy_dfn
244
245 sandbox with clang test.py:
246   variables:
247     TEST_PY_BD: "sandbox"
248     OVERRIDE: "-O clang-13"
249   <<: *buildman_and_testpy_dfn
250
251 sandbox_spl test.py:
252   variables:
253     TEST_PY_BD: "sandbox_spl"
254     TEST_PY_TEST_SPEC: "test_ofplatdata or test_handoff or test_spl"
255   <<: *buildman_and_testpy_dfn
256
257 sandbox_noinst_test.py:
258   variables:
259     TEST_PY_BD: "sandbox_noinst"
260     TEST_PY_TEST_SPEC: "test_ofplatdata or test_handoff or test_spl"
261   <<: *buildman_and_testpy_dfn
262
263 sandbox_vpl test.py:
264   variables:
265     TEST_PY_BD: "sandbox_vpl"
266     TEST_PY_TEST_SPEC: "test_vpl_help or test_spl"
267   <<: *buildman_and_testpy_dfn
268
269 evb-ast2500 test.py:
270   variables:
271     TEST_PY_BD: "evb-ast2500"
272     TEST_PY_ID: "--id qemu"
273   <<: *buildman_and_testpy_dfn
274
275 evb-ast2600 test.py:
276   variables:
277     TEST_PY_BD: "evb-ast2600"
278     TEST_PY_ID: "--id qemu"
279   <<: *buildman_and_testpy_dfn
280
281 sandbox_flattree test.py:
282   variables:
283     TEST_PY_BD: "sandbox_flattree"
284   <<: *buildman_and_testpy_dfn
285
286 vexpress_ca9x4 test.py:
287   variables:
288     TEST_PY_BD: "vexpress_ca9x4"
289     TEST_PY_ID: "--id qemu"
290   <<: *buildman_and_testpy_dfn
291
292 integratorcp_cm926ejs test.py:
293   variables:
294     TEST_PY_BD: "integratorcp_cm926ejs"
295     TEST_PY_TEST_SPEC: "not sleep"
296     TEST_PY_ID: "--id qemu"
297   <<: *buildman_and_testpy_dfn
298
299 qemu_arm test.py:
300   variables:
301     TEST_PY_BD: "qemu_arm"
302     TEST_PY_TEST_SPEC: "not sleep"
303   <<: *buildman_and_testpy_dfn
304
305 qemu_arm64 test.py:
306   variables:
307     TEST_PY_BD: "qemu_arm64"
308     TEST_PY_TEST_SPEC: "not sleep"
309   <<: *buildman_and_testpy_dfn
310
311 qemu_malta test.py:
312   variables:
313     TEST_PY_BD: "malta"
314     TEST_PY_TEST_SPEC: "not sleep and not efi"
315     TEST_PY_ID: "--id qemu"
316   <<: *buildman_and_testpy_dfn
317
318 qemu_maltael test.py:
319   variables:
320     TEST_PY_BD: "maltael"
321     TEST_PY_TEST_SPEC: "not sleep and not efi"
322     TEST_PY_ID: "--id qemu"
323   <<: *buildman_and_testpy_dfn
324
325 qemu_malta64 test.py:
326   variables:
327     TEST_PY_BD: "malta64"
328     TEST_PY_TEST_SPEC: "not sleep and not efi"
329     TEST_PY_ID: "--id qemu"
330   <<: *buildman_and_testpy_dfn
331
332 qemu_malta64el test.py:
333   variables:
334     TEST_PY_BD: "malta64el"
335     TEST_PY_TEST_SPEC: "not sleep and not efi"
336     TEST_PY_ID: "--id qemu"
337   <<: *buildman_and_testpy_dfn
338
339 qemu-ppce500 test.py:
340   variables:
341     TEST_PY_BD: "qemu-ppce500"
342     TEST_PY_TEST_SPEC: "not sleep"
343   <<: *buildman_and_testpy_dfn
344
345 qemu-riscv32 test.py:
346   variables:
347     TEST_PY_BD: "qemu-riscv32"
348     TEST_PY_TEST_SPEC: "not sleep"
349   <<: *buildman_and_testpy_dfn
350
351 qemu-riscv64 test.py:
352   variables:
353     TEST_PY_BD: "qemu-riscv64"
354     TEST_PY_TEST_SPEC: "not sleep"
355   <<: *buildman_and_testpy_dfn
356
357 qemu-riscv32_spl test.py:
358   variables:
359     TEST_PY_BD: "qemu-riscv32_spl"
360     TEST_PY_TEST_SPEC: "not sleep"
361   <<: *buildman_and_testpy_dfn
362
363 qemu-riscv64_spl test.py:
364   variables:
365     TEST_PY_BD: "qemu-riscv64_spl"
366     TEST_PY_TEST_SPEC: "not sleep"
367   <<: *buildman_and_testpy_dfn
368
369 qemu-x86 test.py:
370   variables:
371     TEST_PY_BD: "qemu-x86"
372     TEST_PY_TEST_SPEC: "not sleep"
373   <<: *buildman_and_testpy_dfn
374
375 qemu-x86_64 test.py:
376   variables:
377     TEST_PY_BD: "qemu-x86_64"
378     TEST_PY_TEST_SPEC: "not sleep"
379   <<: *buildman_and_testpy_dfn
380
381 r2dplus_i82557c test.py:
382   variables:
383     TEST_PY_BD: "r2dplus"
384     TEST_PY_ID: "--id i82557c_qemu"
385   <<: *buildman_and_testpy_dfn
386
387 r2dplus_pcnet test.py:
388   variables:
389     TEST_PY_BD: "r2dplus"
390     TEST_PY_ID: "--id pcnet_qemu"
391   <<: *buildman_and_testpy_dfn
392
393 r2dplus_rtl8139 test.py:
394   variables:
395     TEST_PY_BD: "r2dplus"
396     TEST_PY_ID: "--id rtl8139_qemu"
397   <<: *buildman_and_testpy_dfn
398
399 r2dplus_tulip test.py:
400   variables:
401     TEST_PY_BD: "r2dplus"
402     TEST_PY_ID: "--id tulip_qemu"
403   <<: *buildman_and_testpy_dfn
404
405 sifive_unleashed_sdcard test.py:
406   variables:
407     TEST_PY_BD: "sifive_unleashed"
408     TEST_PY_ID: "--id sdcard_qemu"
409   <<: *buildman_and_testpy_dfn
410
411 sifive_unleashed_spi-nor test.py:
412   variables:
413     TEST_PY_BD: "sifive_unleashed"
414     TEST_PY_ID: "--id spi-nor_qemu"
415   <<: *buildman_and_testpy_dfn
416
417 xilinx_zynq_virt test.py:
418   variables:
419     TEST_PY_BD: "xilinx_zynq_virt"
420     TEST_PY_TEST_SPEC: "not sleep"
421     TEST_PY_ID: "--id qemu"
422   <<: *buildman_and_testpy_dfn
423
424 xilinx_versal_virt test.py:
425   variables:
426     TEST_PY_BD: "xilinx_versal_virt"
427     TEST_PY_TEST_SPEC: "not sleep"
428     TEST_PY_ID: "--id qemu"
429   <<: *buildman_and_testpy_dfn
430
431 xtfpga test.py:
432   variables:
433     TEST_PY_BD: "xtfpga"
434     TEST_PY_TEST_SPEC: "not sleep"
435     TEST_PY_ID: "--id qemu"
436   <<: *buildman_and_testpy_dfn
437
438 coreboot test.py:
439   variables:
440     TEST_PY_BD: "coreboot"
441     TEST_PY_TEST_SPEC: "not sleep"
442     TEST_PY_ID: "--id qemu"
443   artifacts:
444     paths:
445       - "*.html"
446       - "*.css"
447     expire_in: 1 week
448   <<: *buildman_and_testpy_dfn