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.

154 lines
4.5 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.2.11
  12. PKG_RELEASE:=1
  13. PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
  14. PKG_SOURCE_URL:=https://www.haproxy.org/download/2.2/src
  15. PKG_HASH:=173a98506472bb1ba5a4a7f3a281125163f78bab5793bf6ba1f1d50853eb5f23
  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. ifeq ($(CONFIG_USE_UCLIBC),y)
  67. ADDON+=USE_LIBCRYPT=
  68. endif
  69. ifeq ($(BUILD_VARIANT),ssl)
  70. ADDON+=USE_OPENSSL=1
  71. ADDON+=ADDLIB="-lcrypto -lm"
  72. endif
  73. define Build/Compile
  74. $(MAKE) TARGET=linux-glibc -C $(PKG_BUILD_DIR) \
  75. DESTDIR="$(PKG_INSTALL_DIR)" \
  76. CC="$(TARGET_CC)" \
  77. PCREDIR="$(STAGING_DIR)/usr/" \
  78. USE_LUA=1 LUA_LIB_NAME="lua5.3" LUA_INC="$(STAGING_DIR)/usr/include/lua5.3" LUA_LIB="$(STAGING_DIR)/usr/lib" \
  79. SMALL_OPTS="-DBUFSIZE=16384 -DMAXREWRITE=1030 -DSYSTEM_MAXCONN=165530" \
  80. USE_LINUX_TPROXY=1 USE_LINUX_SPLICE=1 USE_TFO=1 USE_NS=1 \
  81. USE_ZLIB=1 USE_PCRE=1 USE_PCRE_JIT=1 USE_GETADDRINFO=1 \
  82. USE_THREAD=1 USE_PTHREAD_PSHARED=1 \
  83. VERSION="$(PKG_VERSION)" SUBVERS="-$(PKG_RELEASE)" \
  84. VERDATE="$(shell date -d @$(SOURCE_DATE_EPOCH) '+%Y/%m/%d')" IGNOREGIT=1 \
  85. $(ADDON) USE_BACKTRACE= \
  86. 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" \
  87. LD="$(TARGET_CC)" \
  88. LDFLAGS="$(TARGET_LDFLAGS) -latomic" \
  89. EXTRA_OBJS="contrib/prometheus-exporter/service-prometheus.o"
  90. $(MAKE_VARS) $(MAKE) -C $(PKG_BUILD_DIR) \
  91. DESTDIR="$(PKG_INSTALL_DIR)" \
  92. LD="$(TARGET_CC)" \
  93. LDFLAGS="$(TARGET_LDFLAGS)" \
  94. $(MAKE_FLAGS) \
  95. install
  96. $(MAKE_VARS) $(MAKE) -C $(PKG_BUILD_DIR)/contrib/halog \
  97. DESTDIR="$(PKG_INSTALL_DIR)" \
  98. $(MAKE_FLAGS) \
  99. OPTIMIZE="$(TARGET_CFLAGS)" \
  100. ADDLIB="-lcrypto" \
  101. halog
  102. endef
  103. define Package/haproxy/install
  104. $(INSTALL_DIR) $(1)/usr/sbin
  105. $(INSTALL_BIN) $(PKG_BUILD_DIR)/haproxy $(1)/usr/sbin/
  106. $(INSTALL_DIR) $(1)/etc
  107. $(INSTALL_CONF) ./files/haproxy.cfg $(1)/etc/
  108. $(INSTALL_DIR) $(1)/etc/init.d
  109. $(INSTALL_BIN) ./files/haproxy.init $(1)/etc/init.d/haproxy
  110. endef
  111. Package/haproxy-nossl/install = $(Package/haproxy/install)
  112. define Package/halog
  113. MENU:=1
  114. $(call Package/haproxy)
  115. TITLE+= halog
  116. DEPENDS:=haproxy
  117. endef
  118. define Package/halog/description
  119. HAProxy Log Analyzer
  120. endef
  121. define Package/halog/install
  122. $(INSTALL_DIR) $(1)/usr/bin
  123. $(INSTALL_BIN) $(PKG_BUILD_DIR)/contrib/halog/halog $(1)/usr/bin/
  124. endef
  125. $(eval $(call BuildPackage,haproxy))
  126. $(eval $(call BuildPackage,halog))
  127. $(eval $(call BuildPackage,haproxy-nossl))