From owner-freebsd-hackers@FreeBSD.ORG Sat Mar 31 23:16:28 2007 Return-Path: X-Original-To: freebsd-hackers@freebsd.org Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [69.147.83.52]) by hub.freebsd.org (Postfix) with ESMTP id 7A04716A401 for ; Sat, 31 Mar 2007 23:16:28 +0000 (UTC) (envelope-from pieter@degoeje.nl) Received: from smtp.utwente.nl (smtp1.utsp.utwente.nl [130.89.2.8]) by mx1.freebsd.org (Postfix) with ESMTP id 006EE13C4BF for ; Sat, 31 Mar 2007 23:16:27 +0000 (UTC) (envelope-from pieter@degoeje.nl) Received: from nox.student.utwente.nl (nox.student.utwente.nl [130.89.165.91]) by smtp.utwente.nl (8.12.10/SuSE Linux 0.7) with ESMTP id l2VNGOLr004864; Sun, 1 Apr 2007 01:16:24 +0200 From: Pieter de Goeje To: freebsd-hackers@freebsd.org Date: Sun, 1 Apr 2007 01:16:24 +0200 User-Agent: KMail/1.9.6 References: <200703310426.23953.pieter@degoeje.nl> <460DE02F.5020202@u.washington.edu> In-Reply-To: <460DE02F.5020202@u.washington.edu> MIME-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: 7bit Content-Disposition: inline Message-Id: <200704010116.24514.pieter@degoeje.nl> X-UTwente-MailScanner-Information: Scanned by MailScanner. Contact helpdesk@ITBE.utwente.nl for more information. X-UTwente-MailScanner: Found to be clean X-UTwente-MailScanner-From: pieter@degoeje.nl X-Spam-Status: No Cc: Garrett Cooper Subject: Re: Thread local storage not working with -fPIC and shared objects X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 31 Mar 2007 23:16:28 -0000 On zaterdag 31 maart 2007, Garrett Cooper wrote: > Pieter de Goeje wrote: > > Hello List, > > > > I have these files: > > --- loader.cpp --- > > #include > > #include "tls.h" > > > > int main() { > > tls = 0; > > printf("%d\n", tls); > > } > > > > --- tls.cpp --- > > #include "tls.h" > > int __thread tls; > > > > --- tls.h --- > > extern __thread int tls; > > > > When I compile them like this: > > c++ -fPIC -o tls.so tls.cpp -shared > > c++ -fPIC -o loader loader.cpp tls.so > > > > And run the resulting program, I get: > > pyotr@nox:~/projects/misc/tls> ./loader > > /libexec/ld-elf.so.1: ./loader: Unsupported relocation type 37 in non-PLT > > relocations > > > > When I omit -fPIC, it runs fine. But I need fPIC for the shared object on > > amd64 arch. I've tried it on Linux/i386 (gcc 4.1) and it ran fine (with > > fPIC). > > > > Much to my surprise however, a particularly large application I'm working > > on did compile & run on FreeBSD/amd64 using -fpic (lowercase) and gcc > > 4.3. Trying -fpic on FreeBSD/i386 resulted in failure. > > > > FYI, I need tls to work because I'm using OpenMP's tls (#pragma omp > > threadprivate()) support in gcc 4.3. > > > > The workaround I found on FreeBSD/amd64 was linking the main executable > > with -fno-PIC, or building everything with -fpic. (both workarounds > > didn't work on FreeBSD/i386) > > > > I would be grateful if someone could shed some light on this. > > > > Regards, > > Pieter de Goeje > > Pieter, > Did you know that -fPIC and -fpic aren't the same? From > I was aware of that, however: > : > |-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. > > |-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. tells me that there should not be a difference between the two on the AMD64 arch. Apparently there is... > > Position-independent code requires special support, and therefore > works only on certain machines. Cheers, Pieter de Goeje