blob: 47ea5610029322b1e41895a531843606943d4041 [file] [log] [blame]
Patrick Williamsc124f4f2015-09-15 14:41:29 -05001SUMMARY = "GRUB2 is the next-generation GRand Unified Bootloader"
2
3DESCRIPTION = "GRUB2 is the next generaion of a GPLed bootloader \
4intended to unify bootloading across x86 operating systems. In \
5addition to loading the Linux kernel, it implements the Multiboot \
6standard, which allows for flexible loading of multiple boot images."
7
8HOMEPAGE = "http://www.gnu.org/software/grub/"
9SECTION = "bootloaders"
10
Andrew Geissler7e0e3c02022-02-25 20:34:39 +000011LICENSE = "GPL-3.0-only"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050012LIC_FILES_CHKSUM = "file://COPYING;md5=d32239bcb673463ab874e80d47fae504"
13
Andrew Geissler635e0e42020-08-21 15:58:33 -050014CVE_PRODUCT = "grub2"
15
Andrew Geissler09036742021-06-25 14:25:14 -050016SRC_URI = "${GNU_MIRROR}/grub/grub-${PV}.tar.gz \
Brad Bishopd7bf8c12018-02-25 22:55:05 -050017 file://0001-Disable-mfpmath-sse-as-well-when-SSE-is-disabled.patch \
Brad Bishopd7bf8c12018-02-25 22:55:05 -050018 file://autogen.sh-exclude-pc.patch \
19 file://grub-module-explicitly-keeps-symbole-.module_license.patch \
20 file://0001-grub.d-10_linux.in-add-oe-s-kernel-name.patch \
Andrew Geisslerd1e89492021-02-12 15:35:20 -060021 file://determinism.patch \
Andrew Geissler95ac1b82021-03-31 14:34:31 -050022 file://0001-RISC-V-Restore-the-typcast-to-long.patch \
Andrew Geissler595f6302022-01-24 19:11:47 +000023 file://CVE-2021-3981-grub-mkconfig-Restore-umask-for-the-grub.cfg.patch \
Andrew Geissler7e0e3c02022-02-25 20:34:39 +000024 file://0001-configure.ac-Use-_zicsr_zifencei-extentions-on-riscv.patch \
Patrick Williams92b42cb2022-09-03 06:53:57 -050025 file://video-Remove-trailing-whitespaces.patch \
26 file://CVE-2021-3695-video-readers-png-Drop-greyscale-support-to-fix-heap.patch \
27 file://CVE-2021-3696-video-readers-png-Avoid-heap-OOB-R-W-inserting-huff.patch \
28 file://video-readers-jpeg-Abort-sooner-if-a-read-operation-.patch \
29 file://video-readers-jpeg-Refuse-to-handle-multiple-start-o.patch \
30 file://CVE-2021-3697-video-readers-jpeg-Block-int-underflow-wild-pointer.patch \
31 file://CVE-2022-28733-net-ip-Do-IP-fragment-maths-safely.patch \
32 file://CVE-2022-28734-net-http-Fix-OOB-write-for-split-http-headers.patch \
33 file://CVE-2022-28734-net-http-Error-out-on-headers-with-LF-without-CR.patch \
34 file://CVE-2022-28735-kern-efi-sb-Reject-non-kernel-files-in-the-shim_lock.patch \
Brad Bishopd7bf8c12018-02-25 22:55:05 -050035"
Andrew Geissler95ac1b82021-03-31 14:34:31 -050036
Andrew Geissler09036742021-06-25 14:25:14 -050037SRC_URI[sha256sum] = "23b64b4c741569f9426ed2e3d0e6780796fca081bee4c99f62aa3f53ae803f5f"
William A. Kennington IIIac69b482021-06-02 12:28:27 -070038
39# Applies only to RHEL
Andrew Geissler7e0e3c02022-02-25 20:34:39 +000040CVE_CHECK_IGNORE += "CVE-2019-14865"
Andrew Geissler9aee5002022-03-30 16:27:02 +000041# Applies only to SUSE
42CVE_CHECK_IGNORE += "CVE-2021-46705"
William A. Kennington IIIac69b482021-06-02 12:28:27 -070043
Brad Bishop08902b02019-08-20 09:16:51 -040044DEPENDS = "flex-native bison-native gettext-native"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050045
Andrew Geissler6ce62a22020-11-30 19:58:47 -060046COMPATIBLE_HOST = '(x86_64.*|i.86.*|arm.*|aarch64.*|riscv.*)-(linux.*|freebsd.*)'
Patrick Williams213cb262021-08-07 19:21:33 -050047COMPATIBLE_HOST:armv7a = 'null'
48COMPATIBLE_HOST:armv7ve = 'null'
Patrick Williamsc124f4f2015-09-15 14:41:29 -050049
Brad Bishopd7bf8c12018-02-25 22:55:05 -050050# configure.ac has code to set this automagically from the target tuple
51# but the OE freeform one (core2-foo-bar-linux) don't work with that.
52
Patrick Williams213cb262021-08-07 19:21:33 -050053GRUBPLATFORM:arm = "efi"
54GRUBPLATFORM:aarch64 = "efi"
55GRUBPLATFORM:riscv32 = "efi"
56GRUBPLATFORM:riscv64 = "efi"
Brad Bishopd7bf8c12018-02-25 22:55:05 -050057GRUBPLATFORM ??= "pc"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050058
Andrew Geissler82c905d2020-04-13 13:39:40 -050059inherit autotools gettext texinfo pkgconfig
Patrick Williamsc124f4f2015-09-15 14:41:29 -050060
Patrick Williams213cb262021-08-07 19:21:33 -050061CFLAGS:remove = "-O2"
William A. Kennington IIIac69b482021-06-02 12:28:27 -070062
Brad Bishopd7bf8c12018-02-25 22:55:05 -050063EXTRA_OECONF = "--with-platform=${GRUBPLATFORM} \
64 --disable-grub-mkfont \
65 --program-prefix="" \
66 --enable-liblzma=no \
67 --enable-libzfs=no \
68 --enable-largefile \
Brad Bishop08902b02019-08-20 09:16:51 -040069 --disable-werror \
Brad Bishopd7bf8c12018-02-25 22:55:05 -050070"
71
Patrick Williamsc124f4f2015-09-15 14:41:29 -050072PACKAGECONFIG ??= ""
73PACKAGECONFIG[grub-mount] = "--enable-grub-mount,--disable-grub-mount,fuse"
Brad Bishop316dfdd2018-06-25 12:45:53 -040074PACKAGECONFIG[device-mapper] = "--enable-device-mapper,--disable-device-mapper,libdevmapper"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050075
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050076# grub2 creates its own set of -nostdinc / -isystem / -ffreestanding CFLAGS and
77# OE's default BUILD_CFLAGS (assigned to CFLAGS for native builds) etc, conflict
78# with that. Note that since BUILD_CFLAGS etc are not used by grub2 target
79# builds, it's safe to clear them unconditionally for both target and native.
80BUILD_CPPFLAGS = ""
81BUILD_CFLAGS = ""
82BUILD_CXXFLAGS = ""
83BUILD_LDFLAGS = ""
84
Brad Bishop96ff1982019-08-19 13:50:42 -040085export PYTHON = "python3"
86
Patrick Williams213cb262021-08-07 19:21:33 -050087do_configure:prepend() {
Andrew Geissler82c905d2020-04-13 13:39:40 -050088 cd ${S}
89 FROM_BOOTSTRAP=1 ${S}/autogen.sh
90 cd ${B}
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050091}