Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 28 Dec 2011 17:31:57 +0100
From:      Rainer Hurling <rhurlin@gwdg.de>
To:        Kostik Belousov <kostikbel@gmail.com>
Cc:        Current FreeBSD <freebsd-current@freebsd.org>, "O. Hartmann" <ohartman@zedat.fu-berlin.de>, Ports FreeBSD <freebsd-ports@freebsd.org>
Subject:   Re: /usr/local/lib/gcc46/gcc/x86_64-portbld-freebsd9.0/4.6.3/../../../libstdc++.a: could not read symbols: Bad value
Message-ID:  <4EFB447D.3000808@gwdg.de>
In-Reply-To: <20111228142957.GX50300@deviant.kiev.zoral.com.ua>
References:  <4EFAF3FC.60002@zedat.fu-berlin.de> <20111228135808.GW50300@deviant.kiev.zoral.com.ua> <4EFB2344.3000302@zedat.fu-berlin.de> <20111228142957.GX50300@deviant.kiev.zoral.com.ua>

next in thread | previous in thread | raw e-mail | index | archive | help
On 28.12.2011 15:29 (UTC+1), Kostik Belousov wrote:
> On Wed, Dec 28, 2011 at 03:10:12PM +0100, O. Hartmann wrote:
>> Am 12/28/11 14:58, schrieb Kostik Belousov:
>>> On Wed, Dec 28, 2011 at 11:48:28AM +0100, O. Hartmann wrote:
>>>> Hello out here.
>>>>
>>>> I run into a problem since one of the last portupdates and I do not know
>>>> whether this has to do with binutils or gcc46 or even FreeBSD 9.0/10.0
>>>> AMD64.
>>>>
>>>> Background:
>>>> We use a scientific graphical toolset for planetary research called
>>>> ISIS3, which is provided by the USGS. We patched ISIS3 to run on FreeBSD
>>>> 8/9/10 so far and it ran well with FreeBSD 8.2-STABLE and 9.0-PRE a
>>>> couple of weeks ago.
>>>> On all of my boxes, I do frequently a portupgrade, so I saw binutils got
>>>> bumped up and gcc 4.6 is also getting really frequently changed these days.
>>>> After a some portupdates within the last weeks, I just decided to
>>>> compile ISIS3 again to keep it "fresh and on track", but it won't
>>>> compile anymore.
>>>>
>>>> On all FreeBSD 9.0-PRERELEASE and FreeBSD 10.0-CURRENT (all AMD64 and
>>>> CLANG built) I receive in some subfolders containing sources the
>>>> follwoing error:
>>>>
>>>> [...]
>>>>      Adding API object [UniqueIOCachingAlgorithm]
>>>>      Adding API object [UniversalGroundMap]
>>>>      Adding API object [UserInterface]
>>>>      Adding API object [VariableLineScanCameraDetectorMap]
>>>>      Adding API object [VecFilter]
>>>>      Adding API object [WorldMapper]
>>>>      Adding API object [iException]
>>>>      Adding API object [iString]
>>>>      Adding API object [iTime]
>>>>    Working on Package [mex] (11:30:15)
>>>>      Adding API object [HrscCamera]
>>>> /usr/local/bin/ld:
>>>> /usr/local/lib/gcc46/gcc/x86_64-portbld-freebsd9.0/4.6.3/../../../libstdc++.a(functexcept.o):
>>>> relocation R_X86_64_32 against `std::bad_exception::~bad_exception()'
>>>> can not be used when making a shared object; recompile with -fPIC
>>>> /usr/local/lib/gcc46/gcc/x86_64-portbld-freebsd9.0/4.6.3/../../../libstdc++.a:
>>>> could not read symbols: Bad value
>>>> collect2: ld returned 1 exit status
>>>> gmake[5]: *** [plugin] Error 1
>>>> cp: libHrscCamera.so: No such file or directory
>>>> gmake[4]: *** [install] Error 1
>>> The error is completely clear as it is: the build tries to link static
>>> library libstdc++.so into shared object. This is not supported.
>>
>> Thanks, Kostik, for the fast response.
>> The error isn't so clear to me, sorry. I thought libstdc++.a is the
>> static library and it is taken to be referenced/compiled into a shared
> Linked in.
>
>> object created by the application I try to compile.
> Right, and this is not supported. Code linked into shared object must
> be compiled PIC. An .a library usually does not contain objects compiled
> by PIC, ld just dutifully reported back.
>
>>
>> I'm much more confused now, since I thought the last time I compiled
>> that piece of software, I never got any error like that. Well, clang
>> fails with some obscure errors on the code itself and I'm unwilling to
>> correct them, I'll try the legacy gcc 4.2.1 and will report what's
>> happening.
>
> It might have worked by accident (because libstdc++.a objects referenced
> during the link did not carried unsupported relocations), or, much more
> likely, the build system has changed and started doing stupid things.
> It must not link static libraries into shared objects.
>
> You should examine why it does this, and fix it. Changing compilers is
> just wasting a time.


Hmm, I get a similar error when trying to build lang/gcc46 on recent 
10-CURRENT:

----------------------------------------------------------------
[..snip..]
Making all in include
gmake[4]: Entering directory 
`/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include'
mkdir -p ./x86_64-portbld-freebsd10.0/bits/stdc++.h.gch
/usr/ports/lang/gcc46/work/build/./gcc/xgcc -shared-libgcc 
-B/usr/ports/lang/gcc46/work/build/./gcc -nostdinc++ 
-L/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/src 
-L/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/src/.libs 
-B/usr/local/x86_64-portbld-freebsd10.0/bin/ 
-B/usr/local/x86_64-portbld-freebsd10.0/lib/ -isystem 
/usr/local/x86_64-portbld-freebsd10.0/include -isystem 
/usr/local/x86_64-portbld-freebsd10.0/sys-include    -x c++-header 
-nostdinc++ -g -O2 -pipe -I/usr/local/include -fno-strict-aliasing 
-I/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/x86_64-portbld-freebsd10.0 
-I/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include 
-I/usr/ports/lang/gcc46/work/gcc-4.6-20111209/libstdc++-v3/libsupc++ -O2 
-g -std=gnu++0x 
/usr/ports/lang/gcc46/work/gcc-4.6-20111209/libstdc++-v3/include/precompiled/stdc++.h 
\
-o x86_64-portbld-freebsd10.0/bits/stdc++.h.gch/O2ggnu++0x.gch
In file included from 
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/chrono:38:0,
                  from 
/usr/ports/lang/gcc46/work/gcc-4.6-20111209/libstdc++-v3/include/precompiled/stdc++.h:100:
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/ratio:133:31: 
error: macro "_Static_assert" passed 3 arguments, but takes just 2
In file included from 
/usr/ports/lang/gcc46/work/gcc-4.6-20111209/libstdc++-v3/include/precompiled/stdc++.h:103:0:
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/future:376:39: 
error: macro "_Static_assert" passed 4 arguments, but takes just 2
In file included from 
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/memory:85:0,
                  from 
/usr/ports/lang/gcc46/work/gcc-4.6-20111209/libstdc++-v3/include/precompiled/stdc++.h:81:
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/bits/unique_ptr.h: 
In constructor 'constexpr std::unique_ptr<_Tp, _Dp>::unique_ptr()':
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/bits/unique_ptr.h:117:59: 
error: constexpr constructor does not have empty body
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/bits/unique_ptr.h: 
In constructor 'constexpr std::unique_ptr<_Tp, 
_Dp>::unique_ptr(std::nullptr_t)':
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/bits/unique_ptr.h:139:59: 
error: constexpr constructor does not have empty body
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/bits/unique_ptr.h: 
In constructor 'constexpr std::unique_ptr<_Tp [], _Dp>::unique_ptr()':
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/bits/unique_ptr.h:279:59: 
error: constexpr constructor does not have empty body
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/bits/unique_ptr.h: 
In constructor 'constexpr std::unique_ptr<_Tp [], 
_Dp>::unique_ptr(std::nullptr_t)':
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/bits/unique_ptr.h:301:59: 
error: constexpr constructor does not have empty body
In file included from 
/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include/cassert:45:0,
                  from 
/usr/ports/lang/gcc46/work/gcc-4.6-20111209/libstdc++-v3/include/precompiled/stdc++.h:34:
/usr/include/assert.h: At global scope:
/usr/include/assert.h:62:23: error: '_Static_assert' does not name a type
/usr/include/assert.h:62:23: error: '_Static_assert' does not name a type
gmake[4]: *** 
[x86_64-portbld-freebsd10.0/bits/stdc++.h.gch/O2ggnu++0x.gch] Fehler 1
gmake[4]: Leaving directory 
`/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3/include'
gmake[3]: *** [all-recursive] Fehler 1
gmake[3]: Leaving directory 
`/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3'
gmake[2]: *** [all] Fehler 2
gmake[2]: Leaving directory 
`/usr/ports/lang/gcc46/work/build/x86_64-portbld-freebsd10.0/libstdc++-v3'
gmake[1]: *** [all-target-libstdc++-v3] Fehler 2
gmake[1]: Leaving directory `/usr/ports/lang/gcc46/work/build'
gmake: *** [bootstrap-lean] Fehler 2
*** Error code 1
Stop in /usr/ports/lang/gcc46.
----------------------------------------------------------------


I guess that this error could have something to do with r228902 from 
2011-12-26:

/head/include/assert.h: As per C11, add static_assert() to <assert.h>.

lang/gcc46 builts fine for me before this revision. What do you think 
about it?
Rainer



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?4EFB447D.3000808>