Move baytrail & fsp_baytrail to the common IFD interface.
- Add the common/firmware subdir to the baytrail & fsp_baytrail makefiles and remove the code it replaces. - Update baytrail & fsp_baytrail Kconfigs to use the common code. - Update the IFD Kconfig help and prompts for the TXE vs ME. - Whittle away at the CBFS_SIZE defaults. All the fsp_baytrail platforms have their own defaults. Change-Id: I96a9d4acd6578225698dba28d132d203b8fb71a0 Signed-off-by: Martin Roth <gaumless@gmail.com> Reviewed-on: http://review.coreboot.org/10647 Tested-by: build bot (Jenkins) Reviewed-by: Werner Zeh <werner.zeh@siemens.com> Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
This commit is contained in:
parent
c528c2e3e9
commit
c407cb97bc
10 changed files with 13 additions and 186 deletions
|
@ -342,9 +342,8 @@ config CBFS_SIZE
|
|||
NORTHBRIDGE_INTEL_GM45 || NORTHBRIDGE_INTEL_SANDYBRIDGE || \
|
||||
NORTHBRIDGE_INTEL_IVYBRIDGE || NORTHBRIDGE_INTEL_IVYBRIDGE_NATIVE || \
|
||||
NORTHBRIDGE_INTEL_SANDYBRIDGE_NATIVE || \
|
||||
NORTHBRIDGE_INTEL_NEHALEM || SOC_INTEL_BAYTRAIL || SOC_INTEL_BRASWELL || \
|
||||
NORTHBRIDGE_INTEL_NEHALEM || SOC_INTEL_BRASWELL || \
|
||||
SOC_INTEL_BROADWELL
|
||||
default 0x200000 if SOC_INTEL_FSP_BAYTRAIL
|
||||
default ROM_SIZE
|
||||
help
|
||||
This is the part of the ROM actually managed by CBFS, located at the
|
||||
|
|
|
@ -34,14 +34,6 @@ config MAINBOARD_DIR
|
|||
string
|
||||
default "intel/bayleybay_fsp"
|
||||
|
||||
config INCLUDE_ME
|
||||
bool
|
||||
default n
|
||||
|
||||
config LOCK_MANAGEMENT_ENGINE
|
||||
bool
|
||||
default n
|
||||
|
||||
config MAINBOARD_PART_NUMBER
|
||||
string
|
||||
default "Bakersport CRB (FSP)"
|
||||
|
|
|
@ -34,14 +34,6 @@ config MAINBOARD_DIR
|
|||
string
|
||||
default "intel/bayleybay_fsp"
|
||||
|
||||
config INCLUDE_ME
|
||||
bool
|
||||
default n
|
||||
|
||||
config LOCK_MANAGEMENT_ENGINE
|
||||
bool
|
||||
default n
|
||||
|
||||
config MAINBOARD_PART_NUMBER
|
||||
string
|
||||
default "Bayley Bay CRB (FSP)"
|
||||
|
|
|
@ -33,14 +33,6 @@ config MAINBOARD_DIR
|
|||
string
|
||||
default "intel/minnowmax"
|
||||
|
||||
config INCLUDE_ME
|
||||
bool
|
||||
default n
|
||||
|
||||
config LOCK_MANAGEMENT_ENGINE
|
||||
bool
|
||||
default n
|
||||
|
||||
config MAINBOARD_PART_NUMBER
|
||||
string
|
||||
default "Minnow Max"
|
||||
|
|
|
@ -37,10 +37,6 @@ config MAINBOARD_DIR
|
|||
string
|
||||
default "siemens/mc_tcu3"
|
||||
|
||||
config INCLUDE_ME
|
||||
bool
|
||||
default n
|
||||
|
||||
config MAINBOARD_PART_NUMBER
|
||||
string
|
||||
default "MC_TCU3 (FSP)"
|
||||
|
|
|
@ -35,6 +35,7 @@ config CPU_SPECIFIC_OPTIONS
|
|||
select TSC_SYNC_MFENCE
|
||||
select UDELAY_TSC
|
||||
select SOC_INTEL_COMMON
|
||||
select HAVE_INTEL_FIRMWARE
|
||||
|
||||
config BOOTBLOCK_CPU_INIT
|
||||
string
|
||||
|
@ -153,63 +154,6 @@ config ENABLE_BUILTIN_COM1
|
|||
configure the pads and enable it. This serial port can be used for
|
||||
the debug console.
|
||||
|
||||
config HAVE_ME_BIN
|
||||
bool "Add Intel Management Engine firmware"
|
||||
default y
|
||||
help
|
||||
The Intel processor in the selected system requires a special firmware
|
||||
for an integrated controller called Management Engine (ME). The ME
|
||||
firmware might be provided in coreboot's 3rdparty/blobs repository. If
|
||||
not and if you don't have the firmware elsewhere, you can still
|
||||
build coreboot without it. In this case however, you'll have to make
|
||||
sure that you don't overwrite your ME firmware on your flash ROM.
|
||||
|
||||
config ME_BIN_PATH
|
||||
string "Path to management engine firmware"
|
||||
depends on HAVE_ME_BIN
|
||||
default "3rdparty/blobs/mainboard/$(MAINBOARDDIR)/me.bin"
|
||||
|
||||
config HAVE_IFD_BIN
|
||||
bool
|
||||
default y
|
||||
|
||||
config BUILD_WITH_FAKE_IFD
|
||||
bool "Build with a fake IFD"
|
||||
default y if !HAVE_IFD_BIN
|
||||
help
|
||||
If you don't have an Intel Firmware Descriptor (ifd.bin) for your
|
||||
board, you can select this option and coreboot will build without it.
|
||||
Though, the resulting coreboot.rom will not contain all parts required
|
||||
to get coreboot running on your board. You can however write only the
|
||||
BIOS section to your board's flash ROM and keep the other sections
|
||||
untouched. Unfortunately the current version of flashrom doesn't
|
||||
support this yet. But there is a patch pending [1].
|
||||
|
||||
WARNING: Never write a complete coreboot.rom to your flash ROM if it
|
||||
was built with a fake IFD. It just won't work.
|
||||
|
||||
[1] http://www.flashrom.org/pipermail/flashrom/2013-June/011083.html
|
||||
|
||||
config IFD_BIOS_SECTION
|
||||
depends on BUILD_WITH_FAKE_IFD
|
||||
string
|
||||
default ""
|
||||
|
||||
config IFD_ME_SECTION
|
||||
depends on BUILD_WITH_FAKE_IFD
|
||||
string
|
||||
default ""
|
||||
|
||||
config IFD_PLATFORM_SECTION
|
||||
depends on BUILD_WITH_FAKE_IFD
|
||||
string
|
||||
default ""
|
||||
|
||||
config IFD_BIN_PATH
|
||||
string "Path to intel firmware descriptor"
|
||||
depends on !BUILD_WITH_FAKE_IFD
|
||||
default "3rdparty/blobs/mainboard/$(MAINBOARDDIR)/descriptor.bin"
|
||||
|
||||
config HAVE_REFCODE_BLOB
|
||||
depends on ARCH_X86
|
||||
bool "An external reference code blob should be put into cbfs."
|
||||
|
|
|
@ -9,6 +9,7 @@ subdirs-y += ../../../cpu/x86/smm
|
|||
subdirs-y += ../../../cpu/x86/tsc
|
||||
subdirs-y += ../../../cpu/intel/microcode
|
||||
subdirs-y += ../../../cpu/intel/turbo
|
||||
subdirs-y += ../../../southbridge/intel/common/firmware
|
||||
|
||||
ramstage-y += memmap.c
|
||||
romstage-y += memmap.c
|
||||
|
@ -56,40 +57,6 @@ ramstage-y += placeholders.c
|
|||
|
||||
CPPFLAGS_common += -Isrc/soc/intel/baytrail/include
|
||||
|
||||
# Run an intermediate step when producing coreboot.rom
|
||||
# that adds additional components to the final firmware
|
||||
# image outside of CBFS
|
||||
INTERMEDIATE:=baytrail_add_me
|
||||
|
||||
ifeq ($(CONFIG_BUILD_WITH_FAKE_IFD),y)
|
||||
IFD_BIN_PATH := $(objgenerated)/ifdfake.bin
|
||||
IFD_SECTIONS := $(addprefix -b ,$(CONFIG_IFD_BIOS_SECTION:"%"=%)) \
|
||||
$(addprefix -m ,$(CONFIG_IFD_ME_SECTION:"%"=%)) \
|
||||
$(addprefix -p ,$(CONFIG_IFD_PLATFORM_SECTION:"%"=%))
|
||||
else
|
||||
IFD_BIN_PATH := $(CONFIG_IFD_BIN_PATH)
|
||||
endif
|
||||
|
||||
baytrail_add_me: $(obj)/coreboot.pre $(IFDTOOL) $(IFDFAKE)
|
||||
ifeq ($(CONFIG_BUILD_WITH_FAKE_IFD),y)
|
||||
printf "\n** WARNING **\n"
|
||||
printf "Coreboot will be built with a fake Intel Firmware Descriptor (IFD).\n"
|
||||
printf "Never write a complete coreboot.rom with a fake IFD to your board's\n"
|
||||
printf "flash ROM! Make sure that you only write valid flash regions.\n\n"
|
||||
printf " IFDFAKE Building a fake Intel Firmware Descriptor\n"
|
||||
$(IFDFAKE) $(IFD_SECTIONS) $(IFD_BIN_PATH)
|
||||
endif
|
||||
printf " DD Adding Intel Firmware Descriptor\n"
|
||||
dd if=$(IFD_BIN_PATH) \
|
||||
of=$(obj)/coreboot.pre conv=notrunc >/dev/null 2>&1
|
||||
ifeq ($(CONFIG_HAVE_ME_BIN),y)
|
||||
printf " IFDTOOL me.bin -> coreboot.pre\n"
|
||||
$(objutil)/ifdtool/ifdtool \
|
||||
-i ME:$(CONFIG_ME_BIN_PATH) \
|
||||
$(obj)/coreboot.pre
|
||||
mv $(obj)/coreboot.pre.new $(obj)/coreboot.pre
|
||||
endif
|
||||
|
||||
# If an MRC file is an ELF file determine the entry address and first loadable
|
||||
# section offset in the file. Subtract the offset from the entry address to
|
||||
# determine the final location.
|
||||
|
@ -102,6 +69,4 @@ mrc.bin-file := $(call strip_quotes,$(CONFIG_MRC_FILE))
|
|||
mrc.bin-position := $(if $(findstring elf,$(CONFIG_MRC_FILE)),$(shell printf "0x%x" $$(( $(mrcelfentry) - $(mrcelfoffset) )) ),$(CONFIG_MRC_BIN_ADDRESS))
|
||||
mrc.bin-type := mrc
|
||||
|
||||
PHONY += baytrail_add_me
|
||||
|
||||
endif
|
||||
|
|
|
@ -47,6 +47,7 @@ config CPU_SPECIFIC_OPTIONS
|
|||
select TSC_SYNC_MFENCE
|
||||
select UDELAY_TSC
|
||||
select SUPPORT_CPU_UCODE_IN_CBFS
|
||||
select HAVE_INTEL_FIRMWARE
|
||||
|
||||
config SOC_INTEL_FSP_BAYTRAIL_MD
|
||||
bool
|
||||
|
@ -94,34 +95,6 @@ config CPU_MICROCODE_CBFS_LOC
|
|||
hex
|
||||
default 0xfff10040
|
||||
|
||||
config INCLUDE_ME
|
||||
bool "Include the TXE"
|
||||
default n
|
||||
help
|
||||
Build the TXE and descriptor.bin into the ROM image. If you want to use a
|
||||
descriptor.bin and TXE file from the previous ROM image, you may not want
|
||||
to build it in here.
|
||||
|
||||
config ME_PATH
|
||||
string "Path to ME"
|
||||
depends on INCLUDE_ME
|
||||
help
|
||||
The path of the TXE and Descriptor files.
|
||||
|
||||
config LOCK_MANAGEMENT_ENGINE
|
||||
bool "Lock TXE section"
|
||||
default n
|
||||
depends on INCLUDE_ME
|
||||
help
|
||||
The Intel Trusted Execution Engine supports preventing write accesses
|
||||
from the host to the Management Engine section in the firmware
|
||||
descriptor. If the ME section is locked, it can only be overwritten
|
||||
with an external SPI flash programmer. You will want this if you
|
||||
want to increase security of your ROM image once you are sure
|
||||
that the ME firmware is no longer going to change.
|
||||
|
||||
If unsure, say N.
|
||||
|
||||
config ENABLE_BUILTIN_COM1
|
||||
bool "Enable built-in legacy Serial Port"
|
||||
help
|
||||
|
|
|
@ -30,6 +30,7 @@ subdirs-y += ../../../cpu/x86/cache
|
|||
subdirs-y += ../../../cpu/intel/turbo
|
||||
subdirs-y += ../../../lib/fsp
|
||||
subdirs-y += fsp
|
||||
subdirs-y += ../../../southbridge/intel/common/firmware
|
||||
|
||||
ramstage-y += memmap.c
|
||||
romstage-y += memmap.c
|
||||
|
@ -62,33 +63,4 @@ ramstage-y += i2c.c
|
|||
CPPFLAGS_common += -I$(src)/soc/intel/fsp_baytrail/
|
||||
CPPFLAGS_common += -I$(src)/soc/intel/fsp_baytrail/fsp
|
||||
|
||||
# Run an intermediate step when producing coreboot.rom
|
||||
# that adds additional components to the final firmware
|
||||
# image outside of CBFS
|
||||
ifeq ($(CONFIG_INCLUDE_ME),y)
|
||||
ifneq ($(CONFIG_ME_PATH),)
|
||||
INTERMEDIATE:=baytrail_add_txe
|
||||
|
||||
baytrail_add_txe: $(obj)/coreboot.pre $(IFDTOOL)
|
||||
printf " DD Adding Intel Firmware Descriptor\n"
|
||||
dd if=$(call strip_quotes,$(CONFIG_ME_PATH))/descriptor.bin \
|
||||
of=$(obj)/coreboot.pre conv=notrunc >/dev/null 2>&1
|
||||
printf " IFDTOOL txe.bin -> coreboot.pre\n"
|
||||
$(objutil)/ifdtool/ifdtool \
|
||||
-i ME:$(call strip_quotes,$(CONFIG_ME_PATH))/txe.bin \
|
||||
$(obj)/coreboot.pre
|
||||
mv $(obj)/coreboot.pre.new $(obj)/coreboot.pre
|
||||
ifeq ($(CONFIG_LOCK_MANAGEMENT_ENGINE),y)
|
||||
printf " IFDTOOL Locking Management Engine\n"
|
||||
$(objutil)/ifdtool/ifdtool -l $(obj)/coreboot.pre
|
||||
mv $(obj)/coreboot.pre.new $(obj)/coreboot.pre
|
||||
else
|
||||
printf " IFDTOOL Unlocking Management Engine\n"
|
||||
$(objutil)/ifdtool/ifdtool -u $(obj)/coreboot.pre
|
||||
mv $(obj)/coreboot.pre.new $(obj)/coreboot.pre
|
||||
endif
|
||||
|
||||
endif
|
||||
endif
|
||||
|
||||
endif
|
||||
|
|
|
@ -38,15 +38,17 @@ config IFD_BIN_PATH
|
|||
depends on HAVE_IFD_BIN && !BUILD_WITH_FAKE_IFD
|
||||
|
||||
config HAVE_ME_BIN
|
||||
bool "Add Intel Management Engine firmware"
|
||||
bool "Add Intel ME/TXE firmware"
|
||||
depends on HAVE_IFD_BIN
|
||||
help
|
||||
The Intel processor in the selected system requires a special firmware
|
||||
for an integrated controller called Management Engine (ME). The ME
|
||||
firmware might be provided in coreboot's 3rdparty/blobs repository. If
|
||||
not and if you don't have the firmware elsewhere, you can still
|
||||
build coreboot without it. In this case however, you'll have to make
|
||||
sure that you don't overwrite your ME firmware on your flash ROM.
|
||||
for an integrated controller. This might be called the Management
|
||||
Engine (ME), the Trusted Execution Engine (TXE) or something else
|
||||
depending on the chip. This firmware might or might not be available
|
||||
in coreboot's 3rdparty/blobs repository. If it is not and if you don't
|
||||
have access to the firmware from elsewhere, you can still build
|
||||
coreboot without it. In this case however, you'll have to make sure
|
||||
that you don't overwrite your ME/TXE firmware on your flash ROM.
|
||||
|
||||
config ME_BIN_PATH
|
||||
string "Path to management engine firmware"
|
||||
|
|
Loading…
Reference in a new issue