-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
yaml --- r: 70776 b: refs/heads/master c: 451ad11 h: refs/heads/master v: v3
- Loading branch information
Rob Landley
authored and
Linus Torvalds
committed
Oct 17, 2007
1 parent
f2a0be0
commit 2015357
Showing
2 changed files
with
47 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,2 @@ | ||
--- | ||
refs/heads/master: 1ee052253c780493fa8814c1fe83e87494ae694d | ||
refs/heads/master: 451ad114c6d8c5d39fd41d886fe87179d012ac73 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
Exporting kernel headers for use by userspace | ||
============================================= | ||
|
||
The "make headers_install" command exports the kernel's header files in a | ||
form suitable for use by userspace programs. | ||
|
||
The linux kernel's exported header files describe the API for user space | ||
programs attempting to use kernel services. These kernel header files are | ||
used by the system's C library (such as glibc or uClibc) to define available | ||
system calls, as well as constants and structures to be used with these | ||
system calls. The C library's header files include the kernel header files | ||
from the "linux" subdirectory. The system's libc headers are usually | ||
installed at the default location /usr/include and the kernel headers in | ||
subdirectories under that (most notably /usr/include/linux and | ||
/usr/include/asm). | ||
|
||
Kernel headers are backwards compatible, but not forwards compatible. This | ||
means that a program built against a C library using older kernel headers | ||
should run on a newer kernel (although it may not have access to new | ||
features), but a program built against newer kernel headers may not work on an | ||
older kernel. | ||
|
||
The "make headers_install" command can be run in the top level directory of the | ||
kernel source code (or using a standard out-of-tree build). It takes two | ||
optional arguments: | ||
|
||
make headers_install ARCH=i386 INSTALL_HDR_PATH=/usr/include | ||
|
||
ARCH indicates which architecture to produce headers for, and defaults to the | ||
current architecture. The linux/asm directory of the exported kernel headers | ||
is platform-specific, to see a complete list of supported architectures use | ||
the command: | ||
|
||
ls -d include/asm-* | sed 's/.*-//' | ||
|
||
INSTALL_HDR_PATH indicates where to install the headers. It defaults to | ||
"./usr/include". | ||
|
||
The command "make headers_install_all" exports headers for all architectures | ||
simultaneously. (This is mostly of interest to distribution maintainers, | ||
who create an architecture-independent tarball from the resulting include | ||
directory.) Remember to provide the appropriate linux/asm directory via "mv" | ||
or "ln -s" before building a C library with headers exported this way. | ||
|
||
The kernel header export infrastructure is maintained by David Woodhouse | ||
<dwmw2@infradead.org>. |