CROSS_TOOLCHAIN=amd64-gcc fails to build after clang 3.6.0 import

Warner Losh imp at bsdimp.com
Wed Apr 1 00:09:24 UTC 2015


> On Mar 31, 2015, at 1:43 PM, Craig Rodrigues <rodrigc at FreeBSD.org> wrote:
> 
> On Tue, Mar 31, 2015 at 1:41 PM, Dimitry Andric <dim at freebsd.org> wrote:
> 
>> On 31 Mar 2015, at 22:06, Craig Rodrigues <rodrigc at FreeBSD.org> wrote:
>>> 
>>> On Tue, Mar 31, 2015 at 12:48 PM, Dimitry Andric <dim at freebsd.org>
>> wrote:
>>> On 31 Mar 2015, at 21:38, Craig Rodrigues <rodrigc at FreeBSD.org> wrote:
>>>> 
>>>> On Tue, Mar 31, 2015 at 11:20 AM, Dimitry Andric <dim at freebsd.org>
>> wrote:
>>>> 
>>>>> On 31 Mar 2015, at 20:13, Dimitry Andric <dim at FreeBSD.org> wrote:
>>>>> ...
>>>>>> but then:
>>>>>> 
>>>>>> + patch
>>>>>> Hmm...  Looks like a unified diff to me...
>>>>>> The text leading up to this was:
>>>>>> --------------------------
>>>>>> |Index: contrib/libc++/include/type_traits
>>>>>> |===================================================================
>>>>>> |--- contrib/libc++/include/type_traits (revision 280762)
>>>>>> |+++ contrib/libc++/include/type_traits (working copy)
>>>>>> --------------------------
>>>>>> Patching file contrib/libc++/include/type_traits using Plan A...
>>>>>> Reversed (or previously applied) patch detected!  Assume -R? [y]
>>>>>> Hunk #1 succeeded at 842.
>>>>>> Hunk #2 succeeded at 877.
>>>>>> Hmm...  Ignoring the trailing garbage.
>>>>>> done
>>>>>> 
>>>>>> E.g., it undoes the change to type_traits that was merged in the
>>>>> subversion update.
>>>>> 
>>>>> 
>>>> OK, I undid the patch.  Now the clang and libc++ parts build, but I'm
>>>> still getting problems building rescue:
>>>> 
>>>> 
>> https://jenkins.freebsd.org/job/FreeBSD_HEAD_external_toolchain_gcc/29/console
>>> 
>>> Hm, that is strange.  I have just completed a build with
>>> amd64-xtoolchain-gcc, and apart from boot2, everything worked...
>>> 
>>> What does readelf say when you run it on the cat.lo file which is
>>> complained about in the log?  And what happens if you delete it, and
>>> restart the build?
>>> 
>>> See:
>>> 
>> https://lists.freebsd.org/pipermail/freebsd-toolchain/2015-March/001545.html
>> 
>> I'm suspecting this might have something to do with crunchide, or least,
>> the copy of crunchide that is run for this:
>> 
>> --- cat.lo ---
>> /usr/local/x86_64-freebsd/bin/ld -dc -r -o cat.lo cat_stub.o
>> /builds/FreeBSD_HEAD_external_toolchain_gcc/obj/builds/FreeBSD_HEAD_external_toolchain_gcc/rescue/rescue//builds/FreeBSD_HEAD_external_toolchain_gcc/bin/cat/cat.o
>> crunchide -k _crunched_cat_stub cat.lo
>> 
>> If I look at my own build logs, it seems to pick the crunchide
>> executable in /usr/bin, and Makefile.inc1 does *not* build it during the
>> cross-tools stage if ${TARGET_ARCH} is the same as ${MACHINE_ARCH}:
>> 
>> .if ${TARGET_ARCH} != ${MACHINE_ARCH}
>> .if ${MK_RESCUE} != "no" || defined(RELEASEDIR)
>> _crunchide=     usr.sbin/crunch/crunchide
>> .endif
>> 
>> However, this does not explain why my /usr/bin/crunchide seems to not
>> screw up cat.lo, while yours does.  As far as I can see, we're both
>> building this on a stable/10 amd64 box...
>> 
> 
>> Maybe, as a hack, you can force cross-tools to build crunchide, by
>> patching Makefile.inc1 to ignore the arch check, and see what that
>> results in?
>> 
> 
> 
> 
> Well my build host is 10.1-RELEASE, so maybe there are changes
> that went into 10-STABLE after 10.1 that prevent this from working.
> 
> I'll give a shot at hacking things and let you know how far I get.

BTW, we don’t officially support 4.8 / 4.9 yet. There are things that
are known to be broken with it, and since we don’t tinderbox it, it is
likely that we’ll break it over and over again…

When I was building it, as a test, I used WITHOUT_RESCUE.

Warner

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 842 bytes
Desc: Message signed with OpenPGP using GPGMail
URL: <http://lists.freebsd.org/pipermail/freebsd-toolchain/attachments/20150331/41a71c66/attachment.sig>


More information about the freebsd-toolchain mailing list