summaryrefslogtreecommitdiff
path: root/include/uapi
diff options
context:
space:
mode:
authorStefano Garzarella <sgarzare@redhat.com>2025-06-23 12:00:53 +0200
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2025-07-06 11:00:12 +0200
commit8f96a2ae16b5ede2746a2f4f5186b6981e1638fe (patch)
tree8c91dd4236f26cef4c086223dbfed3c48f709818 /include/uapi
parentd58343f813540807048b0ca329f54127f25942b3 (diff)
downloadlinux-8f96a2ae16b5ede2746a2f4f5186b6981e1638fe.tar.gz
linux-8f96a2ae16b5ede2746a2f4f5186b6981e1638fe.tar.bz2
linux-8f96a2ae16b5ede2746a2f4f5186b6981e1638fe.zip
vsock/uapi: fix linux/vm_sockets.h userspace compilation errors
[ Upstream commit 22bbc1dcd0d6785fb390c41f0dd5b5e218d23bdd ] If a userspace application just include <linux/vm_sockets.h> will fail to build with the following errors: /usr/include/linux/vm_sockets.h:182:39: error: invalid application of ‘sizeof’ to incomplete type ‘struct sockaddr’ 182 | unsigned char svm_zero[sizeof(struct sockaddr) - | ^~~~~~ /usr/include/linux/vm_sockets.h:183:39: error: ‘sa_family_t’ undeclared here (not in a function) 183 | sizeof(sa_family_t) - | Include <sys/socket.h> for userspace (guarded by ifndef __KERNEL__) where `struct sockaddr` and `sa_family_t` are defined. We already do something similar in <linux/mptcp.h> and <linux/if.h>. Fixes: d021c344051a ("VSOCK: Introduce VM Sockets") Reported-by: Daan De Meyer <daan.j.demeyer@gmail.com> Signed-off-by: Stefano Garzarella <sgarzare@redhat.com> Link: https://patch.msgid.link/20250623100053.40979-1-sgarzare@redhat.com Signed-off-by: Jakub Kicinski <kuba@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'include/uapi')
-rw-r--r--include/uapi/linux/vm_sockets.h4
1 files changed, 4 insertions, 0 deletions
diff --git a/include/uapi/linux/vm_sockets.h b/include/uapi/linux/vm_sockets.h
index ed07181d4eff..e05280e41522 100644
--- a/include/uapi/linux/vm_sockets.h
+++ b/include/uapi/linux/vm_sockets.h
@@ -17,6 +17,10 @@
#ifndef _UAPI_VM_SOCKETS_H
#define _UAPI_VM_SOCKETS_H
+#ifndef __KERNEL__
+#include <sys/socket.h> /* for struct sockaddr and sa_family_t */
+#endif
+
#include <linux/socket.h>
#include <linux/types.h>