On Mon, Sep 06, 2021 at 03:24:41PM -0700, Linus Torvalds wrote: > On Mon, Sep 6, 2021 at 2:52 PM Jakub Jelinek <jakub@xxxxxxxxxx> wrote: > > > > It is actually not that bad, stdlib.h is indeed included there because of 2 > > intrinsics out of more than 5000 and when one doesn't need those, just > > #define _MM_MALLOC_H_INCLUDED > > .. and on clang? Clang apparently has __MM_MALLOC_H as header guard here. But Clang does say #if __STDC_HOSTED__ #include <mm_malloc.h> #endif so they do not have this bug in the first place. GCC should fix this as well. I filed <https://gcc.gnu.org/PR102231>. Thanks for bringing thisd to our attention! > There, I think you have to undefine __STDC_HOSTED__. Maybe by using > -ffreestanding? That defines it to 0, instead, as required by the C standard: $ :|gcc -E -dM -|grep HOSTED #define __STDC_HOSTED__ 1 $ :|gcc -E -dM - -ffreestanding|grep HOSTED #define __STDC_HOSTED__ 0 Yes, that is how this works: the command line flag says how the macro should be defined by the compiler (and changing it in your code is UB btw). > Except if you use -ffreestanding, you lose some very bvasic > functionality (*), (see below) > And they should very much *not*at*all* be considered some kind of > sacred "this is the only way to do things". Because that is clearly > not true, and has *never* been true. Take for example <stdint.h>. There is no other way to find out what types to use for exact-width integers. Unless you really want to do typedef unsigned int __attribute__((mode (DI))) u64; but that is rather unportable to other compilers but GCC. <stdint.h> *is* the only portable way for getting exact-width integers (and some other things). This is not something we decide, it is not something you can decide, it follows directly from the C standard. Using it is easy. Not using it leads to the forest of include files and preprocessor conditionals the kernel currently uses. > The usable header files are the odd special case, not the general case. > > Really. > > Is it really so hard to just admit that the kernel shouldn't use those > headers? When we have 30 years of experience in doing exactly that? That isn't the core issue at hand. Yes, Linux has implemented all of it manually historically, and there even were good reasons for some of that. That does not mean that it would be a good idea to throw out the few standard C headers it does use, and implement those with compiler internal interfaces instead, which we advice you against. > (*) iirc, with -ffreestanding gcc doesn't do all the basic memcpy() > optimizations. But I forget the exact details. I would love to hear any details about that. I do know the Glibc headers do (or did?) some premature optimisation wrt. some mem* and str*, hurting performance on newer compilers. But you should not be using the Glibc headers for compiling the kernel at all anyway, so maybe there was some bug thereabouts? Segher