Forum OpenACS Q&A: Problem compiling Aolserver 4.5 with tcl 8.5.5

There is a known problem with Aolserver 4.5 and recent tcl versions causing the following problem when compiling:

nsthread_libinit.o: In function `_init':
nsthread_libinit.o(.text+0x0): multiple definition of `_init'
/usr/lib/gcc-lib/i386-redhat-linux/3.2/../../../crti.o:/tmp/ccLMpyMg.s:28: first defined here
collect2: ld returned 1 exit status
gmake[1]: *** [libnsthread.so] Error 1
gmake[1]: Leaving directory `/usr/local/src/aolserver45r0/aolserver/nsthread'
make: *** [build] Error 1

Apparently it is some kind of naming collision. Here is a relevant thread:

http://www.mail-archive.com/aolserver@listserv.aol.com/msg11285.html

Does anyone have any experience of changing ./nsconfig.tcl to have the same effect as applying the following patch to ./configure?

diff -urNad aolserver4~/configure aolserver4/configure
--- aolserver4~/configure 2007-04-22 19:19:35.000000000 +0200
+++ aolserver4/configure 2007-07-26 16:31:22.000000000 +0200
@@ -2520,11 +2520,7 @@
;;
*)
LDLIB="$TCL_SHLIB_LD"
- case "$LDLIB" in
- *gcc*)
- LDLIB="$LDLIB -nostartfiles"
- ;;
- esac
+ LDLIB="$LDLIB -nostartfiles"
CCRPATH="\$(CCRFLAG)\$(INSTLIB)"
LDRPATH="\$(LDRFLAG)\$(INSTLIB)"
if test "$TCL_EXEC_PREFIX" != "$prefix"

Collapse
Posted by Gustaf Neumann on
Actually, this is mostly a linux/gcc problem. i am compiling aolserver since a while with tcl-8.5 (mimimum Tcl 8.5.1 required), but mostly under Mac OS X, so i have not seen the problem.

However, notice that nsconfig.tcl calls as well configure. configure.in has a similar section about LDLIB (if it contains *gcc* or *shared*, the flag "-nostartfiles" is added). So, it is essentially the same mechanism as in 4.0. What is the value of LDLIB on your system?

Collapse
Posted by Richard Hamilton on
Gustav,

Thank you very much for the reply.

I have checked the values of LDLIB and TCL_SHLIB_LD as root and both are NULL.

This is a RedHat 8.0 installation and I have several versions of tcl installed. The version of tcl that runs by default when is the one that shipped with the distribution which is tcl 8.3.3. At some time I have obviously installed tcl and tk 8.4 in /usr/local/lib which was probably when I moved from ad33.13 to Aolserver 4.0.

In my attempt to compile Aolserver 4.5.0 I have compiled tcl 8.5.5 into /usr/local/aolserver45r0/lib as per Malte's published instructions (actually I worked through his script by hand).

This version works fine when I launch it explicitly by typing /usr/local/aolserver45r0/bin/tclsh8.5

Regards
Richard

Collapse
Posted by Richard Hamilton on
I have now tried compiling Aolserver 4.5.0 with tcl 8.4.19 and I get the same error.
Collapse
Posted by Richard Hamilton on
I am not entirely sure why empty environment variables would cause what appears to be a duplicate definition, but clearly the patch to ./configure is fiddling with the LDLIB variable.

Is LDLIB supposed to hold the path to the dynamic linker?

$ find / -name glibc*

/usr/bin/glibcbug
/usr/lib/glib/include/glibconfig.h
/usr/lib/glib-2.0/include/glibconfig.h
/usr/sbin/glibc_post_upgrade
/usr/share/doc/glibc-2.3.2
/usr/share/doc/glibc-common-2.3.2
/usr/share/aclocal/glibc21.m4

I have always used LD_LIBRARY_PATH in the path for this so am a bit confused.

Regards
Richard

Collapse
Posted by Gustaf Neumann on
LDLIB is not an environment variable, but a configuration variable managed by configure and autoconf.

The quick fix for your problem is to edit aolserver/include/ns.mak and add -nostartfiles to the options in the line with LDLIB (after configure). The real fix is to figure out, why this flag is not added automatically by configure in your environment.

Collapse
Posted by Richard Hamilton on
Gustav,

Thank you very much. Whilst I am very happy thrashing around the OpenACS code, delving into makefiles is hazy new territory for me at the moment!

When I said that installing tcl in /usr/local/aolserver45/lib had worked for me what I meant was that the tcl compiled fine and I could run tclsh8.5 and run ./nsconfig.tcl using it.

However the Aolserver compilation failed.

I will try poking about in the makefile and if I can't sort it out I will try upgrading to tcl 8.4.19 and compiling Aolserver 4.0.latest.

R.

Collapse
Posted by Richard Hamilton on
Gustav,

You say to edit nsmak.in rather than configure.in. Is this because configure.in calls nsmak.in or because I should be using nsconfig.tcl and nsconfig.tcl calls nsmak.in?

If configure.in calls nsmak.in then why does the section that should add -nostartfiles files occur in both?

R.

Collapse
Posted by Richard Hamilton on
The relevant section in configure.in occurs in a "case" statement and is conditional upon the system being "darwin". I am probably misreading the case statement but this looks a bit strange to me. I can't figure out what the *) is doing there. I will continue working on nsmak.in as you suggest.
#
# TCL_SHLIB_LD from tclConfig.sh is not quite right for aolserver.
#

test "x$prefix" = "xNONE" && prefix="/usr/local/aolserver"
system=`uname`
case "$system" in
    Darwin)
	LDLIB="\$(CC) -dynamiclib -install_name \$(INSTLIB)/\$(DLLBIN)"
	LDSO="\$(CC) -bundle"
	CCRFLAG=
	LDRFLAG=
	CCRPATHS=
	LDRPATHS=
	;;
    *)
	LDLIB="$TCL_SHLIB_LD"
	case "$LDLIB" in
	    *gcc*)
		LDLIB="$LDLIB -nostartfiles"
		;;
	    *shared*)
		LDLIB="$LDLIB -nostartfiles"
		;;
	esac
	CCRPATH="\$(CCRFLAG)\$(INSTLIB)"
	LDRPATH="\$(LDRFLAG)\$(INSTLIB)"
	if test "$TCL_EXEC_PREFIX" != "$prefix"
	then
		CCRPATH="$CCRPATH \$(CCRFLAG)\$(TCL_EXEC_PREFIX)/lib"
		LDRPATH="$LDRPATH \$(LDRFLAG)\$(TCL_EXEC_PREFIX)/lib"
	fi
	if test -d /usr/lib/lwp
	then
		CCRPATH="$CCRPATH \$(CCRFLAG)/usr/lib/lwp"
		LDRPATH="$LDRPATH \$(LDRFLAG)/usr/lib/lwp"
	fi
	LDSO="\$(LDLIB)"
	CCRPATHS="\$(CCRPATH)"
	LDRPATHS="\$(LDRPATH)"
	CCRFLAG=$TCL_CC_SEARCH_FLAGS
	LDRFLAG=$TCL_LD_SEARCH_FLAGS
        if test "$CCRFLAG" = "" ; then
            CCRPATH=
        fi
        if test "$LDRFLAG" = "" ; then
            LDRPATH=
        fi
	;;
esac
Collapse
Posted by Richard Hamilton on
The only bit I can find in nsmak.in is:

# Add dynamic library entry point flags.
ifdef DLLINIT
    ifneq (,$(findstring Darwin,$(uname)))
	INIT	 =  _$(DLLINIT)
	LDLIB	+= -init _$(INIT)
    else
	INIT	 =  _init
    endif
endif
Collapse
Posted by Gustaf Neumann on
no, i did not say to edit nsmak.in, i sayed edit aolserver/include/ns.mak ... if you primary goal is the get a compiled aolserver.
Collapse
Posted by Gustaf Neumann on
If the goal is to get configure work correctly, configure.in is the right place to fix, or at least to figure out, why the configurations goes wrong.

But you are misreading the code. The first case branch is for "Darwin", all other systems ("*") use the 2nd branch. That's why i asked you in http://www.openacs.org/forums/message-view?message_id=2376173, what the value of LDLIB on your system is.

Collapse
Posted by Richard Hamilton on
Ah! Thank you Gustaf. So that is what the mysterious *) was all about! 😊

I do want to achieve a successful compilation, but I would like to solve the problem properly so that the fix will be documented here.

To find out the value of LDLIB I will add an echo statement to configure.in and run it (unless there's a better way). I now understand what you meant about 'after configure' because ns.mak is created by the configure script. I had not realised initially.

(By the way, I have just realised that I have been mis-spelling your name - I am very sorry, how rude of me.

Regards and thanks
Richard

Collapse
Posted by Richard Hamilton on
Here is the relevant section from ns.mak following the execution of nsconfig.tcl as follows:

# pwd
/usr/local/src/aolserver45r0/aolserver

# /usr/local/aolserver45r0/bin/tclsh8.4 nsconfig.tcl

...
#
# Install directories.
#

AOLSERVER	= /usr/local/aolserver45r0
TCLSH		= /usr/local/aolserver45r0/bin/tclsh8.4
INSTBIN		= $(AOLSERVER)/bin
INSTLIB		= $(AOLSERVER)/lib
INSTINC		= $(AOLSERVER)/include
INSTTCL         = $(AOLSERVER)/modules/tcl
INSTSRV         = $(AOLSERVER)/servers/server1
INSTSRVMOD      = $(INSTSRV)/modules
INSTSRVPAG      = $(INSTSRV)/pages
SH		= /bin/sh

#
# Compiler and linker options.
#

LIBEXT		= .so
LDLIB		= ${CC} -shared ${CFLAGS} ${LDFLAGS} -nostartfiles
LDSO		= $(LDLIB)
CCRFLAG         = -Wl,-rpath,${LIB_RUNTIME_DIR}
LDRFLAG         = -Wl,-rpath,${LIB_RUNTIME_DIR}
CCRPATH         += $(CCRFLAG)$(INSTLIB)
LDRPATH         += $(LDRFLAG)$(INSTLIB)
CC		= $(PURIFY) gcc

I note the following:

  1. The LDLIB assignment DOES in fact have "-nostartfiles" at the end after all.
  2. that CC is defined after LDLIB and that its value is $(PURIFY) gcc
  3. There is no other reference to PURIFY anywhere else in ns.mak
Could the problem be because PURIFY returns no value? What is it supposed to do? R.
Collapse
Posted by Richard Hamilton on
Aha! Fantastic. Aolserver appears to have compiled this time. The only thing I did differently this time was to install vtmalloc which previously I had decided not to do. I had problems with the Google Perftools malloc a few months ago and had not realised that vtmalloc is a tcl specific memory allocator.

Could this be the reason or has it just been one of those strange things where I must have done something in a different order or something?

Collapse
Posted by Richard Hamilton on
Thank you so very much for your help. Aolserver 4.5.0 is now up and running and serving the default page with tcl 8.4.19, vtmalloc and all the other bells and whistles. Fantastic!

Now all I have to do is figure out the differences in the config.tcl file between 4.0.x and 4.5.x

R.