You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

165 lines
4.6 KiB

haproxy: Fix PCRE_DIR include path haproxy's Makefile already happens include/ after specifying PCRE_DIR which would result in the following build errors on an external toolchain that does not automatically search for headers in $(STAGING_DIR): mipsel-linux-gnu-gcc -Iinclude -Iebtree -Wall -O2 -g -fno-strict-aliasing -Wdeclaration-after-statement -DBUFSIZE=16384 -DMAXREWRITE=1030 -DSYSTEM_MAXCONN=165530 -DCONFIG_HAP_LINUX_SPLICE -DTPROXY -DCONFIG_HAP_LINUX_TPROXY -DCONFIG_HAP_CRYPT -DUSE_ZLIB -DENABLE_POLL -DENABLE_EPOLL -DUSE_CPU_AFFINITY -DASSUME_SPLICE_WORKS -DUSE_ACCEPT4 -DNETFILTER -DUSE_GETSOCKNAME -DCONFIG_REGPARM=3 -DUSE_OPENSSL -DUSE_SYSCALL_FUTEX -DUSE_LUA -I/home/florian/dev/openwrt/trunk/staging_dir/target-mipsel-unknown-linux-gnu_glibc/lua-5.3.3/include -DUSE_PCRE -I/home/florian/dev/openwrt/trunk/staging_dir/target-mipsel-unknown-linux-gnu_glibc/usr/include/include -DUSE_PCRE_JIT -DCONFIG_HAPROXY_VERSION=\"1.7.4-patch02\" -DCONFIG_HAPROXY_DATE=\"2017/04/01\" \ -DBUILD_TARGET='"linux2628"' \ -DBUILD_ARCH='""' \ -DBUILD_CPU='"generic"' \ -DBUILD_CC='"mipsel-linux-gnu-gcc"' \ -DBUILD_CFLAGS='"-O2 -g -fno-strict-aliasing -Wdeclaration-after-statement -DBUFSIZE=16384 -DMAXREWRITE=1030 -DSYSTEM_MAXCONN=165530"' \ -DBUILD_OPTIONS='"USE_LINUX_SPLICE=1 USE_LINUX_TPROXY=1 USE_ZLIB=yes USE_REGPARM=1 USE_OPENSSL=1 USE_LUA=1 USE_PCRE=1 USE_PCRE_JIT=1"' \ -c -o src/haproxy.o src/haproxy.c In file included from include/types/proxy.h:33:0, from include/proto/log.h:32, from include/common/cfgparse.h:29, from src/haproxy.c:65: include/common/regex.h:31:18: fatal error: pcre.h: No such file or directory #include <pcre.h> Fix this by stripping the additional include/ being added. Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>
8 years ago
  1. #
  2. # Copyright (C) 2010-2016 OpenWrt.org
  3. # Copyright (C) 2009-2016 Thomas Heil <heil@terminal-consulting.de>
  4. # Copyright (C) 2018 Christian Lachner <gladiac@gmail.com>
  5. #
  6. # This is free software, licensed under the GNU General Public License v2.
  7. # See /LICENSE for more information.
  8. #
  9. include $(TOPDIR)/rules.mk
  10. PKG_NAME:=haproxy
  11. PKG_VERSION:=2.1.4
  12. PKG_RELEASE:=1
  13. PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
  14. PKG_SOURCE_URL:=https://www.haproxy.org/download/2.1/src
  15. PKG_HASH:=51030ff696d7067162b4d24d354044293aecfbb36d7acc2f840c8d928bfe91cd
  16. PKG_MAINTAINER:=Thomas Heil <heil@terminal-consulting.de>, \
  17. Christian Lachner <gladiac@gmail.com>
  18. PKG_LICENSE:=GPL-2.0-only
  19. PKG_LICENSE_FILES:=LICENSE
  20. PKG_CPE_ID:=cpe:/a:haproxy:haproxy
  21. include $(INCLUDE_DIR)/package.mk
  22. define Package/haproxy/Default
  23. SUBMENU:=Web Servers/Proxies
  24. SECTION:=net
  25. CATEGORY:=Network
  26. TITLE:=The Reliable, High Performance TCP/HTTP Load Balancer
  27. URL:=https://www.haproxy.org/
  28. endef
  29. define Build/Prepare
  30. $(call Build/Prepare/Default)
  31. endef
  32. define Package/haproxy/Default/conffiles
  33. /etc/haproxy.cfg
  34. endef
  35. define Package/haproxy/Default/description
  36. Open source Reliable, High Performance TCP/HTTP Load Balancer.
  37. endef
  38. define Package/haproxy
  39. DEPENDS+= +libpcre +libltdl +zlib +libpthread +liblua5.3 +libopenssl +libncurses +libreadline +libatomic
  40. TITLE+= (with SSL support)
  41. VARIANT:=ssl
  42. $(call Package/haproxy/Default)
  43. endef
  44. define Package/haproxy/conffiles
  45. $(call Package/haproxy/Default/conffiles)
  46. endef
  47. define Package/haproxy/description
  48. $(call Package/haproxy/Default/description)
  49. This package is built with SSL and LUA support.
  50. endef
  51. define Package/haproxy-nossl
  52. TITLE+= (without SSL support)
  53. VARIANT:=nossl
  54. DEPENDS+= +libpcre +libltdl +zlib +libpthread +liblua5.3 +libatomic
  55. TITLE+= (without SSL support)
  56. $(call Package/haproxy/Default)
  57. endef
  58. define Package/haproxy-nossl/conffiles
  59. $(call Package/haproxy/Default/conffiles)
  60. endef
  61. define Package/haproxy-nossl/description
  62. $(call Package/haproxy/Default/description)
  63. This package is built without SSL support.
  64. endef
  65. ENABLE_LUA:=y
  66. ENABLE_REGPARM:=n
  67. ifeq ($(CONFIG_TARGET_x86),y)
  68. ENABLE_REGPARM:=y
  69. endif
  70. ifeq ($(CONFIG_USE_UCLIBC),y)
  71. LINUX_TARGET:=linux-uclibc
  72. else
  73. LINUX_TARGET:=linux-glibc
  74. endif
  75. ifeq ($(BUILD_VARIANT),ssl)
  76. ADDON+=USE_OPENSSL=1
  77. ADDON+=ADDLIB="-lcrypto -lm "
  78. endif
  79. ifeq ($(ENABLE_REGPARM),y)
  80. ADDON+=USE_REGPARM=1
  81. endif
  82. define Build/Compile
  83. $(MAKE) TARGET=$(LINUX_TARGET) -C $(PKG_BUILD_DIR) \
  84. DESTDIR="$(PKG_INSTALL_DIR)" \
  85. CC="$(TARGET_CC)" \
  86. PCREDIR="$(STAGING_DIR)/usr/" \
  87. USE_LUA=1 LUA_LIB_NAME="lua5.3" LUA_INC="$(STAGING_DIR)/usr/include/lua5.3" LUA_LIB="$(STAGING_DIR)/usr/lib" \
  88. SMALL_OPTS="-DBUFSIZE=16384 -DMAXREWRITE=1030 -DSYSTEM_MAXCONN=165530" \
  89. USE_LINUX_TPROXY=1 USE_LINUX_SPLICE=1 USE_TFO=1 USE_NS=1 \
  90. USE_ZLIB=1 USE_PCRE=1 USE_PCRE_JIT=1 USE_GETADDRINFO=1 \
  91. USE_THREAD=1 USE_PTHREAD_PSHARED=1 \
  92. VERSION="$(PKG_VERSION)" SUBVERS="-$(PKG_RELEASE)" \
  93. VERDATE="$(shell date -d @$(SOURCE_DATE_EPOCH) '+%Y/%m/%d')" IGNOREGIT=1 \
  94. $(ADDON) \
  95. CFLAGS="$(TARGET_CFLAGS) -fno-strict-aliasing -Wdeclaration-after-statement -fwrapv -Wno-format-truncation -Wno-unused-label -Wno-sign-compare -Wno-unused-parameter -Wno-old-style-declaration -Wno-ignored-qualifiers -Wno-clobbered -Wno-missing-field-initializers -Wno-implicit-fallthrough -Wno-stringop-overflow -Wno-cast-function-type -Wtype-limits -Wshift-negative-value -Wshift-overflow=2 -Wduplicated-cond -Wnull-dereference" \
  96. LD="$(TARGET_CC)" \
  97. LDFLAGS="$(TARGET_LDFLAGS) -latomic" \
  98. EXTRA_OBJS="contrib/prometheus-exporter/service-prometheus.o"
  99. $(MAKE_VARS) $(MAKE) -C $(PKG_BUILD_DIR) \
  100. DESTDIR="$(PKG_INSTALL_DIR)" \
  101. LD="$(TARGET_CC)" \
  102. LDFLAGS="$(TARGET_LDFLAGS)" \
  103. $(MAKE_FLAGS) \
  104. install
  105. $(MAKE_VARS) $(MAKE) -C $(PKG_BUILD_DIR)/contrib/halog \
  106. DESTDIR="$(PKG_INSTALL_DIR)" \
  107. $(MAKE_FLAGS) \
  108. OPTIMIZE="$(TARGET_CFLAGS)" \
  109. ADDLIB="-lcrypto" \
  110. halog
  111. endef
  112. define Package/haproxy/install
  113. $(INSTALL_DIR) $(1)/usr/sbin
  114. $(INSTALL_BIN) $(PKG_BUILD_DIR)/haproxy $(1)/usr/sbin/
  115. $(INSTALL_DIR) $(1)/etc
  116. $(INSTALL_CONF) ./files/haproxy.cfg $(1)/etc/
  117. $(INSTALL_DIR) $(1)/etc/init.d
  118. $(INSTALL_BIN) ./files/haproxy.init $(1)/etc/init.d/haproxy
  119. endef
  120. Package/haproxy-nossl/install = $(Package/haproxy/install)
  121. define Package/halog
  122. MENU:=1
  123. $(call Package/haproxy)
  124. TITLE+= halog
  125. DEPENDS:=haproxy
  126. endef
  127. define Package/halog/description
  128. HAProxy Log Analyzer
  129. endef
  130. define Package/halog/install
  131. $(INSTALL_DIR) $(1)/usr/bin
  132. $(INSTALL_BIN) $(PKG_BUILD_DIR)/contrib/halog/halog $(1)/usr/bin/
  133. endef
  134. $(eval $(call BuildPackage,haproxy))
  135. $(eval $(call BuildPackage,halog))
  136. $(eval $(call BuildPackage,haproxy-nossl))