diff options
| author | Rob Landley <rob@landley.net> | 2007-10-17 02:31:16 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-17 11:43:05 -0400 |
| commit | 451ad114c6d8c5d39fd41d886fe87179d012ac73 (patch) | |
| tree | 48fad4816938f4113df89ee13b6aa4205fef740d /Documentation | |
| parent | 1ee052253c780493fa8814c1fe83e87494ae694d (diff) | |
Documentation/make/headers_install.txt
Some documentation for "make headers_install".
Signed-off-by: Rob Landley <rob@landley.net>
Cc: David Woodhouse <dwmw2@infradead.org>
Cc: Sam Ravnborg <sam@ravnborg.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'Documentation')
| -rw-r--r-- | Documentation/make/headers_install.txt | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/Documentation/make/headers_install.txt b/Documentation/make/headers_install.txt new file mode 100644 index 000000000000..f2481cabffcb --- /dev/null +++ b/Documentation/make/headers_install.txt | |||
| @@ -0,0 +1,46 @@ | |||
| 1 | Exporting kernel headers for use by userspace | ||
| 2 | ============================================= | ||
| 3 | |||
| 4 | The "make headers_install" command exports the kernel's header files in a | ||
| 5 | form suitable for use by userspace programs. | ||
| 6 | |||
| 7 | The linux kernel's exported header files describe the API for user space | ||
| 8 | programs attempting to use kernel services. These kernel header files are | ||
| 9 | used by the system's C library (such as glibc or uClibc) to define available | ||
| 10 | system calls, as well as constants and structures to be used with these | ||
| 11 | system calls. The C library's header files include the kernel header files | ||
| 12 | from the "linux" subdirectory. The system's libc headers are usually | ||
| 13 | installed at the default location /usr/include and the kernel headers in | ||
| 14 | subdirectories under that (most notably /usr/include/linux and | ||
| 15 | /usr/include/asm). | ||
| 16 | |||
| 17 | Kernel headers are backwards compatible, but not forwards compatible. This | ||
| 18 | means that a program built against a C library using older kernel headers | ||
| 19 | should run on a newer kernel (although it may not have access to new | ||
| 20 | features), but a program built against newer kernel headers may not work on an | ||
| 21 | older kernel. | ||
| 22 | |||
| 23 | The "make headers_install" command can be run in the top level directory of the | ||
| 24 | kernel source code (or using a standard out-of-tree build). It takes two | ||
| 25 | optional arguments: | ||
| 26 | |||
| 27 | make headers_install ARCH=i386 INSTALL_HDR_PATH=/usr/include | ||
| 28 | |||
| 29 | ARCH indicates which architecture to produce headers for, and defaults to the | ||
| 30 | current architecture. The linux/asm directory of the exported kernel headers | ||
| 31 | is platform-specific, to see a complete list of supported architectures use | ||
| 32 | the command: | ||
| 33 | |||
| 34 | ls -d include/asm-* | sed 's/.*-//' | ||
| 35 | |||
| 36 | INSTALL_HDR_PATH indicates where to install the headers. It defaults to | ||
| 37 | "./usr/include". | ||
| 38 | |||
| 39 | The command "make headers_install_all" exports headers for all architectures | ||
| 40 | simultaneously. (This is mostly of interest to distribution maintainers, | ||
| 41 | who create an architecture-independent tarball from the resulting include | ||
| 42 | directory.) Remember to provide the appropriate linux/asm directory via "mv" | ||
| 43 | or "ln -s" before building a C library with headers exported this way. | ||
| 44 | |||
| 45 | The kernel header export infrastructure is maintained by David Woodhouse | ||
| 46 | <dwmw2@infradead.org>. | ||
