Re: Buildowrld tries to use old ld, and fails

From: <soralx_at_cydem.org>
Date: Mon, 24 Sep 2018 23:55:55 -0700
> > Howdy!
> >
> >  Since a couple months ago, the world on -CURRENT cannot be built
> > using the normal procedure:
> >    time env LD=ld.lld make -j6 buildworld buildkernel  
> 
> The normal procedure shouldn't need any LD= overrides; is there
> something unique in your build? Any src.conf settings?

Indeed, I had "WITHOUT_LLD_BOOTSTRAP=yes" in src.conf. Not sure how
that line made it into this file on a number of my systems... perhaps
an artifact of old -CURRENT upgrade procedure that I've forgotten about.

Soon as I emptied /etc/src.conf, and dropped the 'LD=' from environment,
the build succeeds no problem. Thanks, Ed!

> >  Here's the result:
> >    [late in buildowrld process]
> >    --- all_subdir_stand ---
> >    /usr/obj/usr/src/amd64.amd64/tmp/usr/bin/ld: unrecognized option
> > '--no-rosegment' /usr/obj/usr/src/amd64.amd64/tmp/usr/bin/ld: use the
> > --help option for usage information cc: error: linker command failed
> > with exit code 1 (use -v to see invocation) make[5]: stopped
> > in /usr/src/stand/i386/mbr
> >
> >  Workaround is to use linker from binutils:
> >    env LD=/usr/local/bin/ld make buildworld  
> 
> Just overriding LD isn't sufficient to choose a linker, because most
> linking is performed by the compiler driver (i.e., cc) which does not
> use the LD variable.

I was just following a note 20180510 from UPDATING. It worked before.
And there are no newer entries overruling the old note, so I thought
it should still work as before...

Strange that overriding LD works when pointing to ld from binutils, but
not always with ld.lld linker; for example, 'stand/i386/mbr/' ignores
"LD=ld.lld", but not "LD=/usr/local/bin/ld".

-- 
[SorAlx]  ridin' VN2000 Classic LT
Received on Tue Sep 25 2018 - 04:56:03 UTC

This archive was generated by hypermail 2.4.0 : Wed May 19 2021 - 11:41:18 UTC