qemu-devel
[Top][All Lists]
Advanced

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

Re: [PATCH] gitlab-ci/custom-runners: Disable -static-pie for ubuntu-20.


From: Alex Bennée
Subject: Re: [PATCH] gitlab-ci/custom-runners: Disable -static-pie for ubuntu-20.04-aarch64
Date: Wed, 24 Aug 2022 18:15:54 +0100
User-agent: mu4e 1.9.0; emacs 28.1.91

Richard Henderson <richard.henderson@linaro.org> writes:

> The project has reached the magic size at which we see
>
> /usr/aarch64-linux-gnu/lib/libc.a(init-first.o): in function 
> `__libc_init_first':
> (.text+0x10): relocation truncated to fit: R_AARCH64_LD64_GOTPAGE_LO15 
> against \
> symbol `__environ' defined in .bss section in 
> /usr/aarch64-linux-gnu/lib/libc.a(environ.o)
> /usr/bin/ld: (.text+0x10): warning: too many GOT entries for -fpic, please 
> recompile with -fPIC
>
> The bug has been reported upstream, but in the meantime there is
> nothing we can do except build a non-pie executable.
>
> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
> ---
>
> Irritatingly, once this is fixed, we're still in a broken state because
> we're now picking up an x86_64 cross-compiler, without all of the
> required static libraries:
>
>   https://gitlab.com/qemu-project/qemu/-/jobs/2923714301#L3028
>
>     Cross compilers
>     aarch64                      : cc
>     arm                          : arm-linux-gnueabihf-gcc
>     i386                         : i686-linux-gnu-gcc
>     mips64el                     : mips64el-linux-gnuabi64-gcc
>     mipsel                       : mipsel-linux-gnu-gcc
>     riscv64                      : riscv64-linux-gnu-gcc
>     s390x                        : s390x-linux-gnu-gcc
>     x86_64                       : x86_64-linux-gnu-gcc
>
> where we hadn't done so just 4 days ago:
>
>   https://gitlab.com/qemu-project/qemu/-/jobs/2908305198
>
>     Cross compilers
>     aarch64                      : cc
>     arm                          : arm-linux-gnueabihf-gcc
>     i386                         : i686-linux-gnu-gcc
>     riscv64                      : riscv64-linux-gnu-gcc
>     s390x                        : s390x-linux-gnu-gcc
>
> Alex? I think you're the only one who would know how this host
> is supposed to be configured for gitlab...

Ahh because aarch64.ci.qemu.org is also a developer box I had enabled a
bunch of additional cross compilers for the tests (because we can't take
full advantage of the docker images on non-x86). However it shouldn't
affect the main build, these compilers are only used for the TCG tests.

It looks like the compiler is borked because:

/usr/lib/gcc-cross/x86_64-linux-gnu/11/../../../../x86_64-linux-gnu/bin/ld: 
cannot find /usr/lib/x86_64-linux-gnu/libm-2.35.a: No such file or directory    
                 
/usr/lib/gcc-cross/x86_64-linux-gnu/11/../../../../x86_64-linux-gnu/bin/ld: 
cannot find /usr/lib/x86_64-linux-gnu/libmvec.a: No such file or directory      
 

but the libc6-dev-amd64-cross package puts this in:

  /usr/x86_64-linux-gnu/lib/libmvec.a

Anyway as x86_64 is the one compiler that is available in the docker
multiarch I've dropped that for now. It won't get used by the CI system
as it can't use docker but developers using the box should get:

  Cross compilers
    aarch64                      : cc
    arm                          : arm-linux-gnueabihf-gcc
    i386                         : i686-linux-gnu-gcc
    mips64el                     : mips64el-linux-gnuabi64-gcc
    mipsel                       : mipsel-linux-gnu-gcc
    riscv64                      : riscv64-linux-gnu-gcc
    s390x                        : s390x-linux-gnu-gcc
    x86_64                       : $(DOCKER_SCRIPT) cc --cc 
x86_64-linux-gnu-gcc -i qemu/debian-amd64-cross -s /home/alex/lsrc/qemu.git --

> I guess I'm not going to let this affect the release, but we
> do have quite a number of annoyingly consistent failures now.
> We should either fix them or disable them.

The rest of the tests build and run fine now.

>
>
> r~
>
> ---
>  .gitlab-ci.d/custom-runners/ubuntu-20.04-aarch64.yml | 4 +++-
>  1 file changed, 3 insertions(+), 1 deletion(-)
>
> diff --git a/.gitlab-ci.d/custom-runners/ubuntu-20.04-aarch64.yml 
> b/.gitlab-ci.d/custom-runners/ubuntu-20.04-aarch64.yml
> index 3d878914e7..85a234801a 100644
> --- a/.gitlab-ci.d/custom-runners/ubuntu-20.04-aarch64.yml
> +++ b/.gitlab-ci.d/custom-runners/ubuntu-20.04-aarch64.yml
> @@ -16,7 +16,9 @@ ubuntu-20.04-aarch64-all-linux-static:
>   # --disable-glusterfs is needed because there's no static version of those 
> libs in distro supplied packages
>   - mkdir build
>   - cd build
> - - ../configure --enable-debug --static --disable-system --disable-glusterfs 
> --disable-libssh
> + # Disable -static-pie due to build error with system libc:
> + # https://bugs.launchpad.net/ubuntu/+source/glibc/+bug/1987438
> + - ../configure --enable-debug --static --disable-system --disable-glusterfs 
> --disable-libssh --disable-pie --extra-cflags='-fno-pie -no-pie'
>     || { cat config.log meson-logs/meson-log.txt; exit 1; }
>   - make --output-sync -j`nproc --ignore=40`
>   - make --output-sync -j`nproc --ignore=40` check V=1

I'll update this once the tree is open as you may have noticed the host
is now a 22.04 one (which hopefully means we can enable glusterfs and
libssh now)

-- 
Alex Bennée



reply via email to

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