grub2.mk 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. ################################################################################
  2. #
  3. # grub2
  4. #
  5. ################################################################################
  6. GRUB2_VERSION = 2.04
  7. GRUB2_SITE = http://ftp.gnu.org/gnu/grub
  8. GRUB2_SOURCE = grub-$(GRUB2_VERSION).tar.xz
  9. GRUB2_LICENSE = GPL-3.0+
  10. GRUB2_LICENSE_FILES = COPYING
  11. GRUB2_DEPENDENCIES = host-bison host-flex host-grub2
  12. HOST_GRUB2_DEPENDENCIES = host-bison host-flex
  13. GRUB2_INSTALL_IMAGES = YES
  14. # 0001-build-Fix-GRUB-i386-pc-build-with-Ubuntu-gcc.patch and 2021/03/02
  15. # security fixes (patches 0029-0149)
  16. define GRUB2_AVOID_AUTORECONF
  17. $(Q)touch $(@D)/Makefile.util.am
  18. $(Q)touch $(@D)/aclocal.m4
  19. $(Q)touch $(@D)/Makefile.in
  20. $(Q)touch $(@D)/configure
  21. endef
  22. GRUB2_POST_PATCH_HOOKS += GRUB2_AVOID_AUTORECONF
  23. HOST_GRUB2_POST_PATCH_HOOKS += GRUB2_AVOID_AUTORECONF
  24. # 0002-yylex-Make-lexer-fatal-errors-actually-be-fatal.patch
  25. GRUB2_IGNORE_CVES += CVE-2020-10713
  26. # 0005-calloc-Use-calloc-at-most-places.patch
  27. GRUB2_IGNORE_CVES += CVE-2020-14308
  28. # 0006-malloc-Use-overflow-checking-primitives-where-we-do-.patch
  29. GRUB2_IGNORE_CVES += CVE-2020-14309 CVE-2020-14310 CVE-2020-14311
  30. # 0019-script-Avoid-a-use-after-free-when-redefining-a-func.patch
  31. GRUB2_IGNORE_CVES += CVE-2020-15706
  32. # 0028-linux-Fix-integer-overflows-in-initrd-size-handling.patch
  33. GRUB2_IGNORE_CVES += CVE-2020-15707
  34. # 2021/03/02 security fixes - patches 0029-0149
  35. GRUB2_IGNORE_CVES += CVE-2020-25632 CVE-2020-25647 CVE-2020-27749 \
  36. CVE-2020-27779 CVE-2021-3418 CVE-2021-20225 CVE-2021-20233
  37. # 0039-acpi-Don-t-register-the-acpi-command-when-locked-dow.patch
  38. GRUB2_IGNORE_CVES += CVE-2020-14372
  39. # CVE-2019-14865 is about a flaw in the grub2-set-bootflag tool, which
  40. # doesn't exist upstream, but is added by the Redhat/Fedora
  41. # packaging. Not applicable to Buildroot.
  42. GRUB2_IGNORE_CVES += CVE-2019-14865
  43. # CVE-2020-15705 is related to a flaw in the use of the
  44. # grub_linuxefi_secure_validate(), which was added by Debian/Ubuntu
  45. # patches. The issue doesn't affect upstream Grub, and
  46. # grub_linuxefi_secure_validate() is not implemented in the grub2
  47. # version available in Buildroot.
  48. GRUB2_IGNORE_CVES += CVE-2020-15705
  49. ifeq ($(BR2_TARGET_GRUB2_INSTALL_TOOLS),y)
  50. GRUB2_INSTALL_TARGET = YES
  51. else
  52. GRUB2_INSTALL_TARGET = NO
  53. endif
  54. GRUB2_CPE_ID_VENDOR = gnu
  55. GRUB2_BUILTIN_MODULES = $(call qstrip,$(BR2_TARGET_GRUB2_BUILTIN_MODULES))
  56. GRUB2_BUILTIN_CONFIG = $(call qstrip,$(BR2_TARGET_GRUB2_BUILTIN_CONFIG))
  57. GRUB2_BOOT_PARTITION = $(call qstrip,$(BR2_TARGET_GRUB2_BOOT_PARTITION))
  58. ifeq ($(BR2_TARGET_GRUB2_I386_PC),y)
  59. GRUB2_IMAGE = $(BINARIES_DIR)/grub.img
  60. GRUB2_CFG = $(TARGET_DIR)/boot/grub/grub.cfg
  61. GRUB2_PREFIX = ($(GRUB2_BOOT_PARTITION))/boot/grub
  62. GRUB2_TUPLE = i386-pc
  63. GRUB2_TARGET = i386
  64. GRUB2_PLATFORM = pc
  65. else ifeq ($(BR2_TARGET_GRUB2_I386_EFI),y)
  66. GRUB2_IMAGE = $(BINARIES_DIR)/efi-part/EFI/BOOT/bootia32.efi
  67. GRUB2_CFG = $(BINARIES_DIR)/efi-part/EFI/BOOT/grub.cfg
  68. GRUB2_PREFIX = /EFI/BOOT
  69. GRUB2_TUPLE = i386-efi
  70. GRUB2_TARGET = i386
  71. GRUB2_PLATFORM = efi
  72. else ifeq ($(BR2_TARGET_GRUB2_X86_64_EFI),y)
  73. GRUB2_IMAGE = $(BINARIES_DIR)/efi-part/EFI/BOOT/bootx64.efi
  74. GRUB2_CFG = $(BINARIES_DIR)/efi-part/EFI/BOOT/grub.cfg
  75. GRUB2_PREFIX = /EFI/BOOT
  76. GRUB2_TUPLE = x86_64-efi
  77. GRUB2_TARGET = x86_64
  78. GRUB2_PLATFORM = efi
  79. else ifeq ($(BR2_TARGET_GRUB2_ARM_UBOOT),y)
  80. GRUB2_IMAGE = $(BINARIES_DIR)/boot-part/grub/grub.img
  81. GRUB2_CFG = $(BINARIES_DIR)/boot-part/grub/grub.cfg
  82. GRUB2_PREFIX = ($(GRUB2_BOOT_PARTITION))/boot/grub
  83. GRUB2_TUPLE = arm-uboot
  84. GRUB2_TARGET = arm
  85. GRUB2_PLATFORM = uboot
  86. else ifeq ($(BR2_TARGET_GRUB2_ARM_EFI),y)
  87. GRUB2_IMAGE = $(BINARIES_DIR)/efi-part/EFI/BOOT/bootarm.efi
  88. GRUB2_CFG = $(BINARIES_DIR)/efi-part/EFI/BOOT/grub.cfg
  89. GRUB2_PREFIX = /EFI/BOOT
  90. GRUB2_TUPLE = arm-efi
  91. GRUB2_TARGET = arm
  92. GRUB2_PLATFORM = efi
  93. else ifeq ($(BR2_TARGET_GRUB2_ARM64_EFI),y)
  94. GRUB2_IMAGE = $(BINARIES_DIR)/efi-part/EFI/BOOT/bootaa64.efi
  95. GRUB2_CFG = $(BINARIES_DIR)/efi-part/EFI/BOOT/grub.cfg
  96. GRUB2_PREFIX = /EFI/BOOT
  97. GRUB2_TUPLE = arm64-efi
  98. GRUB2_TARGET = aarch64
  99. GRUB2_PLATFORM = efi
  100. endif
  101. # Grub2 is kind of special: it considers CC, LD and so on to be the
  102. # tools to build the host programs and uses TARGET_CC, TARGET_CFLAGS,
  103. # TARGET_CPPFLAGS, TARGET_LDFLAGS to build the bootloader itself.
  104. #
  105. # NOTE: TARGET_STRIP is overridden by !BR2_STRIP_strip, so always
  106. # use the cross compile variant to ensure grub2 builds
  107. HOST_GRUB2_CONF_ENV = \
  108. CPP="$(HOSTCC) -E"
  109. GRUB2_CONF_ENV = \
  110. CPP="$(TARGET_CC) -E" \
  111. TARGET_CC="$(TARGET_CC)" \
  112. TARGET_CFLAGS="$(TARGET_CFLAGS)" \
  113. TARGET_CPPFLAGS="$(TARGET_CPPFLAGS) -fno-stack-protector" \
  114. TARGET_LDFLAGS="$(TARGET_LDFLAGS)" \
  115. TARGET_NM="$(TARGET_NM)" \
  116. TARGET_OBJCOPY="$(TARGET_OBJCOPY)" \
  117. TARGET_STRIP="$(TARGET_CROSS)strip"
  118. GRUB2_CONF_OPTS = \
  119. --target=$(GRUB2_TARGET) \
  120. --with-platform=$(GRUB2_PLATFORM) \
  121. --prefix=/ \
  122. --exec-prefix=/ \
  123. --disable-grub-mkfont \
  124. --enable-efiemu=no \
  125. ac_cv_lib_lzma_lzma_code=no \
  126. --enable-device-mapper=no \
  127. --enable-libzfs=no \
  128. --disable-werror
  129. HOST_GRUB2_CONF_OPTS = \
  130. --disable-grub-mkfont \
  131. --enable-efiemu=no \
  132. ac_cv_lib_lzma_lzma_code=no \
  133. --enable-device-mapper=no \
  134. --enable-libzfs=no \
  135. --disable-werror
  136. ifeq ($(BR2_TARGET_GRUB2_I386_PC),y)
  137. define GRUB2_IMAGE_INSTALL_ELTORITO
  138. cat $(HOST_DIR)/lib/grub/$(GRUB2_TUPLE)/cdboot.img $(GRUB2_IMAGE) > \
  139. $(BINARIES_DIR)/grub-eltorito.img
  140. endef
  141. endif
  142. define GRUB2_INSTALL_IMAGES_CMDS
  143. mkdir -p $(dir $(GRUB2_IMAGE))
  144. $(HOST_DIR)/usr/bin/grub-mkimage \
  145. -d $(@D)/grub-core/ \
  146. -O $(GRUB2_TUPLE) \
  147. -o $(GRUB2_IMAGE) \
  148. -p "$(GRUB2_PREFIX)" \
  149. $(if $(GRUB2_BUILTIN_CONFIG),-c $(GRUB2_BUILTIN_CONFIG)) \
  150. $(GRUB2_BUILTIN_MODULES)
  151. mkdir -p $(dir $(GRUB2_CFG))
  152. $(INSTALL) -D -m 0644 boot/grub2/grub.cfg $(GRUB2_CFG)
  153. $(GRUB2_IMAGE_INSTALL_ELTORITO)
  154. endef
  155. ifeq ($(GRUB2_PLATFORM),efi)
  156. define GRUB2_EFI_STARTUP_NSH
  157. echo $(notdir $(GRUB2_IMAGE)) > \
  158. $(BINARIES_DIR)/efi-part/startup.nsh
  159. endef
  160. GRUB2_POST_INSTALL_IMAGES_HOOKS += GRUB2_EFI_STARTUP_NSH
  161. endif
  162. $(eval $(autotools-package))
  163. $(eval $(host-autotools-package))