diff --git a/net/gatling/Makefile b/net/gatling/Makefile new file mode 100644 index 0000000000..15c38fef98 --- /dev/null +++ b/net/gatling/Makefile @@ -0,0 +1,40 @@ +include $(TOPDIR)/rules.mk + +PKG_NAME:=gatling +PKG_VERSION:=0.16 +PKG_RELEASE:=1 + +PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.xz +PKG_SOURCE_URL:=https://www.fefe.de/gatling/ +PKG_HASH:=5f96438ee201d7f1f6c2e0849ff273b196bdc7493f29a719ce8ed08c8be6365b + +PKG_BUILD_DEPENDS:=px5g-mbedtls libowfat + +PKG_MAINTAINER:=Martin Hübner +PKG_LICENSE:=GPL-2.0-only +PKG_LICENSE_FILES:=LICENSE + +include $(INCLUDE_DIR)/package.mk + +define Package/gatling + SECTION:=net + CATEGORY:=Network + SUBMENU:=Web Servers/Proxies + TITLE:=gatling - a high performance web server + URL:=https://www.fefe.de/gatling/ + DEPENDS:=+zlib +libcap +libopenssl +endef + +define Package/gatling/description + gatling - a high performance web server + with a a rather small binary size but a decent set of extra features + like ftp, basic htaccess and basic DoS-Protection. + Gatling is particularly good in situations with very high load. +endef + +define Package/gatling/install + $(INSTALL_DIR) $(1)/usr/bin + $(INSTALL_BIN) $(PKG_BUILD_DIR)/gatling $(1)/usr/bin/ +endef + +$(eval $(call BuildPackage,gatling)) diff --git a/net/gatling/patches/010-decrease_optimisation.patch b/net/gatling/patches/010-decrease_optimisation.patch new file mode 100644 index 0000000000..8788b073d4 --- /dev/null +++ b/net/gatling/patches/010-decrease_optimisation.patch @@ -0,0 +1,25 @@ +gatling: decrease optimisation + +When compiling on MIPS-architectures, in -O2 there happen some +errors on interlinking. Linker will will fail with: + +``` +Unsupported jump between ISA modes; consider recompiling with interlinking enabled +``` + +Reducing optimisation works around these errors and looks like +a fairly common solution to this problem. +https://forum.openwrt.org/t/unsupported-jump-between-isa-modes-consider-recompiling-with-interlinking-enabled/55786 + +Signed-off-by: Martin Hübner +--- a/GNUmakefile ++++ b/GNUmakefile +@@ -47,7 +47,7 @@ ifneq ($(DEBUG),) + CFLAGS+=-g -Og + LDFLAGS+=-g + else +-CFLAGS+=-O2 -fomit-frame-pointer -I/usr/local/include ++CFLAGS+=-O1 -fomit-frame-pointer -I/usr/local/include + LDFLAGS+=-s + ifneq ($(DIET),) + DIET+=-Os diff --git a/net/gatling/patches/020-configure_features.patch b/net/gatling/patches/020-configure_features.patch new file mode 100644 index 0000000000..0a296b312f --- /dev/null +++ b/net/gatling/patches/020-configure_features.patch @@ -0,0 +1,30 @@ +gatling: configure features + +Disables SMB-support, as only deprecated SMBv1 is supported, +which most users wouldn't use anyway. Avoids potential +vulnerabilities. + +Activates threaded opening: Thus gatling will open files in +threads to open kernel I/O scheduling opportunities. + +Signed-off-by: Martin Hübner +--- a/gatling_features.h ++++ b/gatling_features.h +@@ -7,7 +7,7 @@ + + #define SUPPORT_SERVERSTATUS + // #define SUPPORT_DAV +-#define SUPPORT_SMB ++// #define SUPPORT_SMB + #define SUPPORT_FTP + #define SUPPORT_PROXY + /* #define DEBUG to enable more verbose debug messages for tracking fd +@@ -36,7 +36,7 @@ + #define SUPPORT_FALLBACK_REDIR + + /* open files in threads to open kernel I/O scheduling opportunities */ +-#undef SUPPORT_THREADED_OPEN ++#define SUPPORT_THREADED_OPEN + + /* try to divine MIME type by looking at content */ + #define SUPPORT_MIMEMAGIC diff --git a/net/gatling/test.sh b/net/gatling/test.sh new file mode 100644 index 0000000000..166afe3774 --- /dev/null +++ b/net/gatling/test.sh @@ -0,0 +1,3 @@ +#!/bin/sh + +gatling -h