# This GNU Makefile supports different OS and CPU combinations. # # You should use it this way : # [g]make TARGET=os ARCH=arch CPU=cpu USE_xxx=1 ... # # Valid USE_* options are the following. Most of them are automatically set by # the TARGET, others have to be explictly specified : # USE_CTTPROXY : enable CTTPROXY on Linux (needs kernel patch). # USE_DLMALLOC : enable use of dlmalloc (see DLMALLOC_SRC) # USE_EPOLL : enable epoll() on Linux 2.6. Automatic. # USE_GETSOCKNAME : enable getsockname() on Linux 2.2. Automatic. # USE_KQUEUE : enable kqueue() on BSD. Automatic. # USE_MY_EPOLL : redefine epoll_* syscalls. Automatic. # USE_NETFILTER : enable netfilter on Linux. Automatic. # USE_PCRE : enable use of libpcre for regex. Recommended. # USE_POLL : enable poll(). Automatic. # USE_REGPARM : enable regparm optimization. Recommended on x86. # USE_SEPOLL : enable speculative epoll(). Automatic. # USE_STATIC_PCRE : enable static libpcre. Recommended. # USE_TPROXY : enable transparent proxy. Automatic. # USE_LINUX_TPROXY : enable full transparent proxy (need kernel patch). # USE_LINUX_SPLICE : enable kernel 2.6 splicing (broken on old kernels) # # Options can be forced by specifying "USE_xxx=1" or can be disabled by using # "USE_xxx=" (empty string). # # Variables useful for packagers : # CC is set to "gcc" by default and is used for compilation only. # LD is set to "gcc" by default and is used for linking only. # ARCH may be useful to force build of 32-bit binary on 64-bit systems # CFLAGS is automatically set for the specified CPU and may be overridden. # LDFLAGS is automatically set to -g and may be overridden. # SMALL_OPTS may be used to specify some options to shrink memory usage. # DEBUG may be used to set some internal debugging options. # ADDINC may be used to complete the include path in the form -Ipath. # ADDLIB may be used to complete the library list in the form -Lpath -llib. # DEFINE may be used to specify any additional define, which will be reported # by "haproxy -vv" in CFLAGS. # SILENT_DEFINE may be used to specify other defines which will not be # reported by "haproxy -vv". # DESTDIR is not set by default and is used for installation only. # It might be useful to set DESTDIR if you want to install haproxy # in a sandbox. # PREFIX is set to "/usr/local" by default and is used for installation only. # SBINDIR is set to "$(PREFIX)/sbin" by default and is used for installation # only. # MANDIR is set to "$(PREFIX)/share/man" by default and is used for # installation only. # DOCDIR is set to "$(PREFIX)/doc/haproxy" by default and is used for # installation only. # # Other variables : # DLMALLOC_SRC : build with dlmalloc, indicate the location of dlmalloc.c. # DLMALLOC_THRES : should match PAGE_SIZE on every platform (default: 4096). # PCREDIR : force the path to libpcre. # IGNOREGIT : ignore GIT commit versions if set. # VERSION : force haproxy version reporting. # SUBVERS : add a sub-version (eg: platform, model, ...). # VERDATE : force haproxy's release date. #### Installation options. DESTDIR = PREFIX = /usr/local SBINDIR = $(PREFIX)/sbin MANDIR = $(PREFIX)/share/man DOCDIR = $(PREFIX)/doc/haproxy #### TARGET system # Use TARGET= to optimize for a specifc target OS among the # following list (use the default "generic" if uncertain) : # generic, linux22, linux24, linux24e, linux26, solaris, # freebsd, openbsd, cygwin, custom TARGET = #### TARGET CPU # Use CPU= to optimize for a particular CPU, among the following # list : # generic, i586, i686, ultrasparc, custom CPU = generic #### Architecture, used when not building for native architecture # Use ARCH= to force build for a specific architecture. Known # architectures will lead to "-m32" or "-m64" being added to CFLAGS and # LDFLAGS. This can be required to build 32-bit binaries on 64-bit targets. # Currently, only x86_64, i386, i486, i586 and i686 are understood. ARCH = #### Toolchain options. # GCC is normally used both for compiling and linking. CC = gcc LD = $(CC) #### Debug flags (typically "-g"). # Those flags only feed CFLAGS so it is not mandatory to use this form. DEBUG_CFLAGS = -g #### Memory usage tuning # If small memory footprint is required, you can reduce the buffer size. There # are 2 buffers per concurrent session, so 16 kB buffers will eat 32 MB memory # with 1000 concurrent sessions. Putting it slightly lower than a page size # will prevent the additional parameters to go beyond a page. 8030 bytes is # exactly 5.5 TCP segments of 1460 bytes and is generally good. Useful tuning # macros include : # SYSTEM_MAXCONN, BUFSIZE, MAXREWRITE, REQURI_LEN, CAPTURE_LEN. # Example: SMALL_OPTS = -DBUFSIZE=8030 -DMAXREWRITE=1030 -DSYSTEM_MAXCONN=1024 SMALL_OPTS = #### Debug settings # You can enable debugging on specific code parts by setting DEBUG=-DDEBUG_xxx. # Currently defined DEBUG macros include DEBUG_FULL, DEBUG_MEMORY, DEBUG_FSM, # and DEBUG_HASH. Please check sources for exact meaning or do not use at all. DEBUG = #### Additional include and library dirs # Redefine this if you want to add some special PATH to include/libs ADDINC = ADDLIB = #### Specific macro definitions # Use DEFINE=-Dxxx to set any tunable macro. Anything declared here will appear # in the build options reported by "haproxy -vv". Use SILENT_DEFINE if you do # not want to pollute the report with complex defines. DEFINE = SILENT_DEFINE = #### CPU dependant optimizations # Some CFLAGS are set by default depending on the target CPU. Those flags only # feed CPU_CFLAGS, which in turn feed CFLAGS, so it is not mandatory to use # them. You should not have to change these options. Better use CPU_CFLAGS or # even CFLAGS instead. CPU_CFLAGS.generic = -O2 CPU_CFLAGS.i586 = -O2 -march=i586 CPU_CFLAGS.i686 = -O2 -march=i686 CPU_CFLAGS.ultrasparc = -O6 -mcpu=v9 -mtune=ultrasparc CPU_CFLAGS = $(CPU_CFLAGS.$(CPU)) #### ARCH dependant flags, may be overriden by CPU flags ARCH_FLAGS.i386 = -m32 -march=i386 ARCH_FLAGS.i486 = -m32 -march=i486 ARCH_FLAGS.i586 = -m32 -march=i586 ARCH_FLAGS.i686 = -m32 -march=i686 ARCH_FLAGS.x86_64 = -m64 -march=x86-64 ARCH_FLAGS = $(ARCH_FLAGS.$(ARCH)) #### Common CFLAGS # These CFLAGS contain general optimization options, CPU-specific optimizations # and debug flags. They may be overridden by some distributions which prefer to # set all of them at once instead of playing with the CPU and DEBUG variables. CFLAGS = $(ARCH_FLAGS) $(CPU_CFLAGS) $(DEBUG_CFLAGS) #### Common LDFLAGS # These LDFLAGS are used as the first "ld" options, regardless of any library # path or any other option. They may be changed to add any linker-specific # option at the beginning of the ld command line. LDFLAGS = $(ARCH_FLAGS) -g #### Target system options # Depending on the target platform, some options are set, as well as some # CFLAGS and LDFLAGS. The USE_* values are set to "implicit" so that they are # not reported in the build options string. You should not have to change # anything there. ifeq ($(TARGET),generic) # generic system target has nothing specific USE_POLL = implicit USE_TPROXY = implicit else ifeq ($(TARGET),linux22) # This is for Linux 2.2 USE_GETSOCKNAME = implicit USE_POLL = implicit USE_TPROXY = implicit else ifeq ($(TARGET),linux24) # This is for standard Linux 2.4 with netfilter but without epoll() USE_GETSOCKNAME = implicit USE_NETFILTER = implicit USE_POLL = implicit USE_TPROXY = implicit else ifeq ($(TARGET),linux24e) # This is for enhanced Linux 2.4 with netfilter and epoll() patch > 0.21 USE_GETSOCKNAME = implicit USE_NETFILTER = implicit USE_POLL = implicit USE_EPOLL = implicit USE_SEPOLL = implicit USE_MY_EPOLL = implicit USE_TPROXY = implicit else ifeq ($(TARGET),linux26) # This is for standard Linux 2.6 with netfilter and standard epoll() USE_GETSOCKNAME = implicit USE_NETFILTER = implicit USE_POLL = implicit USE_EPOLL = implicit USE_SEPOLL = implicit USE_TPROXY = implicit else ifeq ($(TARGET),solaris) # This is for Solaris 8 USE_POLL = implicit TARGET_CFLAGS = -fomit-frame-pointer -DFD_SETSIZE=65536 -D_REENTRANT TARGET_LDFLAGS = -lnsl -lsocket USE_TPROXY = implicit else ifeq ($(TARGET),freebsd) # This is for FreeBSD USE_POLL = implicit USE_KQUEUE = implicit USE_TPROXY = implicit else ifeq ($(TARGET),openbsd) # This is for OpenBSD >= 3.0 USE_POLL = implicit USE_KQUEUE = implicit USE_TPROXY = implicit else ifeq ($(TARGET),cygwin) # This is for Cygwin # Cygwin adds IPv6 support only in version 1.7 (in beta right now). USE_POLL = implicit USE_TPROXY = implicit TARGET_CFLAGS = $(if $(filter 1.5.%, $(shell uname -r)), -DUSE_IPV6 -DAF_INET6=23 -DINET6_ADDRSTRLEN=46, ) endif # cygwin endif # openbsd endif # freebsd endif # solaris endif # linux26 endif # linux24e endif # linux24 endif # linux22 endif # generic #### Old-style REGEX library settings for compatibility with previous setups. # It is still possible to use REGEX= to select an alternative regex # library. By default, we use libc's regex. On Solaris 8/Sparc, grouping seems # to be broken using libc, so consider using pcre instead. Supported values are # "libc", "pcre", and "static-pcre". Use of this method is deprecated in favor # of "USE_PCRE" and "USE_STATIC_PCRE" (see build options below). REGEX = libc ifeq ($(REGEX),pcre) USE_PCRE = 1 $(warning WARNING! use of "REGEX=pcre" is deprecated, consider using "USE_PCRE=1" instead.) endif ifeq ($(REGEX),static-pcre) USE_STATIC_PCRE = 1 $(warning WARNING! use of "REGEX=pcre-static" is deprecated, consider using "USE_STATIC_PCRE=1" instead.) endif #### Old-style TPROXY settings ifneq ($(findstring -DTPROXY,$(DEFINE)),) USE_TPROXY = 1 $(warning WARNING! use of "DEFINE=-DTPROXY" is deprecated, consider using "USE_TPROXY=1" instead.) endif #### Determine version, sub-version and release date. # If GIT is found, and IGNOREGIT is not set, VERSION, SUBVERS and VERDATE are # extracted from the last commit. Otherwise, use the contents of the files # holding the same names in the current directory. ifeq ($(IGNOREGIT),) VERSION := $(shell [ -d .git/. ] && ref=`(git describe --tags) 2>/dev/null` && ref=$${ref%-g*} && echo "$${ref\#v}") ifneq ($(VERSION),) # OK git is there and works. SUBVERS := $(shell comms=`git log --no-merges v$(VERSION).. 2>/dev/null |grep -c ^commit `; [ $$comms -gt 0 ] && echo "-$$comms" ) VERDATE := $(shell date +%Y/%m/%d -d "`git log --pretty=fuller HEAD^.. 2>/dev/null | sed -ne '/^CommitDate:/{s/\(^[^ ]*:\)\|\( [-+].*\)//gp;q}'`" ) endif endif # Last commit version not found, take it from the files. ifeq ($(VERSION),) VERSION := $(shell cat VERSION 2>/dev/null || touch VERSION) endif ifeq ($(SUBVERS),) SUBVERS := $(shell cat SUBVERS 2>/dev/null || touch SUBVERS) endif ifeq ($(VERDATE),) VERDATE := $(shell cat VERDATE 2>/dev/null || touch VERDATE) endif #### Build options # Do not change these ones, enable USE_* variables instead. OPTIONS_CFLAGS = OPTIONS_LDFLAGS = OPTIONS_OBJS = # This variable collects all USE_* values except those set to "implicit". This # is used to report a list of all flags which were used to build this version. # Do not assign anything to it. BUILD_OPTIONS = # Return USE_xxx=$(USE_xxx) unless $(USE_xxx) = "implicit" # Usage: # BUILD_OPTIONS += $(call ignore_implicit,USE_xxx) ignore_implicit = $(patsubst %=implicit,,$(1)=$($(1))) ifneq ($(USE_TCPSPLICE),) $(error experimental option USE_TCPSPLICE has been removed, check USE_LINUX_SPLICE) endif ifneq ($(USE_LINUX_SPLICE),) OPTIONS_CFLAGS += -DCONFIG_HAP_LINUX_SPLICE BUILD_OPTIONS += $(call ignore_implicit,USE_LINUX_SPLICE) endif ifneq ($(USE_CTTPROXY),) OPTIONS_CFLAGS += -DCONFIG_HAP_CTTPROXY OPTIONS_OBJS += src/cttproxy.o BUILD_OPTIONS += $(call ignore_implicit,USE_CTTPROXY) endif ifneq ($(USE_TPROXY),) OPTIONS_CFLAGS += -DTPROXY BUILD_OPTIONS += $(call ignore_implicit,USE_TPROXY) endif ifneq ($(USE_LINUX_TPROXY),) OPTIONS_CFLAGS += -DCONFIG_HAP_LINUX_TPROXY BUILD_OPTIONS += $(call ignore_implicit,USE_LINUX_TPROXY) endif ifneq ($(USE_POLL),) OPTIONS_CFLAGS += -DENABLE_POLL OPTIONS_OBJS += src/ev_poll.o BUILD_OPTIONS += $(call ignore_implicit,USE_POLL) endif ifneq ($(USE_EPOLL),) OPTIONS_CFLAGS += -DENABLE_EPOLL OPTIONS_OBJS += src/ev_epoll.o BUILD_OPTIONS += $(call ignore_implicit,USE_EPOLL) endif ifneq ($(USE_SEPOLL),) OPTIONS_CFLAGS += -DENABLE_SEPOLL OPTIONS_OBJS += src/ev_sepoll.o BUILD_OPTIONS += $(call ignore_implicit,USE_SEPOLL) endif ifneq ($(USE_MY_EPOLL),) OPTIONS_CFLAGS += -DUSE_MY_EPOLL BUILD_OPTIONS += $(call ignore_implicit,USE_MY_EPOLL) endif ifneq ($(USE_KQUEUE),) OPTIONS_CFLAGS += -DENABLE_KQUEUE OPTIONS_OBJS += src/ev_kqueue.o BUILD_OPTIONS += $(call ignore_implicit,USE_KQUEUE) endif ifneq ($(USE_NETFILTER),) OPTIONS_CFLAGS += -DNETFILTER BUILD_OPTIONS += $(call ignore_implicit,USE_NETFILTER) endif ifneq ($(USE_GETSOCKNAME),) OPTIONS_CFLAGS += -DUSE_GETSOCKNAME BUILD_OPTIONS += $(call ignore_implicit,USE_GETSOCKNAME) endif ifneq ($(USE_REGPARM),) OPTIONS_CFLAGS += -DCONFIG_HAP_USE_REGPARM BUILD_OPTIONS += $(call ignore_implicit,USE_REGPARM) endif # report DLMALLOC_SRC only if explicitly specified ifneq ($(DLMALLOC_SRC),) BUILD_OPTIONS += DLMALLOC_SRC=$(DLMALLOC_SRC) endif ifneq ($(USE_DLMALLOC),) BUILD_OPTIONS += $(call ignore_implicit,USE_DLMALLOC) ifeq ($(DLMALLOC_SRC),) DLMALLOC_SRC=src/dlmalloc.c endif endif ifneq ($(DLMALLOC_SRC),) # DLMALLOC_THRES may be changed to match PAGE_SIZE on every platform DLMALLOC_THRES = 4096 OPTIONS_OBJS += src/dlmalloc.o endif ifneq ($(USE_PCRE),) # PCREDIR is the directory hosting include/pcre.h and lib/libpcre.*. It is # automatically detected but can be forced if required. ifeq ($(PCREDIR),) PCREDIR := $(shell pcre-config --prefix 2>/dev/null || echo /usr/local) endif ifeq ($(USE_STATIC_PCRE),) OPTIONS_CFLAGS += -DUSE_PCRE -I$(PCREDIR)/include OPTIONS_LDFLAGS += -L$(PCREDIR)/lib -lpcreposix -lpcre endif BUILD_OPTIONS += $(call ignore_implicit,USE_PCRE) endif ifneq ($(USE_STATIC_PCRE),) # PCREDIR is the directory hosting include/pcre.h and lib/libpcre.*. It is # automatically detected but can be forced if required. ifeq ($(PCREDIR),) PCREDIR := $(shell pcre-config --prefix 2>/dev/null || echo /usr/local) endif OPTIONS_CFLAGS += -DUSE_PCRE -I$(PCREDIR)/include OPTIONS_LDFLAGS += -L$(PCREDIR)/lib -Wl,-Bstatic -lpcreposix -lpcre -Wl,-Bdynamic BUILD_OPTIONS += $(call ignore_implicit,USE_STATIC_PCRE) endif #### Global compile options VERBOSE_CFLAGS = $(CFLAGS) $(TARGET_CFLAGS) $(SMALL_OPTS) $(DEFINE) COPTS = -Iinclude -Wall COPTS += $(CFLAGS) $(TARGET_CFLAGS) $(SMALL_OPTS) $(DEFINE) $(SILENT_DEFINE) COPTS += $(DEBUG) $(OPTIONS_CFLAGS) $(ADDINC) ifneq ($(VERSION)$(SUBVERS),) COPTS += -DCONFIG_HAPROXY_VERSION=\"$(VERSION)$(SUBVERS)\" endif ifneq ($(VERDATE),) COPTS += -DCONFIG_HAPROXY_DATE=\"$(VERDATE)\" endif #### Global link options # These options are added at the end of the "ld" command line. Use LDFLAGS to # add options at the beginning of the "ld" command line if needed. LDOPTS = $(TARGET_LDFLAGS) $(OPTIONS_LDFLAGS) $(ADDLIB) ifeq ($(TARGET),) all: @echo @echo "Due to too many reports of suboptimized setups, building without" @echo "specifying the target is no longer supported. Please specify the" @echo "target OS in the TARGET variable, in the following form:" @echo @echo " $ make TARGET=xxx" @echo @echo "Please choose the target among the following supported list :" @echo @echo " linux26, linux24, linux24e, linux22, solaris" @echo " freebsd, openbsd, cygwin, custom, generic" @echo @echo "Use \"generic\" if you don't want any optimization, \"custom\" if you" @echo "want to precisely tweak every option, or choose the target which" @echo "matches your OS the most in order to gain the maximum performance" @echo "out of it. Please check the Makefile in case of doubts." @echo @exit 1 else all: haproxy endif OBJS = src/haproxy.o src/sessionhash.o src/base64.o src/protocols.o \ src/uri_auth.o src/standard.o src/buffers.o src/log.o src/task.o \ src/time.o src/fd.o src/pipe.o src/regex.o src/cfgparse.o src/server.o \ src/checks.o src/queue.o src/client.o src/proxy.o src/proto_uxst.o \ src/proto_http.o src/stream_sock.o src/appsession.o src/backend.o \ src/stream_interface.o src/dumpstats.o src/proto_tcp.o \ src/session.o src/hdr_idx.o src/ev_select.o src/signal.o \ src/acl.o src/memory.o src/freq_ctr.o \ src/ebtree.o src/eb32tree.o haproxy: $(OBJS) $(OPTIONS_OBJS) $(LD) $(LDFLAGS) -o $@ $^ $(LDOPTS) objsize: haproxy @objdump -t $^|grep ' g '|grep -F '.text'|awk '{print $$5 FS $$6}'|sort %.o: %.c $(CC) $(COPTS) -c -o $@ $< src/haproxy.o: src/haproxy.c $(CC) $(COPTS) \ -DBUILD_TARGET='"$(strip $(TARGET))"' \ -DBUILD_ARCH='"$(strip $(ARCH))"' \ -DBUILD_CPU='"$(strip $(CPU))"' \ -DBUILD_CC='"$(strip $(CC))"' \ -DBUILD_CFLAGS='"$(strip $(VERBOSE_CFLAGS))"' \ -DBUILD_OPTIONS='"$(strip $(BUILD_OPTIONS))"' \ -c -o $@ $< src/dlmalloc.o: $(DLMALLOC_SRC) $(CC) $(COPTS) -DDEFAULT_MMAP_THRESHOLD=$(DLMALLOC_THRES) -c -o $@ $< install-man: install -d $(DESTDIR)$(MANDIR)/man1 install -m 644 doc/haproxy.1 $(DESTDIR)$(MANDIR)/man1 install-doc: install -d $(DESTDIR)$(DOCDIR) for x in configuration architecture haproxy-en haproxy-fr; do \ install -m 644 doc/$$x.txt $(DESTDIR)$(DOCDIR) ; \ done install-bin: haproxy install -d $(DESTDIR)$(SBINDIR) install haproxy $(DESTDIR)$(SBINDIR) install: install-bin install-man install-doc clean: rm -f *.[oas] src/*.[oas] core haproxy test for dir in . src include/* doc; do rm -f $$dir/*~ $$dir/*.rej;done rm -f haproxy-$(VERSION).tar.gz haproxy-$(VERSION)$(SUBVERS).tar.gz rm -f haproxy-$(VERSION) nohup.out gmon.out tar: clean ln -s . haproxy-$(VERSION) tar --exclude=haproxy-$(VERSION)/.git \ --exclude=haproxy-$(VERSION)/haproxy-$(VERSION) \ --exclude=haproxy-$(VERSION)/haproxy-$(VERSION).tar.gz \ -cf - haproxy-$(VERSION)/* | gzip -c9 >haproxy-$(VERSION).tar.gz rm -f haproxy-$(VERSION) git-tar: clean git archive --format=tar --prefix="haproxy-$(VERSION)/" HEAD | gzip -9 > haproxy-$(VERSION)$(SUBVERS).tar.gz version: @echo "VERSION: $(VERSION)" @echo "SUBVERS: $(SUBVERS)" @echo "VERDATE: $(VERDATE)" # never use this one if you don't know what it is used for. update-version: @echo "Ready to update the following versions :" @echo "VERSION: $(VERSION)" @echo "SUBVERS: $(SUBVERS)" @echo "VERDATE: $(VERDATE)" @echo "Press [ENTER] to continue or Ctrl-C to abort now.";read echo "$(VERSION)" > VERSION echo "$(SUBVERS)" > SUBVERS echo "$(VERDATE)" > VERDATE