From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:37497) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1cW2AX-0004Yt-2n for qemu-devel@nongnu.org; Tue, 24 Jan 2017 09:34:02 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1cW2AV-0005LU-KO for qemu-devel@nongnu.org; Tue, 24 Jan 2017 09:33:57 -0500 Received: from mail-wm0-x235.google.com ([2a00:1450:400c:c09::235]:37838) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1cW2AV-0005L0-F0 for qemu-devel@nongnu.org; Tue, 24 Jan 2017 09:33:55 -0500 Received: by mail-wm0-x235.google.com with SMTP id c206so212473634wme.0 for ; Tue, 24 Jan 2017 06:33:55 -0800 (PST) From: =?UTF-8?q?Alex=20Benn=C3=A9e?= Date: Tue, 24 Jan 2017 14:33:44 +0000 Message-Id: <20170124143346.22240-6-alex.bennee@linaro.org> In-Reply-To: <20170124143346.22240-1-alex.bennee@linaro.org> References: <20170124143346.22240-1-alex.bennee@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Subject: [Qemu-devel] [PATCH v2 5/7] new debian-multiarch-cross.docker: a cross-compiling docker guest List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: =?UTF-8?q?Alex=20Benn=C3=A9e?= , Fam Zheng , "open list:All patches CC here" This provides a basic Debian install with access to the emdebian cross compilers for armhf, arm64, mipsel and ppc64el. On its own it provides the basic cross build essentials for building any of those architectures. More complex cross-compilations would need to install library dependencies on top of this image. An example use: docker run --rm -it \ -v /home/alex/lsrc/qemu/qemu.git/:/home/alex/lsrc/qemu/qemu.git/ \ --user=alex:alex \ -w /home/alex/lsrc/qemu/qemu.git/arm-linux-user/tests \ -e CROSS_CC="arm-linux-gnueabihf-gcc" \ debian:cross make -f ../../tests/tcg/arm/Makefile Signed-off-by: Alex Bennée --- v2 - add clang (keep shippable happy) - rm adduser code (done direct now) - add aptitude (useful for debugging package clashes) --- .../dockerfiles/debian-multiarch-cross.docker | 45 ++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 tests/docker/dockerfiles/debian-multiarch-cross.docker diff --git a/tests/docker/dockerfiles/debian-multiarch-cross.docker b/tests/docker/dockerfiles/debian-multiarch-cross.docker new file mode 100644 index 0000000000..749fdf07e1 --- /dev/null +++ b/tests/docker/dockerfiles/debian-multiarch-cross.docker @@ -0,0 +1,45 @@ +# +# Docker multiarch cross-compiler target +# +# This docker target is builds on Debian and Emdebian's cross compiler targets +# to build distro with a selection of cross compilers for building test binaries. +# +# This does not include the build dependancies for QEMU as there are +# so many there are unresolvable clashes. +# +FROM debian:stable-slim + +# Setup some basic tools we need +RUN apt update +RUN apt install -yy curl aptitude + +# Setup Emdebian +RUN echo "deb http://emdebian.org/tools/debian/ jessie main" >> /etc/apt/sources.list +RUN curl http://emdebian.org/tools/debian/emdebian-toolchain-archive.key | apt-key add - + +# Duplicate deb line as deb-src +RUN cat /etc/apt/sources.list | sed "s/deb/deb-src/" >> /etc/apt/sources.list + +# Add the foriegn architectures we want +RUN dpkg --add-architecture armhf +RUN dpkg --add-architecture arm64 +RUN dpkg --add-architecture mipsel +RUN dpkg --add-architecture ppc64el + +#FIXME: Currently these cause clashes due to multi-arch being an ongoig process +#RUN dpkg --add-architecture mips +#RUN dpkg --add-architecture powerpc + +# Final update +RUN apt update + +# Install the crossbuild essential packages +# FIXME: crossbuild-essential-powerpc has a clash with '/lib/ld.so.1' +RUN apt install -yy clang crossbuild-essential-arm64 crossbuild-essential-armhf crossbuild-essential-mipsel crossbuild-essential-ppc64el + +# Before you can actually build something you need to install its build dependancies. +# This is best done in a child container as architecture specific -dev packages have a habit of clashing with +# each other because not everything is fully complient with the multiarch specififcation. +# +# To install the QEMU build dependacnies you need to run: +# RUN apt-get build-dep -yy -a armhf qemu -- 2.11.0