X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=.travis.yml;h=eb531f1e5b7ab86aac2d46e9bd412197ed09acab;hb=3ef55a74739a09b2f56495a3fe5852b15f09b9d9;hp=7b0eb6e4f6b576267157a977ad3205cadd8fbb2a;hpb=03b54997d568a6879a045ba775e44d62289a8fb9;p=oweals%2Fu-boot.git diff --git a/.travis.yml b/.travis.yml index 7b0eb6e4f6..eb531f1e5b 100644 --- a/.travis.yml +++ b/.travis.yml @@ -10,6 +10,9 @@ language: c addons: apt: + sources: + - ubuntu-toolchain-r-test + - llvm-toolchain-trusty-7 packages: - cppcheck - sloccount @@ -23,15 +26,14 @@ addons: - libpython-dev - iasl - grub-efi-ia32-bin + - grub-efi-amd64-bin - rpm2cpio - wget - device-tree-compiler - lzop - -before_install: - - sudo add-apt-repository ppa:ubuntu-toolchain-r/test -y - - sudo apt-get update -q - - sudo apt-get install libisl15 -y + - liblz4-tool + - libisl15 + - clang-7 install: # Clone uboot-test-hooks @@ -40,13 +42,15 @@ install: - ln -s travis-ci /tmp/uboot-test-hooks/py/`hostname` # prepare buildman environment - echo -e "[toolchain]\nroot = /usr" > ~/.buildman - - echo -e "arc = /tmp/arc_gnu_2017.09_prebuilt_uclibc_le_archs_linux_install" >> ~/.buildman + - echo -e "arc = /tmp/arc_gnu_2018.09_prebuilt_uclibc_le_archs_linux_install" >> ~/.buildman - echo -e "\n[toolchain-alias]\nsh = sh2\n" >> ~/.buildman - cat ~/.buildman - virtualenv /tmp/venv - . /tmp/venv/bin/activate - - pip install pytest + - pip install pytest==2.8.7 + - pip install python-subunit - grub-mkimage -o ~/grub_x86.efi -O i386-efi normal echo lsefimmap lsefi lsefisystab efinet tftp minicmd + - grub-mkimage -o ~/grub_x64.efi -O x86_64-efi normal echo lsefimmap lsefi lsefisystab efinet tftp minicmd - mkdir ~/grub2-arm - ( cd ~/grub2-arm; wget -O - http://download.opensuse.org/ports/armv7hl/distribution/leap/42.2/repo/oss/suse/armv7hl/grub2-arm-efi-2.02~beta2-87.1.armv7hl.rpm | rpm2cpio | cpio -di ) - mkdir ~/grub2-arm64 @@ -59,21 +63,26 @@ env: - BUILD_DIR=build - HOSTCC="cc" - HOSTCXX="c++" + - QEMU_VERSION="v3.1.0" before_script: # install toolchains based on TOOLCHAIN} variable - if [[ "${TOOLCHAIN}" == *m68k* ]]; then ./tools/buildman/buildman --fetch-arch m68k ; fi - if [[ "${TOOLCHAIN}" == *microblaze* ]]; then ./tools/buildman/buildman --fetch-arch microblaze ; fi - if [[ "${TOOLCHAIN}" == *mips* ]]; then ./tools/buildman/buildman --fetch-arch mips ; fi - - if [[ "${TOOLCHAIN}" == *or32* ]]; then ./tools/buildman/buildman --fetch-arch or32 ; fi - if [[ "${TOOLCHAIN}" == *sh* ]]; then ./tools/buildman/buildman --fetch-arch sh2 ; fi - - if [[ "${TOOLCHAIN}" == *x86_64* ]]; then - ./tools/buildman/buildman --fetch-arch x86_64; - echo -e "\n[toolchain-prefix]\nx86 = ${HOME}/.buildman-toolchains/gcc-7.3.0-nolibc/x86_64-linux/bin/x86_64-linux-" >> ~/.buildman; + - if [[ "${TOOLCHAIN}" == *i386* ]]; then + ./tools/buildman/buildman --fetch-arch i386; + echo -e "\n[toolchain-alias]\nx86 = i386" >> ~/.buildman; fi - if [[ "${TOOLCHAIN}" == arc ]]; then - wget https://github.com/foss-for-synopsys-dwc-arc-processors/toolchain/releases/download/arc-2017.09-release/arc_gnu_2017.09_prebuilt_uclibc_le_archs_linux_install.tar.gz && - tar -C /tmp -xf arc_gnu_2017.09_prebuilt_uclibc_le_archs_linux_install.tar.gz; + wget https://github.com/foss-for-synopsys-dwc-arc-processors/toolchain/releases/download/arc-2018.09-release/arc_gnu_2018.09_prebuilt_uclibc_le_archs_linux_install.tar.gz && + tar -C /tmp -xf arc_gnu_2018.09_prebuilt_uclibc_le_archs_linux_install.tar.gz; + fi + - if [[ "${TOOLCHAIN}" == "nds32" ]]; then + wget https://github.com/vincentzwc/prebuilt-nds32-toolchain/releases/download/20180521/nds32le-linux-glibc-v3-upstream.tar.gz && + tar -C /tmp -xf nds32le-linux-glibc-v3-upstream.tar.gz && + echo -e "\n[toolchain-prefix]\nnds32 = /tmp/nds32le-linux-glibc-v3-upstream/bin/nds32le-linux-" >> ~/.buildman; fi - if [[ "${TOOLCHAIN}" == *xtensa* ]]; then wget https://github.com/foss-xtensa/toolchain/releases/download/2018.02/x86_64-2018.02-${TOOLCHAIN}.tar.gz && @@ -87,15 +96,14 @@ before_script: fi - if [[ "${TOOLCHAIN}" == "powerpc" ]]; then ./tools/buildman/buildman --fetch-arch powerpc; fi - if [[ "${TOOLCHAIN}" == "riscv" ]]; then - wget https://github.com/andestech/prebuilt/releases/download/20180530/riscv64-unknown-linux-gnu.tar.gz && - tar -C /tmp -xf riscv64-unknown-linux-gnu.tar.gz && - echo -e "\n[toolchain-prefix]\nriscv = /tmp/riscv64-unknown-linux-gnu/bin/riscv64-unknown-linux-gnu-" >> ~/.buildman; + ./tools/buildman/buildman --fetch-arch riscv64; + echo -e "\n[toolchain-alias]\nriscv = riscv64" >> ~/.buildman; fi - if [[ "${QEMU_TARGET}" != "" ]]; then git clone git://git.qemu.org/qemu.git /tmp/qemu; pushd /tmp/qemu; git submodule update --init dtc && - git checkout v2.8.0-rc3 && + git checkout ${QEMU_VERSION} && ./configure --prefix=/tmp/qemu-install --target-list=${QEMU_TARGET} && make -j4 all install; popd; @@ -105,10 +113,11 @@ script: # Comments must be outside the command strings below, or the Travis parser # will get confused. # - # Exit code 129 means warnings only. + # From buildman, exit code 129 means warnings only. If we've been asked to + # use clang only do one configuration. - if [[ "${BUILDMAN}" != "" ]]; then ret=0; - tools/buildman/buildman -P -E ${BUILDMAN} || ret=$?; + tools/buildman/buildman -P -E ${BUILDMAN} ${OVERRIDE}|| ret=$?; if [[ $ret -ne 0 && $ret -ne 129 ]]; then tools/buildman/buildman -sdeP ${BUILDMAN}; exit $ret; @@ -120,6 +129,7 @@ script: # value. - export UBOOT_TRAVIS_BUILD_DIR=`cd .. && pwd`/.bm-work/${TEST_PY_BD}; cp ~/grub_x86.efi $UBOOT_TRAVIS_BUILD_DIR/; + cp ~/grub_x64.efi $UBOOT_TRAVIS_BUILD_DIR/; cp ~/grub2-arm/usr/lib/grub2/arm-efi/grub.efi $UBOOT_TRAVIS_BUILD_DIR/grub_arm.efi; cp ~/grub2-arm64/usr/lib/grub2/arm64-efi/grub.efi $UBOOT_TRAVIS_BUILD_DIR/grub_arm64.efi; if [[ "${TEST_PY_BD}" != "" ]]; then @@ -146,233 +156,325 @@ matrix: include: # we need to build by vendor due to 50min time limit for builds # each env setting here is a dedicated build - - env: + - name: "buildman arc" + env: - BUILDMAN="arc" TOOLCHAIN="arc" - - env: + - name: "buildman arm11 arm7 arm920t arm946es" + env: - BUILDMAN="arm11 arm7 arm920t arm946es" - - env: + - name: "buildman arm926ejs (non-NXP,siemens,at91,kirkwood,spear)" + env: - JOB="arm926ejs" - BUILDMAN="arm926ejs -x mx,siemens,atmel" - - env: - - BUILDMAN="atmel" - - env: - BUILDMAN="boundary engicam toradex" - - env: - - JOB="Freescale ARM32" - BUILDMAN="freescale -x powerpc,m68k,aarch64" - - env: - - JOB="Freescale AArch64" - BUILDMAN="freescale&aarch64" - - env: - - JOB="i.MX6 (non-Freescale)" - BUILDMAN="mx6 -x freescale,toradex,boundary,engicam" - - env: - - JOB="i.MX (non-Freescale, non-i.MX6)" - BUILDMAN="mx -x freescale,mx6,toradex" - - env: + BUILDMAN="arm926ejs -x freescale,siemens,at91,kirkwood,spear,omap" + - name: "buildman at91 (non arm v7)" + env: + - BUILDMAN="at91 -x armv7" + - name: "buildman at91 (non arm926ejs)" + env: + - BUILDMAN="at91 -x arm926ejs" + - name: "buildman boundary engicam toradex" + env: + - BUILDMAN="boundary engicam toradex" + - name: "buildman NXP ARM32" + env: + - BUILDMAN="freescale -x powerpc,m68k,aarch64" + - name: "buildman NXP AArch64 LS101x" + env: + - BUILDMAN="freescale&aarch64&ls101" + - name: "buildman NXP AArch64 LS104x" + env: + - BUILDMAN="freescale&aarch64&ls104" + - name: "buildman NXP AArch64 LS108x" + env: + - BUILDMAN="freescale&aarch64&ls108" + - name: "buildman NXP AArch64 LS20xx" + env: + - BUILDMAN="freescale&aarch64&&ls20" + - name: "buildman i.MX6 (non-NXP)" + env: + - BUILDMAN="mx6 -x freescale,toradex,boundary,engicam" + - name: "buildman i.MX (non-NXP,i.MX6,toradex)" + env: + - BUILDMAN="mx -x freescale,mx6,toradex" + - name: "buildman k2" + env: - BUILDMAN="k2" - - env: + - name: "buildman samsung socfpga" + env: - BUILDMAN="samsung socfpga" - - env: + - name: "buildman spear" + env: + - BUILDMAN="spear" + - name: "buildman sun4i" + env: - BUILDMAN="sun4i" - - env: + - name: "buildman sun5i" + env: - BUILDMAN="sun5i" - - env: + - name: "buildman sun6i" + env: - BUILDMAN="sun6i" - - env: + - name: "buildman sun7i" + env: - BUILDMAN="sun7i" - - env: + - name: "buildman sun8i" + env: - BUILDMAN="sun8i" - - env: + - name: "buildman sun9i" + env: - BUILDMAN="sun9i" - - env: + - name: "buildman sun50i" + env: - BUILDMAN="sun50i" - - env: - - JOB="Catch-all ARM" - BUILDMAN="arm -x arm11,arm7,arm9,aarch64,atmel,freescale,kirkwood,mvebu,siemens,tegra,uniphier,mx,samsung,sunxi,am33xx,omap,pxa,rockchip,toradex,socfpga,k2,xilinx" - - env: + - name: "buildman catch-all ARM" + env: + - BUILDMAN="arm -x arm11,arm7,arm9,aarch64,at91,freescale,kirkwood,mvebu,siemens,tegra,uniphier,mx,samsung,sunxi,am33xx,omap,pxa,rockchip,toradex,socfpga,k2,xilinx" + - name: "buildman sandbox x86" + env: - BUILDMAN="sandbox x86" - TOOLCHAIN="x86_64" - - env: - - BUILDMAN="kirkwood" - - env: + TOOLCHAIN="i386" + - name: "buildman kirkwood (excluding openrd)" + env: + - BUILDMAN="kirkwood -x openrd" + - name: "buildman mvebu" + env: - BUILDMAN="mvebu" - - env: - - JOB="PXA" + - name: "buildman PXA (non-toradex)" + env: - BUILDMAN="pxa -x toradex" - - env: + - name: "buildman m68k" + env: - BUILDMAN="m68k" TOOLCHAIN="m68k" - - env: + - name: "buildman microblaze" + env: - BUILDMAN="microblaze" TOOLCHAIN="microblaze" - - env: + - name: "buildman mips" + env: - BUILDMAN="mips" TOOLCHAIN="mips" - - env: - - JOB="Non-Freescale PowerPC" - BUILDMAN="powerpc -x freescale" + - name: "buildman non-Freescale PowerPC" + env: + - BUILDMAN="powerpc -x freescale" TOOLCHAIN="powerpc" - - env: + - name: "buildman mpc85xx&freescale (excluding many)" + env: - BUILDMAN="mpc85xx&freescale -x t208xrdb -x t4qds -x t102* -x p1_p2_rdb_pc -x p1010rdb -x corenet_ds -x b4860qds -x bsc91*" TOOLCHAIN="powerpc" - - env: + - name: "buildman t208xrdb corenet_ds" + env: - BUILDMAN="t208xrdb corenet_ds" TOOLCHAIN="powerpc" - - env: + - name: "buildman Freescale PowerPC" + env: - BUILDMAN="t4qds b4860qds mpc83xx&freescale mpc86xx&freescale" TOOLCHAIN="powerpc" - - env: + - name: "buildman t102*" + env: - BUILDMAN="t102*" TOOLCHAIN="powerpc" - - env: + - name: "buildman p1_p2_rdb_pc" + env: - BUILDMAN="p1_p2_rdb_pc" TOOLCHAIN="powerpc" - - env: + - name: "buildman p1010rdb bsc91" + env: - BUILDMAN="p1010rdb bsc91" TOOLCHAIN="powerpc" - - env: + - name: "buildman siemens" + env: - BUILDMAN="siemens" - - env: - - JOB="tegra" - BUILDMAN="tegra -x toradex" - - env: - - JOB="am33xx" - BUILDMAN="am33xx -x siemens" - - env: + - name: "buildman tegra" + env: + - BUILDMAN="tegra -x toradex" + - name: "buildman am33xx (no siemens)" + env: + - BUILDMAN="am33xx -x siemens" + - name: "buildman omap" + env: - BUILDMAN="omap" - - env: + - name: "buildman uniphier" + env: - BUILDMAN="uniphier" - - env: - - JOB="Catch-all AArch64" - BUILDMAN="aarch64 -x tegra,freescale,mvebu,uniphier,sunxi,samsung,rockchip,xilinx" - - env: + - name: "buildman catch-all AArch64" + env: + - BUILDMAN="aarch64 -x tegra,ls1,ls2,mvebu,uniphier,sunxi,samsung,rockchip,xilinx" + - name: "buildman rockchip" + env: - BUILDMAN="rockchip" - - env: - - JOB="sh" - BUILDMAN="sh -x arm" + - name: "buildman sh" + env: + - BUILDMAN="sh -x arm" TOOLCHAIN="sh" - - env: - - JOB="Xilinx (ARM)" - BUILDMAN="xilinx -x microblaze" - - env: + - name: "buildman Xilinx (ARM)" + env: + - BUILDMAN="xilinx -x microblaze" + - name: "buildman xtensa" + env: - BUILDMAN="xtensa" TOOLCHAIN="xtensa-dc233c-elf" - - env: + - name: "buildman riscv" + env: - BUILDMAN="riscv" TOOLCHAIN="riscv" + - name: "buildman nds32" + env: + - BUILDMAN="nds32" + TOOLCHAIN="nds32" # QA jobs for code analytics # static code analysis with cppcheck (we can add --enable=all later) - - env: - - JOB="cppcheck" + - name: "cppcheck" script: - cppcheck --force --quiet --inline-suppr . # search for TODO within source tree - - env: - - JOB="grep TODO" + - name: "grep TODO" script: - grep -r TODO . # search for FIXME within source tree - - env: - - JOB="grep FIXME HACK" + - name: "grep FIXME HACK" script: - grep -r FIXME . # search for HACK within source tree and ignore HACKKIT board script: - grep -r HACK . | grep -v HACKKIT # some statistics about the code base - - env: - - JOB="sloccount" + - name: "sloccount" script: - sloccount . + # ensure all configs have MAINTAINERS entries + - name: "Check for configs without MAINTAINERS entry" + script: + - if [ `./tools/genboardscfg.py -f 2>&1 | wc -l` -ne 0 ]; then exit 1; fi + # Ensure host tools build + - name: "Build tools-only" + script: + - make tools-only_config tools-only -j$(nproc) # test/py - - env: + - name: "test/py sandbox" + env: + - TEST_PY_BD="sandbox" + BUILDMAN="^sandbox$" + TOOLCHAIN="i386" + - name: "test/py sandbox with clang" + env: - TEST_PY_BD="sandbox" BUILDMAN="^sandbox$" - TOOLCHAIN="x86_64" - - env: + OVERRIDE="clang-7" + - name: "test/py sandbox_spl" + env: - TEST_PY_BD="sandbox_spl" TEST_PY_TEST_SPEC="test_ofplatdata" BUILDMAN="^sandbox$" - TOOLCHAIN="x86_64" + TOOLCHAIN="i386" TEST_PY_TOOLS="yes" - - env: + - name: "test/py sandbox_flattree" + env: - TEST_PY_BD="sandbox_flattree" BUILDMAN="^sandbox_flattree$" - TOOLCHAIN="x86_64" - - env: + TOOLCHAIN="i386" + - name: "test/py vexpress_ca15_tc2" + env: - TEST_PY_BD="vexpress_ca15_tc2" TEST_PY_ID="--id qemu" QEMU_TARGET="arm-softmmu" + QEMU_VERSION="v3.0.0" BUILDMAN="^vexpress_ca15_tc2$" - - env: + - name: "test/py vexpress_ca9x4" + env: - TEST_PY_BD="vexpress_ca9x4" TEST_PY_ID="--id qemu" QEMU_TARGET="arm-softmmu" BUILDMAN="^vexpress_ca9x4$" - - env: + - name: "test/py integratorcp_cm926ejs" + env: - TEST_PY_BD="integratorcp_cm926ejs" TEST_PY_TEST_SPEC="not sleep" TEST_PY_ID="--id qemu" QEMU_TARGET="arm-softmmu" BUILDMAN="^integratorcp_cm926ejs$" - - env: + - name: "test/py qemu_arm" + env: - TEST_PY_BD="qemu_arm" TEST_PY_TEST_SPEC="not sleep" QEMU_TARGET="arm-softmmu" BUILDMAN="^qemu_arm$" - - env: + - name: "test/py qemu_arm64" + env: - TEST_PY_BD="qemu_arm64" TEST_PY_TEST_SPEC="not sleep" QEMU_TARGET="aarch64-softmmu" BUILDMAN="^qemu_arm64$" - - env: + - name: "test/py qemu_mips" + env: - TEST_PY_BD="qemu_mips" TEST_PY_TEST_SPEC="not sleep" QEMU_TARGET="mips-softmmu" BUILDMAN="^qemu_mips$" TOOLCHAIN="mips" - - env: + - name: "test/py qemu_mipsel" + env: - TEST_PY_BD="qemu_mipsel" TEST_PY_TEST_SPEC="not sleep" QEMU_TARGET="mipsel-softmmu" BUILDMAN="^qemu_mipsel$" TOOLCHAIN="mips" - - env: + - name: "test/py qemu_mips64" + env: - TEST_PY_BD="qemu_mips64" TEST_PY_TEST_SPEC="not sleep" QEMU_TARGET="mips64-softmmu" BUILDMAN="^qemu_mips64$" TOOLCHAIN="mips" - - env: + - name: "test/py qemu_mips64el" + env: - TEST_PY_BD="qemu_mips64el" TEST_PY_TEST_SPEC="not sleep" QEMU_TARGET="mips64el-softmmu" BUILDMAN="^qemu_mips64el$" TOOLCHAIN="mips" - - env: + - name: "test/py qemu-ppce500" + env: - TEST_PY_BD="qemu-ppce500" TEST_PY_TEST_SPEC="not sleep" QEMU_TARGET="ppc-softmmu" BUILDMAN="^qemu-ppce500$" TOOLCHAIN="powerpc" - - env: + - name: "test/py qemu-x86" + env: - TEST_PY_BD="qemu-x86" TEST_PY_TEST_SPEC="not sleep" QEMU_TARGET="i386-softmmu" BUILDMAN="^qemu-x86$" - TOOLCHAIN="x86_64" + TOOLCHAIN="i386" BUILD_ROM="yes" - - env: + - name: "test/py qemu-x86_64" + env: + - TEST_PY_BD="qemu-x86_64" + TEST_PY_TEST_SPEC="not sleep" + QEMU_TARGET="x86_64-softmmu" + BUILDMAN="^qemu-x86_64$" + TOOLCHAIN="i386" + BUILD_ROM="yes" + - name: "test/py zynq_zc702" + env: - TEST_PY_BD="zynq_zc702" TEST_PY_TEST_SPEC="not sleep" QEMU_TARGET="arm-softmmu" TEST_PY_ID="--id qemu" BUILDMAN="^zynq_zc702$" - - env: + - name: "test/py xilinx_versal_virt" + env: + - TEST_PY_BD="xilinx_versal_virt" + TEST_PY_TEST_SPEC="not sleep" + QEMU_TARGET="aarch64-softmmu" + TEST_PY_ID="--id qemu" + BUILDMAN="^xilinx_versal_virt$" + - name: "test/py xtfpga" + env: - TEST_PY_BD="xtfpga" TEST_PY_TEST_SPEC="not sleep" QEMU_TARGET="xtensa-softmmu"