Makefile.PL for Pg.so

Started by Larry Rosenmanover 24 years ago19 messages
#1Larry Rosenman
ler@lerctr.org

I made the following patch, and it works for MY platform.

Peter,
Can we do something similar for the distribution to set the
RUNPATH for Pg.so?

Index: Makefile.PL
===================================================================
RCS file: /home/projects/pgsql/cvsroot/pgsql/src/interfaces/perl5/Makefile.PL,v
retrieving revision 1.17
diff -c -r1.17 Makefile.PL
*** Makefile.PL	2001/03/06 22:07:09	1.17
--- Makefile.PL	2001/08/13 04:12:28
***************
*** 64,66 ****
--- 64,77 ----
  ];
  }
+ sub MY::dynamic_lib {
+       package MY;
+       my $inherited= shift->SUPER::dynamic_lib(@_);
+       if (! -d $ENV{POSTGRES_LIB} ) {
+        my $cwd = `pwd`;
+       chop $cwd;
+       $ENV{POSTGRES_LIB} = "$cwd/../libpq";
+       }
+       $inherited=~ s@OTHERLDFLAGS =@OTHERLDFLAGS =-R$ENV{POSTGRES_LIB}@;
+       $inherited;
+ }

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

#2Peter Eisentraut
peter_e@gmx.net
In reply to: Larry Rosenman (#1)
Re: [PATCHES] Makefile.PL for Pg.so

Larry Rosenman writes:

I made the following patch, and it works for MY platform.

Peter,
Can we do something similar for the distribution to set the
RUNPATH for Pg.so?

This is an interesting idea. I'd rather rip out MakeMaker completely, but
this might be a good start.

--
Peter Eisentraut peter_e@gmx.net http://funkturm.homeip.net/~peter

#3Larry Rosenman
ler@lerctr.org
In reply to: Peter Eisentraut (#2)
Re: [PATCHES] Makefile.PL for Pg.so

* Peter Eisentraut <peter_e@gmx.net> [010814 16:58]:

Larry Rosenman writes:

I made the following patch, and it works for MY platform.

Peter,
Can we do something similar for the distribution to set the
RUNPATH for Pg.so?

This is an interesting idea. I'd rather rip out MakeMaker completely, but
this might be a good start.

I'm not familiar enough with the config / autoconf stuff to do a
portable patch. Can you help in this area?

LER

--
Peter Eisentraut peter_e@gmx.net http://funkturm.homeip.net/~peter

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

#4Larry Rosenman
ler@lerctr.org
In reply to: Larry Rosenman (#1)
Re: [PATCHES] Makefile.PL for Pg.so

* Peter Eisentraut <peter_e@gmx.net> [010825 18:14]:

Larry Rosenman writes:

Can we do something similar for the distribution to set the
RUNPATH for Pg.so?

AFAICT, Pg.so does get the runpath set correctly. Are you saying it
doesn't work on your system or do you want to get rid of the
recompilation during installation?

It doesn't work on this systsm .

(you still have a login here).

LER

--
Peter Eisentraut peter_e@gmx.net http://funkturm.homeip.net/~peter

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

#5Peter Eisentraut
peter_e@gmx.net
In reply to: Larry Rosenman (#1)
Re: [PATCHES] Makefile.PL for Pg.so

Larry Rosenman writes:

Can we do something similar for the distribution to set the
RUNPATH for Pg.so?

AFAICT, Pg.so does get the runpath set correctly. Are you saying it
doesn't work on your system or do you want to get rid of the
recompilation during installation?

--
Peter Eisentraut peter_e@gmx.net http://funkturm.homeip.net/~peter

#6Larry Rosenman
ler@lerctr.org
In reply to: Peter Eisentraut (#5)
Re: [PATCHES] Makefile.PL for Pg.so

* Peter Eisentraut <peter_e@gmx.net> [010825 18:14]:

Larry Rosenman writes:

Can we do something similar for the distribution to set the
RUNPATH for Pg.so?

AFAICT, Pg.so does get the runpath set correctly. Are you saying it
doesn't work on your system or do you want to get rid of the
recompilation during installation?

Oh, BTW, LD_RUN_PATH is *NOT* used to set the runpath on SVR5. That's
why I needed to pass -R to the build.

LER

--
Peter Eisentraut peter_e@gmx.net http://funkturm.homeip.net/~peter

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

#7Lamar Owen
lamar.owen@wgcr.org
In reply to: Peter Eisentraut (#5)
Re: Re: [PATCHES] Makefile.PL for Pg.so

On Saturday 25 August 2001 19:18, Peter Eisentraut wrote:

AFAICT, Pg.so does get the runpath set correctly. Are you saying it
doesn't work on your system or do you want to get rid of the
recompilation during installation?

Pg.so does not get the proper RPATH in a DESTDIR build environment.

Trying to fix this for the RPMS -- the RPATH contains the buildroot instead
of where the libs really are. Could cause security problems. Working on it,
but it's slow going for me at this busy time.
--
Lamar Owen
WGCR Internet Radio
1 Peter 4:11

#8Peter Eisentraut
peter_e@gmx.net
In reply to: Lamar Owen (#7)
Re: Re: [PATCHES] Makefile.PL for Pg.so

Lamar Owen writes:

Pg.so does not get the proper RPATH in a DESTDIR build environment.

Trying to fix this for the RPMS -- the RPATH contains the buildroot instead
of where the libs really are. Could cause security problems. Working on it,
but it's slow going for me at this busy time.

Another fun feature of the DESTDIR build environment is that the
writability test of the target directory will most likely fail because it
doesn't exist at all.

I've been thinking how I'd like to fix this: We add an option to
configure that says to *not* install the Perl module into the standard
Perl tree, but instead somewhere under our own $prefix. That way people
that don't have root access can use this option and still install the
whole tree in one run. But then we'd remove that writability check and
people that have root access or failed to use that option will get a hard
failure. This would create a much more reliable and predictable build
environment.

Comments? And a good name for such an option?

--
Peter Eisentraut peter_e@gmx.net http://funkturm.homeip.net/~peter

#9Tom Lane
tgl@sss.pgh.pa.us
In reply to: Peter Eisentraut (#8)
Re: Re: [PATCHES] Makefile.PL for Pg.so

Peter Eisentraut <peter_e@gmx.net> writes:

Another fun feature of the DESTDIR build environment is that the
writability test of the target directory will most likely fail because it
doesn't exist at all.

I've been thinking how I'd like to fix this: We add an option to
configure that says to *not* install the Perl module into the standard
Perl tree, but instead somewhere under our own $prefix. That way people
that don't have root access can use this option and still install the
whole tree in one run. But then we'd remove that writability check and
people that have root access or failed to use that option will get a hard
failure. This would create a much more reliable and predictable build
environment.

Why would we remove the writability check? Perhaps it needs to be
extended to recognize the case of target-dir-doesn't-exist-but-can-be-
created, but I don't see why a hard failure is better.

regards, tom lane

#10Larry Rosenman
ler@lerctr.org
In reply to: Tom Lane (#9)
Re: Re: [PATCHES] Makefile.PL for Pg.so

* Tom Lane <tgl@sss.pgh.pa.us> [010826 11:11]:

Peter Eisentraut <peter_e@gmx.net> writes:

Another fun feature of the DESTDIR build environment is that the
writability test of the target directory will most likely fail because it
doesn't exist at all.

I've been thinking how I'd like to fix this: We add an option to
configure that says to *not* install the Perl module into the standard
Perl tree, but instead somewhere under our own $prefix. That way people
that don't have root access can use this option and still install the
whole tree in one run. But then we'd remove that writability check and
people that have root access or failed to use that option will get a hard
failure. This would create a much more reliable and predictable build
environment.

Why would we remove the writability check? Perhaps it needs to be
extended to recognize the case of target-dir-doesn't-exist-but-can-be-
created, but I don't see why a hard failure is better.

I tend to agree with Tom here. The original problem I was seeing is
*NOT* related to DESTDIR (I don't believe).

CC=cc CXX=CC ./configure --prefix=/usr/local/pgsql --enable-syslog \
--with-CXX --with-perl --enable-multibyte --enable-cassert \
--with-includes=/usr/local/include --with-libs=/usr/local/lib \
--enable-debug \
--with-tcl --with-tclconfig=/usr/local/lib \
--with-tkconfig=/usr/local/lib --enable-locale --with-python

The above is my configure input.

regards, tom lane

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

#11Noname
teg@redhat.com
In reply to: Lamar Owen (#7)
Re: Re: [PATCHES] Makefile.PL for Pg.so

Lamar Owen <lamar.owen@wgcr.org> writes:

On Saturday 25 August 2001 19:18, Peter Eisentraut wrote:

AFAICT, Pg.so does get the runpath set correctly. Are you saying it
doesn't work on your system or do you want to get rid of the
recompilation during installation?

Pg.so does not get the proper RPATH in a DESTDIR build environment.

Rather: Perl decides it wants to specify a LD_RUN_PATH in its makefile.
This will automatically make use of -R. It's fixed in the RPMs
available at http://people.redhat.com/teg/pg/

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

#12Peter Eisentraut
peter_e@gmx.net
In reply to: Noname (#11)
Re: Re: [PATCHES] Makefile.PL for Pg.so

Trond Eivind Glomsr�d writes:

Pg.so does not get the proper RPATH in a DESTDIR build environment.

Rather: Perl decides it wants to specify a LD_RUN_PATH in its makefile.
This will automatically make use of -R. It's fixed in the RPMs
available at http://people.redhat.com/teg/pg/

AFAICT, these RPMs still contain the same problem that the runpath will
point the the temporary installation directory, not the final location.

--
Peter Eisentraut peter_e@gmx.net http://funkturm.homeip.net/~peter

#13Noname
teg@redhat.com
In reply to: Peter Eisentraut (#12)
Re: Re: [PATCHES] Makefile.PL for Pg.so

Peter Eisentraut <peter_e@gmx.net> writes:

Trond Eivind Glomsr�d writes:

Pg.so does not get the proper RPATH in a DESTDIR build environment.

Rather: Perl decides it wants to specify a LD_RUN_PATH in its makefile.
This will automatically make use of -R. It's fixed in the RPMs
available at http://people.redhat.com/teg/pg/

AFAICT, these RPMs still contain the same problem that the runpath will
point the the temporary installation directory, not the final location.

Doh... these were just temporary rpms, I've put the final -2 rpms
there now (built later the same day).

Basically, I fixed it by removing references to LD_RUN_PATH after perl
had generated it.
--
Trond Eivind Glomsr�d
Red Hat, Inc.

#14Larry Rosenman
ler@lerctr.org
In reply to: Larry Rosenman (#10)
Re: Re: [PATCHES] Makefile.PL for Pg.so

* Peter Eisentraut <peter_e@gmx.net> [010826 17:42]:

I've checked in a fix for the runpath, DESTDIR, and VPATH problems. The
first needs to be tested on a variety of platforms because I had to guess
the osname configuration values and the linker/compiler that Perl uses.

I ass/u/me that you tested it on lerami?

LER

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

#15Peter Eisentraut
peter_e@gmx.net
In reply to: Larry Rosenman (#10)
Re: Re: [PATCHES] Makefile.PL for Pg.so

I've checked in a fix for the runpath, DESTDIR, and VPATH problems. The
first needs to be tested on a variety of platforms because I had to guess
the osname configuration values and the linker/compiler that Perl uses.

--
Peter Eisentraut peter_e@gmx.net http://funkturm.homeip.net/~peter

#16Bruce Momjian
pgman@candle.pha.pa.us
In reply to: Larry Rosenman (#1)
Re: Makefile.PL for Pg.so

Can someone comment on this?

I made the following patch, and it works for MY platform.

Peter,
Can we do something similar for the distribution to set the
RUNPATH for Pg.so?

Index: Makefile.PL
===================================================================
RCS file: /home/projects/pgsql/cvsroot/pgsql/src/interfaces/perl5/Makefile.PL,v
retrieving revision 1.17
diff -c -r1.17 Makefile.PL
*** Makefile.PL	2001/03/06 22:07:09	1.17
--- Makefile.PL	2001/08/13 04:12:28
***************
*** 64,66 ****
--- 64,77 ----
];
}
+ sub MY::dynamic_lib {
+       package MY;
+       my $inherited= shift->SUPER::dynamic_lib(@_);
+       if (! -d $ENV{POSTGRES_LIB} ) {
+        my $cwd = `pwd`;
+       chop $cwd;
+       $ENV{POSTGRES_LIB} = "$cwd/../libpq";
+       }
+       $inherited=~ s@OTHERLDFLAGS =@OTHERLDFLAGS =-R$ENV{POSTGRES_LIB}@;
+       $inherited;
+ }

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

---------------------------(end of broadcast)---------------------------
TIP 2: you can get off all lists at once with the unregister command
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)

-- 
  Bruce Momjian                        |  http://candle.pha.pa.us
  pgman@candle.pha.pa.us               |  (610) 853-3000
  +  If your life is a hard drive,     |  830 Blythe Avenue
  +  Christ can be your backup.        |  Drexel Hill, Pennsylvania 19026
#17Larry Rosenman
ler@lerctr.org
In reply to: Bruce Momjian (#16)
Re: Makefile.PL for Pg.so

I think peter_e dealt with this....

LER

* Bruce Momjian <pgman@candle.pha.pa.us> [010907 13:25]:

Can someone comment on this?

I made the following patch, and it works for MY platform.

Peter,
Can we do something similar for the distribution to set the
RUNPATH for Pg.so?

Index: Makefile.PL
===================================================================
RCS file: /home/projects/pgsql/cvsroot/pgsql/src/interfaces/perl5/Makefile.PL,v
retrieving revision 1.17
diff -c -r1.17 Makefile.PL
*** Makefile.PL	2001/03/06 22:07:09	1.17
--- Makefile.PL	2001/08/13 04:12:28
***************
*** 64,66 ****
--- 64,77 ----
];
}
+ sub MY::dynamic_lib {
+       package MY;
+       my $inherited= shift->SUPER::dynamic_lib(@_);
+       if (! -d $ENV{POSTGRES_LIB} ) {
+        my $cwd = `pwd`;
+       chop $cwd;
+       $ENV{POSTGRES_LIB} = "$cwd/../libpq";
+       }
+       $inherited=~ s@OTHERLDFLAGS =@OTHERLDFLAGS =-R$ENV{POSTGRES_LIB}@;
+       $inherited;
+ }

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

---------------------------(end of broadcast)---------------------------
TIP 2: you can get off all lists at once with the unregister command
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)

-- 
Bruce Momjian                        |  http://candle.pha.pa.us
pgman@candle.pha.pa.us               |  (610) 853-3000
+  If your life is a hard drive,     |  830 Blythe Avenue
+  Christ can be your backup.        |  Drexel Hill, Pennsylvania 19026

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

#18Bruce Momjian
pgman@candle.pha.pa.us
In reply to: Larry Rosenman (#17)
Re: Makefile.PL for Pg.so

Yes, thanks. Cleaning out my mailbox, as usualy before a beta.

I think peter_e dealt with this....

LER

* Bruce Momjian <pgman@candle.pha.pa.us> [010907 13:25]:

Can someone comment on this?

I made the following patch, and it works for MY platform.

Peter,
Can we do something similar for the distribution to set the
RUNPATH for Pg.so?

Index: Makefile.PL
===================================================================
RCS file: /home/projects/pgsql/cvsroot/pgsql/src/interfaces/perl5/Makefile.PL,v
retrieving revision 1.17
diff -c -r1.17 Makefile.PL
*** Makefile.PL	2001/03/06 22:07:09	1.17
--- Makefile.PL	2001/08/13 04:12:28
***************
*** 64,66 ****
--- 64,77 ----
];
}
+ sub MY::dynamic_lib {
+       package MY;
+       my $inherited= shift->SUPER::dynamic_lib(@_);
+       if (! -d $ENV{POSTGRES_LIB} ) {
+        my $cwd = `pwd`;
+       chop $cwd;
+       $ENV{POSTGRES_LIB} = "$cwd/../libpq";
+       }
+       $inherited=~ s@OTHERLDFLAGS =@OTHERLDFLAGS =-R$ENV{POSTGRES_LIB}@;
+       $inherited;
+ }

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

---------------------------(end of broadcast)---------------------------
TIP 2: you can get off all lists at once with the unregister command
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)

-- 
Bruce Momjian                        |  http://candle.pha.pa.us
pgman@candle.pha.pa.us               |  (610) 853-3000
+  If your life is a hard drive,     |  830 Blythe Avenue
+  Christ can be your backup.        |  Drexel Hill, Pennsylvania 19026

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

-- 
  Bruce Momjian                        |  http://candle.pha.pa.us
  pgman@candle.pha.pa.us               |  (610) 853-3000
  +  If your life is a hard drive,     |  830 Blythe Avenue
  +  Christ can be your backup.        |  Drexel Hill, Pennsylvania 19026
#19Peter Eisentraut
peter_e@gmx.net
In reply to: Bruce Momjian (#16)
Re: [PATCHES] Makefile.PL for Pg.so

Bruce Momjian writes:

Can someone comment on this?

It's done.

I made the following patch, and it works for MY platform.

Peter,
Can we do something similar for the distribution to set the
RUNPATH for Pg.so?

Index: Makefile.PL
===================================================================
RCS file: /home/projects/pgsql/cvsroot/pgsql/src/interfaces/perl5/Makefile.PL,v
retrieving revision 1.17
diff -c -r1.17 Makefile.PL
*** Makefile.PL	2001/03/06 22:07:09	1.17
--- Makefile.PL	2001/08/13 04:12:28
***************
*** 64,66 ****
--- 64,77 ----
];
}
+ sub MY::dynamic_lib {
+       package MY;
+       my $inherited= shift->SUPER::dynamic_lib(@_);
+       if (! -d $ENV{POSTGRES_LIB} ) {
+        my $cwd = `pwd`;
+       chop $cwd;
+       $ENV{POSTGRES_LIB} = "$cwd/../libpq";
+       }
+       $inherited=~ s@OTHERLDFLAGS =@OTHERLDFLAGS =-R$ENV{POSTGRES_LIB}@;
+       $inherited;
+ }

--
Larry Rosenman http://www.lerctr.org/~ler
Phone: +1 972-414-9812 E-Mail: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

---------------------------(end of broadcast)---------------------------
TIP 2: you can get off all lists at once with the unregister command
(send "unregister YourEmailAddressHere" to majordomo@postgresql.org)

--
Peter Eisentraut peter_e@gmx.net http://funkturm.homeip.net/~peter