2014-05-01 01:36:13 +02:00
|
|
|
config SOC_INTEL_BROADWELL
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
Intel Broadwell and Haswell ULT support.
|
|
|
|
|
|
|
|
if SOC_INTEL_BROADWELL
|
|
|
|
|
|
|
|
config CPU_SPECIFIC_OPTIONS
|
|
|
|
def_bool y
|
|
|
|
select ARCH_BOOTBLOCK_X86_32
|
2015-01-14 19:51:47 +01:00
|
|
|
select ARCH_VERSTAGE_X86_32
|
2014-05-01 01:36:13 +02:00
|
|
|
select ARCH_ROMSTAGE_X86_32
|
|
|
|
select ARCH_RAMSTAGE_X86_32
|
|
|
|
select BACKUP_DEFAULT_SMM_REGION
|
|
|
|
select CACHE_MRC_SETTINGS
|
2015-01-16 00:42:43 +01:00
|
|
|
select MRC_SETTINGS_PROTECT
|
2014-05-01 01:36:13 +02:00
|
|
|
select CACHE_RELOCATED_RAMSTAGE_OUTSIDE_CBMEM
|
|
|
|
select CPU_INTEL_FIRMWARE_INTERFACE_TABLE
|
2014-12-27 11:57:06 +01:00
|
|
|
select SUPPORT_CPU_UCODE_IN_CBFS
|
2014-05-01 01:36:13 +02:00
|
|
|
select HAVE_MONOTONIC_TIMER
|
|
|
|
select HAVE_SMI_HANDLER
|
|
|
|
select HAVE_HARD_RESET
|
|
|
|
select HAVE_USBDEBUG
|
|
|
|
select IOAPIC
|
|
|
|
select MMCONF_SUPPORT
|
|
|
|
select MMCONF_SUPPORT_DEFAULT
|
|
|
|
select RELOCATABLE_MODULES
|
2014-12-27 06:11:14 +01:00
|
|
|
select RELOCATABLE_RAMSTAGE
|
2014-05-01 01:36:13 +02:00
|
|
|
select REG_SCRIPT
|
|
|
|
select PARALLEL_MP
|
|
|
|
select PCIEXP_ASPM
|
|
|
|
select PCIEXP_COMMON_CLOCK
|
2014-10-01 07:22:52 +02:00
|
|
|
select PCIEXP_CLK_PM
|
2014-10-09 21:08:15 +02:00
|
|
|
select PCIEXP_L1_SUB_STATE
|
2014-05-01 01:36:13 +02:00
|
|
|
select SMM_TSEG
|
|
|
|
select SMP
|
|
|
|
select SPI_FLASH
|
|
|
|
select SSE2
|
2014-12-27 06:11:14 +01:00
|
|
|
select SUPPORT_CPU_UCODE_IN_CBFS
|
2014-05-01 01:36:13 +02:00
|
|
|
select TSC_CONSTANT_RATE
|
|
|
|
select TSC_SYNC_MFENCE
|
|
|
|
select UDELAY_TSC
|
2015-04-29 19:45:22 +02:00
|
|
|
select SOC_INTEL_COMMON
|
2014-05-01 01:36:13 +02:00
|
|
|
|
|
|
|
config BOOTBLOCK_CPU_INIT
|
|
|
|
string
|
|
|
|
default "soc/intel/broadwell/bootblock/cpu.c"
|
|
|
|
|
|
|
|
config BOOTBLOCK_NORTHBRIDGE_INIT
|
|
|
|
string
|
|
|
|
default "soc/intel/broadwell/bootblock/systemagent.c"
|
|
|
|
|
|
|
|
config BOOTBLOCK_SOUTHBRIDGE_INIT
|
|
|
|
string
|
|
|
|
default "soc/intel/broadwell/bootblock/pch.c"
|
|
|
|
|
|
|
|
|
|
|
|
config MMCONF_BASE_ADDRESS
|
|
|
|
hex
|
|
|
|
default 0xf0000000
|
|
|
|
|
|
|
|
config SERIAL_CPU_INIT
|
|
|
|
bool
|
|
|
|
default n
|
|
|
|
|
|
|
|
config SMM_TSEG_SIZE
|
|
|
|
hex
|
|
|
|
default 0x800000
|
|
|
|
|
|
|
|
config IED_REGION_SIZE
|
|
|
|
hex
|
|
|
|
default 0x400000
|
|
|
|
|
|
|
|
config SMM_RESERVED_SIZE
|
|
|
|
hex
|
|
|
|
default 0x100000
|
|
|
|
|
|
|
|
config VGA_BIOS_ID
|
|
|
|
string
|
|
|
|
default "8086,0406"
|
|
|
|
|
|
|
|
config CACHE_MRC_SIZE_KB
|
|
|
|
int
|
|
|
|
default 512
|
|
|
|
|
|
|
|
config DCACHE_RAM_BASE
|
|
|
|
hex
|
|
|
|
default 0xff7c0000
|
|
|
|
|
|
|
|
config DCACHE_RAM_SIZE
|
|
|
|
hex
|
|
|
|
default 0x10000
|
|
|
|
help
|
|
|
|
The size of the cache-as-ram region required during bootblock
|
|
|
|
and/or romstage. Note DCACHE_RAM_SIZE and DCACHE_RAM_MRC_VAR_SIZE
|
|
|
|
must add up to a power of 2.
|
|
|
|
|
|
|
|
config DCACHE_RAM_MRC_VAR_SIZE
|
|
|
|
hex
|
|
|
|
default 0x30000
|
|
|
|
help
|
|
|
|
The amount of cache-as-ram region required by the reference code.
|
|
|
|
|
|
|
|
config DCACHE_RAM_ROMSTAGE_STACK_SIZE
|
|
|
|
hex
|
|
|
|
default 0x2000
|
|
|
|
help
|
|
|
|
The amount of anticipated stack usage from the data cache
|
|
|
|
during pre-ram rom stage execution.
|
|
|
|
|
|
|
|
config HAVE_MRC
|
|
|
|
bool "Add a Memory Reference Code binary"
|
|
|
|
help
|
|
|
|
Select this option to add a Memory Reference Code binary to
|
|
|
|
the resulting coreboot image.
|
|
|
|
|
|
|
|
Note: Without this binary coreboot will not work
|
|
|
|
|
|
|
|
if HAVE_MRC
|
|
|
|
|
|
|
|
config MRC_FILE
|
|
|
|
string "Intel Memory Reference Code path and filename"
|
|
|
|
depends on HAVE_MRC
|
|
|
|
default "mrc.bin"
|
|
|
|
help
|
|
|
|
The filename of the file to use as Memory Reference Code binary.
|
|
|
|
|
|
|
|
config MRC_BIN_ADDRESS
|
|
|
|
hex
|
|
|
|
default 0xfffa0000
|
|
|
|
|
|
|
|
config CACHE_MRC_SETTINGS
|
|
|
|
bool "Save cached MRC settings"
|
|
|
|
default y
|
|
|
|
|
|
|
|
endif # HAVE_MRC
|
|
|
|
|
|
|
|
config PRE_GRAPHICS_DELAY
|
|
|
|
int "Graphics initialization delay in ms"
|
|
|
|
default 0
|
|
|
|
help
|
|
|
|
On some systems, coreboot boots so fast that connected monitors
|
|
|
|
(mostly TVs) won't be able to wake up fast enough to talk to the
|
|
|
|
VBIOS. On those systems we need to wait for a bit before executing
|
|
|
|
the VBIOS.
|
|
|
|
|
|
|
|
config RESET_ON_INVALID_RAMSTAGE_CACHE
|
|
|
|
bool "Reset the system on S3 wake when ramstage cache invalid."
|
|
|
|
default n
|
|
|
|
depends on RELOCATABLE_RAMSTAGE
|
|
|
|
help
|
|
|
|
The romstage code caches the loaded ramstage program in SMM space.
|
|
|
|
On S3 wake the romstage will copy over a fresh ramstage that was
|
|
|
|
cached in the SMM space. This option determines the action to take
|
|
|
|
when the ramstage cache is invalid. If selected the system will
|
|
|
|
reset otherwise the ramstage will be reloaded from cbfs.
|
|
|
|
|
2014-05-05 19:42:35 +02:00
|
|
|
config INTEL_PCH_UART_CONSOLE
|
|
|
|
bool "Use Serial IO UART for console"
|
|
|
|
default n
|
2015-07-02 07:09:42 +02:00
|
|
|
select DRIVERS_UART_8250MEM
|
2014-05-05 19:42:35 +02:00
|
|
|
|
|
|
|
config INTEL_PCH_UART_CONSOLE_NUMBER
|
|
|
|
hex "Serial IO UART number to use for console"
|
|
|
|
default "0x0"
|
|
|
|
depends on INTEL_PCH_UART_CONSOLE
|
|
|
|
|
|
|
|
config TTYS0_BASE
|
|
|
|
hex
|
|
|
|
default 0xd6000000
|
|
|
|
depends on INTEL_PCH_UART_CONSOLE
|
|
|
|
|
2014-05-01 01:36:13 +02:00
|
|
|
config EHCI_BAR
|
|
|
|
hex
|
|
|
|
default 0xd8000000
|
|
|
|
|
|
|
|
config EHCI_DEBUG_OFFSET
|
|
|
|
hex
|
|
|
|
default 0xa0
|
|
|
|
|
|
|
|
config SERIRQ_CONTINUOUS_MODE
|
|
|
|
bool
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
If you set this option to y, the serial IRQ machine will be
|
|
|
|
operated in continuous mode.
|
2015-06-22 22:26:45 +02:00
|
|
|
|
|
|
|
config HAVE_REFCODE_BLOB
|
|
|
|
depends on ARCH_X86
|
|
|
|
bool "An external reference code blob should be put into cbfs."
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
The reference code blob will be placed into cbfs.
|
|
|
|
|
|
|
|
if HAVE_REFCODE_BLOB
|
|
|
|
|
|
|
|
config REFCODE_BLOB_FILE
|
|
|
|
string "Path and filename to reference code blob."
|
|
|
|
default "refcode.elf"
|
|
|
|
help
|
|
|
|
The path and filename to the file to be added to cbfs.
|
|
|
|
|
|
|
|
endif # HAVE_REFCODE_BLOB
|
|
|
|
|
2014-12-27 06:11:14 +01:00
|
|
|
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
|
2015-05-05 22:27:25 +02:00
|
|
|
firmware might be provided in coreboot's 3rdparty/blobs repository. If
|
2014-12-27 06:11:14 +01:00
|
|
|
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
|
2015-05-05 22:27:25 +02:00
|
|
|
default "3rdparty/blobs/mainboard/$(MAINBOARDDIR)/me.bin"
|
2014-12-27 06:11:14 +01:00
|
|
|
|
|
|
|
config HAVE_IFD_BIN
|
2015-04-30 21:31:17 +02:00
|
|
|
bool "Use Intel Firmware Descriptor from existing binary"
|
2014-12-27 06:11:14 +01:00
|
|
|
default n
|
|
|
|
|
|
|
|
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
|
2015-05-05 22:27:25 +02:00
|
|
|
default "3rdparty/blobs/mainboard/$(MAINBOARDDIR)/descriptor.bin"
|
2014-05-01 01:36:13 +02:00
|
|
|
|
|
|
|
config LOCK_MANAGEMENT_ENGINE
|
|
|
|
bool "Lock Management Engine section"
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
The Intel Management 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.
|
|
|
|
|
|
|
|
endif
|