Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 11 May 2005 09:39:22 GMT
From:      "Andrey V. Semyonov" <wilfre@tcom.ru>
To:        freebsd-gnats-submit@FreeBSD.org
Subject:   ports/80883: Freeradius port doesn't build if already installed
Message-ID:  <200505110939.j4B9dMNK097197@www.freebsd.org>
Resent-Message-ID: <200505110940.j4B9e2MF045257@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

>Number:         80883
>Category:       ports
>Synopsis:       Freeradius port doesn't build if already installed
>Confidential:   no
>Severity:       serious
>Priority:       low
>Responsible:    freebsd-ports-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          change-request
>Submitter-Id:   current-users
>Arrival-Date:   Wed May 11 09:40:02 GMT 2005
>Closed-Date:
>Last-Modified:
>Originator:     Andrey V. Semyonov
>Release:        5.3-RELEASE
>Organization:
Tower-Telecom
>Environment:
FreeBSD valhalla.starnet 5.3-RELEASE FreeBSD 5.3-RELEASE #0: Wed Apr 20 15:26:00 MSD 2005     root@valhalla.starnet:/usr/obj/usr/src/sys/VALHALLA  i386

>Description:
/usr/ports/net/freeradius (port version 1.0.2_1) doesn't build if libradius is already installed on the system.

The linker exits with an error while compiling 'radwho' module:
Making all in main...
gmake[4]: Entering directory `/usr/ports/net/freeradius/work/freeradius-1.0.2/src/main'
/usr/ports/net/freeradius/work/freeradius-1.0.2/libtool --mode=link cc -export-dynamic -dlopen self \
	 -O -pipe  -D_REENTRANT -D_POSIX_PTHREAD_SEMANTICS -DOPENSSL_NO_KRB5   -Wall -D_GNU_SOURCE -DNDEBUG -I/usr/local/include -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 -I../include  -DHOSTINFO=\"\" -DRADIUSD_VERSION=\"1.0.2\"   -rpath=/usr/local/lib -L/usr/local/lib  -L../lib -o radiusd \
	radiusd.o files.o util.o acct.o nas.o log.o valuepair.o version.o proxy.o exec.o auth.o timestr.o conffile.o modules.o modcall.o session.o xlat.o threads.o smux.o radius_snmp.o client.o request_list.o mainconfig.o -lcrypt  -lpthread -lcrypto -lssl  -lradius  \
	 -lltdl -lcrypt
rm -f .libs/radiusd.nm .libs/radiusd.nmS .libs/radiusd.nmT
creating .libs/radiusdS.c
(cd .libs && cc -c -fno-builtin -fno-rtti -fno-exceptions "radiusdS.c")
cc1: warning: command line option "-fno-rtti" is valid for C++/ObjC++ but not for C
rm -f .libs/radiusdS.c .libs/radiusd.nm .libs/radiusd.nmS .libs/radiusd.nmT
cc .libs/radiusdS.o -O -pipe -D_REENTRANT -D_POSIX_PTHREAD_SEMANTICS -DOPENSSL_NO_KRB5 -Wall -D_GNU_SOURCE -DNDEBUG -I/usr/local/include -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 -I../include -DHOSTINFO=\"\" -DRADIUSD_VERSION=\"1.0.2\" -rpath=/usr/local/lib -o radiusd radiusd.o files.o util.o acct.o nas.o log.o valuepair.o version.o proxy.o exec.o auth.o timestr.o conffile.o modules.o modcall.o session.o xlat.o threads.o smux.o radius_snmp.o client.o request_list.o mainconfig.o -Wl,--export-dynamic  -L/usr/local/lib -L/usr/ports/net/freeradius/work/freeradius-1.0.2/src/lib -lcrypt -lpthread -lcrypto -lssl /usr/local/lib/libradius.so /usr/local/lib/libltdl.so -lcrypt -Wl,--rpath -Wl,/usr/local/lib -Wl,--rpath -Wl,/usr/local/lib
rm -f .libs/radiusdS.o
cc -rpath=/usr/local/lib -L/usr/local/lib  -L../lib -o radwho radwho.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o -lpthread -lcrypto -lssl  -lradius 
/usr/local/lib/libradius.so: undefined reference to `crypt'
gmake[4]: *** [radwho] Error 1
gmake[4]: Leaving directory `/usr/ports/net/freeradius/work/freeradius-1.0.2/src/main'
gmake[3]: *** [common] Error 1
gmake[3]: Leaving directory `/usr/ports/net/freeradius/work/freeradius-1.0.2/src'
gmake[2]: *** [all] Error 2
gmake[2]: Leaving directory `/usr/ports/net/freeradius/work/freeradius-1.0.2/src'
gmake[1]: *** [common] Error 1
gmake[1]: Leaving directory `/usr/ports/net/freeradius/work/freeradius-1.0.2'
gmake: *** [all] Error 2
*** Error code 2

Stop in /usr/ports/net/freeradius.

so it seems like freeradius-port conflicts with itself.

After '#make deinstall' the problem didn't appear.

And, for one-time build-and-install the port behaves well. For furter compiling (i.e. making a package for fast-installation of a second-third-... server while the main has already the port installed) the port doesn't compile.
>How-To-Repeat:
#cd /usr/ports/net/freeradius
#make install clean
#make build

This will repeat the problem.
>Fix:
As it seems to me, the linker-library path in
'cc -rpath=/usr/local/lib -L/usr/local/lib  -L../lib -o radwho radwho.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o -lpthread -lcrypto -lssl  -lradius'
should be corrected - instead of '-L/usr/local/lib -L../lib' it should be reversed to '-L../lib -L/usr/local/lib' so the linker first checks for 'libradius' in src/main/../lib (which compiles earlier) and so for all the objects, referenced by that library (which also compile into src/main/../lib).

A sample patch, which works fine for me:

--- src/main/Makefile.in.orig	Wed Jun  2 20:17:06 2004
+++ src/main/Makefile.in	Wed May 11 13:18:27 2005
@@ -14,7 +14,7 @@
 CFLAGS		+= -DHOSTINFO=\"${HOSTINFO}\"
 CFLAGS          += -DRADIUSD_VERSION=\"${RADIUSD_VERSION}\"
 CFLAGS          += $(SNMP_INCLUDE) 
-LDFLAGS		+= -L../lib
+LDFLAGS_MAIN	= -L../lib $(LDFLAGS)
 MODULE_LIBS	= $(STATIC_MODULES)
 MODULE_OBJS	=
 VFLAGS		= -DRADIUSD_MAJOR_VERSION=$(RADIUSD_MAJOR_VERSION)
@@ -52,7 +52,7 @@
 
 radiusd: $(SERVER_OBJS) ../lib/libradius.a $(MODULE_OBJS)
 	$(LIBTOOL) --mode=link $(CC) -export-dynamic -dlopen self \
-		$(CFLAGS) $(LDFLAGS) -o $@ \
+		$(CFLAGS) $(LDFLAGS_MAIN) -o $@ \
 		$(SERVER_OBJS) $(LCRYPT) $(MODULE_LIBS) $(LIBS) \
 		$(PTHREADLIB) $(LIBLTDL) $(LCRYPT)
 
@@ -123,13 +123,13 @@
 	$(CC) $(CFLAGS) -o radius_snmp.o -c radius_snmp.c
 
 radclient: radclient.o ../lib/libradius.a
-	$(CC) $(CFLAGS) $(LDFLAGS) -o radclient radclient.o $(LIBS)
+	$(CC) $(CFLAGS) $(LDFLAGS_MAIN) -o radclient radclient.o $(LIBS)
 
 radclient.o: radclient.c $(INCLUDES)
 	$(CC) $(CFLAGS) -c radclient.c
 
 radrelay: radrelay.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o ../lib/libradius.a
-	$(CC) $(CFLAGS) $(LDFLAGS) -o radrelay radrelay.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o $(LIBS)
+	$(CC) $(CFLAGS) $(LDFLAGS_MAIN) -o radrelay radrelay.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o $(LIBS)
 
 radrelay.o: radrelay.c $(INCLUDES)
 	$(CC) $(CFLAGS) -c radrelay.c
@@ -138,13 +138,13 @@
 	$(CC) $(CFLAGS) -c radwho.c
 
 radwho: radwho.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o
-	$(CC) $(LDFLAGS) -o radwho radwho.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o $(LIBS)
+	$(CC) $(LDFLAGS_MAIN) -o radwho radwho.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o $(LIBS)
 
 radzap.o: radzap.c $(INCLUDES)
 	$(CC) $(CFLAGS) -c radzap.c
 
 radzap: radzap.o mainconfig.o util.o nas.o log.o client.o conffile.o files.o xlat.o
-	$(CC) $(CFLAGS) $(LDFLAGS) -o radzap radzap.o mainconfig.o util.o nas.o log.o client.o conffile.o files.o xlat.o $(LIBS)
+	$(CC) $(CFLAGS) $(LDFLAGS_MAIN) -o radzap radzap.o mainconfig.o util.o nas.o log.o client.o conffile.o files.o xlat.o $(LIBS)
 
 clean:
 	rm -rf *.o *.so *~ $(BINARIES) .libs

>Release-Note:
>Audit-Trail:
>Unformatted:



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200505110939.j4B9dMNK097197>