blob: 3a8d32e7857136bf779298133f9d0a4a9bf2a38f [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"
Andrew Geissler7e0e3c02022-02-25 20:34:39 +00005LICENSE = "GPL-2.0-only"
Patrick Williamsc124f4f2015-09-15 14:41:29 -05006
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")
Andrew Geissler517393d2023-01-13 08:55:19 -060047 elif major == "6":
48 d.setVar("HEADER_FETCH_VER", "6.x")
Patrick Williamsc124f4f2015-09-15 14:41:29 -050049 else:
50 d.setVar("HEADER_FETCH_VER", "2.6")
51}
52
Andrew Geissler635e0e42020-08-21 15:58:33 -050053MAJ_VER = "${@oe.utils.trim_version("${PV}", 2).split('.')[0]}"
54MIN_VER = "${@oe.utils.trim_version("${PV}", 2).split('.')[1]}"
55
Brad Bishop6e60e8b2018-02-01 10:27:11 -050056inherit kernel-arch pkgconfig multilib_header
Patrick Williamsc124f4f2015-09-15 14:41:29 -050057
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050058KORG_ARCHIVE_COMPRESSION ?= "xz"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050059
60SRC_URI = "${KERNELORG_MIRROR}/linux/kernel/v${HEADER_FETCH_VER}/linux-${PV}.tar.${KORG_ARCHIVE_COMPRESSION}"
Brad Bishop6e60e8b2018-02-01 10:27:11 -050061UPSTREAM_CHECK_URI = "https://www.kernel.org/"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050062
63S = "${WORKDIR}/linux-${PV}"
64
Patrick Williamsc0f7c042017-02-23 20:41:17 -060065EXTRA_OEMAKE = " HOSTCC="${BUILD_CC}" HOSTCPP="${BUILD_CPP}""
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050066
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080067do_configure[noexec] = "1"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050068
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080069do_compile[noexec] = "1"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050070
71do_install() {
72 oe_runmake headers_install INSTALL_HDR_PATH=${D}${exec_prefix}
73 # Kernel should not be exporting this header
74 rm -f ${D}${exec_prefix}/include/scsi/scsi.h
75
76 # The ..install.cmd conflicts between various configure runs
77 find ${D}${includedir} -name ..install.cmd | xargs rm -f
78}
79
Patrick Williams213cb262021-08-07 19:21:33 -050080do_install:append:aarch64 () {
Brad Bishop6e60e8b2018-02-01 10:27:11 -050081 do_install_armmultilib
82}
83
Patrick Williams213cb262021-08-07 19:21:33 -050084do_install:append:arm () {
Brad Bishop6e60e8b2018-02-01 10:27:11 -050085 do_install_armmultilib
86}
87
Patrick Williams213cb262021-08-07 19:21:33 -050088do_install:append:armeb () {
Brad Bishopd5ae7d92018-06-14 09:52:03 -070089 do_install_armmultilib
90}
91
Brad Bishop6e60e8b2018-02-01 10:27:11 -050092do_install_armmultilib () {
Andrew Geissler635e0e42020-08-21 15:58:33 -050093 if [ ${MAJ_VER} -gt 5 ]; then
94 ARM_KVM_HEADER=""
95 else
96 if [ ${MAJ_VER} -eq 5 ] && [ ${MIN_VER} -ge 8 ]; then
97 ARM_KVM_HEADER=""
98 else
99 ARM_KVM_HEADER="asm/kvm.h"
100 fi
101 fi
102 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 -0500103 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
104}
105
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500106BBCLASSEXTEND = "nativesdk"
107
Andrew Geissler615f2f12022-07-15 14:00:58 -0500108DEV_PKG_DEPENDENCY = ""
Patrick Williams213cb262021-08-07 19:21:33 -0500109RRECOMMENDS:${PN}-dbg = "${PN}-dev (= ${EXTENDPKGV})"
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500110
111INHIBIT_DEFAULT_DEPS = "1"
Andrew Geissler82c905d2020-04-13 13:39:40 -0500112DEPENDS += "unifdef-native bison-native rsync-native"