installing CLN on darwin

John Whitley whitley at acm.org
Mon Feb 23 05:59:49 CET 2004


Richard B. Kreckel writes:
> Note that you'll find some linker problems at a later stage.
> Somebody knowledgeable about the way that linker works needs to fix this.

In my Great Quest to get GiNaC running on Mac OS X, I've done some digging on this problem.
The issue lies with the machine-dependent hacks in include/cln/modules.h for forcing
construction time ordering.

The following quote from 
http://mail.gnu.org/archive/html/users-prolog/2004-01/msg00028.html
sums up the issue at hand:

   The problem comes down to the fact that Mach-o has lazy linking and
   does not allow any changes in the .text section where our compiled
   code resides.  Therefore the message below, which states "
   non-writable section".  This means that all external symbols need a
   stub construct in the .data section. The code in .text jumps to
   .data section, which in the meantime has magically been changed to
   point to the actual implementation of the target routine in linked
   shared libraries.

I still need to fullly understand the approach implemented by CL_PROVIDE and related macros in
modules.h, then determine/implement/test the solution for Darwin-based platforms.

FWIW, I've had to manage this problem in C++ embedded systems before,  e.g. via a linker 
directive files.  I'm unclear as to what motivated the design choices in CLN, such that it even 
encounters the constructor ordering problem in the first place?  

Thanks,
John Whitley

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://www.ginac.de/pipermail/ginac-devel/attachments/20040222/512decf1/attachment.htm>


More information about the GiNaC-devel mailing list