From: David Bauer Date: Thu, 25 Jul 2019 16:58:03 +0000 (+0200) Subject: fastd: fix segmentation fault with musl >1.1.20 X-Git-Url: http://git.cdn.openwrt.org/?a=commitdiff_plain;h=ed3c3e3c7975f9688fe76784a34be6ad189538ed;p=feed%2Fpackages.git fastd: fix segmentation fault with musl >1.1.20 When compiled with musl >1.1.20, fastd will crash in case it can't resolve a peers hostname. This is due to a changed implementation of freeaddrinfo in musl 1.1.21 onwards. This segfault is fixed by not calling freeaddrinfo in case the supplied pointer is null. Signed-off-by: David Bauer --- diff --git a/net/fastd/Makefile b/net/fastd/Makefile index 4e2bcd5f96..2626b6921f 100644 --- a/net/fastd/Makefile +++ b/net/fastd/Makefile @@ -9,7 +9,7 @@ include $(TOPDIR)/rules.mk PKG_NAME:=fastd PKG_VERSION:=18 -PKG_RELEASE:=2 +PKG_RELEASE:=3 PKG_MAINTAINER:=Matthias Schiffer PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.xz diff --git a/net/fastd/patches/0001-resolve-fix-segmentation-fault-with-musl-1.1.20.patch b/net/fastd/patches/0001-resolve-fix-segmentation-fault-with-musl-1.1.20.patch new file mode 100644 index 0000000000..52c1917408 --- /dev/null +++ b/net/fastd/patches/0001-resolve-fix-segmentation-fault-with-musl-1.1.20.patch @@ -0,0 +1,35 @@ +From 9710132c04cd378bd36f16a2a3d98d9c4c5fdbac Mon Sep 17 00:00:00 2001 +From: David Bauer +Date: Thu, 25 Jul 2019 18:51:25 +0200 +Subject: [PATCH] resolve: fix segmentation fault with musl >1.1.20 + +When compiled with musl >1.1.20, fastd will crash in case it can't +resolve a peers hostname. This is due to a changed implementation of +freeaddrinfo in musl 1.1.21 onwards. + +This segfault is fixed by not calling freeaddrinfo in case the supplied +pointer is null. + +Signed-off-by: David Bauer +--- + src/resolve.c | 4 +++- + 1 file changed, 3 insertions(+), 1 deletion(-) + +diff --git a/src/resolve.c b/src/resolve.c +index 9bdfa1c..bfd2a59 100644 +--- a/src/resolve.c ++++ b/src/resolve.c +@@ -104,7 +104,9 @@ static void * resolve_peer(void *varg) { + + fastd_async_enqueue(ASYNC_TYPE_RESOLVE_RETURN, ret, sizeof(fastd_async_resolve_return_t) + n_addr*sizeof(fastd_peer_address_t)); + +- freeaddrinfo(res); ++ if (res) ++ freeaddrinfo(res); ++ + free(arg->hostname); + free(arg); + +-- +2.20.1 +