import libndp-1.7-4.el8
This commit is contained in:
parent
1c2d213134
commit
e9e7f9af14
152
SOURCES/0007-libndp-ndptool-use-poll-instead-of-select.patch
Normal file
152
SOURCES/0007-libndp-ndptool-use-poll-instead-of-select.patch
Normal file
@ -0,0 +1,152 @@
|
|||||||
|
From 682b0ccabdc7970f89544c0d19477515583a5f5b Mon Sep 17 00:00:00 2001
|
||||||
|
From: Beniamino Galvani <bgalvani@redhat.com>
|
||||||
|
Date: Thu, 25 Feb 2021 14:38:16 +0100
|
||||||
|
Subject: [PATCH] libndp,ndptool: use poll() instead of select()
|
||||||
|
|
||||||
|
select() doesn't support file descriptors greater than 1023. If the
|
||||||
|
program has many files open, the socket descriptor can be > 1023 and
|
||||||
|
then FD_SET(fd, &rfds) causes a buffer overflow.
|
||||||
|
|
||||||
|
Switch to poll() and ppoll() which don't have this limitation.
|
||||||
|
|
||||||
|
Signed-off-by: Beniamino Galvani <bgalvani@redhat.com>
|
||||||
|
Signed-off-by: Jiri Pirko <jiri@nvidia.com>
|
||||||
|
---
|
||||||
|
libndp/libndp.c | 20 +++++++++-----------
|
||||||
|
utils/Makefile.am | 2 +-
|
||||||
|
utils/Makefile.in | 2 +-
|
||||||
|
utils/ndptool.c | 22 +++++++++-------------
|
||||||
|
4 files changed, 20 insertions(+), 26 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/libndp/libndp.c b/libndp/libndp.c
|
||||||
|
index 06a3d23..6314717 100644
|
||||||
|
--- a/libndp/libndp.c
|
||||||
|
+++ b/libndp/libndp.c
|
||||||
|
@@ -25,7 +25,7 @@
|
||||||
|
#include <errno.h>
|
||||||
|
#include <ctype.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
-#include <sys/select.h>
|
||||||
|
+#include <poll.h>
|
||||||
|
#include <netinet/in.h>
|
||||||
|
#include <netinet/icmp6.h>
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
@@ -2107,22 +2107,20 @@ int ndp_call_eventfd_handler(struct ndp *ndp)
|
||||||
|
NDP_EXPORT
|
||||||
|
int ndp_callall_eventfd_handler(struct ndp *ndp)
|
||||||
|
{
|
||||||
|
- fd_set rfds;
|
||||||
|
- int fdmax;
|
||||||
|
- struct timeval tv;
|
||||||
|
- int fd = ndp_get_eventfd(ndp);
|
||||||
|
+ struct pollfd pfd;
|
||||||
|
int ret;
|
||||||
|
int err;
|
||||||
|
|
||||||
|
- memset(&tv, 0, sizeof(tv));
|
||||||
|
- FD_ZERO(&rfds);
|
||||||
|
- FD_SET(fd, &rfds);
|
||||||
|
- fdmax = fd + 1;
|
||||||
|
+ pfd = (struct pollfd) {
|
||||||
|
+ .fd = ndp_get_eventfd(ndp),
|
||||||
|
+ .events = POLLIN,
|
||||||
|
+ };
|
||||||
|
+
|
||||||
|
while (true) {
|
||||||
|
- ret = select(fdmax, &rfds, NULL, NULL, &tv);
|
||||||
|
+ ret = poll(&pfd, 1, 0);
|
||||||
|
if (ret == -1)
|
||||||
|
return -errno;
|
||||||
|
- if (!FD_ISSET(fd, &rfds))
|
||||||
|
+ if (!(pfd.revents & POLLIN))
|
||||||
|
return 0;
|
||||||
|
err = ndp_call_eventfd_handler(ndp);
|
||||||
|
if (err)
|
||||||
|
diff --git a/utils/Makefile.am b/utils/Makefile.am
|
||||||
|
index cca00c2..75e452c 100644
|
||||||
|
--- a/utils/Makefile.am
|
||||||
|
+++ b/utils/Makefile.am
|
||||||
|
@@ -2,7 +2,7 @@ MAINTAINERCLEANFILES = Makefile.in
|
||||||
|
|
||||||
|
ACLOCAL_AMFLAGS = -I m4
|
||||||
|
|
||||||
|
-AM_CFLAGS = -I${top_srcdir}/include
|
||||||
|
+AM_CFLAGS = -I${top_srcdir}/include -D_GNU_SOURCE
|
||||||
|
|
||||||
|
ndptool_LDADD = $(top_builddir)/libndp/libndp.la
|
||||||
|
|
||||||
|
diff --git a/utils/Makefile.in b/utils/Makefile.in
|
||||||
|
index e339b19..d81de50 100644
|
||||||
|
--- a/utils/Makefile.in
|
||||||
|
+++ b/utils/Makefile.in
|
||||||
|
@@ -294,7 +294,7 @@ top_builddir = @top_builddir@
|
||||||
|
top_srcdir = @top_srcdir@
|
||||||
|
MAINTAINERCLEANFILES = Makefile.in
|
||||||
|
ACLOCAL_AMFLAGS = -I m4
|
||||||
|
-AM_CFLAGS = -I${top_srcdir}/include
|
||||||
|
+AM_CFLAGS = -I${top_srcdir}/include -D_GNU_SOURCE
|
||||||
|
ndptool_LDADD = $(top_builddir)/libndp/libndp.la
|
||||||
|
ndptool_SOURCES = ndptool.c
|
||||||
|
all: all-am
|
||||||
|
diff --git a/utils/ndptool.c b/utils/ndptool.c
|
||||||
|
index 662ff01..618f167 100644
|
||||||
|
--- a/utils/ndptool.c
|
||||||
|
+++ b/utils/ndptool.c
|
||||||
|
@@ -28,7 +28,7 @@
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <ndp.h>
|
||||||
|
-#include <sys/select.h>
|
||||||
|
+#include <poll.h>
|
||||||
|
|
||||||
|
enum verbosity_level {
|
||||||
|
VERB1,
|
||||||
|
@@ -59,13 +59,10 @@ static void empty_signal_handler(int signal)
|
||||||
|
|
||||||
|
static int run_main_loop(struct ndp *ndp)
|
||||||
|
{
|
||||||
|
- fd_set rfds;
|
||||||
|
- fd_set rfds_tmp;
|
||||||
|
- int fdmax;
|
||||||
|
+ struct pollfd pfd;
|
||||||
|
int ret;
|
||||||
|
struct sigaction siginfo;
|
||||||
|
sigset_t mask;
|
||||||
|
- int ndp_fd;
|
||||||
|
int err = 0;
|
||||||
|
|
||||||
|
sigemptyset(&siginfo.sa_mask);
|
||||||
|
@@ -100,23 +97,22 @@ static int run_main_loop(struct ndp *ndp)
|
||||||
|
|
||||||
|
sigemptyset(&mask);
|
||||||
|
|
||||||
|
- FD_ZERO(&rfds);
|
||||||
|
- ndp_fd = ndp_get_eventfd(ndp);
|
||||||
|
- FD_SET(ndp_fd, &rfds);
|
||||||
|
- fdmax = ndp_fd + 1;
|
||||||
|
+ pfd = (struct pollfd) {
|
||||||
|
+ .fd = ndp_get_eventfd(ndp),
|
||||||
|
+ .events = POLLIN,
|
||||||
|
+ };
|
||||||
|
|
||||||
|
for (;;) {
|
||||||
|
- rfds_tmp = rfds;
|
||||||
|
- ret = pselect(fdmax, &rfds_tmp, NULL, NULL, NULL, &mask);
|
||||||
|
+ ret = ppoll(&pfd, 1, NULL, &mask);
|
||||||
|
if (ret == -1) {
|
||||||
|
if (errno == EINTR) {
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
- pr_err("Select failed\n");
|
||||||
|
+ pr_err("Poll failed\n");
|
||||||
|
err = -errno;
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
- if (FD_ISSET(ndp_fd, &rfds_tmp)) {
|
||||||
|
+ if (pfd.revents & POLLIN) {
|
||||||
|
err = ndp_call_eventfd_handler(ndp);
|
||||||
|
if (err) {
|
||||||
|
pr_err("ndp eventfd handler call failed\n");
|
||||||
|
--
|
||||||
|
2.26.2
|
||||||
|
|
@ -1,6 +1,6 @@
|
|||||||
Name: libndp
|
Name: libndp
|
||||||
Version: 1.7
|
Version: 1.7
|
||||||
Release: 3%{?dist}
|
Release: 4%{?dist}
|
||||||
Summary: Library for Neighbor Discovery Protocol
|
Summary: Library for Neighbor Discovery Protocol
|
||||||
Group: System Environment/Libraries
|
Group: System Environment/Libraries
|
||||||
License: LGPLv2+
|
License: LGPLv2+
|
||||||
@ -13,6 +13,7 @@ Patch3: 0003-libndp-close-sockfd-after-using-to-avoid-handle-leak.patch
|
|||||||
Patch4: 0004-libndp-fix-nd_msg-typo-when-setting-target-address.patch
|
Patch4: 0004-libndp-fix-nd_msg-typo-when-setting-target-address.patch
|
||||||
Patch5: 0005-ndptool-add-D-dest-support.patch
|
Patch5: 0005-ndptool-add-D-dest-support.patch
|
||||||
Patch6: 0006-ndptool-fix-potential-memory-leak-caused-by-strdup.patch
|
Patch6: 0006-ndptool-fix-potential-memory-leak-caused-by-strdup.patch
|
||||||
|
Patch7: 0007-libndp-ndptool-use-poll-instead-of-select.patch
|
||||||
|
|
||||||
%description
|
%description
|
||||||
This package contains a library which provides a wrapper
|
This package contains a library which provides a wrapper
|
||||||
@ -36,6 +37,7 @@ necessary for developing programs using libndp.
|
|||||||
%patch4 -p1 -b .libndp_fix_nd_msg_typo
|
%patch4 -p1 -b .libndp_fix_nd_msg_typo
|
||||||
%patch5 -p1 -b .ndptool_add_D_dest_support
|
%patch5 -p1 -b .ndptool_add_D_dest_support
|
||||||
%patch6 -p1 -b .ndptool_fix_potential_memory_leak
|
%patch6 -p1 -b .ndptool_fix_potential_memory_leak
|
||||||
|
%patch7 -p1 -b .ndptool_use_poll
|
||||||
|
|
||||||
%build
|
%build
|
||||||
%configure --disable-static
|
%configure --disable-static
|
||||||
@ -61,6 +63,9 @@ find $RPM_BUILD_ROOT -name \*.la -delete
|
|||||||
%{_libdir}/pkgconfig/*.pc
|
%{_libdir}/pkgconfig/*.pc
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri Mar 05 2021 Hangbin Liu <haliu@redhat.com> - 1.7-4
|
||||||
|
- libndp,ndptool: use poll() instead of select (rhbz 1933041)
|
||||||
|
|
||||||
* Fri Nov 01 2019 Hangbin Liu <haliu@redhat.com> - 1.7-3
|
* Fri Nov 01 2019 Hangbin Liu <haliu@redhat.com> - 1.7-3
|
||||||
- ndptool: add -D dest support (rhbz 1697595)
|
- ndptool: add -D dest support (rhbz 1697595)
|
||||||
- ndptool: fix potential memory leak caused by strdup (rhbz 1697595)
|
- ndptool: fix potential memory leak caused by strdup (rhbz 1697595)
|
||||||
|
Loading…
Reference in New Issue
Block a user