2021-12-06 10:01:50 +01:00
|
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
|
|
|
|
VBOOT_BUILD_DIR ?= $(abspath $(obj)/external/vboot)
|
|
|
|
VBOOT_FW_LIB = $(VBOOT_BUILD_DIR)/vboot_fw.a
|
|
|
|
TLCL_LIB = $(VBOOT_BUILD_DIR)/tlcl.a
|
|
|
|
|
|
|
|
vboot_fw-objs += $(VBOOT_FW_LIB)
|
|
|
|
tlcl-objs += $(TLCL_LIB)
|
|
|
|
|
2022-02-17 18:08:09 +01:00
|
|
|
kconfig-to-binary=$(if $(strip $(1)),1,0)
|
2022-03-22 17:56:51 +01:00
|
|
|
vboot-fixup-includes = $(filter -I$(coreboottop)/%, $(1)) \
|
|
|
|
$(patsubst -I%,-I$(top)/%,\
|
2021-12-06 10:01:50 +01:00
|
|
|
$(patsubst include/%.h,$(top)/include/%.h,\
|
2022-03-22 17:56:51 +01:00
|
|
|
$(filter-out -I$(obj),\
|
|
|
|
$(filter-out -I$(coreboottop)/%,$(1)))))
|
2021-12-06 10:01:50 +01:00
|
|
|
|
|
|
|
VBOOT_FIRMWARE_ARCH-$(CONFIG_LP_ARCH_ARM) := arm
|
|
|
|
VBOOT_FIRMWARE_ARCH-$(CONFIG_LP_ARCH_X86) := x86
|
|
|
|
VBOOT_FIRMWARE_ARCH-$(CONFIG_LP_ARCH_ARM64) := arm64
|
|
|
|
|
2024-01-10 08:27:11 +01:00
|
|
|
ifneq ($(CONFIG_LP_ARCH_MOCK),)
|
|
|
|
VBOOT_FIRMWARE_ARCH-y := mock
|
|
|
|
else
|
|
|
|
VBOOT_CFLAGS += $(call vboot-fixup-includes,$(CFLAGS))
|
|
|
|
VBOOT_CFLAGS += -I$(abspath $(obj))
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(VBOOT_FIRMWARE_ARCH-y),)
|
2021-12-06 10:01:50 +01:00
|
|
|
$(error vboot requires architecture to be set in the configuration)
|
|
|
|
endif
|
|
|
|
|
2024-01-10 08:27:11 +01:00
|
|
|
# Enable vboot debug by default
|
|
|
|
VBOOT_CFLAGS += -DVBOOT_DEBUG
|
|
|
|
|
2023-11-28 00:01:28 +01:00
|
|
|
ifeq ($(CONFIG_LP_VBOOT_X86_RSA_ACCELERATION),y)
|
|
|
|
CPPFLAGS_common += -DVB2_X86_RSA_ACCELERATION
|
|
|
|
endif
|
|
|
|
|
2021-12-06 10:01:50 +01:00
|
|
|
$(VBOOT_FW_LIB): $(obj)/libpayload-config.h
|
|
|
|
@printf " MAKE $(subst $(obj)/,,$(@))\n"
|
2022-02-18 10:24:08 +01:00
|
|
|
+$(Q) FIRMWARE_ARCH="$(VBOOT_FIRMWARE_ARCH-y)" \
|
|
|
|
CC="$(CC)" \
|
2021-12-06 10:01:50 +01:00
|
|
|
CFLAGS="$(VBOOT_CFLAGS)" \
|
|
|
|
$(MAKE) -C "$(VBOOT_SOURCE)" \
|
|
|
|
TPM2_MODE=$(call kconfig-to-binary, $(CONFIG_LP_VBOOT_TPM2_MODE)) \
|
|
|
|
X86_SHA_EXT=$(call kconfig-to-binary, $(CONFIG_LP_VBOOT_X86_SHA_EXT)) \
|
2023-11-28 00:01:28 +01:00
|
|
|
VB2_X86_RSA_ACCELERATION=$(call kconfig-to-binary, $(CONFIG_LP_VBOOT_X86_RSA_ACCELERATION)) \
|
2023-01-31 08:09:24 +01:00
|
|
|
ARMV8_CRYPTO_EXT=$(call kconfig-to-binary, $(CONFIG_LP_VBOOT_SHA_ARMV8_CE)) \
|
2021-12-06 10:01:50 +01:00
|
|
|
UNROLL_LOOPS=1 \
|
2022-02-18 10:24:08 +01:00
|
|
|
BUILD="$(VBOOT_BUILD_DIR)" \
|
2021-12-06 10:01:50 +01:00
|
|
|
V=$(V) \
|
|
|
|
$(VBOOT_BUILD_DIR)/vboot_fw.a tlcl
|
|
|
|
|
|
|
|
$(TLCL_LIB): $(VBOOT_FW_LIB)
|
|
|
|
|
|
|
|
.PHONY: $(VBOOT_FW_LIB) $(TLCL_LIB)
|