summaryrefslogtreecommitdiffstats
path: root/meta/recipes-kernel/linux-libc-headers/linux-libc-headers.inc
diff options
context:
space:
mode:
Diffstat (limited to 'meta/recipes-kernel/linux-libc-headers/linux-libc-headers.inc')
-rw-r--r--meta/recipes-kernel/linux-libc-headers/linux-libc-headers.inc73
1 files changed, 73 insertions, 0 deletions
diff --git a/meta/recipes-kernel/linux-libc-headers/linux-libc-headers.inc b/meta/recipes-kernel/linux-libc-headers/linux-libc-headers.inc
new file mode 100644
index 0000000000..b18d09fd6c
--- /dev/null
+++ b/meta/recipes-kernel/linux-libc-headers/linux-libc-headers.inc
@@ -0,0 +1,73 @@
1SUMMARY = "Sanitized set of kernel headers for the C library's use"
2SECTION = "devel"
3LICENSE = "GPLv2"
4
5#########################################################################
6#### PLEASE READ
7#########################################################################
8#
9# You're probably looking here thinking you need to create some new copy
10# of linux-libc-headers since you have your own custom kernel. To put
11# this simply, you DO NOT.
12#
13# Why? These headers are used to build the libc. If you customise the
14# headers you are customising the libc and the libc becomes machine
15# specific. Most people do not add custom libc extensions to the kernel
16# and have a machine specific libc.
17#
18# But you have some kernel headers you need for some driver? That is fine
19# but get them from STAGING_KERNEL_DIR where the kernel installs itself.
20# This will make the package using them machine specific but this is much
21# better than having a machine specific C library. This does mean your
22# recipe needs a DEPENDS += "virtual/kernel" but again, that is fine and
23# makes total sense.
24#
25# There can also be a case where your kernel extremely old and you want
26# an older libc ABI for that old kernel. The headers installed by this
27# recipe should still be a standard mainline kernel, not your own custom
28# one.
29#
30# -- RP
31
32LIC_FILES_CHKSUM = "file://COPYING;md5=d7810fab7487fb0aad327b76f1be7cd7"
33
34python __anonymous () {
35 major = d.getVar("PV",True).split('.')[0]
36 if major == "3":
37 d.setVar("HEADER_FETCH_VER", "3.0")
38 else:
39 d.setVar("HEADER_FETCH_VER", "2.6")
40}
41
42inherit kernel-arch
43
44KORG_ARCHIVE_COMPRESSION ?= "bz2"
45
46SRC_URI = "${KERNELORG_MIRROR}/linux/kernel/v${HEADER_FETCH_VER}/linux-${PV}.tar.${KORG_ARCHIVE_COMPRESSION}"
47
48S = "${WORKDIR}/linux-${PV}"
49
50do_configure() {
51 oe_runmake allnoconfig
52}
53
54do_compile () {
55}
56
57do_install() {
58 oe_runmake headers_install INSTALL_HDR_PATH=${D}${exec_prefix}
59 # Kernel should not be exporting this header
60 rm -f ${D}${exec_prefix}/include/scsi/scsi.h
61
62 # The ..install.cmd conflicts between various configure runs
63 find ${D}${includedir} -name ..install.cmd | xargs rm -f
64}
65
66BBCLASSEXTEND = "nativesdk"
67
68#DEPENDS = "cross-linkage"
69RDEPENDS_${PN}-dev = ""
70RRECOMMENDS_${PN}-dbg = "${PN}-dev (= ${EXTENDPKGV})"
71
72INHIBIT_DEFAULT_DEPS = "1"
73DEPENDS += "unifdef-native"