diff options
| author | Kuniyuki Iwashima <kuniyu@google.com> | 2025-07-03 01:35:18 +0300 | 
|---|---|---|
| committer | Jakub Kicinski <kuba@kernel.org> | 2025-07-09 04:05:25 +0300 | 
| commit | df30285b3670bf52e1e5512e4d4482bec5e93c16 (patch) | |
| tree | f36deb4e3c02ddf77741e9ecdb7f64ba2afd2c4b /arch/sparc/include/uapi/asm/socket.h | |
| parent | 8b77338eb2af74bb93986e4a8cfd86724168fe39 (diff) | |
| download | linux-df30285b3670bf52e1e5512e4d4482bec5e93c16.tar.xz | |
af_unix: Introduce SO_INQ.
We have an application that uses almost the same code for TCP and
AF_UNIX (SOCK_STREAM).
TCP can use TCP_INQ, but AF_UNIX doesn't have it and requires an
extra syscall, ioctl(SIOCINQ) or getsockopt(SO_MEMINFO) as an
alternative.
Let's introduce the generic version of TCP_INQ.
If SO_INQ is enabled, recvmsg() will put a cmsg of SCM_INQ that
contains the exact value of ioctl(SIOCINQ).  The cmsg is also
included when msg->msg_get_inq is non-zero to make sockets
io_uring-friendly.
Note that SOCK_CUSTOM_SOCKOPT is flagged only for SOCK_STREAM to
override setsockopt() for SOL_SOCKET.
By having the flag in struct unix_sock, instead of struct sock, we
can later add SO_INQ support for TCP and reuse tcp_sk(sk)->recvmsg_inq.
Note also that supporting custom getsockopt() for SOL_SOCKET will need
preparation for other SOCK_CUSTOM_SOCKOPT users (UDP, vsock, MPTCP).
Signed-off-by: Kuniyuki Iwashima <kuniyu@google.com>
Reviewed-by: Willem de Bruijn <willemb@google.com>
Link: https://patch.msgid.link/20250702223606.1054680-7-kuniyu@google.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Diffstat (limited to 'arch/sparc/include/uapi/asm/socket.h')
| -rw-r--r-- | arch/sparc/include/uapi/asm/socket.h | 3 | 
1 files changed, 3 insertions, 0 deletions
| diff --git a/arch/sparc/include/uapi/asm/socket.h b/arch/sparc/include/uapi/asm/socket.h index adcba7329386..71befa109e1c 100644 --- a/arch/sparc/include/uapi/asm/socket.h +++ b/arch/sparc/include/uapi/asm/socket.h @@ -145,6 +145,9 @@  #define SO_PASSRIGHTS            0x005c +#define SO_INQ                   0x005d +#define SCM_INQ                  SO_INQ +  #if !defined(__KERNEL__) | 
