qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH] tests/docker: Add gentoo-loongarch64-cross image and run cro


From: Alex Bennée
Subject: Re: [PATCH] tests/docker: Add gentoo-loongarch64-cross image and run cross builds in GitLab
Date: Tue, 04 Jan 2022 18:31:27 +0000
User-agent: mu4e 1.7.5; emacs 28.0.90

WANG Xuerui <git@xen0n.name> writes:

> Normally this would be based on qemu/debian10 or qemu/ubuntu2004, but
> after a week-long struggle, I still cannot build stage2 gcc with the
> known-good LoongArch toolchain sources, so I chose the least-resistance
> path with Gentoo as base image. As this image is not expected to be
> re-built by CI, like hexagon, it should not take much maintenance
> effort; also it's expected to be replaced as soon as Debian is
> available.
>
> As the LoongArch *target* has not been merged yet, a check-tcg job is
> not added at the moment, but cross builds with the TCG *host* port are
> already possible, and added to CI matrix.
>
> Due to constant flux of the toolchain sources used (especially that of
> glibc), the binaries built with this image may or may not work when
> run on actual hardware, but still useful for ensuring things correctly
> build. This image is expected to be updated every once in a while,
> before everything settles down.
>
> As a reference, the image takes about 25 minutes to rebuild on a
> Threadripper 3990X system with Docker operating on HDD; YMMV but it
> probably wouldn't become significantly shorter, as everything needs to
> be built from source in our case.
>
> (In the original submission along with the rest of LoongArch TCG
> patches, I forgot to make the dependency to the container build job
> optional, thus CI was passing in my own fork but broke upstream. Fixed
> for a 2nd take, and I also took the chance to update base image versions
> and such.)
>
> Signed-off-by: WANG Xuerui <git@xen0n.name>
> ---
>
> (Note to CI maintainers: obviously this image has to be built and pushed
> manually, for everything to keep working. Sorry for the extra work
> early-on, but the community around LoongArch still hope to upstream most
> things during 2022 so eventually we will transition away from this.
> This work is no hurry though, and Happy Holidays everyone!)
>
>  .gitlab-ci.d/container-cross.yml              |  27 +++++
>  .gitlab-ci.d/crossbuilds.yml                  |  25 ++++
>  MAINTAINERS                                   |   2 +
>  tests/docker/Makefile.include                 |  21 ++++
>  .../gentoo-loongarch64-cross.docker           |  21 ++++
>  .../build-toolchain.sh                        | 109 ++++++++++++++++++
>  6 files changed, 205 insertions(+)
>  create mode 100644 tests/docker/dockerfiles/gentoo-loongarch64-cross.docker
>  create mode 100755 
> tests/docker/dockerfiles/gentoo-loongarch64-cross.docker.d/build-toolchain.sh
>
> diff --git a/.gitlab-ci.d/container-cross.yml 
> b/.gitlab-ci.d/container-cross.yml
> index a3b5b90552..7a8cc556cc 100644
> --- a/.gitlab-ci.d/container-cross.yml
> +++ b/.gitlab-ci.d/container-cross.yml
> @@ -82,6 +82,33 @@ hppa-debian-cross-container:
>    variables:
>      NAME: debian-hppa-cross
>  
> +# Similar to hexagon, we don't want to build loongarch64 in the CI either.
> +loongarch64-cross-container:
> +  image: docker:stable
> +  stage: containers
> +  rules:
> +    - if: '$CI_PROJECT_NAMESPACE == "qemu-project"'
> +      when: never
> +    - when: always
> +  variables:
> +    NAME: gentoo-loongarch64-cross
> +    GIT_DEPTH: 1
> +  services:
> +    - docker:dind
> +  before_script:
> +    - export TAG="$CI_REGISTRY_IMAGE/qemu/$NAME:latest"
> +    - export COMMON_TAG="$CI_REGISTRY/qemu-project/qemu/qemu/$NAME:latest"
> +    - docker info
> +    - docker login $CI_REGISTRY -u "$CI_REGISTRY_USER" -p 
> "$CI_REGISTRY_PASSWORD"
> +  script:
> +    - echo "TAG:$TAG"
> +    - echo "COMMON_TAG:$COMMON_TAG"
> +    - docker pull $COMMON_TAG
> +    - docker tag $COMMON_TAG $TAG
> +    - docker push "$TAG"
> +  after_script:
> +    - docker logout
> +
>  m68k-debian-cross-container:
>    extends: .container_job_template
>    stage: containers-layer2
> diff --git a/.gitlab-ci.d/crossbuilds.yml b/.gitlab-ci.d/crossbuilds.yml
> index 17d6cb3e45..ef19ade554 100644
> --- a/.gitlab-ci.d/crossbuilds.yml
> +++ b/.gitlab-ci.d/crossbuilds.yml
> @@ -68,6 +68,31 @@ cross-i386-tci:
>      EXTRA_CONFIGURE_OPTS: 
> --target-list=i386-softmmu,i386-linux-user,aarch64-softmmu,aarch64-linux-user,ppc-softmmu,ppc-linux-user
>      MAKE_CHECK_ARGS: check check-tcg
>  
> +# Upstream LoongArch support is still incomplete, but toolchain is already
> +# usable and partially merged, so the host support is already testable; but
> +# don't let failures block CI.
> +#
> +# Similar to hexagon, the container image is built outside of CI and manually
> +# uploaded at the moment, so make the dependency to container build job
> +# optional.
> +cross-loongarch64-system:
> +  extends: .cross_system_build_job
> +  allow_failure: true
> +  needs:
> +    job: loongarch64-cross-container
> +    optional: true
> +  variables:
> +    IMAGE: gentoo-loongarch64-cross
> +
> +cross-loongarch64-user:
> +  extends: .cross_user_build_job
> +  allow_failure: true
> +  needs:
> +    job: loongarch64-cross-container
> +    optional: true
> +  variables:
> +    IMAGE: gentoo-loongarch64-cross
> +
>  cross-mips-system:
>    extends: .cross_system_build_job
>    needs:
> diff --git a/MAINTAINERS b/MAINTAINERS
> index 5456536805..6b42fe16c7 100644
> --- a/MAINTAINERS
> +++ b/MAINTAINERS
> @@ -3148,6 +3148,8 @@ LoongArch64 TCG target
>  M: WANG Xuerui <git@xen0n.name>
>  S: Maintained
>  F: tcg/loongarch64/
> +F: tests/docker/dockerfiles/gentoo-loongarch64-cross.docker
> +F: tests/docker/dockerfiles/gentoo-loongarch64-cross.docker.d/
>  
>  MIPS TCG target
>  M: Philippe Mathieu-Daudé <f4bug@amsat.org>
> diff --git a/tests/docker/Makefile.include b/tests/docker/Makefile.include
> index f1a0c5db7a..a2cdf193bb 100644
> --- a/tests/docker/Makefile.include
> +++ b/tests/docker/Makefile.include
> @@ -176,6 +176,27 @@ docker-image-debian-hexagon-cross: 
> $(DOCKER_FILES_DIR)/debian-hexagon-cross.dock
>                               qemu/debian-hexagon-cross --add-current-user,   
>         \
>                       "PREPARE", "debian-hexagon-cross"))
>  
> +#
> +# Same for loongarch64-cross.
> +#
> +docker-image-gentoo-loongarch64-cross: 
> $(DOCKER_FILES_DIR)/gentoo-loongarch64-cross.docker
> +     $(if $(NOCACHE),                                                        
>         \
> +             $(call quiet-command,                                           
>         \
> +                     $(DOCKER_SCRIPT) build -t qemu/gentoo-loongarch64-cross 
> -f $<   \
> +                     $(if $V,,--quiet) --no-cache                            
>         \
> +                     --registry $(DOCKER_REGISTRY) --extra-files             
>         \
> +                     
> $(DOCKER_FILES_DIR)/gentoo-loongarch64-cross.docker.d/build-toolchain.sh, \
> +                     "BUILD", "gentoo-loongarch64-cross"),                   
>         \
> +             $(call quiet-command,                                           
>         \
> +                     $(DOCKER_SCRIPT) fetch $(if $V,,--quiet)                
>         \
> +                             qemu/gentoo-loongarch64-cross 
> $(DOCKER_REGISTRY),       \
> +                     "FETCH", "gentoo-loongarch64-cross")                    
>         \
> +             $(call quiet-command,                                           
>         \
> +                     $(DOCKER_SCRIPT) update $(if $V,,--quiet)               
>         \
> +                             qemu/gentoo-loongarch64-cross 
> --add-current-user,       \
> +                     "PREPARE", "gentoo-loongarch64-cross"))
> +
> +

Can this not use debian-toolchain-run (possibly renamed) like the
microblaze and nios2 toolchains? The hexagon only has the legacy setup
because we never merged the more traditional image due to signal issues.

>  debian-toolchain-run = \
>       $(if $(NOCACHE),                                                \
>               $(call quiet-command,                                   \
> diff --git a/tests/docker/dockerfiles/gentoo-loongarch64-cross.docker 
> b/tests/docker/dockerfiles/gentoo-loongarch64-cross.docker
> new file mode 100644
> index 0000000000..59846223d3
> --- /dev/null
> +++ b/tests/docker/dockerfiles/gentoo-loongarch64-cross.docker
> @@ -0,0 +1,21 @@
> +#
> +# Docker LoongArch64 cross-compiler target
> +#
> +# This docker target is used for building loongarch64 tests. As it also
> +# needs to be able to build QEMU itself in CI we include it's
> +# build-deps. It is also a "stand-alone" image so as not to be
> +# triggered by re-builds on other base images given it takes a long
> +# time to build.
> +#
> +
> +FROM docker.io/gentoo/stage3:20211229
> +
> +ADD build-toolchain.sh /root/build-toolchain.sh
> +RUN cd /root && ./build-toolchain.sh
> +
> +# Specify the cross prefix for this image (see tests/docker/common.rc)
> +# Also gcc 12 currently produces spurious warnings under our condition so
> +# disable Werror as well
> +ENV QEMU_CONFIGURE_OPTS --cross-prefix=loongarch64-unknown-linux-gnu- 
> --disable-werror
> +# We don't have target support at the moment, so just verify that things 
> build
> +ENV DEF_TARGET_LIST x86_64-softmmu,x86_64-linux-user
> diff --git 
> a/tests/docker/dockerfiles/gentoo-loongarch64-cross.docker.d/build-toolchain.sh
>  
> b/tests/docker/dockerfiles/gentoo-loongarch64-cross.docker.d/build-toolchain.sh
> new file mode 100755
> index 0000000000..654f1394e9
> --- /dev/null
> +++ 
> b/tests/docker/dockerfiles/gentoo-loongarch64-cross.docker.d/build-toolchain.sh
> @@ -0,0 +1,109 @@
> +#!/bin/bash
> +
> +set -e
> +
> +TRIPLE=loongarch64-unknown-linux-gnu
> +CROSSDEV_OV=/opt/crossdev-overlay
> +LOONGSON_OV=/opt/loongson-overlay
> +CROSS_EMERGE="${TRIPLE}-emerge"
> +
> +# this will break on non-SMP machines, but no one should build this image
> +# on such machine in the first place
> +J=$(expr $(nproc) / 2)
> +echo "MAKEOPTS=\"-j${J} -l${J}\"" >> /etc/portage/make.conf
> +echo "EGIT_CLONE_TYPE=shallow" >> /etc/portage/make.conf
> +
> +# these features are not supported in Docker
> +export FEATURES="-ipc-sandbox -network-sandbox"
> +
> +# populate Portage tree
> +GENTOO_MIRROR='https://bouncer.gentoo.org/fetch/root/all'
> +PORTAGE_SNAPSHOT_FILE=gentoo-20211228.tar.xz
> +pushd /tmp
> +    # not every mirror will have this file synced yet, so retry until success
> +    i=0
> +    max_retry=5
> +    while [[ $i -lt $max_retry ]]; do
> +        [[ $i -gt 0 ]] && echo "Retrying ($i of $max_retry)..."
> +        wget "${GENTOO_MIRROR}/snapshots/${PORTAGE_SNAPSHOT_FILE}" && break
> +        : $((i++))
> +    done
> +    [[ -f "$PORTAGE_SNAPSHOT_FILE" ]] || exit 1
> +
> +    mkdir -p /var/db/repos/gentoo
> +    pushd /var/db/repos/gentoo
> +        tar -xf "/tmp/${PORTAGE_SNAPSHOT_FILE}" --strip-components=1
> +    popd
> +
> +    rm "$PORTAGE_SNAPSHOT_FILE"
> +popd

This seems a little excessive. Wouldn't a straight emerge --sync do or
even just sticking to the state of portage in the source docker image?

Maybe:

  emerge-webrsync --revert=20211228

> +
> +emerge -j crossdev dev-vcs/git
> +
> +# prepare for crossdev
> +mkdir /etc/portage/repos.conf
> +crossdev -t "$TRIPLE" --ov-output "$CROSSDEV_OV" --init-target
> +
> +git clone https://github.com/xen0n/loongson-overlay.git "$LOONGSON_OV"
> +pushd "$LOONGSON_OV"
> +    git checkout 20b9c9f96fb5ed596bbab6bd6f274932492fb12b
> +popd
> +
> +pushd "${CROSSDEV_OV}/cross-${TRIPLE}"
> +    rm binutils gcc glibc linux-headers
> +    ln -s "${LOONGSON_OV}/sys-devel/binutils" .
> +    ln -s "${LOONGSON_OV}/sys-devel/gcc" .
> +    ln -s "${LOONGSON_OV}/sys-libs/glibc" .
> +    ln -s "${LOONGSON_OV}/sys-kernel/linux-headers" .
> +popd
> +
> +cat > "${CROSSDEV_OV}/metadata/layout.conf" <<EOF
> +masters = gentoo
> +repo-name = crossdev-overlay
> +manifest-hashes = SHA256 SHA512 WHIRLPOOL
> +thin-manifests = true
> +EOF
> +
> +chown -R portage:portage "$CROSSDEV_OV"
> +chown -R portage:portage "$LOONGSON_OV"
> +
> +# make cross toolchain
> +crossdev -t "$TRIPLE" --without-headers \
> +    --binutils 2.37_p1-r1 \
> +    --gcc 12.0.0_pre9999 \
> +    --libc 2.34-r4
> +
> +# prepare for loongarch cross emerges
> +TARGET_PROFILE="default/linux/loong/21.0/la64v100/lp64d/desktop"
> +pushd "/usr/${TRIPLE}/etc/portage"
> +    rm make.profile
> +    ln -s "${LOONGSON_OV}/profiles/${TARGET_PROFILE}" ./make.profile
> +
> +    # util-linux needs this to not depend on pam, causing circular deps later
> +    sed -i '/^USE=".*"$/s/"$/ -su"/' ./make.conf
> +
> +    mkdir repos.conf
> +    cat > repos.conf/loongson.conf <<EOF
> +[loongson]
> +priority = 50
> +location = $LOONGSON_OV
> +auto-sync = No
> +EOF
> +
> +popd
> +
> +# add build deps for qemu
> +
> +# gawk seems to have problems installing with concurrency, and its deps
> +# include ncurses that needs disabling sandbox to correctly build under
> +# Docker, so just turn off sandbox for all emerges
> +export FEATURES="$FEATURES -sandbox -usersandbox"
> +$CROSS_EMERGE -1 --onlydeps -j$J gawk
> +mkdir -p "/usr/${TRIPLE}/bin"
> +MAKEOPTS='-j1' $CROSS_EMERGE -1 gawk
> +
> +# then build the rest
> +$CROSS_EMERGE -1 --onlydeps -j$J qemu
> +
> +# clean up downloaded files and Portage tree for smaller image
> +rm -rf /var/db/repos/gentoo /var/cache/distfiles


-- 
Alex Bennée



reply via email to

[Prev in Thread] Current Thread [Next in Thread]