summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2019-08-20 14:07:09 +0200
committerLennart Poettering <lennart@poettering.net>2019-11-22 10:54:52 +0100
commit88a36d369015674e3f9eb20f0fc4d33beedd91bb (patch)
tree97edaa30faeb48853ef18e1de7da9cada0d96716 /src
parentvarlink: move connection fds > fd2 (diff)
downloadsystemd-88a36d369015674e3f9eb20f0fc4d33beedd91bb.tar.xz
systemd-88a36d369015674e3f9eb20f0fc4d33beedd91bb.zip
varlink: port varlink code over to use getdtablesize() for sizing number of concurrent connections
Use the official glibc API for determining this parameter. In most other cases in our tree it's better to go directly for RLIMIT_NOFILE since it's semantically what we want, but for this case it appears more appropriate to use the friendlier, shorter, explicit API.
Diffstat (limited to 'src')
-rw-r--r--src/shared/varlink.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/shared/varlink.c b/src/shared/varlink.c
index a23525b0a4..ac8930302a 100644
--- a/src/shared/varlink.c
+++ b/src/shared/varlink.c
@@ -2406,17 +2406,18 @@ int varlink_server_bind_connect(VarlinkServer *s, VarlinkConnect callback) {
}
unsigned varlink_server_connections_max(VarlinkServer *s) {
- struct rlimit rl;
+ int dts;
/* If a server is specified, return the setting for that server, otherwise the default value */
if (s)
return s->connections_max;
- assert_se(getrlimit(RLIMIT_NOFILE, &rl) >= 0);
+ dts = getdtablesize();
+ assert_se(dts > 0);
/* Make sure we never use up more than ¾th of RLIMIT_NOFILE for IPC */
- if (VARLINK_DEFAULT_CONNECTIONS_MAX > rl.rlim_cur / 4 * 3)
- return rl.rlim_cur / 4 * 3;
+ if (VARLINK_DEFAULT_CONNECTIONS_MAX > (unsigned) dts / 4 * 3)
+ return dts / 4 * 3;
return VARLINK_DEFAULT_CONNECTIONS_MAX;
}