Re: Error on stock postgresql-tcl-7.1.3-2.i386.rpm included in RH7.2

Lists: pgsql-hackers
From: teg(at)redhat(dot)com (Trond Eivind =?iso-8859-1?q?Glomsr=F8d?=)
To: Deds Castillo <deds(at)infiniteinfo(dot)com>
Cc: pgsql-hackers(at)postgresql(dot)org
Subject: Re: Error on stock postgresql-tcl-7.1.3-2.i386.rpm included in RH7.2
Date: 2001-11-09 21:50:41
Message-ID: xuysnbn7gwe.fsf@halden.devel.redhat.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Lists: pgsql-hackers

Deds Castillo <deds(at)infiniteinfo(dot)com> writes:

> Good day to you. I've searched the net but I can't seem to find the solution
> for this. I've found a few more posts which are exactly the same as my error
> but no solution was given.
>
> The problem is when I install the postgresql-tcl rpm and I try to createlang
> pltcl. The error below occurs:
>
> ERROR: Load of file /usr/lib/pgsql/pltcl.so failed: /usr/lib/pgsql/pltcl.so:
> undefined symbol: Tcl_CreateSlave
>
> So instead of executing createlang, I try to isolate the error using this
> command:
>
> testdb=# CREATE FUNCTION pltcl_call_handler () RETURNS OPAQUE AS
> '/usr/lib/pgsql/pltcl.so' LANGUAGE 'C';

During the build process, the tcl shared module is created like this:

gcc -pipe -shared -Wl,-soname,libtcl.so.0 -o pltcl.so pltcl.o -L/usr/lib -ltcl -ldl -lieee -lm -lc

specifying the soname "libtcl.so.0" and at the same time linking to
libtcl.so.0 (which is the name of the shared tcl library in RHL 7.2)
results in trouble when loading it later.

Creating the module with a different so-name ("libtcl" seems like a
bad idea to use outside the main package) solves the problem and gives
you a module which loads

gcc -pipe -shared -Wl,-soname,libpgtcl.so.0 -o pltcl.so pltcl.o -L/usr/lib -ltcl -ldl -lieee -lm -lc

--
Trond Eivind Glomsrød
Red Hat, Inc.


From: Lamar Owen <lamar(dot)owen(at)wgcr(dot)org>
To: teg(at)redhat(dot)com (Trond Eivind =?iso-8859-1?q?Glomsr=F8d?=), Deds Castillo <deds(at)infiniteinfo(dot)com>
Cc: pgsql-hackers(at)postgresql(dot)org
Subject: Re: Error on stock postgresql-tcl-7.1.3-2.i386.rpm included in RH7.2
Date: 2001-11-09 22:14:06
Message-ID: 200111092214.RAA23389@www.wgcr.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Lists: pgsql-hackers

On Friday 09 November 2001 04:50 pm, Trond Eivind Glomsrød wrote:
> Creating the module with a different so-name ("libtcl" seems like a
> bad idea to use outside the main package) solves the problem and gives
> you a module which loads

> gcc -pipe -shared -Wl,-soname,libpgtcl.so.0 -o pltcl.so pltcl.o -L/usr/lib
> -ltcl -ldl -lieee -lm -lc

Will this cause any conflicts with the tcl client lib 'libpgtcl.so.x'?
Should the soname be 'pltcl.so.0' ?

PeterE?
--
Lamar Owen
WGCR Internet Radio
1 Peter 4:11


From: teg(at)redhat(dot)com (Trond Eivind =?iso-8859-1?q?Glomsr=F8d?=)
To: Lamar Owen <lamar(dot)owen(at)wgcr(dot)org>
Cc: Deds Castillo <deds(at)infiniteinfo(dot)com>, pgsql-hackers(at)postgresql(dot)org
Subject: Re: Error on stock postgresql-tcl-7.1.3-2.i386.rpm included in RH7.2
Date: 2001-11-09 22:16:03
Message-ID: xuyk7wz7fq4.fsf@halden.devel.redhat.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Lists: pgsql-hackers

Lamar Owen <lamar(dot)owen(at)wgcr(dot)org> writes:

> On Friday 09 November 2001 04:50 pm, Trond Eivind Glomsrød wrote:
> > Creating the module with a different so-name ("libtcl" seems like a
> > bad idea to use outside the main package) solves the problem and gives
> > you a module which loads
>
> > gcc -pipe -shared -Wl,-soname,libpgtcl.so.0 -o pltcl.so pltcl.o -L/usr/lib
> > -ltcl -ldl -lieee -lm -lc
>
> Will this cause any conflicts with the tcl client lib 'libpgtcl.so.x'?
> Should the soname be 'pltcl.so.0' ?

--- postgresql-7.1.3/src/pl/tcl/Makefile.tcldefs.tclsoname Fri Nov 9 17:12:38 2001
+++ postgresql-7.1.3/src/pl/tcl/Makefile.tcldefs Fri Nov 9 17:15:03 2001
@@ -19,7 +19,7 @@
TCL_SHLIB_CFLAGS = -fPIC
TCL_CFLAGS_WARNING = -Wall -Wconversion -Wno-implicit-int
TCL_EXTRA_CFLAGS =
-TCL_SHLIB_LD = gcc -pipe -shared -Wl,-soname,libtcl.so.0
+TCL_SHLIB_LD = gcc -pipe -shared -Wl,-soname,libpltcl.so.0
TCL_STLIB_LD = ar cr
TCL_SHLIB_LD_LIBS = ${LIBS}
TCL_SHLIB_SUFFIX = .so

--
Trond Eivind Glomsrød
Red Hat, Inc.


From: teg(at)redhat(dot)com (Trond Eivind =?iso-8859-1?q?Glomsr=F8d?=)
To: Lamar Owen <lamar(dot)owen(at)wgcr(dot)org>
Cc: Deds Castillo <deds(at)infiniteinfo(dot)com>, pgsql-hackers(at)postgresql(dot)org
Subject: Re: Error on stock postgresql-tcl-7.1.3-2.i386.rpm included in RH7.2
Date: 2001-11-09 22:27:01
Message-ID: xuyg07n7f7u.fsf@halden.devel.redhat.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Lists: pgsql-hackers

teg(at)redhat(dot)com (Trond Eivind Glomsrød) writes:

> Lamar Owen <lamar(dot)owen(at)wgcr(dot)org> writes:
>
> > On Friday 09 November 2001 04:50 pm, Trond Eivind Glomsrød wrote:
> > > Creating the module with a different so-name ("libtcl" seems like a
> > > bad idea to use outside the main package) solves the problem and gives
> > > you a module which loads
> >
> > > gcc -pipe -shared -Wl,-soname,libpgtcl.so.0 -o pltcl.so pltcl.o -L/usr/lib
> > > -ltcl -ldl -lieee -lm -lc
> >
> > Will this cause any conflicts with the tcl client lib 'libpgtcl.so.x'?
> > Should the soname be 'pltcl.so.0' ?
>
> --- postgresql-7.1.3/src/pl/tcl/Makefile.tcldefs.tclsoname Fri Nov 9 17:12:38 2001
> +++ postgresql-7.1.3/src/pl/tcl/Makefile.tcldefs Fri Nov 9 17:15:03 2001
> @@ -19,7 +19,7 @@
> TCL_SHLIB_CFLAGS = -fPIC
> TCL_CFLAGS_WARNING = -Wall -Wconversion -Wno-implicit-int
> TCL_EXTRA_CFLAGS =
> -TCL_SHLIB_LD = gcc -pipe -shared -Wl,-soname,libtcl.so.0
> +TCL_SHLIB_LD = gcc -pipe -shared -Wl,-soname,libpltcl.so.0
> TCL_STLIB_LD = ar cr
> TCL_SHLIB_LD_LIBS = ${LIBS}
> TCL_SHLIB_SUFFIX = .so

(scratch that - this file is generated when building)

--
Trond Eivind Glomsrød
Red Hat, Inc.


From: Peter Eisentraut <peter_e(at)gmx(dot)net>
To: Trond Eivind Glomsrød <teg(at)redhat(dot)com>
Cc: Deds Castillo <deds(at)infiniteinfo(dot)com>, <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: Error on stock postgresql-tcl-7.1.3-2.i386.rpm included
Date: 2001-11-11 15:38:48
Message-ID: Pine.LNX.4.30.0111111532510.647-100000@peter.localdomain
Views: Raw Message | Whole Thread | Download mbox | Resend email
Lists: pgsql-hackers

Trond Eivind Glomsrød writes:

> During the build process, the tcl shared module is created like this:
>
> gcc -pipe -shared -Wl,-soname,libtcl.so.0 -o pltcl.so pltcl.o -L/usr/lib -ltcl -ldl -lieee -lm -lc
>
> specifying the soname "libtcl.so.0" and at the same time linking to
> libtcl.so.0 (which is the name of the shared tcl library in RHL 7.2)
> results in trouble when loading it later.

This must be a bug (feature?) in the Tcl package. I see no such thing
happening here (RH 7.0, tcl-8.3.1-46):

gcc -pipe -shared -o pltcl.so pltcl.o -L/usr/lib -ltcl8.3 -ldl -lieee -lm -lc

I don't know whose idea the soname was, but it surely wasn't a good one.

--
Peter Eisentraut peter_e(at)gmx(dot)net