blob: 175b2d18194b815b320e8c4f06dc278cbae18338 [file] [log] [blame]
Patrick Williamsc124f4f2015-09-15 14:41:29 -05001SUMMARY = "Sanitized set of kernel headers for the C library's use"
Andrew Geissler95ac1b82021-03-31 14:34:31 -05002HOMEPAGE = "https://www.kernel.org/"
Andrew Geissler90fd73c2021-03-05 15:25:55 -06003DESCRIPTION = "Designed to maintain an Application Programming Interface (API) stable version of the Linux headers"
Patrick Williamsc124f4f2015-09-15 14:41:29 -05004SECTION = "devel"
5LICENSE = "GPLv2"
6
7#########################################################################
8#### PLEASE READ
9#########################################################################
10#
11# You're probably looking here thinking you need to create some new copy
12# of linux-libc-headers since you have your own custom kernel. To put
13# this simply, you DO NOT.
14#
15# Why? These headers are used to build the libc. If you customise the
16# headers you are customising the libc and the libc becomes machine
17# specific. Most people do not add custom libc extensions to the kernel
18# and have a machine specific libc.
19#
20# But you have some kernel headers you need for some driver? That is fine
Andrew Geisslerc9f78652020-09-18 14:11:35 -050021# but get them from STAGING_KERNEL_BUILDDIR where the kernel installs itself.
Patrick Williamsc124f4f2015-09-15 14:41:29 -050022# This will make the package using them machine specific but this is much
Patrick Williamsc0f7c042017-02-23 20:41:17 -060023# better than having a machine specific C library. This does mean your
24# recipe needs a
25# do_configure[depends] += "virtual/kernel:do_shared_workdir"
26# but again, that is fine and makes total sense.
Patrick Williamsc124f4f2015-09-15 14:41:29 -050027#
28# There can also be a case where your kernel extremely old and you want
29# an older libc ABI for that old kernel. The headers installed by this
30# recipe should still be a standard mainline kernel, not your own custom
31# one.
32#
33# -- RP
34
Andrew Geissler635e0e42020-08-21 15:58:33 -050035LIC_FILES_CHKSUM ?= "file://COPYING;md5=bbea815ee2795b2f4230826c0c6b8814"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050036
Andrew Geissler5a43b432020-06-13 10:46:56 -050037RECIPE_NO_UPDATE_REASON = "Recipe is updated through a separate process"
38
Patrick Williamsc124f4f2015-09-15 14:41:29 -050039python __anonymous () {
Brad Bishop6e60e8b2018-02-01 10:27:11 -050040 major = d.getVar("PV").split('.')[0]
Patrick Williamsc124f4f2015-09-15 14:41:29 -050041 if major == "3":
42 d.setVar("HEADER_FETCH_VER", "3.0")
43 elif major == "4":
44 d.setVar("HEADER_FETCH_VER", "4.x")
Brad Bishop19323692019-04-05 15:28:33 -040045 elif major == "5":
46 d.setVar("HEADER_FETCH_VER", "5.x")
Patrick Williamsc124f4f2015-09-15 14:41:29 -050047 else:
48 d.setVar("HEADER_FETCH_VER", "2.6")
49}
50
Andrew Geissler635e0e42020-08-21 15:58:33 -050051MAJ_VER = "${@oe.utils.trim_version("${PV}", 2).split('.')[0]}"
52MIN_VER = "${@oe.utils.trim_version("${PV}", 2).split('.')[1]}"
53
Brad Bishop6e60e8b2018-02-01 10:27:11 -050054inherit kernel-arch pkgconfig multilib_header
Patrick Williamsc124f4f2015-09-15 14:41:29 -050055
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050056KORG_ARCHIVE_COMPRESSION ?= "xz"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050057
58SRC_URI = "${KERNELORG_MIRROR}/linux/kernel/v${HEADER_FETCH_VER}/linux-${PV}.tar.${KORG_ARCHIVE_COMPRESSION}"
Brad Bishop6e60e8b2018-02-01 10:27:11 -050059UPSTREAM_CHECK_URI = "https://www.kernel.org/"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050060
61S = "${WORKDIR}/linux-${PV}"
62
Patrick Williamsc0f7c042017-02-23 20:41:17 -060063EXTRA_OEMAKE = " HOSTCC="${BUILD_CC}" HOSTCPP="${BUILD_CPP}""
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050064
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080065do_configure[noexec] = "1"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050066
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080067do_compile[noexec] = "1"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050068
69do_install() {
70 oe_runmake headers_install INSTALL_HDR_PATH=${D}${exec_prefix}
71 # Kernel should not be exporting this header
72 rm -f ${D}${exec_prefix}/include/scsi/scsi.h
73
74 # The ..install.cmd conflicts between various configure runs
75 find ${D}${includedir} -name ..install.cmd | xargs rm -f
76}
77
Brad Bishop6e60e8b2018-02-01 10:27:11 -050078do_install_append_aarch64 () {
79 do_install_armmultilib
80}
81
82do_install_append_arm () {
83 do_install_armmultilib
84}
85
Brad Bishopd5ae7d92018-06-14 09:52:03 -070086do_install_append_armeb () {
87 do_install_armmultilib
88}
89
Brad Bishop6e60e8b2018-02-01 10:27:11 -050090do_install_armmultilib () {
Andrew Geissler635e0e42020-08-21 15:58:33 -050091 if [ ${MAJ_VER} -gt 5 ]; then
92 ARM_KVM_HEADER=""
93 else
94 if [ ${MAJ_VER} -eq 5 ] && [ ${MIN_VER} -ge 8 ]; then
95 ARM_KVM_HEADER=""
96 else
97 ARM_KVM_HEADER="asm/kvm.h"
98 fi
99 fi
100 oe_multilib_header asm/auxvec.h asm/bitsperlong.h asm/byteorder.h asm/fcntl.h asm/hwcap.h asm/ioctls.h $ARM_KVM_HEADER asm/kvm_para.h asm/mman.h asm/param.h asm/perf_regs.h asm/bpf_perf_event.h
Brad Bishop6e60e8b2018-02-01 10:27:11 -0500101 oe_multilib_header asm/posix_types.h asm/ptrace.h asm/setup.h asm/sigcontext.h asm/siginfo.h asm/signal.h asm/stat.h asm/statfs.h asm/swab.h asm/types.h asm/unistd.h
102}
103
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500104BBCLASSEXTEND = "nativesdk"
105
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500106RDEPENDS_${PN}-dev = ""
107RRECOMMENDS_${PN}-dbg = "${PN}-dev (= ${EXTENDPKGV})"
108
109INHIBIT_DEFAULT_DEPS = "1"
Andrew Geissler82c905d2020-04-13 13:39:40 -0500110DEPENDS += "unifdef-native bison-native rsync-native"