1################################################################################
2#
3# postgresql
4#
5################################################################################
6
7POSTGRESQL_VERSION = 16.3
8POSTGRESQL_SOURCE = postgresql-$(POSTGRESQL_VERSION).tar.bz2
9POSTGRESQL_SITE = https://ftp.postgresql.org/pub/source/v$(POSTGRESQL_VERSION)
10POSTGRESQL_LICENSE = PostgreSQL
11POSTGRESQL_LICENSE_FILES = COPYRIGHT
12POSTGRESQL_CPE_ID_VENDOR = postgresql
13POSTGRESQL_SELINUX_MODULES = postgresql
14POSTGRESQL_INSTALL_STAGING = YES
15POSTGRESQL_CONFIG_SCRIPTS = pg_config
16POSTGRESQL_CONF_ENV = \
17	ac_cv_type_struct_sockaddr_in6=yes \
18	pgac_cv_prog_cc_LDFLAGS_EX_BE__Wl___export_dynamic=yes \
19	LIBS=$(TARGET_NLS_LIBS)
20POSTGRESQL_CONF_OPTS = --disable-rpath
21POSTGRESQL_DEPENDENCIES = $(TARGET_NLS_DEPENDENCIES)
22
23# CVE-2017-8806 is related to postgresql-common package
24# It is false positive for postgresql
25POSTGRESQL_IGNORE_CVES += CVE-2017-8806
26
27# https://www.postgresql.org/docs/11/static/install-procedure.html:
28# "If you want to invoke the build from another makefile rather than
29# manually, you must unset MAKELEVEL or set it to zero"
30POSTGRESQL_MAKE_OPTS = MAKELEVEL=0
31
32ifeq ($(BR2_PACKAGE_POSTGRESQL_FULL),y)
33POSTGRESQL_MAKE_OPTS += world
34POSTGRESQL_INSTALL_TARGET_OPTS += DESTDIR=$(TARGET_DIR) install-world
35POSTGRESQL_INSTALL_STAGING_OPTS += DESTDIR=$(STAGING_DIR) install-world
36endif
37
38ifeq ($(BR2_TOOLCHAIN_USES_UCLIBC),y)
39# PostgreSQL does not build against uClibc with locales
40# enabled, due to an uClibc bug, see
41# http://lists.uclibc.org/pipermail/uclibc/2014-April/048326.html
42# so overwrite automatic detection and disable locale support
43POSTGRESQL_CONF_ENV += pgac_cv_type_locale_t=no
44endif
45
46ifneq ($(BR2_TOOLCHAIN_HAS_THREADS_NPTL),y)
47POSTGRESQL_CONF_OPTS += --disable-thread-safety
48endif
49
50ifeq ($(BR2_arcle)$(BR2_arceb)$(BR2_microblazeel)$(BR2_microblazebe)$(BR2_or1k)$(BR2_nios2)$(BR2_riscv)$(BR2_xtensa),y)
51POSTGRESQL_CONF_OPTS += --disable-spinlocks
52endif
53
54ifeq ($(BR2_PACKAGE_READLINE),y)
55POSTGRESQL_DEPENDENCIES += readline
56else
57POSTGRESQL_CONF_OPTS += --without-readline
58endif
59
60ifeq ($(BR2_PACKAGE_ZLIB),y)
61POSTGRESQL_DEPENDENCIES += zlib
62else
63POSTGRESQL_CONF_OPTS += --without-zlib
64endif
65
66ifeq ($(BR2_PACKAGE_TZDATA),y)
67POSTGRESQL_DEPENDENCIES += tzdata
68POSTGRESQL_CONF_OPTS += --with-system-tzdata=/usr/share/zoneinfo
69else
70POSTGRESQL_DEPENDENCIES += host-zic
71POSTGRESQL_CONF_ENV += ZIC="$(ZIC)"
72endif
73
74ifeq ($(BR2_PACKAGE_OPENSSL),y)
75POSTGRESQL_DEPENDENCIES += openssl
76POSTGRESQL_CONF_OPTS += --with-openssl
77else
78# PostgreSQL checks for /dev/urandom and fails if it's being cross-compiled and
79# an SSL library isn't found. Since /dev/urandom is guaranteed to be provided
80# on Linux systems, explicitly tell the configure script it's available.
81POSTGRESQL_CONF_ENV += ac_cv_file__dev_urandom=yes
82endif
83
84ifeq ($(BR2_PACKAGE_OPENLDAP),y)
85POSTGRESQL_DEPENDENCIES += openldap
86POSTGRESQL_CONF_OPTS += --with-ldap
87else
88POSTGRESQL_CONF_OPTS += --without-ldap
89endif
90
91ifeq ($(BR2_PACKAGE_ICU),y)
92POSTGRESQL_DEPENDENCIES += icu
93POSTGRESQL_CONF_OPTS += --with-icu
94else
95POSTGRESQL_CONF_OPTS += --without-icu
96endif
97
98ifeq ($(BR2_PACKAGE_LIBXML2),y)
99POSTGRESQL_DEPENDENCIES += libxml2
100POSTGRESQL_CONF_OPTS += --with-libxml
101POSTGRESQL_CONF_ENV += XML2_CONFIG=$(STAGING_DIR)/usr/bin/xml2-config
102else
103POSTGRESQL_CONF_OPTS += --without-libxml
104endif
105
106ifeq ($(BR2_PACKAGE_ZSTD),y)
107POSTGRESQL_DEPENDENCIES += host-pkgconf zstd
108POSTGRESQL_CONF_OPTS += --with-zstd
109else
110POSTGRESQL_CONF_OPTS += --without-zstd
111endif
112
113ifeq ($(BR2_PACKAGE_LZ4),y)
114POSTGRESQL_DEPENDENCIES += host-pkgconf lz4
115POSTGRESQL_CONF_OPTS += --with-lz4
116else
117POSTGRESQL_CONF_OPTS += --without-lz4
118endif
119
120# required for postgresql.service Type=notify
121ifeq ($(BR2_PACKAGE_SYSTEMD),y)
122POSTGRESQL_DEPENDENCIES += systemd
123POSTGRESQL_CONF_OPTS += --with-systemd
124else
125POSTGRESQL_CONF_OPTS += --without-systemd
126endif
127
128POSTGRESQL_CFLAGS = $(TARGET_CFLAGS)
129
130ifneq ($(BR2_TOOLCHAIN_HAS_GCC_BUG_43744)$(BR2_TOOLCHAIN_HAS_GCC_BUG_85180),)
131POSTGRESQL_CFLAGS += -O0
132endif
133
134POSTGRESQL_CONF_ENV += CFLAGS="$(POSTGRESQL_CFLAGS)"
135
136define POSTGRESQL_USERS
137	postgres -1 postgres -1 * /var/lib/pgsql /bin/sh - PostgreSQL Server
138endef
139
140define POSTGRESQL_INSTALL_TARGET_FIXUP
141	$(INSTALL) -dm 0700 $(TARGET_DIR)/var/lib/pgsql
142	$(RM) -rf $(TARGET_DIR)/usr/lib/postgresql/pgxs
143endef
144
145POSTGRESQL_POST_INSTALL_TARGET_HOOKS += POSTGRESQL_INSTALL_TARGET_FIXUP
146
147define POSTGRESQL_INSTALL_CUSTOM_PG_CONFIG
148	$(INSTALL) -m 0755 -D package/postgresql/pg_config \
149		$(STAGING_DIR)/usr/bin/pg_config
150	$(SED) "s|@POSTGRESQL_CONF_OPTIONS@|$(POSTGRESQL_CONF_OPTS)|g" $(STAGING_DIR)/usr/bin/pg_config
151	$(SED) "s|@POSTGRESQL_VERSION@|$(POSTGRESQL_VERSION)|g" $(STAGING_DIR)/usr/bin/pg_config
152	$(SED) "s|@TARGET_CFLAGS@|$(TARGET_CFLAGS)|g" $(STAGING_DIR)/usr/bin/pg_config
153	$(SED) "s|@TARGET_CC@|$(TARGET_CC)|g" $(STAGING_DIR)/usr/bin/pg_config
154endef
155
156POSTGRESQL_POST_INSTALL_STAGING_HOOKS += POSTGRESQL_INSTALL_CUSTOM_PG_CONFIG
157
158define POSTGRESQL_INSTALL_INIT_SYSV
159	$(INSTALL) -m 0755 -D package/postgresql/S50postgresql \
160		$(TARGET_DIR)/etc/init.d/S50postgresql
161endef
162
163define POSTGRESQL_INSTALL_INIT_SYSTEMD
164	$(INSTALL) -D -m 644 package/postgresql/postgresql.service \
165		$(TARGET_DIR)/usr/lib/systemd/system/postgresql.service
166endef
167
168$(eval $(autotools-package))
169