[pgsql-pkg-debian] Re: [HACKERS] [PATCH] relocation truncated to fit: citus buildfailure on s390x - Mailing list pgsql-pkg-debian

From Christoph Berg
Subject [pgsql-pkg-debian] Re: [HACKERS] [PATCH] relocation truncated to fit: citus buildfailure on s390x
Date
Msg-id 20170529155850.qojdfrwkkqnjb3ap@msg.df7cb.de
Whole thread Raw
In response to relocation truncated to fit: citus build failure on s390x  (Christoph Berg <myon@debian.org>)
Responses Re: [pgsql-pkg-debian] [HACKERS] [PATCH] relocation truncated to fit: citus build failure on s390x  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-pkg-debian
Re: To Andres Freund 2016-04-28 <20160428080824.GA22412@msg.df7cb.de>
> > I'm not clear why citus triggers this, when other extensions don't?
>
> Maybe it's simply because citus.so is bigger than all the other
> extension .so files:
>
>        -fpic
>        Generate position-independent code (PIC) suitable for use
>        in a shared library, if supported for the target machine.
>        Such code accesses all constant addresses through a global
>        offset table (GOT).  The dynamic loader resolves the GOT
>        entries when the program starts (the dynamic loader is not
>        part of GCC; it is part of the operating system).  If the
>        GOT size for the linked executable exceeds a machine-
>        specific maximum size, you get an error message from the
>        linker indicating that -fpic does not work; in that case,
>        recompile with -fPIC instead.  (These maximums are 8k on
>        the SPARC and 32k on the m68k and RS/6000.  The 386 has no
>        such limit.)
>
>        Position-independent code requires special support, and
>        therefore works only on certain machines.  For the 386, GCC
>        supports PIC for System V but not for the Sun 386i.  Code
>        generated for the IBM RS/6000 is always
>        position-independent.
>
>        When this flag is set, the macros "__pic__" and "__PIC__"
>        are defined to 1.
>
>        -fPIC
>        If supported for the target machine, emit
>        position-independent code, suitable for dynamic linking and
>        avoiding any limit on the size of the global offset table.
>        This option makes a difference on the m68k, PowerPC and
>        SPARC.
>
>        Position-independent code requires special support, and
>        therefore works only on certain machines.
>
>        When this flag is set, the macros "__pic__" and "__PIC__"
>        are defined to 2.
>
> This doesn't mention s390(x), but citus.so 382952 bytes (on amd64) is
> well beyond the 8k/32k limits mentioned above.
>
> PostgreSQL itself links correctly on s390x:
> ... -I/usr/include/mit-krb5 -fPIC -pie -I../../../../src/include
>
> I'm not an expert in compiler flags, but it seems to me CFLAGS_SL is
> wrong on s390(x) in Makefile.port, it should use -fPIC like sparc.

After talking to a s390x Debian porter, -fPIC is the correct flag to
use. The quoted patch made the previously failing builds for citus and
pglogical (which have larger-than-average .so files) on s390x succeed
(and the sparc64 case still works):

--- a/src/makefiles/Makefile.linux
+++ b/src/makefiles/Makefile.linux
@@ -5,7 +5,8 @@ export_dynamic = -Wl,-E
 rpath = -Wl,-rpath,'$(rpathdir)',--enable-new-dtags
 DLSUFFIX = .so

-ifeq "$(findstring sparc,$(host_cpu))" "sparc"
+# Enable -fPIC to avoid "relocation truncated to fit" linker errors
+ifneq "$(filter sparc% s390%,$(host_cpu))" ""
 CFLAGS_SL = -fPIC
 else
 CFLAGS_SL = -fpic


The patch was made against 9.6; I'd opt to include it in master and
the back branches.

https://buildd.debian.org/status/logs.php?pkg=citus&arch=s390x
https://buildd.debian.org/status/logs.php?pkg=pglogical&arch=s390x

Christoph


pgsql-pkg-debian by date:

Previous
From: apt.postgresql.org repository
Date:
Subject: [pgsql-pkg-debian] libdbd-pg-perl updated to version 3.6.2-1~pgdg+1
Next
From: Tom Lane
Date:
Subject: Re: [pgsql-pkg-debian] [HACKERS] [PATCH] relocation truncated to fit: citus build failure on s390x