postgresql/postgresql.patch

Tue, 29 Mar 2011 20:04:34 +0200

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Tue, 29 Mar 2011 20:04:34 +0200
changeset 334
4a34d7a82eab
child 699
da76d565ccd3
permissions
-rw-r--r--

Rework package yet again, correcting and introducing new buildconf logic:
Conditionally disable bootstrap stage comparison correctly, correct
english grammar, better find system as(1) and ld(1), indotruce detailed
optimization option messages, more completely guess cpu types, allow
profiled bootstrapping without a preinstalled GCC because many other
compilers have long since implemented 64-bit arithmetic, instruct make
to build sequentially (not in sparallel) when building a profiled
bootstrap as GCC online documents recommend, and generally improve
comment blocks.

The single most important correction in this changeset relates to the
GCC changed optimization policy since at least GCC 4.5, in which -march
is always passed and not always correctly guessed. In the case of this
package, allowing GCC to guess the architecture leads to wild build
errors at various subcomponents (zlib, libgcc, libiberty...) and
bootstrap stages. It seems quite platform specific, and the safest
approach to correcting this seems to be explicitly always specifying the
-march argument when bootstrapping GCC. Because the best choice 'native'
is not available when bootstrapping using a foreign (non GCC) compiler,
a guess is made according to rpmmacros l_platform in that case.

It is questionable as to whether these recent optimization changes
on the part of GCC or this package are compatible with each other,
or if either are complete or correct at all. At least applying these
corrections allows this package to build again in most cases test.

michael@300 1 Index: src/Makefile.shlib
michael@300 2 --- src/Makefile.shlib.orig 2010-07-06 05:55:33.000000000 +0200
michael@300 3 +++ src/Makefile.shlib 2010-09-21 08:58:56.000000000 +0200
michael@300 4 @@ -329,7 +329,7 @@
michael@300 5
michael@300 6 .PHONY: all-lib all-static-lib all-shared-lib
michael@300 7
michael@300 8 -all-lib: all-shared-lib
michael@300 9 +all-lib:
michael@300 10 ifdef soname
michael@300 11 # no static library when building a dynamically loadable module
michael@300 12 all-lib: all-static-lib
michael@300 13 Index: src/backend/Makefile
michael@300 14 --- src/backend/Makefile.orig 2010-07-05 20:54:37.000000000 +0200
michael@300 15 +++ src/backend/Makefile 2010-09-21 08:58:56.000000000 +0200
michael@300 16 @@ -41,7 +41,7 @@
michael@300 17 LIBS := $(filter-out -lpgport, $(LIBS)) $(LDAP_LIBS_BE)
michael@300 18
michael@300 19 # The backend doesn't need everything that's in LIBS, however
michael@300 20 -LIBS := $(filter-out -lz -lreadline -ledit -ltermcap -lncurses -lcurses, $(LIBS))
michael@300 21 +LIBS := $(filter-out -lreadline -ledit -ltermcap -lncurses -lcurses, $(LIBS))
michael@300 22
michael@300 23 ##########################################################################
michael@300 24
michael@300 25 Index: src/include/port.h
michael@300 26 --- src/include/port.h.orig 2010-05-15 16:44:13.000000000 +0200
michael@300 27 +++ src/include/port.h 2010-09-21 08:58:56.000000000 +0200
michael@300 28 @@ -374,7 +374,7 @@
michael@300 29 extern int getopt(int nargc, char *const * nargv, const char *ostr);
michael@300 30 #endif
michael@300 31
michael@300 32 -#ifndef HAVE_ISINF
michael@300 33 +#if !defined(HAVE_ISINF) && !defined(__FreeBSD__)
michael@300 34 extern int isinf(double x);
michael@300 35 #endif
michael@300 36
michael@300 37 Index: src/makefiles/Makefile.freebsd
michael@300 38 --- src/makefiles/Makefile.freebsd.orig 2010-07-05 20:54:38.000000000 +0200
michael@300 39 +++ src/makefiles/Makefile.freebsd 2010-09-21 09:00:42.000000000 +0200
michael@300 40 @@ -17,7 +17,7 @@
michael@300 41 # Rule for building a shared library from a single .o file
michael@300 42 %.so: %.o
michael@300 43 ifdef ELF_SYSTEM
michael@300 44 - $(CC) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SL) -shared -o $@ $<
michael@300 45 + $(CC) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SL) -shared -o $@ $< $(SHLIB_LINK)
michael@300 46 else
michael@300 47 $(LD) $(LDREL) $(LDOUT) $<.obj -x $<
michael@300 48 @echo building shared object $@
michael@300 49 Index: src/makefiles/Makefile.linux
michael@300 50 --- src/makefiles/Makefile.linux.orig 2010-07-05 20:54:38.000000000 +0200
michael@300 51 +++ src/makefiles/Makefile.linux 2010-09-21 09:01:01.000000000 +0200
michael@300 52 @@ -14,4 +14,4 @@
michael@300 53
michael@300 54 # Rule for building a shared library from a single .o file
michael@300 55 %.so: %.o
michael@300 56 - $(CC) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SL) -shared -o $@ $<
michael@300 57 + $(CC) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SL) -shared -o $@ $< $(SHLIB_LINK)
michael@300 58 Index: src/makefiles/Makefile.solaris
michael@300 59 --- src/makefiles/Makefile.solaris.orig 2010-07-05 20:54:38.000000000 +0200
michael@300 60 +++ src/makefiles/Makefile.solaris 2010-09-21 09:01:22.000000000 +0200
michael@300 61 @@ -19,9 +19,9 @@
michael@300 62 # Rule for building a shared library from a single .o file
michael@300 63 %.so: %.o
michael@300 64 ifeq ($(GCC), yes)
michael@300 65 - $(CC) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SL) -shared -o $@ $<
michael@300 66 + $(CC) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SL) -shared -o $@ $< $(SHLIB_LINK)
michael@300 67 else
michael@300 68 - $(CC) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SL) -G -o $@ $<
michael@300 69 + $(CC) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SL) -G -o $@ $< $(SHLIB_LINK)
michael@300 70 endif
michael@300 71
michael@300 72 sqlmansect = 5sql

mercurial