Re: Kernel includefile bug not fixed after a year :-(

From: Joerg Schilling
Date: Tue Sep 30 2003 - 06:48:00 EST


>From axboe@xxxxxxx Tue Sep 30 13:05:18 2003

>On Tue, Sep 30 2003, Joerg Schilling wrote:
>> A year after I did report this inconsistency, it is still not fixed
>>
>> If include/scsi/scsi.h is included without __KERNEL__ #defined, then this
>> error message apears.
>>
>> /usr/src/linux/include/scsi/scsi.h:172: parse error before "u8"
>> /usr/src/linux/include/scsi/scsi.h:172: warning: no semicolon at end of struct
>> or union
>> /usr/src/linux/include/scsi/scsi.h:173: warning: data definition has no type or
>> storage class
>>
>> Is there no interest in user applications for kernel features or is there just
>> no kernel maintainer left over who makes the needed work?

>/usr/include/scsi/scsi.h looks fine on my system, probably also on
>yours. You should not include kernel headers in your user space program.

Looks like you did not understand the background :-(

In order to use kernel interfaces you _need_ to include kernel include files.

This is in particular true as long as we are talking about beta/testing kernels.


Background: on homogeneous platforms like e.g. Solaris or FreeBSD which are
maintained and distributed as whole, an _enduser_ should include
files from /usr/include only.

This is not even true for people who do Solaris or FreeBSD kernel
development and like to test new features with user level programs.
It is definitely not true for compilations against Linux kernel
interfaces.

Linux is not a homogeneous system. There is a separately developed kernel and
a separate base user level system. People often install a newer kernel and need
to recompile software because the kernel/user interfaces are not stable between
different Linux releases.

These people need to compile against the recent Linux kernel include files if
they use Linux kernel <-> user level interfaces.

- ... why do you believe that #ifdef __KERNEL__ kernel do exist inside
Linux kernel include files if they are not intended for user level
programs?

- How should user level program that depend on kernel interfaces be
compiled if not by using kernel include files?


Jörg

--
EMail:joerg@xxxxxxxxxxxxxxxxxxxxxxxxxxx (home) Jörg Schilling D-13353 Berlin
js@xxxxxxxxxxxxxxx (uni) If you don't have iso-8859-1
schilling@xxxxxxxxxxxxxxxxxxx (work) chars I am J"org Schilling
URL: http://www.fokus.fraunhofer.de/usr/schilling ftp://ftp.berlios.de/pub/schily
-
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/