Re: [GIT PULL v2] Kbuild updates for v5.15-rc1
From: Segher Boessenkool
Date: Mon Sep 06 2021 - 11:51:12 EST
On Sat, Sep 04, 2021 at 12:58:50PM -0700, Linus Torvalds wrote:
> On Sat, Sep 4, 2021 at 12:18 PM Segher Boessenkool
> <segher@xxxxxxxxxxxxxxxxxxx> wrote:
> > And the C standard requires you to use these headers to use some
> > features of the C language
>
> That's really the point here: we don't care AT ALL.
>
> The C standard headers are simply not relevant for the kernel. Never
> have been, never will be.
Yes they are. It is the single standard way to get the functionality
you want.
These are not library headers. These headers are provided by the
compiler itself. (The one exception is limits.h, but you have no use
for that in the kernel anyway).
> We care about the low-level compiler infrastructure, not the standard C headers.
I don't know why you think you can separate that. Take <stdarg.h> --
there is no other (portable, standard) way to implement receiving
variadic arguments.
Yes you can mimic what GCC currently does in its <stdarg.h>, and hope
that keeps working on later versions of GCC, and on all older compiler
versions you care about, and that it works on other compilers as well.
> Those standards are designed for - and try to cater to - a completely
> different audience.
"""
This International Standard specifies the form and establishes the
interpretation of programs expressed in the programming language C.
Its purpose is to promote portability, reliability, maintainability,
and efficient execution of C language programs on a variety of
computing systems.
"""
Is the kernel not written in C? The C standard is not the POSIX
standard, or anything like it.
> We do our own type system, and again, we don't care at all about the C
> "official" type system and odd name rules that change from one version
> to the other.
<stdint.h> has existed since C99, and has not relevantly changed since.
And you *do* care about this feature, deeply. That is why the kernel
has u8, for the exact same reason standard C has uint8_t: to get exact
width integer types. The kernel could just include the standard header
and then
typedef uint8_t u8;
instead of the dance it currently goes through.
> We generally *cannot* use the system header files, because they bring
> in things that the kernel simply cannot handle.
Like?
These header files are part of the compiler. The compiler is required
to provide these to be a C compiler. Without using those header files
there is no portable way to use some important features of C.
These are not library headers. These are not headers provided by some
third party. These headers are an intricate part of the compiler
itself.
> > You also need <stdint.h> and <stddef.h>.
>
> No, you really don't.
>
> We avoid those intentionally, and always have. Because the system
> header files have never been a good match.
Linux re-implements all of it. It *does* need it, it just has its own
implementation if it. It needs the features it provides.
> But it does look like gcc and clang have both ended up exposing the
> interfaces the same way, using the __buildin_xyz model to just wrap
> the standard names in a namespace-clean way.
>
> That really wasn't historically true. Back in the bad old days of
> varargs etc, you literally had "va_list" be a "char *" and the
> accessor functions were magic macros that updated things by hand by
> the size of the arguments etc...
Before C90 there was <varargs.h> instead, and that was like that indeed.
The standard C <stdarg.h> header *cannot* be implemented in terms of
other building blocks in C. This is the underlying theme of all
standard C headers.
> In ways that a lot of other "standard C header files" very much are
> *not* - many of those are about the types that the system provides.
>
> And in fact often the kernel is the *source* and definition of parts of them.
That is not true at all. These headers in no way depend on Linux or any
other OS. Some of it is mandated by the C standard, some of it is
mandated by the low-level ABI used (the size of an int for example, that
kind of thing). But none of it is from any kernel.
I get that long ago in the dark ages Linux had to implement many things
from scratch. And that implementing things from scratch is more fun
anyway. Also, everything seems to work now, tinkering with it is not
necessarily the best idea.
But that does not mean that if you had to start over you should not use
the standard C headers, or that it would be a bad idea to use them more
often now.
Segher