Re: [RFC][PATCH 1/2] Create initial kernel ABI header infrastructure

From: Kyle Moffett
Date: Sun Mar 26 2006 - 07:48:03 EST


On Mar 26, 2006, at 07:32:31, Arjan van de Ven wrote:
On Sun, 2006-03-26 at 06:54 -0500, Kyle Moffett wrote:
Create initial kernel ABI header infrastructure

it's nice that you picked this one;
for this you want an arch-generic/stddef32.h and stddef64.h

and have arch-foo just only include the proper generic one..

I plan to add a lot of other definitions to this file later on. For example different architectures have different notions of what a __kernel_ino_t is (unsigned int versus unsigned long). I may rename this file as types.h, but from looking through the code I figure I'll have enough general purpose declarations about "This architecture has blah" that a separate stddef.h file will be worth it.

(and... why do you prefix these with _KABI? that's a mistake imo. Don't bother with that. Really. Either these need exporting to userspace, but then either use __ as prefix or don't use a prefix. But KABI.. No.)

According to the various standards all symbols beginning with __ are reserved for "The Implementation", including the compiler, the standard library, the kernel, etc. In order to avoid clashing with any/all of those, I picked the __KABI_ and __kabi_ prefixes for uniqueness. In theory I could just use __, but there are problems with that too. For example, note how the current compiler.h files redefine __always_inline to mean something kinda different. The GCC manual says we should be able to write this:

inline __attribute__((__always_inline)) int increment(int x)
{
return x+1;
}

Except when compiling the kernel headers turn that into this (which obviously doesn't compile):
inline __attribute__((__attribute__((always_inline)))) int increment (int x)
{
return x+1;
}

As a result, I kinda want to stay away from anything that remotely looks like a conflicting namespace. Using such a unique namespace means we can also safely do this if necessary (Since you can't "typedef struct foo struct bar"):

kabi/foo.h:
struct __kabi_foo {
int x;
int y;
};

linux/foo.h:
#define __kabi_foo foo
#include <kabi/foo.h>

drivers/foo/foo.h:
#include <linux/foo.h>
void func()
{
struct foo = { .x = 1, .y = 2 };
}

Cheers,
Kyle Moffett

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/