diff options
Diffstat (limited to 'src/backend/Makefile')
-rw-r--r-- | src/backend/Makefile | 325 |
1 files changed, 325 insertions, 0 deletions
diff --git a/src/backend/Makefile b/src/backend/Makefile new file mode 100644 index 0000000..0da848b --- /dev/null +++ b/src/backend/Makefile @@ -0,0 +1,325 @@ +#------------------------------------------------------------------------- +# +# Makefile for the postgres backend +# +# Portions Copyright (c) 1996-2021, PostgreSQL Global Development Group +# Portions Copyright (c) 1994, Regents of the University of California +# +# src/backend/Makefile +# +#------------------------------------------------------------------------- + +PGFILEDESC = "PostgreSQL Server" +# This is a daemon process, which is why it is not labeled as an executable +#PGAPPICON=win32 + +subdir = src/backend +top_builddir = ../.. +include $(top_builddir)/src/Makefile.global + +SUBDIRS = access bootstrap catalog parser commands executor foreign lib libpq \ + main nodes optimizer partitioning port postmaster \ + regex replication rewrite \ + statistics storage tcop tsearch utils $(top_builddir)/src/timezone \ + jit + +include $(srcdir)/common.mk + +# As of 1/2010: +# The probes.o file is necessary for dtrace support on Solaris, and on recent +# versions of systemtap. (Older systemtap releases just produce an empty +# file, but that's okay.) However, macOS's dtrace doesn't use it and doesn't +# even recognize the -G option. So, build probes.o except on macOS. +# This might need adjustment as other platforms add dtrace support. +ifneq ($(PORTNAME), darwin) +ifeq ($(enable_dtrace), yes) +LOCALOBJS += utils/probes.o +endif +endif + +OBJS = \ + $(LOCALOBJS) \ + $(SUBDIROBJS) \ + $(top_builddir)/src/common/libpgcommon_srv.a \ + $(top_builddir)/src/port/libpgport_srv.a + +# We put libpgport and libpgcommon into OBJS, so remove it from LIBS; also add +# libldap and ICU +LIBS := $(filter-out -lpgport -lpgcommon, $(LIBS)) $(LDAP_LIBS_BE) $(ICU_LIBS) + +# The backend doesn't need everything that's in LIBS, however +LIBS := $(filter-out -lz -lreadline -ledit -ltermcap -lncurses -lcurses, $(LIBS)) + +ifeq ($(with_systemd),yes) +LIBS += -lsystemd +endif + +########################################################################## + +all: submake-libpgport submake-catalog-headers submake-utils-headers postgres $(POSTGRES_IMP) + +ifneq ($(PORTNAME), cygwin) +ifneq ($(PORTNAME), win32) +ifneq ($(PORTNAME), aix) + +postgres: $(OBJS) + $(CC) $(CFLAGS) $(call expand_subsys,$^) $(LDFLAGS) $(LDFLAGS_EX) $(export_dynamic) $(LIBS) -o $@ + +endif +endif +endif + +ifeq ($(PORTNAME), cygwin) + +postgres: $(OBJS) + $(CC) $(CFLAGS) $(call expand_subsys,$^) $(LDFLAGS) $(LDFLAGS_EX) $(export_dynamic) -Wl,--stack,$(WIN32_STACK_RLIMIT) -Wl,--export-all-symbols -Wl,--out-implib=libpostgres.a $(LIBS) -o $@ + +# libpostgres.a is actually built in the preceding rule, but we need this to +# ensure it's newer than postgres; see notes in src/backend/parser/Makefile +libpostgres.a: postgres + touch $@ + +endif # cygwin + +ifeq ($(PORTNAME), win32) +LIBS += -lsecur32 + +postgres: $(OBJS) $(WIN32RES) + $(CC) $(CFLAGS) $(call expand_subsys,$(OBJS)) $(WIN32RES) $(LDFLAGS) $(LDFLAGS_EX) -Wl,--stack=$(WIN32_STACK_RLIMIT) -Wl,--export-all-symbols -Wl,--out-implib=libpostgres.a $(LIBS) -o $@$(X) + +# libpostgres.a is actually built in the preceding rule, but we need this to +# ensure it's newer than postgres; see notes in src/backend/parser/Makefile +libpostgres.a: postgres + touch $@ + +endif # win32 + +ifeq ($(PORTNAME), aix) + +postgres: $(POSTGRES_IMP) + $(CC) $(CFLAGS) $(call expand_subsys,$(OBJS)) $(LDFLAGS) $(LDFLAGS_EX) -Wl,-bE:$(top_builddir)/src/backend/$(POSTGRES_IMP) $(LIBS) -Wl,-brtllib -o $@ + +$(POSTGRES_IMP): $(OBJS) + $(LD) $(LDREL) $(LDOUT) SUBSYS.o $(call expand_subsys,$^) +ifeq ($(host_os), aix3.2.5) + $(MKLDEXPORT) SUBSYS.o $(bindir)/postgres > $@ +else +ifneq (,$(findstring aix4.1, $(host_os))) + $(MKLDEXPORT) SUBSYS.o $(bindir)/postgres > $@ +else + $(MKLDEXPORT) SUBSYS.o . > $@ +endif +endif + @rm -f SUBSYS.o + +endif # aix + +$(top_builddir)/src/port/libpgport_srv.a: | submake-libpgport + + +# The postgres.o target is needed by the rule in Makefile.global that +# creates the exports file when MAKE_EXPORTS = true. +postgres.o: $(OBJS) + $(CC) $(LDREL) $(call expand_subsys,$^) $(LDFLAGS) $(LDFLAGS_EX) $(LIBS) -o $@ + + +# The following targets are specified in make commands that appear in +# the make files in our subdirectories. Note that it's important we +# match the dependencies shown in the subdirectory makefiles! +# Also, in cases where a subdirectory makefile generates two files in +# what's really one step, such as bison producing both gram.h and gram.c, +# we must request making the one that is shown as the secondary (dependent) +# output, else the timestamp on it might be wrong. By project convention, +# the .h file is the dependent one for bison output, so we need only request +# that; but in other cases, request both for safety. + +parser/gram.h: parser/gram.y + $(MAKE) -C parser gram.h + +storage/lmgr/lwlocknames.h: storage/lmgr/generate-lwlocknames.pl storage/lmgr/lwlocknames.txt + $(MAKE) -C storage/lmgr lwlocknames.h lwlocknames.c + +# run this unconditionally to avoid needing to know its dependencies here: +submake-catalog-headers: + $(MAKE) -C catalog distprep generated-header-symlinks + +# run this unconditionally to avoid needing to know its dependencies here: +submake-utils-headers: + $(MAKE) -C utils distprep generated-header-symlinks + +.PHONY: submake-catalog-headers submake-utils-headers + +# Make symlinks for these headers in the include directory. That way +# we can cut down on the -I options. Also, a symlink is automatically +# up to date when we update the base file. +# +# The point of the prereqdir incantation in some of the rules below is to +# force the symlink to use an absolute path rather than a relative path. +# For headers which are generated by make distprep, the actual header within +# src/backend will be in the source tree, while the symlink in src/include +# will be in the build tree, so a simple ../.. reference won't work. +# For headers generated during regular builds, we prefer a relative symlink. + +.PHONY: generated-headers + +generated-headers: $(top_builddir)/src/include/parser/gram.h $(top_builddir)/src/include/storage/lwlocknames.h submake-catalog-headers submake-utils-headers + +$(top_builddir)/src/include/parser/gram.h: parser/gram.h + prereqdir=`cd '$(dir $<)' >/dev/null && pwd` && \ + cd '$(dir $@)' && rm -f $(notdir $@) && \ + $(LN_S) "$$prereqdir/$(notdir $<)" . + +$(top_builddir)/src/include/storage/lwlocknames.h: storage/lmgr/lwlocknames.h + prereqdir=`cd '$(dir $<)' >/dev/null && pwd` && \ + cd '$(dir $@)' && rm -f $(notdir $@) && \ + $(LN_S) "$$prereqdir/$(notdir $<)" . + +utils/probes.o: utils/probes.d $(SUBDIROBJS) + $(DTRACE) $(DTRACEFLAGS) -C -G -s $(call expand_subsys,$^) -o $@ + + +########################################################################## + +# Be sure that these files get removed by the maintainer-clean target +distprep: + $(MAKE) -C parser gram.c gram.h scan.c + $(MAKE) -C bootstrap bootparse.c bootscanner.c + $(MAKE) -C catalog distprep + $(MAKE) -C replication repl_gram.c repl_scanner.c syncrep_gram.c syncrep_scanner.c + $(MAKE) -C storage/lmgr lwlocknames.h lwlocknames.c + $(MAKE) -C utils distprep + $(MAKE) -C utils/adt jsonpath_gram.c jsonpath_scan.c + $(MAKE) -C utils/misc guc-file.c + + +########################################################################## + +install: all installdirs install-bin +ifeq ($(PORTNAME), cygwin) +ifeq ($(MAKE_DLL), true) + $(INSTALL_DATA) libpostgres.a '$(DESTDIR)$(libdir)/libpostgres.a' +endif +endif +ifeq ($(PORTNAME), win32) +ifeq ($(MAKE_DLL), true) + $(INSTALL_DATA) libpostgres.a '$(DESTDIR)$(libdir)/libpostgres.a' +endif +endif + $(MAKE) -C catalog install-data + $(MAKE) -C tsearch install-data + $(MAKE) -C utils install-data + $(INSTALL_DATA) $(srcdir)/libpq/pg_hba.conf.sample '$(DESTDIR)$(datadir)/pg_hba.conf.sample' + $(INSTALL_DATA) $(srcdir)/libpq/pg_ident.conf.sample '$(DESTDIR)$(datadir)/pg_ident.conf.sample' + $(INSTALL_DATA) $(srcdir)/utils/misc/postgresql.conf.sample '$(DESTDIR)$(datadir)/postgresql.conf.sample' + +ifeq ($(with_llvm), yes) +install-bin: install-postgres-bitcode + +install-postgres-bitcode: $(OBJS) all + $(call install_llvm_module,postgres,$(call expand_subsys, $(filter-out $(top_builddir)/src/timezone/objfiles.txt, $(SUBDIROBJS)))) +endif + +install-bin: postgres $(POSTGRES_IMP) installdirs + $(INSTALL_PROGRAM) postgres$(X) '$(DESTDIR)$(bindir)/postgres$(X)' +ifneq ($(PORTNAME), win32) + @rm -f '$(DESTDIR)$(bindir)/postmaster$(X)' + ln -s postgres$(X) '$(DESTDIR)$(bindir)/postmaster$(X)' +else + $(INSTALL_PROGRAM) postgres$(X) '$(DESTDIR)$(bindir)/postmaster$(X)' +endif +ifeq ($(MAKE_EXPORTS), true) + $(INSTALL_DATA) $(POSTGRES_IMP) '$(DESTDIR)$(pkglibdir)/$(POSTGRES_IMP)' + $(INSTALL_PROGRAM) $(MKLDEXPORT) '$(DESTDIR)$(pgxsdir)/$(MKLDEXPORT_DIR)/mkldexport.sh' +endif + +.PHONY: install-bin + +installdirs: + $(MKDIR_P) '$(DESTDIR)$(bindir)' '$(DESTDIR)$(datadir)' +ifeq ($(PORTNAME), cygwin) +ifeq ($(MAKE_DLL), true) + $(MKDIR_P) '$(DESTDIR)$(libdir)' +endif +endif +ifeq ($(PORTNAME), win32) +ifeq ($(MAKE_DLL), true) + $(MKDIR_P) '$(DESTDIR)$(libdir)' +endif +endif +ifeq ($(MAKE_EXPORTS), true) + $(MKDIR_P) '$(DESTDIR)$(pkglibdir)' + $(MKDIR_P) '$(DESTDIR)$(pgxsdir)/$(MKLDEXPORT_DIR)' +endif + + +########################################################################## + +uninstall: + rm -f '$(DESTDIR)$(bindir)/postgres$(X)' '$(DESTDIR)$(bindir)/postmaster' +ifeq ($(MAKE_EXPORTS), true) + rm -f '$(DESTDIR)$(pkglibdir)/$(POSTGRES_IMP)' + rm -f '$(DESTDIR)$(pgxsdir)/$(MKLDEXPORT_DIR)/mkldexport.sh' +endif +ifeq ($(PORTNAME), cygwin) +ifeq ($(MAKE_DLL), true) + rm -f '$(DESTDIR)$(libdir)/libpostgres.a' +endif +endif +ifeq ($(PORTNAME), win32) +ifeq ($(MAKE_DLL), true) + rm -f '$(DESTDIR)$(libdir)/libpostgres.a' +endif +endif + $(MAKE) -C catalog uninstall-data + $(MAKE) -C tsearch uninstall-data + $(MAKE) -C utils uninstall-data + rm -f '$(DESTDIR)$(datadir)/pg_hba.conf.sample' \ + '$(DESTDIR)$(datadir)/pg_ident.conf.sample' \ + '$(DESTDIR)$(datadir)/postgresql.conf.sample' +ifeq ($(with_llvm), yes) + $(call uninstall_llvm_module,postgres) +endif + + +########################################################################## + +clean: + rm -f $(LOCALOBJS) postgres$(X) $(POSTGRES_IMP) +ifeq ($(PORTNAME), cygwin) + rm -f postgres.dll libpostgres.a +endif +ifeq ($(PORTNAME), win32) + rm -f postgres.dll libpostgres.a $(WIN32RES) +endif + +distclean: clean + rm -f port/tas.s port/pg_sema.c port/pg_shmem.c + +maintainer-clean: distclean + $(MAKE) -C catalog $@ + $(MAKE) -C utils $@ + rm -f bootstrap/bootparse.c \ + bootstrap/bootscanner.c \ + parser/gram.c \ + parser/gram.h \ + parser/scan.c \ + replication/repl_gram.c \ + replication/repl_scanner.c \ + replication/syncrep_gram.c \ + replication/syncrep_scanner.c \ + storage/lmgr/lwlocknames.c \ + storage/lmgr/lwlocknames.h \ + utils/adt/jsonpath_gram.c \ + utils/adt/jsonpath_scan.c \ + utils/misc/guc-file.c + + +########################################################################## +# +# Support for code development. +# +# Use target "quick" to build "postgres" when you know all the subsystems +# are up to date. It saves the time of doing all the submakes. +.PHONY: quick +quick: $(OBJS) + $(CC) $(CFLAGS) $(call expand_subsys,$^) $(LDFLAGS) $(LDFLAGS_EX) $(export_dynamic) $(LIBS) -o postgres |