mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Don't put library-supplied -L/-I switches before user-supplied ones.
For many optional libraries, we extract the -L and -l switches needed
to link the library from a helper program such as llvm-config.  In
some cases we put the resulting -L switches into LDFLAGS ahead of
-L switches specified via --with-libraries.  That risks breaking
the user's intention for --with-libraries.
It's not such a problem if the library's -L switch points to a
directory containing only that library, but on some platforms a
library helper may "helpfully" offer a switch such as -L/usr/lib
that points to a directory holding all standard libraries.  If the
user specified --with-libraries in hopes of overriding the standard
build of some library, the -L/usr/lib switch prevents that from
happening since it will come before the user-specified directory.
To fix, avoid inserting these switches directly into LDFLAGS during
configure, instead adding them to LIBDIRS or SHLIB_LINK.  They will
still eventually get added to LDFLAGS, but only after the switches
coming from --with-libraries.
The same problem exists for -I switches: those coming from
--with-includes should appear before any coming from helper programs
such as llvm-config.  We have not heard field complaints about this
case, but it seems certain that a user attempting to override a
standard library could have issues.
The changes for this go well beyond configure itself, however,
because many Makefiles have occasion to manipulate CPPFLAGS to
insert locally-desirable -I switches, and some of them got it wrong.
The correct ordering is any -I switches pointing at within-the-
source-tree-or-build-tree directories, then those from the tree-wide
CPPFLAGS, then those from helper programs.  There were several places
that risked pulling in a system-supplied copy of libpq headers, for
example, instead of the in-tree files.  (Commit cb36f8ec2 fixed one
instance of that a few months ago, but this exercise found more.)
The Meson build scripts may or may not have any comparable problems,
but I'll leave it to someone else to investigate that.
Reported-by: Charles Samborski <demurgos@demurgos.net>
Author: Tom Lane <tgl@sss.pgh.pa.us>
Discussion: https://postgr.es/m/70f2155f-27ca-4534-b33d-7750e20633d7@demurgos.net
Backpatch-through: 13
			
			
This commit is contained in:
		| @@ -4,7 +4,7 @@ | ||||
| # ----------------- | ||||
| # | ||||
| # Look for the LLVM installation, check that it's new enough, set the | ||||
| # corresponding LLVM_{CFLAGS,CXXFLAGS,BINPATH} and LDFLAGS | ||||
| # corresponding LLVM_{CFLAGS,CXXFLAGS,BINPATH,LIBS} | ||||
| # variables. Also verify that CLANG is available, to transform C | ||||
| # into bitcode. | ||||
| # | ||||
| @@ -55,7 +55,7 @@ AC_DEFUN([PGAC_LLVM_SUPPORT], | ||||
|  | ||||
|   for pgac_option in `$LLVM_CONFIG --ldflags`; do | ||||
|     case $pgac_option in | ||||
|       -L*) LDFLAGS="$LDFLAGS $pgac_option";; | ||||
|       -L*) LLVM_LIBS="$LLVM_LIBS $pgac_option";; | ||||
|     esac | ||||
|   done | ||||
|  | ||||
|   | ||||
							
								
								
									
										16
									
								
								configure
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								configure
									
									
									
									
										vendored
									
									
								
							| @@ -5158,7 +5158,7 @@ fi | ||||
|  | ||||
|   for pgac_option in `$LLVM_CONFIG --ldflags`; do | ||||
|     case $pgac_option in | ||||
|       -L*) LDFLAGS="$LDFLAGS $pgac_option";; | ||||
|       -L*) LLVM_LIBS="$LLVM_LIBS $pgac_option";; | ||||
|     esac | ||||
|   done | ||||
|  | ||||
| @@ -9191,12 +9191,12 @@ fi | ||||
|   # Note the user could also set XML2_CFLAGS/XML2_LIBS directly | ||||
|   for pgac_option in $XML2_CFLAGS; do | ||||
|     case $pgac_option in | ||||
|       -I*|-D*) CPPFLAGS="$CPPFLAGS $pgac_option";; | ||||
|       -I*|-D*) INCLUDES="$INCLUDES $pgac_option";; | ||||
|     esac | ||||
|   done | ||||
|   for pgac_option in $XML2_LIBS; do | ||||
|     case $pgac_option in | ||||
|       -L*) LDFLAGS="$LDFLAGS $pgac_option";; | ||||
|       -L*) LIBDIRS="$LIBDIRS $pgac_option";; | ||||
|     esac | ||||
|   done | ||||
| fi | ||||
| @@ -9421,12 +9421,12 @@ fi | ||||
|   # note that -llz4 will be added by AC_CHECK_LIB below. | ||||
|   for pgac_option in $LZ4_CFLAGS; do | ||||
|     case $pgac_option in | ||||
|       -I*|-D*) CPPFLAGS="$CPPFLAGS $pgac_option";; | ||||
|       -I*|-D*) INCLUDES="$INCLUDES $pgac_option";; | ||||
|     esac | ||||
|   done | ||||
|   for pgac_option in $LZ4_LIBS; do | ||||
|     case $pgac_option in | ||||
|       -L*) LDFLAGS="$LDFLAGS $pgac_option";; | ||||
|       -L*) LIBDIRS="$LIBDIRS $pgac_option";; | ||||
|     esac | ||||
|   done | ||||
| fi | ||||
| @@ -17349,7 +17349,7 @@ _ACEOF | ||||
|  | ||||
| if test "$with_icu" = yes; then | ||||
|   ac_save_CPPFLAGS=$CPPFLAGS | ||||
|   CPPFLAGS="$ICU_CFLAGS $CPPFLAGS" | ||||
|   CPPFLAGS="$CPPFLAGS $ICU_CFLAGS" | ||||
|  | ||||
|   # Verify we have ICU's header files | ||||
|   ac_fn_c_check_header_mongrel "$LINENO" "unicode/ucol.h" "ac_cv_header_unicode_ucol_h" "$ac_includes_default" | ||||
| @@ -19553,7 +19553,7 @@ Use --without-tcl to disable building PL/Tcl." "$LINENO" 5 | ||||
|     fi | ||||
|     # now that we have TCL_INCLUDE_SPEC, we can check for <tcl.h> | ||||
|     ac_save_CPPFLAGS=$CPPFLAGS | ||||
|     CPPFLAGS="$TCL_INCLUDE_SPEC $CPPFLAGS" | ||||
|     CPPFLAGS="$CPPFLAGS $TCL_INCLUDE_SPEC" | ||||
|     ac_fn_c_check_header_mongrel "$LINENO" "tcl.h" "ac_cv_header_tcl_h" "$ac_includes_default" | ||||
| if test "x$ac_cv_header_tcl_h" = xyes; then : | ||||
|  | ||||
| @@ -19622,7 +19622,7 @@ fi | ||||
| # check for <Python.h> | ||||
| if test "$with_python" = yes; then | ||||
|   ac_save_CPPFLAGS=$CPPFLAGS | ||||
|   CPPFLAGS="$python_includespec $CPPFLAGS" | ||||
|   CPPFLAGS="$CPPFLAGS $python_includespec" | ||||
|   ac_fn_c_check_header_mongrel "$LINENO" "Python.h" "ac_cv_header_Python_h" "$ac_includes_default" | ||||
| if test "x$ac_cv_header_Python_h" = xyes; then : | ||||
|  | ||||
|   | ||||
							
								
								
									
										14
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -1039,12 +1039,12 @@ if test "$with_libxml" = yes ; then | ||||
|   # Note the user could also set XML2_CFLAGS/XML2_LIBS directly | ||||
|   for pgac_option in $XML2_CFLAGS; do | ||||
|     case $pgac_option in | ||||
|       -I*|-D*) CPPFLAGS="$CPPFLAGS $pgac_option";; | ||||
|       -I*|-D*) INCLUDES="$INCLUDES $pgac_option";; | ||||
|     esac | ||||
|   done | ||||
|   for pgac_option in $XML2_LIBS; do | ||||
|     case $pgac_option in | ||||
|       -L*) LDFLAGS="$LDFLAGS $pgac_option";; | ||||
|       -L*) LIBDIRS="$LIBDIRS $pgac_option";; | ||||
|     esac | ||||
|   done | ||||
| fi | ||||
| @@ -1088,12 +1088,12 @@ if test "$with_lz4" = yes; then | ||||
|   # note that -llz4 will be added by AC_CHECK_LIB below. | ||||
|   for pgac_option in $LZ4_CFLAGS; do | ||||
|     case $pgac_option in | ||||
|       -I*|-D*) CPPFLAGS="$CPPFLAGS $pgac_option";; | ||||
|       -I*|-D*) INCLUDES="$INCLUDES $pgac_option";; | ||||
|     esac | ||||
|   done | ||||
|   for pgac_option in $LZ4_LIBS; do | ||||
|     case $pgac_option in | ||||
|       -L*) LDFLAGS="$LDFLAGS $pgac_option";; | ||||
|       -L*) LIBDIRS="$LIBDIRS $pgac_option";; | ||||
|     esac | ||||
|   done | ||||
| fi | ||||
| @@ -2016,7 +2016,7 @@ AC_CHECK_DECLS([strtoll, strtoull]) | ||||
|  | ||||
| if test "$with_icu" = yes; then | ||||
|   ac_save_CPPFLAGS=$CPPFLAGS | ||||
|   CPPFLAGS="$ICU_CFLAGS $CPPFLAGS" | ||||
|   CPPFLAGS="$CPPFLAGS $ICU_CFLAGS" | ||||
|  | ||||
|   # Verify we have ICU's header files | ||||
|   AC_CHECK_HEADER(unicode/ucol.h, [], | ||||
| @@ -2360,7 +2360,7 @@ Use --without-tcl to disable building PL/Tcl.]) | ||||
|     fi | ||||
|     # now that we have TCL_INCLUDE_SPEC, we can check for <tcl.h> | ||||
|     ac_save_CPPFLAGS=$CPPFLAGS | ||||
|     CPPFLAGS="$TCL_INCLUDE_SPEC $CPPFLAGS" | ||||
|     CPPFLAGS="$CPPFLAGS $TCL_INCLUDE_SPEC" | ||||
|     AC_CHECK_HEADER(tcl.h, [], [AC_MSG_ERROR([header file <tcl.h> is required for Tcl])]) | ||||
|     CPPFLAGS=$ac_save_CPPFLAGS | ||||
| fi | ||||
| @@ -2397,7 +2397,7 @@ fi | ||||
| # check for <Python.h> | ||||
| if test "$with_python" = yes; then | ||||
|   ac_save_CPPFLAGS=$CPPFLAGS | ||||
|   CPPFLAGS="$python_includespec $CPPFLAGS" | ||||
|   CPPFLAGS="$CPPFLAGS $python_includespec" | ||||
|   AC_CHECK_HEADER(Python.h, [], [AC_MSG_ERROR([header file <Python.h> is required for Python])]) | ||||
|   CPPFLAGS=$ac_save_CPPFLAGS | ||||
| fi | ||||
|   | ||||
| @@ -242,7 +242,7 @@ CPP = @CPP@ | ||||
| CPPFLAGS = @CPPFLAGS@ | ||||
| PG_SYSROOT = @PG_SYSROOT@ | ||||
|  | ||||
| override CPPFLAGS := $(ICU_CFLAGS) $(CPPFLAGS) | ||||
| override CPPFLAGS += $(ICU_CFLAGS) | ||||
|  | ||||
| ifdef PGXS | ||||
| override CPPFLAGS := -I$(includedir_server) -I$(includedir_internal) $(CPPFLAGS) | ||||
|   | ||||
| @@ -31,7 +31,7 @@ endif | ||||
| # All files in this directory use LLVM. | ||||
| CFLAGS += $(LLVM_CFLAGS) | ||||
| CXXFLAGS += $(LLVM_CXXFLAGS) | ||||
| override CPPFLAGS := $(LLVM_CPPFLAGS) $(CPPFLAGS) | ||||
| override CPPFLAGS += $(LLVM_CPPFLAGS) | ||||
| SHLIB_LINK += $(LLVM_LIBS) | ||||
|  | ||||
| # Because this module includes C++ files, we need to use a C++ | ||||
|   | ||||
| @@ -21,7 +21,7 @@ NAME= pq | ||||
| SO_MAJOR_VERSION= 5 | ||||
| SO_MINOR_VERSION= $(MAJORVERSION) | ||||
|  | ||||
| override CPPFLAGS :=  -DFRONTEND -DUNSAFE_STAT_OK -I$(srcdir) $(CPPFLAGS) -I$(top_builddir)/src/port -I$(top_srcdir)/src/port | ||||
| override CPPFLAGS := -DFRONTEND -DUNSAFE_STAT_OK -I$(srcdir) -I$(top_builddir)/src/port -I$(top_srcdir)/src/port $(CPPFLAGS) | ||||
| ifneq ($(PORTNAME), win32) | ||||
| override CFLAGS += $(PTHREAD_CFLAGS) | ||||
| endif | ||||
|   | ||||
| @@ -11,7 +11,7 @@ ifeq ($(PORTNAME), win32) | ||||
| override python_libspec = | ||||
| endif | ||||
|  | ||||
| override CPPFLAGS := -I. -I$(srcdir) $(python_includespec) $(CPPFLAGS) | ||||
| override CPPFLAGS := -I. -I$(srcdir) $(CPPFLAGS) $(python_includespec) | ||||
|  | ||||
| rpathdir = $(python_libdir) | ||||
|  | ||||
|   | ||||
| @@ -11,7 +11,7 @@ top_builddir = ../../.. | ||||
| include $(top_builddir)/src/Makefile.global | ||||
|  | ||||
|  | ||||
| override CPPFLAGS := -I. -I$(srcdir) $(TCL_INCLUDE_SPEC) $(CPPFLAGS) | ||||
| override CPPFLAGS := -I. -I$(srcdir) $(CPPFLAGS) $(TCL_INCLUDE_SPEC) | ||||
|  | ||||
| # On Windows, we don't link directly with the Tcl library; see below | ||||
| ifneq ($(PORTNAME), win32) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user