git: 72ddb6de1028 - main - unix: increase net.local.(stream|seqpacket).(recv|send)space to 64 KiB
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Fri, 22 Aug 2025 16:22:36 UTC
The branch main has been updated by glebius:
URL: https://cgit.FreeBSD.org/src/commit/?id=72ddb6de1028426305df3ab6c81ff3834d5a69e5
commit 72ddb6de1028426305df3ab6c81ff3834d5a69e5
Author: Gleb Smirnoff <glebius@FreeBSD.org>
AuthorDate: 2025-08-22 16:22:25 +0000
Commit: Gleb Smirnoff <glebius@FreeBSD.org>
CommitDate: 2025-08-22 16:22:25 +0000
unix: increase net.local.(stream|seqpacket).(recv|send)space to 64 KiB
The limit of 8 KiB comes straight from the 80-ies, when memory sizes were
two orders of magnitude less. Microbenchmarking clearly shows that
increased maximum buffer size is needed to improve bulk transfer
performance over unix(4). Most operating system have larger default
sizes. This brings us another reason for increase. A buggy application,
that treats a stream socket as a datagram socket, shall work on Linux as
long as its messages are smaller than socket buffer size without any
issues 99.99% of time. But on FreeBSD it will instantly fail. In the
ports system there are already applications that suggest increase of this
sysctls for the application to work. We don't want to be a bug catcher
for bad applications in the default configuration.
Note that buffer size increase will not increase memory usage even on a
system with a million unix(4) sockets at normal runtime, as long as
applications are written properly and receivers drain their sockets and
system has enough CPU time for them to do that.
Reviewed by: peter.lei_ieee.org, rscheff, tuexen
Differential Revision: https://reviews.freebsd.org/D51903
---
sys/kern/uipc_usrreq.c | 11 ++++-------
1 file changed, 4 insertions(+), 7 deletions(-)
diff --git a/sys/kern/uipc_usrreq.c b/sys/kern/uipc_usrreq.c
index 0056dac65c7d..19870e989437 100644
--- a/sys/kern/uipc_usrreq.c
+++ b/sys/kern/uipc_usrreq.c
@@ -154,15 +154,12 @@ static struct task unp_defer_task;
* and don't really want to reserve the sendspace. Their recvspace should be
* large enough for at least one max-size datagram plus address.
*/
-#ifndef PIPSIZ
-#define PIPSIZ 8192
-#endif
-static u_long unpst_sendspace = PIPSIZ;
-static u_long unpst_recvspace = PIPSIZ;
+static u_long unpst_sendspace = 64*1024;
+static u_long unpst_recvspace = 64*1024;
static u_long unpdg_maxdgram = 8*1024; /* support 8KB syslog msgs */
static u_long unpdg_recvspace = 16*1024;
-static u_long unpsp_sendspace = PIPSIZ;
-static u_long unpsp_recvspace = PIPSIZ;
+static u_long unpsp_sendspace = 64*1024;
+static u_long unpsp_recvspace = 64*1024;
static SYSCTL_NODE(_net, PF_LOCAL, local, CTLFLAG_RW | CTLFLAG_MPSAFE, 0,
"Local domain");