[<prev] [next>] [day] [month] [year] [list]
Message-ID: <20250521212644.981148-1-kuba@kernel.org>
Date: Wed, 21 May 2025 14:26:44 -0700
From: Jakub Kicinski <kuba@...nel.org>
To: davem@...emloft.net
Cc: linux-kernel@...r.kernel.org,
netdev@...r.kernel.org,
Jakub Kicinski <kuba@...nel.org>,
dhowells@...hat.com,
kees@...nel.org,
gustavoars@...nel.org,
aleksander.lobakin@...el.com,
tstruk@...aio.com
Subject: [PATCH] stddef: don't include compiler_types.h in the uAPI header
The uAPI stddef header includes compiler_types.h, a non-uAPI
header. There is a hack in scripts/headers_install.sh which
strips includes of compiler.h and compiler_types.h.
But AFAICT there is nothing in stddef.h which would need
the include. The include dates back to when uAPI stddef.h
was first created, back then the including of compiler.h
was the only line in the file. So presumably stddef.h
has been including compiler headers to retain some
chain of dependency? Perhaps someone with more build system
understanding knows what that chain would be, given
kernel doesn't include uAPI stddef.h, and user space
has the compiler headers stripped.
Since nothing needs this include, let's remove it.
Builds pass on x86, arm64, csky, m68k, riscv32.
The direct motivation for the change is that the includes
of compiler.h and co. make it hard to include uAPI headers
from tools/.
Signed-off-by: Jakub Kicinski <kuba@...nel.org>
---
CC: dhowells@...hat.com
CC: kees@...nel.org
CC: gustavoars@...nel.org
CC: aleksander.lobakin@...el.com
CC: tstruk@...aio.com
---
include/uapi/linux/stddef.h | 2 --
1 file changed, 2 deletions(-)
diff --git a/include/uapi/linux/stddef.h b/include/uapi/linux/stddef.h
index b87df1b485c2..3da0266643e6 100644
--- a/include/uapi/linux/stddef.h
+++ b/include/uapi/linux/stddef.h
@@ -2,8 +2,6 @@
#ifndef _UAPI_LINUX_STDDEF_H
#define _UAPI_LINUX_STDDEF_H
-#include <linux/compiler_types.h>
-
#ifndef __always_inline
#define __always_inline inline
#endif
--
2.49.0
Powered by blists - more mailing lists