Problems compiling modules outside of tree in 2.6.0test1

Carl Thompson (cet@carlthompson.net)
Mon, 14 Jul 2003 23:46:27 -0700


[This problem still exists in Linux 2.6.0test1]

I am not on the kernel mailing list so please CC with any responses. I am
new to this kernel / module stuff so if I am doing something obviously
wrong please correct me gently!

Hello,

I have noticed a problem when compiling kernel modules outside of the
kernel tree for 2.5(.75). I am compiling a 3rd party network module for
2.5 and it needs to include "linux/netdevice.h" . This file includes a
bunch of other kernel headers which in turn include more kernel headers.
This eventually gets to "asm/irq.h" and on my architechture (i386) this
file has the line

#include "irq_vectors.h"

The problem is that this "irq_vectors.h" file is not found in the same
directory as "irq.h" but in a different directory that is explicitly added
to the include path for the kernel in "arch/i386/Makefile" . This is just
fine for kernel compiles using the kernel makefiles, but for stuff outside
of the tree it means that "irq_vectors.h" won't be found. A solution would
be to to duplicate the relevant sections of the kernel's architecture
specific makefile stuff to calculate and add the include path myself, but
this seems unclean and would require me to add more architecture specific
voodoo for each architecture to be supported.

I believe the proper solution would be for the kernel build system to
create a symbolic link to "irq_vectors.h" in "asm-i386/" just as "asm/"
itself is a symbolic link to "asm-i386/" instead of adding an include path
in the architecture specific makefile that breaks out-of-tree compiles.

Thank you,
Carl Thompson

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