git: fe4dc1fd7105 - main - net/nss-pam-ldapd: use closefrom in nslcd
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Tue, 11 Oct 2022 18:49:13 UTC
The branch main has been updated by asomers (src committer):
URL: https://cgit.FreeBSD.org/ports/commit/?id=fe4dc1fd7105b8d28031f9fab5b1260fbd0bbcaa
commit fe4dc1fd7105b8d28031f9fab5b1260fbd0bbcaa
Author: Alan Somers <asomers@FreeBSD.org>
AuthorDate: 2022-10-11 18:44:51 +0000
Commit: Alan Somers <asomers@FreeBSD.org>
CommitDate: 2022-10-11 18:48:50 +0000
net/nss-pam-ldapd: use closefrom in nslcd
nslcd tries to close all file descriptors on startup. It does that by
calling close() in a loop, running down from _SC_OPEN_MAX to 0. Since
_SC_OPEN_MAX autoscales with available RAM, this can take more than a
minute on large servers. The solution is to use closefrom. Upstream
has already made that change in the master branch, but due to its slow
release cadence we're applying it here as well.
PR: 266970
Approved by: zi (maintainer)
Sponsored by: Axcient
---
net/nss-pam-ldapd/Makefile | 1 +
net/nss-pam-ldapd/files/patch-config.h.in | 12 +++++++++
net/nss-pam-ldapd/files/patch-configure | 16 +++++++++++
net/nss-pam-ldapd/files/patch-nslcd_daemonize.c | 33 +++++++++++++++++++++++
net/nss-pam-ldapd/files/patch-nslcd_invalidator.c | 29 ++++++++++++++++++++
5 files changed, 91 insertions(+)
diff --git a/net/nss-pam-ldapd/Makefile b/net/nss-pam-ldapd/Makefile
index 28d6cdc1f8fd..149d5edfd438 100644
--- a/net/nss-pam-ldapd/Makefile
+++ b/net/nss-pam-ldapd/Makefile
@@ -1,5 +1,6 @@
PORTNAME= nss-pam-ldapd
PORTVERSION= 0.9.12
+PORTREVISION= 1
CATEGORIES= net
MASTER_SITES= http://arthurdejong.org/nss-pam-ldapd/ \
ZI
diff --git a/net/nss-pam-ldapd/files/patch-config.h.in b/net/nss-pam-ldapd/files/patch-config.h.in
new file mode 100644
index 000000000000..e9ab0c2bf48b
--- /dev/null
+++ b/net/nss-pam-ldapd/files/patch-config.h.in
@@ -0,0 +1,12 @@
+--- config.h.in.orig 2022-10-10 21:16:40 UTC
++++ config.h.in
+@@ -30,6 +30,9 @@
+ /* Define to 1 if you have the `clearenv' function. */
+ #undef HAVE_CLEARENV
+
++/* Define to 1 if you have the `closefrom' function. */
++#undef HAVE_CLOSEFROM
++
+ /* Define to 1 if you have the <ctype.h> header file. */
+ #undef HAVE_CTYPE_H
+
diff --git a/net/nss-pam-ldapd/files/patch-configure b/net/nss-pam-ldapd/files/patch-configure
new file mode 100644
index 000000000000..d97e0366b1af
--- /dev/null
+++ b/net/nss-pam-ldapd/files/patch-configure
@@ -0,0 +1,16 @@
+--- configure.orig 2021-11-20 13:07:41 UTC
++++ configure
+@@ -9684,6 +9684,13 @@ then :
+
+ fi
+
++ ac_fn_c_check_func "$LINENO" "closefrom" "ac_cv_func_closefrom"
++if test "x$ac_cv_func_closefrom" = xyes
++then :
++ printf "%s\n" "#define HAVE_CLOSEFROM 1" >>confdefs.h
++
++fi
++
+
+ # replace some functions if they are not on the system
+ ac_fn_c_check_func "$LINENO" "getopt_long" "ac_cv_func_getopt_long"
diff --git a/net/nss-pam-ldapd/files/patch-nslcd_daemonize.c b/net/nss-pam-ldapd/files/patch-nslcd_daemonize.c
new file mode 100644
index 000000000000..8a8901baaa80
--- /dev/null
+++ b/net/nss-pam-ldapd/files/patch-nslcd_daemonize.c
@@ -0,0 +1,33 @@
+--- nslcd/daemonize.c.orig 2022-10-11 18:31:44 UTC
++++ nslcd/daemonize.c
+@@ -1,7 +1,7 @@
+ /*
+ daemoninze.c - functions for properly daemonising an application
+
+- Copyright (C) 2014-2015 Arthur de Jong
++ Copyright (C) 2014-2022 Arthur de Jong
+
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+@@ -43,15 +43,19 @@ void daemonize_closefds(void)
+
+ void daemonize_closefds(void)
+ {
+- int i;
+ /* close all file descriptors (except stdin/out/err) */
++#ifdef HAVE_CLOSEFROM
++ closefrom(3);
++#else
++ int i;
+ i = sysconf(_SC_OPEN_MAX) - 1;
+ /* if the system does not have OPEN_MAX just close the first 32 and
+ hope we closed enough */
+ if (i < 0)
+ i = 32;
+- for (; i > 3; i--)
++ for (; i > 2; i--)
+ close(i);
++#endif
+ }
+
+ void daemonize_redirect_stdio(void)
diff --git a/net/nss-pam-ldapd/files/patch-nslcd_invalidator.c b/net/nss-pam-ldapd/files/patch-nslcd_invalidator.c
new file mode 100644
index 000000000000..c4bfe8ffe3e7
--- /dev/null
+++ b/net/nss-pam-ldapd/files/patch-nslcd_invalidator.c
@@ -0,0 +1,29 @@
+--- nslcd/invalidator.c.orig 2021-11-15 19:40:49 UTC
++++ nslcd/invalidator.c
+@@ -1,7 +1,7 @@
+ /*
+ invalidator.c - functions for invalidating external caches
+
+- Copyright (C) 2013-2014 Arthur de Jong
++ Copyright (C) 2013-2022 Arthur de Jong
+
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+@@ -97,6 +97,9 @@ static void exec_invalidate(const char *db)
+ {
+ case 0: /* we are the child */
+ /* close all file descriptors */
++#ifdef HAVE_CLOSEFROM
++ closefrom(0);
++#else
+ i = sysconf(_SC_OPEN_MAX) - 1;
+ /* if the system does not have OPEN_MAX just close the first 32 and
+ hope we have closed enough */
+@@ -104,6 +107,7 @@ static void exec_invalidate(const char *db)
+ i = 32;
+ for (; i >= 0; i--)
+ close(i);
++#endif
+ /* execute command */
+ #ifdef HAVE_EXECVPE
+ execvpe(argv[0], argv, newenviron);