grub2.mk 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. ################################################################################
  2. #
  3. # grub2
  4. #
  5. ################################################################################
  6. GRUB2_VERSION = 2.06
  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-Makefile-Make-grub_fstest.pp-depend-on-config-util.h.patch
  15. define GRUB2_AVOID_AUTORECONF
  16. $(Q)touch $(@D)/Makefile.in
  17. endef
  18. GRUB2_POST_PATCH_HOOKS += GRUB2_AVOID_AUTORECONF
  19. HOST_GRUB2_POST_PATCH_HOOKS += GRUB2_AVOID_AUTORECONF
  20. # CVE-2019-14865 is about a flaw in the grub2-set-bootflag tool, which
  21. # doesn't exist upstream, but is added by the Redhat/Fedora
  22. # packaging. Not applicable to Buildroot.
  23. GRUB2_IGNORE_CVES += CVE-2019-14865
  24. # CVE-2020-15705 is related to a flaw in the use of the
  25. # grub_linuxefi_secure_validate(), which was added by Debian/Ubuntu
  26. # patches. The issue doesn't affect upstream Grub, and
  27. # grub_linuxefi_secure_validate() is not implemented in the grub2
  28. # version available in Buildroot.
  29. GRUB2_IGNORE_CVES += CVE-2020-15705
  30. # 0002-grub-mkconfig-Restore-umask-for-the-grub.cfg.patch
  31. GRUB2_IGNORE_CVES += CVE-2021-3981
  32. # vulnerability is specific to the SUSE distribution
  33. GRUB2_IGNORE_CVES += CVE-2021-46705
  34. # 0005-loader-efi-chainloader-Use-grub_loader_set_ex.patch
  35. GRUB2_IGNORE_CVES += CVE-2022-28736
  36. # 0006-kern-efi-sb-Reject-non-kernel-files-in-the-shim_lock.patch
  37. GRUB2_IGNORE_CVES += CVE-2022-28735
  38. # 0010-video-readers-png-Drop-greyscale-support-to-fix-heap.patch
  39. GRUB2_IGNORE_CVES += CVE-2021-3695
  40. # 0011-video-readers-png-Avoid-heap-OOB-R-W-inserting-huff-.patch
  41. GRUB2_IGNORE_CVES += CVE-2021-3696
  42. # 0012-video-readers-jpeg-Block-int-underflow-wild-pointer-.patch
  43. GRUB2_IGNORE_CVES += CVE-2021-3697
  44. # 0013-net-ip-Do-IP-fragment-maths-safely.patch
  45. GRUB2_IGNORE_CVES += CVE-2022-28733
  46. # 0014-net-http-Fix-OOB-write-for-split-http-headers.patch
  47. # 0015-net-http-Error-out-on-headers-with-LF-without-CR.patch
  48. GRUB2_IGNORE_CVES += CVE-2022-28734
  49. # 0017-font-Fix-several-integer-overflows-in-grub_font_cons.patch
  50. GRUB2_IGNORE_CVES += CVE-2022-2601
  51. # 0018-font-Fix-an-integer-underflow-in-blit_comb.patch
  52. GRUB2_IGNORE_CVES += CVE-2022-3775
  53. ifeq ($(BR2_TARGET_GRUB2_INSTALL_TOOLS),y)
  54. GRUB2_INSTALL_TARGET = YES
  55. else
  56. GRUB2_INSTALL_TARGET = NO
  57. endif
  58. GRUB2_CPE_ID_VENDOR = gnu
  59. GRUB2_BUILTIN_MODULES_PC = $(call qstrip,$(BR2_TARGET_GRUB2_BUILTIN_MODULES_PC))
  60. GRUB2_BUILTIN_MODULES_EFI = $(call qstrip,$(BR2_TARGET_GRUB2_BUILTIN_MODULES_EFI))
  61. GRUB2_BUILTIN_CONFIG_PC = $(call qstrip,$(BR2_TARGET_GRUB2_BUILTIN_CONFIG_PC))
  62. GRUB2_BUILTIN_CONFIG_EFI = $(call qstrip,$(BR2_TARGET_GRUB2_BUILTIN_CONFIG_EFI))
  63. GRUB2_BOOT_PARTITION = $(call qstrip,$(BR2_TARGET_GRUB2_BOOT_PARTITION))
  64. GRUB2_IMAGE_i386-pc = $(BINARIES_DIR)/grub.img
  65. GRUB2_CFG_i386-pc = $(TARGET_DIR)/boot/grub/grub.cfg
  66. GRUB2_PREFIX_i386-pc = ($(GRUB2_BOOT_PARTITION))/boot/grub
  67. GRUB2_TARGET_i386-pc = i386
  68. GRUB2_PLATFORM_i386-pc = pc
  69. GRUB2_BUILTIN_CONFIG_i386-pc = $(GRUB2_BUILTIN_CONFIG_PC)
  70. GRUB2_BUILTIN_MODULES_i386-pc = $(GRUB2_BUILTIN_MODULES_PC)
  71. GRUB2_TUPLES-$(BR2_TARGET_GRUB2_I386_PC) += i386-pc
  72. GRUB2_IMAGE_i386-efi = $(BINARIES_DIR)/efi-part/EFI/BOOT/bootia32.efi
  73. GRUB2_CFG_i386-efi = $(BINARIES_DIR)/efi-part/EFI/BOOT/grub.cfg
  74. GRUB2_PREFIX_i386-efi = /EFI/BOOT
  75. GRUB2_TARGET_i386-efi = i386
  76. GRUB2_PLATFORM_i386-efi = efi
  77. GRUB2_BUILTIN_CONFIG_i386-efi = $(GRUB2_BUILTIN_CONFIG_EFI)
  78. GRUB2_BUILTIN_MODULES_i386-efi = $(GRUB2_BUILTIN_MODULES_EFI)
  79. GRUB2_TUPLES-$(BR2_TARGET_GRUB2_I386_EFI) += i386-efi
  80. GRUB2_IMAGE_x86_64-efi = $(BINARIES_DIR)/efi-part/EFI/BOOT/bootx64.efi
  81. GRUB2_CFG_x86_64-efi = $(BINARIES_DIR)/efi-part/EFI/BOOT/grub.cfg
  82. GRUB2_PREFIX_x86_64-efi = /EFI/BOOT
  83. GRUB2_TARGET_x86_64-efi = x86_64
  84. GRUB2_PLATFORM_x86_64-efi = efi
  85. GRUB2_BUILTIN_CONFIG_x86_64-efi = $(GRUB2_BUILTIN_CONFIG_EFI)
  86. GRUB2_BUILTIN_MODULES_x86_64-efi = $(GRUB2_BUILTIN_MODULES_EFI)
  87. GRUB2_TUPLES-$(BR2_TARGET_GRUB2_X86_64_EFI) += x86_64-efi
  88. GRUB2_IMAGE_arm-uboot = $(BINARIES_DIR)/boot-part/grub/grub.img
  89. GRUB2_CFG_arm-uboot = $(BINARIES_DIR)/boot-part/grub/grub.cfg
  90. GRUB2_PREFIX_arm-uboot = ($(GRUB2_BOOT_PARTITION))/boot/grub
  91. GRUB2_TARGET_arm-uboot = arm
  92. GRUB2_PLATFORM_arm-uboot = uboot
  93. GRUB2_BUILTIN_CONFIG_arm-uboot = $(GRUB2_BUILTIN_CONFIG_PC)
  94. GRUB2_BUILTIN_MODULES_arm-uboot = $(GRUB2_BUILTIN_MODULES_PC)
  95. GRUB2_TUPLES-$(BR2_TARGET_GRUB2_ARM_UBOOT) += arm-uboot
  96. GRUB2_IMAGE_arm-efi = $(BINARIES_DIR)/efi-part/EFI/BOOT/bootarm.efi
  97. GRUB2_CFG_arm-efi = $(BINARIES_DIR)/efi-part/EFI/BOOT/grub.cfg
  98. GRUB2_PREFIX_arm-efi = /EFI/BOOT
  99. GRUB2_TARGET_arm-efi = arm
  100. GRUB2_PLATFORM_arm-efi = efi
  101. GRUB2_BUILTIN_CONFIG_arm-efi = $(GRUB2_BUILTIN_CONFIG_EFI)
  102. GRUB2_BUILTIN_MODULES_arm-efi = $(GRUB2_BUILTIN_MODULES_EFI)
  103. GRUB2_TUPLES-$(BR2_TARGET_GRUB2_ARM_EFI) += arm-efi
  104. GRUB2_IMAGE_arm64-efi = $(BINARIES_DIR)/efi-part/EFI/BOOT/bootaa64.efi
  105. GRUB2_CFG_arm64-efi = $(BINARIES_DIR)/efi-part/EFI/BOOT/grub.cfg
  106. GRUB2_PREFIX_arm64-efi = /EFI/BOOT
  107. GRUB2_TARGET_arm64-efi = aarch64
  108. GRUB2_PLATFORM_arm64-efi = efi
  109. GRUB2_BUILTIN_CONFIG_arm64-efi = $(GRUB2_BUILTIN_CONFIG_EFI)
  110. GRUB2_BUILTIN_MODULES_arm64-efi = $(GRUB2_BUILTIN_MODULES_EFI)
  111. GRUB2_TUPLES-$(BR2_TARGET_GRUB2_ARM64_EFI) += arm64-efi
  112. # Grub2 is kind of special: it considers CC, LD and so on to be the
  113. # tools to build the host programs and uses TARGET_CC, TARGET_CFLAGS,
  114. # TARGET_CPPFLAGS, TARGET_LDFLAGS to build the bootloader itself.
  115. #
  116. # NOTE: TARGET_STRIP is overridden by !BR2_STRIP_strip, so always
  117. # use the cross compile variant to ensure grub2 builds
  118. HOST_GRUB2_CONF_ENV = \
  119. CPP="$(HOSTCC) -E"
  120. GRUB2_CONF_ENV = \
  121. CPP="$(TARGET_CC) -E" \
  122. TARGET_CC="$(TARGET_CC)" \
  123. CFLAGS="$(TARGET_CFLAGS) -Os" \
  124. TARGET_CFLAGS="$(TARGET_CFLAGS) -Os" \
  125. CPPFLAGS="$(TARGET_CPPFLAGS) -Os -fno-stack-protector" \
  126. TARGET_CPPFLAGS="$(TARGET_CPPFLAGS) -Os -fno-stack-protector" \
  127. TARGET_LDFLAGS="$(TARGET_LDFLAGS) -Os" \
  128. TARGET_NM="$(TARGET_NM)" \
  129. TARGET_OBJCOPY="$(TARGET_OBJCOPY)" \
  130. TARGET_STRIP="$(TARGET_CROSS)strip"
  131. HOST_GRUB2_CONF_OPTS = \
  132. --with-platform=none \
  133. --disable-grub-mkfont \
  134. --enable-efiemu=no \
  135. ac_cv_lib_lzma_lzma_code=no \
  136. --enable-device-mapper=no \
  137. --enable-libzfs=no \
  138. --disable-werror
  139. define GRUB2_CONFIGURE_CMDS
  140. $(foreach tuple, $(GRUB2_TUPLES-y), \
  141. @$(call MESSAGE,Configuring $(tuple))
  142. mkdir -p $(@D)/build-$(tuple)
  143. cd $(@D)/build-$(tuple) && \
  144. $(TARGET_CONFIGURE_OPTS) \
  145. $(TARGET_CONFIGURE_ARGS) \
  146. $(GRUB2_CONF_ENV) \
  147. ../configure \
  148. --target=$(GRUB2_TARGET_$(tuple)) \
  149. --with-platform=$(GRUB2_PLATFORM_$(tuple)) \
  150. --host=$(GNU_TARGET_NAME) \
  151. --build=$(GNU_HOST_NAME) \
  152. --prefix=/ \
  153. --exec-prefix=/ \
  154. --disable-grub-mkfont \
  155. --enable-efiemu=no \
  156. ac_cv_lib_lzma_lzma_code=no \
  157. --enable-device-mapper=no \
  158. --enable-libzfs=no \
  159. --disable-werror
  160. )
  161. endef
  162. define GRUB2_BUILD_CMDS
  163. $(foreach tuple, $(GRUB2_TUPLES-y), \
  164. @$(call MESSAGE,Building $(tuple))
  165. $(TARGET_MAKE_ENV) $(MAKE) -C $(@D)/build-$(tuple)
  166. )
  167. endef
  168. define GRUB2_INSTALL_IMAGES_CMDS
  169. $(foreach tuple, $(GRUB2_TUPLES-y), \
  170. @$(call MESSAGE,Installing $(tuple) to images directory)
  171. mkdir -p $(dir $(GRUB2_IMAGE_$(tuple)))
  172. $(HOST_DIR)/bin/grub-mkimage \
  173. -d $(@D)/build-$(tuple)/grub-core/ \
  174. -O $(tuple) \
  175. -o $(GRUB2_IMAGE_$(tuple)) \
  176. -p "$(GRUB2_PREFIX_$(tuple))" \
  177. $(if $(GRUB2_BUILTIN_CONFIG_$(tuple)), \
  178. -c $(GRUB2_BUILTIN_CONFIG_$(tuple))) \
  179. $(GRUB2_BUILTIN_MODULES_$(tuple))
  180. $(INSTALL) -D -m 0644 boot/grub2/grub.cfg $(GRUB2_CFG_$(tuple))
  181. $(if $(findstring $(GRUB2_PLATFORM_$(tuple)), pc), \
  182. cat $(@D)/build-$(tuple)/grub-core/cdboot.img $(GRUB2_IMAGE_$(tuple)) > \
  183. $(BINARIES_DIR)/grub-eltorito.img
  184. ) \
  185. )
  186. endef
  187. ifeq ($(BR2_TARGET_GRUB2_INSTALL_TOOLS),y)
  188. define GRUB2_INSTALL_TARGET_CMDS
  189. $(foreach tuple, $(GRUB2_TUPLES-y), \
  190. @$(call MESSAGE,Installing $(tuple) to target directory)
  191. $(TARGET_MAKE_ENV) $(MAKE) -C $(@D)/build-$(tuple) DESTDIR=$(TARGET_DIR) install
  192. )
  193. endef
  194. endif
  195. $(eval $(generic-package))
  196. $(eval $(host-autotools-package))