JiscMail Logo
Email discussion lists for the UK Education and Research communities

Help for STARDEV Archives


STARDEV Archives

STARDEV Archives


STARDEV@JISCMAIL.AC.UK


View:

Message:

[

First

|

Previous

|

Next

|

Last

]

By Topic:

[

First

|

Previous

|

Next

|

Last

]

By Author:

[

First

|

Previous

|

Next

|

Last

]

Font:

Proportional Font

LISTSERV Archives

LISTSERV Archives

STARDEV Home

STARDEV Home

STARDEV  November 2011

STARDEV November 2011

Options

Subscribe or Unsubscribe

Subscribe or Unsubscribe

Log In

Log In

Get Password

Get Password

Subject:

Re: Ubuntu 11 build woes

From:

"Peter W. Draper" <[log in to unmask]>

Reply-To:

Starlink development <[log in to unmask]>

Date:

Fri, 18 Nov 2011 10:10:31 +0000

Content-Type:

MULTIPART/MIXED

Parts/Attachments:

Parts/Attachments

TEXT/PLAIN (64 lines)

On Fri, 18 Nov 2011, David Berry wrote:

> On 17 November 2011 22:59, Tim Jenness <[log in to unmask]> wrote:
>> On Thu, Nov 17, 2011 at 7:26 AM, Peter W. Draper
>> <[log in to unmask]> wrote:
>>> Seems that Ubuntu and Debian have decided to change the way that ld handles
>>> references to shared libraries. See:
>>>
>>>   https://wiki.ubuntu.com/NattyNarwhal/ToolchainTransition
>>>
>>> bad news indeed. I've worked around this and got a build to succeed using
>>>
>>>  LDFLAGS="-Wl,--no-as-needed"
>>>
>>> which seems to restore the old behaviour, but it looks like the real
>>> solution is one we've been avoiding for some years now, namely to identify
>>> all the shared libraries that are necessary to resolve the symbols when
>>> linking a shared library, so that each library ends up with links to the
>>> libraries it depends on (this is the reason why the Cygwin build stopped
>>> working).

I may have spoken too soon, seems there is still a problem building VTK 
with this flag set (didn't clean this submodule). Could be down to the 
library ordering this time, but that's a guess I need to follow up.

>> Thanks for the heads up. We have the link scripts so we do know what
>> each library depends on. What causes me pause is how we handle link
>> script options. If I'm linking against AST I may or may not want to
>> provide an error library or grf plugin. Does this mean that we need to
>> install multiple monolithic AST libraries that cover all the link
>> options?

Good point. You can clearly can still build libraries with missing 
symbols, so the question would seem to be how to satisfy those at runtime. 
Usually you dlload, like with Tcl, Perl etc. The alternative would seem to 
be using the correct ld flags in ast_link etc. that force the dependencies 
of the libraries themselves to be checked, as well as the local objects, 
or just the above to grab all libraries that have been given.


> Not sure I'm following this. Isn't the whole point of the link scripts
> to generate a proper list of all the libraries that should be linked,
> leaving no "indirect" linking? And what is the problem with the AST
> link options? Is it that if libA_link and libB_link invoke the AST
> link script with different options, then an application that links
> against libA and libB will be confused?
>
> Since Peter says there is a problem, I'll believe it, but I'm just
> trying to sort out why the current scheme fails.

Because by default symbols in shared libraries are not checked for 
unresolved symbols, so your new (Grf/Err) code may be deemed unnecessary. 
Previously all the libraries given to the linker would be added to the 
dependencies of the program and show up in "ldd", now only those found as 
needed to resolve the dependencies of the local objects will be found by 
"ldd". One corollary: not completely sure how that would pan out if new 
Grr/Err modules are local objects not buried in some shared library, and 
another, this is all quite subtle, so don't take my word as gospel.

Cheers,

Peter.

Top of Message | Previous Page | Permalink

JiscMail Tools


RSS Feeds and Sharing


Advanced Options


Archives

December 2023
January 2023
December 2022
July 2022
June 2022
April 2022
March 2022
December 2021
October 2021
July 2021
April 2021
January 2021
October 2020
September 2020
August 2020
May 2020
November 2019
October 2019
July 2019
June 2019
February 2019
January 2019
December 2018
November 2018
August 2018
July 2018
May 2018
April 2018
March 2018
February 2018
December 2017
October 2017
August 2017
July 2017
May 2017
April 2017
February 2017
January 2017
December 2016
November 2016
October 2016
September 2016
August 2016
July 2016
May 2016
April 2016
March 2016
February 2016
January 2016
December 2015
October 2015
September 2015
August 2015
April 2015
March 2015
February 2015
January 2015
December 2014
November 2014
October 2014
September 2014
August 2014
July 2014
June 2014
May 2014
April 2014
March 2014
February 2014
January 2014
December 2013
November 2013
October 2013
September 2013
August 2013
July 2013
June 2013
May 2013
April 2013
March 2013
February 2013
January 2013
December 2012
November 2012
October 2012
September 2012
August 2012
July 2012
June 2012
May 2012
April 2012
March 2012
February 2012
January 2012
December 2011
November 2011
October 2011
September 2011
August 2011
July 2011
June 2011
May 2011
April 2011
March 2011
February 2011
January 2011
December 2010
November 2010
October 2010
September 2010
August 2010
July 2010
June 2010
May 2010
April 2010
March 2010
February 2010
January 2010
December 2009
November 2009
October 2009
September 2009
August 2009
July 2009
June 2009
May 2009
April 2009
March 2009
February 2009
January 2009
December 2008
November 2008
October 2008
September 2008
August 2008
July 2008
June 2008
May 2008
April 2008
March 2008
February 2008
January 2008
December 2007
November 2007
October 2007
September 2007
August 2007
July 2007
June 2007
May 2007
April 2007
March 2007
February 2007
January 2007
December 2006
November 2006
October 2006
September 2006
August 2006
July 2006
June 2006
May 2006
April 2006
March 2006
February 2006
January 2006
December 2005
November 2005
October 2005
September 2005
August 2005
July 2005
June 2005
May 2005
April 2005
March 2005
February 2005
January 2005
December 2004
November 2004
October 2004
September 2004
August 2004
July 2004
June 2004
May 2004
April 2004
March 2004
February 2004
January 2004
2004
April 2003
2003


JiscMail is a Jisc service.

View our service policies at https://www.jiscmail.ac.uk/policyandsecurity/ and Jisc's privacy policy at https://www.jisc.ac.uk/website/privacy-notice

For help and support help@jisc.ac.uk

Secured by F-Secure Anti-Virus CataList Email List Search Powered by the LISTSERV Email List Manager