blob: f0153adb95e2c3cbf564bac30b3c48b06118d8c8 [file] [log] [blame]
Rob Landley451ad112007-10-16 23:31:16 -07001Exporting kernel headers for use by userspace
2=============================================
3
4The "make headers_install" command exports the kernel's header files in a
5form suitable for use by userspace programs.
6
7The linux kernel's exported header files describe the API for user space
8programs attempting to use kernel services. These kernel header files are
9used by the system's C library (such as glibc or uClibc) to define available
10system calls, as well as constants and structures to be used with these
11system calls. The C library's header files include the kernel header files
12from the "linux" subdirectory. The system's libc headers are usually
13installed at the default location /usr/include and the kernel headers in
14subdirectories under that (most notably /usr/include/linux and
15/usr/include/asm).
16
17Kernel headers are backwards compatible, but not forwards compatible. This
18means that a program built against a C library using older kernel headers
19should run on a newer kernel (although it may not have access to new
20features), but a program built against newer kernel headers may not work on an
21older kernel.
22
23The "make headers_install" command can be run in the top level directory of the
24kernel source code (or using a standard out-of-tree build). It takes two
25optional arguments:
26
Anish Bhatted45d402015-06-08 17:37:31 -070027 make headers_install ARCH=i386 INSTALL_HDR_PATH=/usr
Rob Landley451ad112007-10-16 23:31:16 -070028
29ARCH indicates which architecture to produce headers for, and defaults to the
30current architecture. The linux/asm directory of the exported kernel headers
31is platform-specific, to see a complete list of supported architectures use
32the command:
33
34 ls -d include/asm-* | sed 's/.*-//'
35
Anish Bhatted45d402015-06-08 17:37:31 -070036INSTALL_HDR_PATH indicates where to install the headers. It defaults to
37"./usr".
38
39An 'include' directory is automatically created inside INSTALL_HDR_PATH and
40headers are installed in 'INSTALL_HDR_PATH/include'.
Rob Landley451ad112007-10-16 23:31:16 -070041
42The command "make headers_install_all" exports headers for all architectures
43simultaneously. (This is mostly of interest to distribution maintainers,
44who create an architecture-independent tarball from the resulting include
Kirill A. Shutemovf6820302010-12-13 19:10:28 +020045directory.) You also can use HDR_ARCH_LIST to specify list of architectures.
46Remember to provide the appropriate linux/asm directory via "mv" or "ln -s"
47before building a C library with headers exported this way.
Rob Landley451ad112007-10-16 23:31:16 -070048
49The kernel header export infrastructure is maintained by David Woodhouse
50<dwmw2@infradead.org>.