Makefile: Allow platform to provide additional params for add cmd
This change adds optional CBFSTOOL_ADD_CMD_OPTIONS that can be used by arch/SoC/mainboard Makefiles to supply any additional arguments that need to be passed into cbfstool when using cbfstool add command. This is useful when platform wants to add these parameters depending upon some arch/SoC/mainboard specific configs. Immediate use case is the fast SPI controller on Intel platforms adding arguments for extended window base and size. BUG=b:171534504 Change-Id: I2f48bc3f494d9a5da7e99b530a39d6078b4a881c Signed-off-by: Furquan Shaikh <furquan@google.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/47884 Reviewed-by: Tim Wawrzynczak <twawrzynczak@chromium.org> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
78c3e1c50a
commit
ae5f8a0751
1 changed files with 11 additions and 5 deletions
16
Makefile.inc
16
Makefile.inc
|
@ -833,6 +833,10 @@ endif
|
||||||
|
|
||||||
# cbfs-add-cmd-for-region
|
# cbfs-add-cmd-for-region
|
||||||
# $(call cbfs-add-cmd-for-region,file in extract_nth format,region name)
|
# $(call cbfs-add-cmd-for-region,file in extract_nth format,region name)
|
||||||
|
#
|
||||||
|
# CBFSTOOL_ADD_CMD_OPTIONS can be used by arch/SoC/mainboard to supply
|
||||||
|
# add commands with any additional arguments for cbfstool.
|
||||||
|
# Example: --ext-win-base <base> --ext-win-size <size>
|
||||||
define cbfs-add-cmd-for-region
|
define cbfs-add-cmd-for-region
|
||||||
$(CBFSTOOL) $@.tmp \
|
$(CBFSTOOL) $@.tmp \
|
||||||
add$(if $(filter stage,$(call extract_nth,3,$(1))),-stage)$(if \
|
add$(if $(filter stage,$(call extract_nth,3,$(1))),-stage)$(if \
|
||||||
|
@ -847,8 +851,8 @@ define cbfs-add-cmd-for-region
|
||||||
-r $(2) \
|
-r $(2) \
|
||||||
$(if $(call extract_nth,6,$(1)),-a $(call extract_nth,6,$(file)), \
|
$(if $(call extract_nth,6,$(1)),-a $(call extract_nth,6,$(file)), \
|
||||||
$(if $(call extract_nth,5,$(file)),-b $(call extract_nth,5,$(file)))) \
|
$(if $(call extract_nth,5,$(file)),-b $(call extract_nth,5,$(file)))) \
|
||||||
$(call extract_nth,7,$(1))
|
$(call extract_nth,7,$(1)) \
|
||||||
|
$(CBFSTOOL_ADD_CMD_OPTIONS)
|
||||||
|
|
||||||
endef
|
endef
|
||||||
# Empty line before endef is necessary so cbfs-add-cmd-for-region ends in a
|
# Empty line before endef is necessary so cbfs-add-cmd-for-region ends in a
|
||||||
|
@ -1083,7 +1087,8 @@ ifeq ($(CONFIG_ARCH_X86),y)
|
||||||
$(TXTIBB) \
|
$(TXTIBB) \
|
||||||
$(CBNTIBB) \
|
$(CBNTIBB) \
|
||||||
-b -$(call file-size,$(objcbfs)/bootblock.bin) $(cbfs-autogen-attributes) \
|
-b -$(call file-size,$(objcbfs)/bootblock.bin) $(cbfs-autogen-attributes) \
|
||||||
$(TS_OPTIONS)
|
$(TS_OPTIONS) \
|
||||||
|
$(CBFSTOOL_ADD_CMD_OPTIONS)
|
||||||
else # ifeq ($(CONFIG_ARCH_X86),y)
|
else # ifeq ($(CONFIG_ARCH_X86),y)
|
||||||
$(CBFSTOOL) $@.tmp write -u \
|
$(CBFSTOOL) $@.tmp write -u \
|
||||||
-r BOOTBLOCK \
|
-r BOOTBLOCK \
|
||||||
|
@ -1095,10 +1100,11 @@ else # ifeq ($(CONFIG_ARCH_X86),y)
|
||||||
-f $@.tmp.2 \
|
-f $@.tmp.2 \
|
||||||
-n "header pointer" \
|
-n "header pointer" \
|
||||||
-t "cbfs header" \
|
-t "cbfs header" \
|
||||||
-b -4
|
-b -4 \
|
||||||
|
$(CBFSTOOL_ADD_CMD_OPTIONS)
|
||||||
rm -f $@.tmp.2
|
rm -f $@.tmp.2
|
||||||
endif # ifeq ($(CONFIG_ARCH_X86),y)
|
endif # ifeq ($(CONFIG_ARCH_X86),y)
|
||||||
$(CBFSTOOL) $@.tmp add-master-header $(TS_OPTIONS)
|
$(CBFSTOOL) $@.tmp add-master-header $(TS_OPTIONS) $(CBFSTOOL_ADD_CMD_OPTIONS)
|
||||||
$(prebuild-files) true
|
$(prebuild-files) true
|
||||||
mv $@.tmp $@
|
mv $@.tmp $@
|
||||||
else # ifneq ($(CONFIG_UPDATE_IMAGE),y)
|
else # ifneq ($(CONFIG_UPDATE_IMAGE),y)
|
||||||
|
|
Loading…
Reference in a new issue