Re: randconfig build error with next-20150316, in samples/kdbus/kdbus-workers

From: David Herrmann
Date: Mon Mar 16 2015 - 19:00:54 EST


Hi

On Mon, Mar 16, 2015 at 11:51 PM, Michael Ellerman <mpe@xxxxxxxxxxxxxx> wrote:
> On Mon, 2015-03-16 at 23:27 +0100, David Herrmann wrote:
>> The uapi-include only causes the warning, not the build failure.
>
> I don't know how you came to that conclusion?
>
> It fails looking for linux/compiler.h, which is only included from the kernel
> headers, never from the exported headers.

We only include linux/kdbus.h. On sanitized headers, this will include
linux/types.h -> linux/posix_types.h -> linux/stddef.h.
If you use the uapi headers, then stddef.h is not sanitized and will
still include linux/compiler.h (which is removed on sanitized
headers). Hence, this error only occurs if you include
uapi/linux/kdbus.h. With sanitized headers in ./usr/, the compiler
will prefer ./usr/linux/kdbus.h and ./usr/linux/stddef.h, thus never
including any linux/compiler.h.

If you drop -I./include/uapi/, you will get "linux/kdbus.h not found".
The error will be different, but it will not fix anything. However, if
you run "make headers_install", everything will compile just fine even
with -I./include/uapi/.

Thanks
David
--
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/