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

Sam Ravnborg sam at ravnborg.org
Sun Mar 26 23:26:01 CEST 2006


On Sun, Mar 26, 2006 at 03:39:32PM -0500, Kyle Moffett wrote:
> On Mar 26, 2006, at 15:05:37, Sam Ravnborg wrote:
> >On Sun, Mar 26, 2006 at 06:54:16AM -0500, Kyle Moffett wrote:
> >>Create initial kernel ABI header infrastructure
> >>
> >>diff --git a/Makefile b/Makefile
> >>index af6210d..8e9045a 100644
> >>--- a/Makefile
> >>+++ b/Makefile
> >>@@ -787,13 +787,15 @@ ifneq ($(KBUILD_SRC),)
> >> 		/bin/false; \
> >> 	fi;
> >> 	$(Q)if [ ! -d include2 ]; then mkdir -p include2; fi;
> >>+	$(Q)if [ ! -d include2/kabi ]; then mkdir -p include2/kabi; fi;
> >> 	$(Q)ln -fsn $(srctree)/include/asm-$(ARCH) include2/asm
> >>+	$(Q)ln -fsn $(srctree)/include/kabi/arch-$(ARCH) include2/kabi/arch
> >
> >No - we do not want another symlink.
> >Create something like:
> >include/i386/kabi-asm/  <= i386 specific files
> >include/kabi/           <= general files
> >
> >Then we can do:
> >LINUXINCLUDE += -Iinclude/kabi-$(ARCH)
> >And the following would work like expected:
> >#include <kabi/foo.h>
> >#include <kabi-asm/foo.h>
> 
> Hmm, I see where you're going with this.  Thanks for the tip!
> 
> >But this leaves all existing users in the dark cold.  So a more  
> >involved approach could be to take the opposite approach. To  
> >dedicate an area for kernel only header files and make sure this  
> >directory is searched _before_ include/
> 
> I'm not entirely sure I understand this bit.  The idea behind this  
> kabi stuff is precisely to split out portions of the headers so that  
> both userspace and kernelspace can get at them; to designate specific  
> items as "userspace clean" by putting them in kabi; everything else  
> need not care at all, and all those headers would remain in include/ 
> linux where they are now.  No sense moving _everything_ in include/  
> around, we just want the parts that userspace needs too.
> 

There are today a great number of users of the existing kernel headers.
Introducing a new namespace for the userspace suers will leave them in a
dilemma where they have to support kernels before kabi, and kernels with
kabi. That alone will limit the acceptance of this.

So shifting to another approach where you take everything that we have
today and clean it up step by step will allow us in small steps to go
from current mess to a clean ernel ABI.
But we will not have this clean and virgin set of headers until a few
years ahead of us.

Keeping include/linux for the kernel ABI will allow us NOT to break
existing users and it will allow a stepwise apporach at the same time.
But what we make clean and virgin is the kernel specific stuff, not the
userspace specific stuff. In final result will be the same but shifting
focus to the kernel internal stuff allows us to do ti in incremental
steps that does NOT break userspace every and so often.
And we will only break external modules that does not use kbuild to
compile - and for hese I really do not care a whit.

Keeping the breakage minimal is the key point here.

	Sam


More information about the llh-discuss mailing list