From 2f4ac3ada03a746ba31db1b7e57a5629d258dea4 Mon Sep 17 00:00:00 2001 From: Stijn Tintel Date: Tue, 10 May 2016 16:52:45 +0300 Subject: [PATCH] bird: fix recvmsg/sendmsg on mips64 Signed-off-by: Stijn Tintel --- bird/Makefile | 2 +- .../001-netlink-update-struct-msghdr.patch | 49 +++++++++++++++++++ 2 files changed, 50 insertions(+), 1 deletion(-) create mode 100644 bird/patches/001-netlink-update-struct-msghdr.patch diff --git a/bird/Makefile b/bird/Makefile index 04c43ef..aa8aa7f 100644 --- a/bird/Makefile +++ b/bird/Makefile @@ -8,7 +8,7 @@ include $(TOPDIR)/rules.mk PKG_NAME:=bird PKG_VERSION:=1.5.0 -PKG_RELEASE:=1 +PKG_RELEASE:=2 PKG_SOURCE:=bird-$(PKG_VERSION).tar.gz PKG_SOURCE_URL:=ftp://bird.network.cz/pub/bird diff --git a/bird/patches/001-netlink-update-struct-msghdr.patch b/bird/patches/001-netlink-update-struct-msghdr.patch new file mode 100644 index 0000000..491e8f9 --- /dev/null +++ b/bird/patches/001-netlink-update-struct-msghdr.patch @@ -0,0 +1,49 @@ +From 31e9e10144a6994773a04d94903fa3bdde6de91e Mon Sep 17 00:00:00 2001 +From: Stijn Tintel +Date: Tue, 10 May 2016 16:45:35 +0300 +Subject: [PATCH] netlink: update struct msghdr + +The netlink code assumes an order for the members of struct msghdr. +This breaks recvmsg and sendmsg with musl libc on mips64. Fix this by +using designated initializers instead. + +Signed-off-by: Stijn Tintel +--- + sysdep/linux/netlink.c | 14 ++++++++++++-- + 1 file changed, 12 insertions(+), 2 deletions(-) + +diff --git a/sysdep/linux/netlink.c b/sysdep/linux/netlink.c +index 1ffdff0..b42e7b6 100644 +--- a/sysdep/linux/netlink.c ++++ b/sysdep/linux/netlink.c +@@ -125,7 +125,12 @@ nl_get_reply(struct nl_sock *nl) + { + struct iovec iov = { nl->rx_buffer, NL_RX_SIZE }; + struct sockaddr_nl sa; +- struct msghdr m = { (struct sockaddr *) &sa, sizeof(sa), &iov, 1, NULL, 0, 0 }; ++ struct msghdr m = { ++ .msg_name = &sa, ++ .msg_namelen = sizeof(sa), ++ .msg_iov = &iov, ++ .msg_iovlen = 1, ++ }; + int x = recvmsg(nl->fd, &m, 0); + if (x < 0) + die("nl_get_reply: %m"); +@@ -1231,7 +1236,12 @@ nl_async_hook(sock *sk, int size UNUSED) + { + struct iovec iov = { nl_async_rx_buffer, NL_RX_SIZE }; + struct sockaddr_nl sa; +- struct msghdr m = { (struct sockaddr *) &sa, sizeof(sa), &iov, 1, NULL, 0, 0 }; ++ struct msghdr m = { ++ .msg_name = &sa, ++ .msg_namelen = sizeof(sa), ++ .msg_iov = &iov, ++ .msg_iovlen = 1, ++ }; + struct nlmsghdr *h; + int x; + uint len; +-- +2.7.3 + -- 2.30.2