1 # The current Travis default is a container based 14.04 Trust on EC2
2 # Additional builds with specific requirements for a full VM need to
3 # be added as additional matrix: entries later on
36 - libspice-protocol-dev
47 # The channel name "irc.oftc.net#qemu" is encrypted against qemu/qemu
48 # to prevent IRC notifications from forks. This was created using:
49 # $ travis encrypt -r "qemu/qemu" "irc.oftc.net#qemu"
53 - secure: "F7GDRgjuOo5IUyRLqSkmDL7kvdU4UcH3Lm/W2db2JnDHTGCqgEdaYEYKciyCLZ57vOTsTsOgesN8iUT7hNHBd1KWKjZe9KDTZWppWRYVwAwQMzVeSOsbbU4tRoJ6Pp+3qhH1Z0eGYR9ZgKYAoTumDFgSAYRp4IscKS8jkoedOqM="
62 - TEST_CMD="make check"
67 # we want to do this ourselves
72 - if [ "$TRAVIS_OS_NAME" == "osx" ]; then brew update ; fi
73 - if [ "$TRAVIS_OS_NAME" == "osx" ]; then brew install libffi gettext glib pixman ; fi
74 - git submodule update --init --recursive capstone dtc ui/keycodemapdb
76 - mkdir -p ${BUILD_DIR} && cd ${BUILD_DIR}
77 - ${SRC_DIR}/configure ${CONFIG} || { cat config.log && exit 1; }
79 - make ${MAKEFLAGS} && ${TEST_CMD}
85 - CONFIG="--disable-system"
89 - CONFIG="--disable-user"
93 - CONFIG="--enable-debug --enable-debug-tcg"
97 - CONFIG="--disable-linux-aio --disable-cap-ng --disable-attr --disable-brlapi --disable-uuid --disable-libusb --disable-user"
101 - CONFIG="--enable-modules --disable-linux-user"
105 - CONFIG="--with-coroutine=ucontext --disable-linux-user"
109 - CONFIG="--with-coroutine=sigaltstack --disable-linux-user"
112 # Test out-of-tree builds
114 - CONFIG="--enable-debug --enable-debug-tcg"
115 - BUILD_DIR="out-of-tree/build/dir" SRC_DIR="../../.."
118 # Test with Clang for compile portability (Travis uses clang-5.0)
120 - CONFIG="--disable-system"
125 - CONFIG="--disable-user"
129 # gprof/gcov are GCC features
131 - CONFIG="--enable-gprof --enable-gcov --disable-pie --target-list=aarch64-softmmu,arm-softmmu,i386-softmmu,mips-softmmu,mips64-softmmu,ppc64-softmmu,riscv64-softmmu,s390x-softmmu,x86_64-softmmu"
133 - ${SRC_DIR}/scripts/travis/coverage-summary.sh
137 # We manually include builds which we disable "make check" for
139 - CONFIG="--enable-debug --enable-tcg-interpreter"
144 # We don't need to exercise every backend with every front-end
146 - CONFIG="--enable-trace-backends=log,simple,syslog --disable-system"
152 - CONFIG="--enable-trace-backends=ftrace --target-list=x86_64-softmmu"
158 - CONFIG="--enable-trace-backends=ust --target-list=x86_64-softmmu"
164 - CONFIG="--disable-tcg"
171 - CONFIG="--target-list=aarch64-softmmu,arm-softmmu,i386-softmmu,mips-softmmu,mips64-softmmu,ppc64-softmmu,riscv64-softmmu,s390x-softmmu,x86_64-softmmu"
178 - CONFIG="--target-list=i386-softmmu,ppc-softmmu,ppc64-softmmu,m68k-softmmu,x86_64-softmmu"
186 - CONFIG="--target-list=x86_64-softmmu"
192 - CONFIG="--target-list=x86_64-softmmu"
197 # Acceptance (Functional) tests
199 - CONFIG="--python=/usr/bin/python3 --target-list=x86_64-softmmu"
200 - TEST_CMD="make AVOCADO_SHOW=app check-acceptance"
208 # Using newer GCC with sanitizers
213 # PPAs for newer toolchains
214 - ubuntu-toolchain-r-test
236 - libspice-protocol-dev
237 - libspice-server-dev
247 - COMPILER_NAME=gcc CXX=g++-7 CC=gcc-7
248 - CONFIG="--cc=gcc-7 --cxx=g++-7 --disable-pie --disable-linux-user"
251 - ./configure ${CONFIG} --extra-cflags="-g3 -O0 -fsanitize=thread -fuse-ld=gold" || { cat config.log && exit 1; }
255 - CONFIG="--disable-system --disable-docs"
256 - TEST_CMD="make check-tcg"
258 - make ${MAKEFLAGS} && ${TEST_CMD} ${MAKEFLAGS}