| ## |
| ## This file is part of the coreboot project. |
| ## |
| ## Copyright (C) 2012 Alexandru Gagniuc <mr.nuke.me@gmail.com> |
| ## Copyright (C) 2009-2010 coresystems GmbH |
| ## |
| ## This program is free software; you can redistribute it and/or modify |
| ## it under the terms of the GNU General Public License as published by |
| ## the Free Software Foundation; version 2 of the License. |
| ## |
| ## This program is distributed in the hope that it will be useful, |
| ## but WITHOUT ANY WARRANTY; without even the implied warranty of |
| ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| ## GNU General Public License for more details. |
| ## |
| |
| mainmenu "coreboot configuration" |
| |
| menu "General setup" |
| |
| config COREBOOT_BUILD |
| bool |
| default y |
| |
| config LOCALVERSION |
| string "Local version string" |
| help |
| Append an extra string to the end of the coreboot version. |
| |
| This can be useful if, for instance, you want to append the |
| respective board's hostname or some other identifying string to |
| the coreboot version number, so that you can easily distinguish |
| boot logs of different boards from each other. |
| |
| config CBFS_PREFIX |
| string "CBFS prefix to use" |
| default "fallback" |
| help |
| Select the prefix to all files put into the image. It's "fallback" |
| by default, "normal" is a common alternative. |
| |
| choice |
| prompt "Compiler to use" |
| default COMPILER_GCC |
| help |
| This option allows you to select the compiler used for building |
| coreboot. |
| You must build the coreboot crosscompiler for the board that you |
| have selected. |
| |
| To build all the GCC crosscompilers (takes a LONG time), run: |
| make crossgcc |
| |
| For help on individual architectures, run the command: |
| make help_toolchain |
| |
| config COMPILER_GCC |
| bool "GCC" |
| help |
| Use the GNU Compiler Collection (GCC) to build coreboot. |
| |
| For details see http://gcc.gnu.org. |
| |
| config COMPILER_LLVM_CLANG |
| bool "LLVM/clang (TESTING ONLY - Not currently working)" |
| help |
| Use LLVM/clang to build coreboot. To use this, you must build the |
| coreboot version of the clang compiler. Run the command |
| make clang |
| Note that this option is not currently working correctly and should |
| really only be selected if you're trying to work on getting clang |
| operational. |
| |
| For details see http://clang.llvm.org. |
| |
| endchoice |
| |
| config ANY_TOOLCHAIN |
| bool "Allow building with any toolchain" |
| default n |
| help |
| Many toolchains break when building coreboot since it uses quite |
| unusual linker features. Unless developers explicitely request it, |
| we'll have to assume that they use their distro compiler by mistake. |
| Make sure that using patched compilers is a conscious decision. |
| |
| config CCACHE |
| bool "Use ccache to speed up (re)compilation" |
| default n |
| help |
| Enables the use of ccache for faster builds. |
| |
| Requires the ccache utility in your system $PATH. |
| |
| For details see https://ccache.samba.org. |
| |
| config FMD_GENPARSER |
| bool "Generate flashmap descriptor parser using flex and bison" |
| default n |
| help |
| Enable this option if you are working on the flashmap descriptor |
| parser and made changes to fmd_scanner.l or fmd_parser.y. |
| |
| Otherwise, say N to use the provided pregenerated scanner/parser. |
| |
| config UTIL_GENPARSER |
| bool "Generate SCONFIG & BLOBTOOL parser using flex and bison" |
| default n |
| help |
| Enable this option if you are working on the sconfig device tree |
| parser or blobtool and made changes to the .l or .y files. |
| |
| Otherwise, say N to use the provided pregenerated scanner/parser. |
| |
| config USE_OPTION_TABLE |
| bool "Use CMOS for configuration values" |
| depends on HAVE_OPTION_TABLE |
| help |
| Enable this option if coreboot shall read options from the "CMOS" |
| NVRAM instead of using hard-coded values. |
| |
| config STATIC_OPTION_TABLE |
| bool "Load default configuration values into CMOS on each boot" |
| depends on USE_OPTION_TABLE |
| help |
| Enable this option to reset "CMOS" NVRAM values to default on |
| every boot. Use this if you want the NVRAM configuration to |
| never be modified from its default values. |
| |
| config COMPRESS_RAMSTAGE |
| bool "Compress ramstage with LZMA" |
| # Default value set at the end of the file |
| help |
| Compress ramstage to save memory in the flash image. Note |
| that decompression might slow down booting if the boot flash |
| is connected through a slow link (i.e. SPI). |
| |
| config COMPRESS_PRERAM_STAGES |
| bool "Compress romstage and verstage with LZ4" |
| depends on !ARCH_X86 |
| # Default value set at the end of the file |
| help |
| Compress romstage and (if it exists) verstage with LZ4 to save flash |
| space and speed up boot, since the time for reading the image from SPI |
| (and in the vboot case verifying it) is usually much greater than the |
| time spent decompressing. Doesn't work for XIP stages (assume all |
| ARCH_X86 for now) for obvious reasons. |
| |
| config INCLUDE_CONFIG_FILE |
| bool "Include the coreboot .config file into the ROM image" |
| # Default value set at the end of the file |
| help |
| Include the .config file that was used to compile coreboot |
| in the (CBFS) ROM image. This is useful if you want to know which |
| options were used to build a specific coreboot.rom image. |
| |
| Saying Y here will increase the image size by 2-3KB. |
| |
| You can use the following command to easily list the options: |
| |
| grep -a CONFIG_ coreboot.rom |
| |
| Alternatively, you can also use cbfstool to print the image |
| contents (including the raw 'config' item we're looking for). |
| |
| Example: |
| |
| $ cbfstool coreboot.rom print |
| coreboot.rom: 4096 kB, bootblocksize 1008, romsize 4194304, |
| offset 0x0 |
| Alignment: 64 bytes |
| |
| Name Offset Type Size |
| cmos_layout.bin 0x0 cmos layout 1159 |
| fallback/romstage 0x4c0 stage 339756 |
| fallback/ramstage 0x53440 stage 186664 |
| fallback/payload 0x80dc0 payload 51526 |
| config 0x8d740 raw 3324 |
| (empty) 0x8e480 null 3610440 |
| |
| config COLLECT_TIMESTAMPS |
| bool "Create a table of timestamps collected during boot" |
| default y if ARCH_X86 |
| help |
| Make coreboot create a table of timer-ID/timer-value pairs to |
| allow measuring time spent at different phases of the boot process. |
| |
| config USE_BLOBS |
| bool "Allow use of binary-only repository" |
| help |
| This draws in the blobs repository, which contains binary files that |
| might be required for some chipsets or boards. |
| This flag ensures that a "Free" option remains available for users. |
| |
| config COVERAGE |
| bool "Code coverage support" |
| depends on COMPILER_GCC |
| help |
| Add code coverage support for coreboot. This will store code |
| coverage information in CBMEM for extraction from user space. |
| If unsure, say N. |
| |
| config UBSAN |
| bool "Undefined behavior sanitizer support" |
| default n |
| help |
| Instrument the code with checks for undefined behavior. If unsure, |
| say N because it adds a small performance penalty and may abort |
| on code that happens to work in spite of the UB. |
| |
| config RELOCATABLE_RAMSTAGE |
| depends on EARLY_CBMEM_INIT |
| bool "Build the ramstage to be relocatable in 32-bit address space." |
| select RELOCATABLE_MODULES |
| help |
| The reloctable ramstage support allows for the ramstage to be built |
| as a relocatable module. The stage loader can identify a place |
| out of the OS way so that copying memory is unnecessary during an S3 |
| wake. When selecting this option the romstage is responsible for |
| determing a stack location to use for loading the ramstage. |
| |
| config CACHE_RELOCATED_RAMSTAGE_OUTSIDE_CBMEM |
| depends on RELOCATABLE_RAMSTAGE |
| bool |
| help |
| The relocated ramstage is saved in an area specified by the |
| by the board and/or chipset. |
| |
| config UPDATE_IMAGE |
| bool "Update existing coreboot.rom image" |
| help |
| If this option is enabled, no new coreboot.rom file |
| is created. Instead it is expected that there already |
| is a suitable file for further processing. |
| The bootblock will not be modified. |
| |
| If unsure, select 'N' |
| |
| config BOARD_ID_STRING |
| string "Board ID" |
| # Default value set at the end of the file |
| depends on BOARD_ID_MANUAL |
| help |
| This string is placed in the 'board_id' CBFS file for indicating |
| board type. |
| |
| config RAM_CODE_SUPPORT |
| bool |
| help |
| If enabled, coreboot discovers RAM configuration (value obtained by |
| reading board straps) and stores it in coreboot table. |
| |
| config BOOTSPLASH_IMAGE |
| bool "Add a bootsplash image" |
| help |
| Select this option if you have a bootsplash image that you would |
| like to add to your ROM. |
| |
| This will only add the image to the ROM. To actually run it check |
| options under 'Display' section. |
| |
| config BOOTSPLASH_FILE |
| string "Bootsplash path and filename" |
| depends on BOOTSPLASH_IMAGE |
| # Default value set at the end of the file |
| help |
| The path and filename of the file to use as graphical bootsplash |
| screen. The file format has to be jpg. |
| |
| endmenu |
| |
| menu "Mainboard" |
| |
| source "src/mainboard/Kconfig" |
| |
| config DEVICETREE |
| string |
| default "devicetree.cb" |
| help |
| This symbol allows mainboards to select a different file under their |
| mainboard directory for the devicetree.cb file. This allows the board |
| variants that need different devicetrees to be in the same directory. |
| |
| Examples: "devicetree.variant.cb" |
| "variant/devicetree.cb" |
| |
| config CBFS_SIZE |
| hex "Size of CBFS filesystem in ROM" |
| # Default value set at the end of the file |
| help |
| This is the part of the ROM actually managed by CBFS, located at the |
| end of the ROM (passed through cbfstool -o) on x86 and at at the start |
| of the ROM (passed through cbfstool -s) everywhere else. It defaults |
| to span the whole ROM on all but Intel systems that use an Intel Firmware |
| Descriptor. It can be overridden to make coreboot live alongside other |
| components like ChromeOS's vboot/FMAP or Intel's IFD / ME / TXE |
| binaries. |
| |
| config FMDFILE |
| string "fmap description file in fmd format" |
| default "src/mainboard/$(CONFIG_MAINBOARD_DIR)/chromeos.fmd" if CHROMEOS |
| default "" |
| help |
| The build system creates a default FMAP from ROM_SIZE and CBFS_SIZE, |
| but in some cases more complex setups are required. |
| When an fmd is specified, it overrides the default format. |
| |
| config MAINBOARD_HAS_TPM2 |
| bool |
| default n |
| help |
| There is a TPM device installed on the mainboard, and it is |
| compliant with version 2 TCG TPM specification. Could be connected |
| over LPC, SPI or I2C. |
| |
| endmenu |
| |
| # load site-local kconfig to allow user specific defaults and overrides |
| source "site-local/Kconfig" |
| |
| config SYSTEM_TYPE_LAPTOP |
| default n |
| bool |
| |
| config CBFS_AUTOGEN_ATTRIBUTES |
| default n |
| bool |
| help |
| If this option is selected, every file in cbfs which has a constraint |
| regarding position or alignment will get an additional file attribute |
| which describes this constraint. |
| |
| menu "Chipset" |
| |
| comment "SoC" |
| source "src/soc/*/Kconfig" |
| comment "CPU" |
| source "src/cpu/Kconfig" |
| comment "Northbridge" |
| source "src/northbridge/*/*/Kconfig" |
| comment "Southbridge" |
| source "src/southbridge/*/*/Kconfig" |
| comment "Super I/O" |
| source "src/superio/*/*/Kconfig" |
| comment "Embedded Controllers" |
| source "src/ec/acpi/Kconfig" |
| source "src/ec/*/*/Kconfig" |
| # FIXME move to vendorcode |
| source "src/drivers/intel/fsp1_0/Kconfig" |
| |
| source "src/southbridge/intel/common/firmware/Kconfig" |
| source "src/vendorcode/*/Kconfig" |
| |
| source "src/arch/*/Kconfig" |
| |
| endmenu |
| |
| source "src/device/Kconfig" |
| |
| menu "Generic Drivers" |
| source "src/drivers/*/Kconfig" |
| source "src/drivers/*/*/Kconfig" |
| source "src/commonlib/storage/Kconfig" |
| endmenu |
| |
| menu "Security" |
| |
| source "src/security/Kconfig" |
| |
| endmenu |
| |
| source "src/acpi/Kconfig" |
| |
| # This option is for the current boards/chipsets where SPI flash |
| # is not the boot device. Currently nearly all boards/chipsets assume |
| # SPI flash is the boot device. |
| config BOOT_DEVICE_NOT_SPI_FLASH |
| bool |
| default n |
| |
| config BOOT_DEVICE_SPI_FLASH |
| bool |
| default y if !BOOT_DEVICE_NOT_SPI_FLASH |
| default n |
| |
| config BOOT_DEVICE_MEMORY_MAPPED |
| bool |
| default y if ARCH_X86 && BOOT_DEVICE_SPI_FLASH |
| default n |
| help |
| Inform system if SPI is memory-mapped or not. |
| |
| config BOOT_DEVICE_SUPPORTS_WRITES |
| bool |
| default n |
| help |
| Indicate that the platform has writable boot device |
| support. |
| |
| config RTC |
| bool |
| default n |
| |
| config TPM |
| bool |
| default n |
| select LPC_TPM if MAINBOARD_HAS_LPC_TPM |
| select I2C_TPM if !MAINBOARD_HAS_LPC_TPM && !SPI_TPM |
| help |
| Enable this option to enable TPM support in coreboot. |
| |
| If unsure, say N. |
| |
| config TPM2 |
| bool |
| select LPC_TPM if MAINBOARD_HAS_LPC_TPM |
| select I2C_TPM if !MAINBOARD_HAS_LPC_TPM && !SPI_TPM |
| help |
| Enable this option to enable TPM2 support in coreboot. |
| |
| If unsure, say N. |
| |
| config POWER_OFF_ON_CR50_UPDATE |
| bool |
| help |
| Power off machine while waiting for CR50 update to take effect. |
| |
| config MAINBOARD_HAS_TPM_CR50 |
| bool |
| default y if MAINBOARD_HAS_SPI_TPM_CR50 || MAINBOARD_HAS_I2C_TPM_CR50 |
| default n |
| select MAINBOARD_HAS_TPM2 |
| select POWER_OFF_ON_CR50_UPDATE if ARCH_X86 |
| |
| config HEAP_SIZE |
| hex |
| default 0x4000 |
| |
| config STACK_SIZE |
| hex |
| default 0x1000 if ARCH_X86 |
| default 0x0 |
| |
| config MAX_CPUS |
| int |
| default 1 |
| |
| source "src/console/Kconfig" |
| |
| config HAVE_ACPI_RESUME |
| bool |
| default n |
| |
| config ACPI_HUGE_LOWMEM_BACKUP |
| bool |
| default n |
| help |
| On S3 resume path, backup low memory from RAMBASE..RAMTOP in CBMEM. |
| |
| config RESUME_PATH_SAME_AS_BOOT |
| bool |
| default y if ARCH_X86 |
| depends on HAVE_ACPI_RESUME |
| help |
| This option indicates that when a system resumes it takes the |
| same path as a regular boot. e.g. an x86 system runs from the |
| reset vector at 0xfffffff0 on both resume and warm/cold boot. |
| |
| config HAVE_HARD_RESET |
| bool |
| default n |
| help |
| This variable specifies whether a given board has a hard_reset |
| function, no matter if it's provided by board code or chipset code. |
| |
| config HAVE_ROMSTAGE_CONSOLE_SPINLOCK |
| bool |
| depends on EARLY_CBMEM_INIT |
| default n |
| |
| config HAVE_ROMSTAGE_NVRAM_CBFS_SPINLOCK |
| bool |
| depends on EARLY_CBMEM_INIT |
| default n |
| help |
| This should be enabled on certain plaforms, such as the AMD |
| SR565x, that cannot handle concurrent CBFS accesses from |
| multiple APs during early startup. |
| |
| config HAVE_ROMSTAGE_MICROCODE_CBFS_SPINLOCK |
| bool |
| depends on EARLY_CBMEM_INIT |
| default n |
| |
| config HAVE_MONOTONIC_TIMER |
| def_bool n |
| help |
| The board/chipset provides a monotonic timer. |
| |
| config GENERIC_UDELAY |
| def_bool n |
| depends on HAVE_MONOTONIC_TIMER |
| help |
| The board/chipset uses a generic udelay function utilizing the |
| monotonic timer. |
| |
| config TIMER_QUEUE |
| def_bool n |
| depends on HAVE_MONOTONIC_TIMER |
| help |
| Provide a timer queue for performing time-based callbacks. |
| |
| config COOP_MULTITASKING |
| def_bool n |
| depends on TIMER_QUEUE && ARCH_X86 |
| help |
| Cooperative multitasking allows callbacks to be multiplexed on the |
| main thread of ramstage. With this enabled it allows for multiple |
| execution paths to take place when they have udelay() calls within |
| their code. |
| |
| config NUM_THREADS |
| int |
| default 4 |
| depends on COOP_MULTITASKING |
| help |
| How many execution threads to cooperatively multitask with. |
| |
| config HAVE_OPTION_TABLE |
| bool |
| default n |
| help |
| This variable specifies whether a given board has a cmos.layout |
| file containing NVRAM/CMOS bit definitions. |
| It defaults to 'n' but can be selected in mainboard/*/Kconfig. |
| |
| config PIRQ_ROUTE |
| bool |
| default n |
| |
| config HAVE_SMI_HANDLER |
| bool |
| default n |
| |
| config PCI_IO_CFG_EXT |
| bool |
| default n |
| |
| config IOAPIC |
| bool |
| default n |
| |
| config CACHE_ROM_SIZE_OVERRIDE |
| hex |
| default 0x0 |
| |
| config USE_WATCHDOG_ON_BOOT |
| bool |
| default n |
| |
| config GFXUMA |
| bool |
| default n |
| help |
| Enable Unified Memory Architecture for graphics. |
| |
| config HAVE_ACPI_TABLES |
| bool |
| help |
| This variable specifies whether a given board has ACPI table support. |
| It is usually set in mainboard/*/Kconfig. |
| |
| config HAVE_MP_TABLE |
| bool |
| help |
| This variable specifies whether a given board has MP table support. |
| It is usually set in mainboard/*/Kconfig. |
| Whether or not the MP table is actually generated by coreboot |
| is configurable by the user via GENERATE_MP_TABLE. |
| |
| config HAVE_PIRQ_TABLE |
| bool |
| help |
| This variable specifies whether a given board has PIRQ table support. |
| It is usually set in mainboard/*/Kconfig. |
| Whether or not the PIRQ table is actually generated by coreboot |
| is configurable by the user via GENERATE_PIRQ_TABLE. |
| |
| config MAX_PIRQ_LINKS |
| int |
| default 4 |
| help |
| This variable specifies the number of PIRQ interrupt links which are |
| routable. On most chipsets, this is 4, INTA through INTD. Some |
| chipsets offer more than four links, commonly up to INTH. They may |
| also have a separate link for ATA or IOAPIC interrupts. When the PIRQ |
| table specifies links greater than 4, pirq_route_irqs will not |
| function properly, unless this variable is correctly set. |
| |
| config COMMON_FADT |
| bool |
| default n |
| |
| config ACPI_NHLT |
| bool |
| default n |
| help |
| Build support for NHLT (non HD Audio) ACPI table generation. |
| |
| #These Options are here to avoid "undefined" warnings. |
| #The actual selection and help texts are in the following menu. |
| |
| menu "System tables" |
| |
| config GENERATE_MP_TABLE |
| prompt "Generate an MP table" if HAVE_MP_TABLE || DRIVERS_GENERIC_IOAPIC |
| bool |
| default HAVE_MP_TABLE || DRIVERS_GENERIC_IOAPIC |
| help |
| Generate an MP table (conforming to the Intel MultiProcessor |
| specification 1.4) for this board. |
| |
| If unsure, say Y. |
| |
| config GENERATE_PIRQ_TABLE |
| prompt "Generate a PIRQ table" if HAVE_PIRQ_TABLE |
| bool |
| default HAVE_PIRQ_TABLE |
| help |
| Generate a PIRQ table for this board. |
| |
| If unsure, say Y. |
| |
| config GENERATE_SMBIOS_TABLES |
| depends on ARCH_X86 |
| bool "Generate SMBIOS tables" |
| default y |
| help |
| Generate SMBIOS tables for this board. |
| |
| If unsure, say Y. |
| |
| config SMBIOS_PROVIDED_BY_MOBO |
| bool |
| default n |
| |
| config MAINBOARD_SERIAL_NUMBER |
| string "SMBIOS Serial Number" |
| depends on GENERATE_SMBIOS_TABLES |
| depends on !SMBIOS_PROVIDED_BY_MOBO |
| default "123456789" |
| help |
| The Serial Number to store in SMBIOS structures. |
| |
| config MAINBOARD_VERSION |
| string "SMBIOS Version Number" |
| depends on GENERATE_SMBIOS_TABLES |
| depends on !SMBIOS_PROVIDED_BY_MOBO |
| default "1.0" |
| help |
| The Version Number to store in SMBIOS structures. |
| |
| config MAINBOARD_SMBIOS_MANUFACTURER |
| string "SMBIOS Manufacturer" |
| depends on GENERATE_SMBIOS_TABLES |
| depends on !SMBIOS_PROVIDED_BY_MOBO |
| default MAINBOARD_VENDOR |
| help |
| Override the default Manufacturer stored in SMBIOS structures. |
| |
| config MAINBOARD_SMBIOS_PRODUCT_NAME |
| string "SMBIOS Product name" |
| depends on GENERATE_SMBIOS_TABLES |
| depends on !SMBIOS_PROVIDED_BY_MOBO |
| default MAINBOARD_PART_NUMBER |
| help |
| Override the default Product name stored in SMBIOS structures. |
| |
| endmenu |
| |
| source "payloads/Kconfig" |
| |
| menu "Debugging" |
| |
| # TODO: Better help text and detailed instructions. |
| config GDB_STUB |
| bool "GDB debugging support" |
| default n |
| depends on CONSOLE_SERIAL |
| help |
| If enabled, you will be able to set breakpoints for gdb debugging. |
| See src/arch/x86/lib/c_start.S for details. |
| |
| config GDB_WAIT |
| bool "Wait for a GDB connection in the ramstage" |
| default n |
| depends on GDB_STUB |
| help |
| If enabled, coreboot will wait for a GDB connection in the ramstage. |
| |
| |
| config FATAL_ASSERTS |
| bool "Halt when hitting a BUG() or assertion error" |
| default n |
| help |
| If enabled, coreboot will call hlt() on a BUG() or failed ASSERT(). |
| |
| config DEBUG_CBFS |
| bool "Output verbose CBFS debug messages" |
| default n |
| help |
| This option enables additional CBFS related debug messages. |
| |
| config HAVE_DEBUG_RAM_SETUP |
| def_bool n |
| |
| config DEBUG_RAM_SETUP |
| bool "Output verbose RAM init debug messages" |
| default n |
| depends on HAVE_DEBUG_RAM_SETUP |
| help |
| This option enables additional RAM init related debug messages. |
| It is recommended to enable this when debugging issues on your |
| board which might be RAM init related. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config HAVE_DEBUG_CAR |
| def_bool n |
| |
| config DEBUG_CAR |
| def_bool n |
| depends on HAVE_DEBUG_CAR |
| |
| if DEFAULT_CONSOLE_LOGLEVEL_7 || DEFAULT_CONSOLE_LOGLEVEL_8 |
| # Only visible if debug level is DEBUG (7) or SPEW (8) as it does additional |
| # printk(BIOS_DEBUG, ...) calls. |
| config DEBUG_CAR |
| bool "Output verbose Cache-as-RAM debug messages" |
| default n |
| depends on HAVE_DEBUG_CAR |
| help |
| This option enables additional CAR related debug messages. |
| endif |
| |
| config DEBUG_PIRQ |
| bool "Check PIRQ table consistency" |
| default n |
| depends on GENERATE_PIRQ_TABLE |
| help |
| If unsure, say N. |
| |
| config HAVE_DEBUG_SMBUS |
| def_bool n |
| |
| config DEBUG_SMBUS |
| bool "Output verbose SMBus debug messages" |
| default n |
| depends on HAVE_DEBUG_SMBUS |
| help |
| This option enables additional SMBus (and SPD) debug messages. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config DEBUG_SMI |
| bool "Output verbose SMI debug messages" |
| default n |
| depends on HAVE_SMI_HANDLER |
| select SPI_FLASH_SMM if SPI_CONSOLE |
| help |
| This option enables additional SMI related debug messages. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config DEBUG_SMM_RELOCATION |
| bool "Debug SMM relocation code" |
| default n |
| depends on HAVE_SMI_HANDLER |
| help |
| This option enables additional SMM handler relocation related |
| debug messages. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| # Only visible if debug level is DEBUG (7) or SPEW (8) as it does additional |
| # printk(BIOS_DEBUG, ...) calls. |
| config DEBUG_MALLOC |
| prompt "Output verbose malloc debug messages" if DEFAULT_CONSOLE_LOGLEVEL_7 || DEFAULT_CONSOLE_LOGLEVEL_8 |
| bool |
| default n |
| help |
| This option enables additional malloc related debug messages. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| # Only visible if debug level is DEBUG (7) or SPEW (8) as it does additional |
| # printk(BIOS_DEBUG, ...) calls. |
| config DEBUG_ACPI |
| prompt "Output verbose ACPI debug messages" if DEFAULT_CONSOLE_LOGLEVEL_7 || DEFAULT_CONSOLE_LOGLEVEL_8 |
| bool |
| default n |
| help |
| This option enables additional ACPI related debug messages. |
| |
| Note: This option will slightly increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| # Only visible if debug level is DEBUG (7) or SPEW (8) as it does additional |
| # printk(BIOS_DEBUG, ...) calls. |
| config REALMODE_DEBUG |
| prompt "Enable debug messages for option ROM execution" if DEFAULT_CONSOLE_LOGLEVEL_7 || DEFAULT_CONSOLE_LOGLEVEL_8 |
| bool |
| default n |
| depends on PCI_OPTION_ROM_RUN_REALMODE |
| help |
| This option enables additional x86emu related debug messages. |
| |
| Note: This option will increase the time to emulate a ROM. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG |
| bool "Output verbose x86emu debug messages" |
| default n |
| depends on PCI_OPTION_ROM_RUN_YABEL |
| help |
| This option enables additional x86emu related debug messages. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_JMP |
| bool "Trace JMP/RETF" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Print information about JMP and RETF opcodes from x86emu. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_TRACE |
| bool "Trace all opcodes" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Print _all_ opcodes that are executed by x86emu. |
| |
| WARNING: This will produce a LOT of output and take a long time. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_PNP |
| bool "Log Plug&Play accesses" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Print Plug And Play accesses made by option ROMs. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_DISK |
| bool "Log Disk I/O" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Print Disk I/O related messages. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_PMM |
| bool "Log PMM" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Print messages related to POST Memory Manager (PMM). |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| |
| config X86EMU_DEBUG_VBE |
| bool "Debug VESA BIOS Extensions" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Print messages related to VESA BIOS Extension (VBE) functions. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_INT10 |
| bool "Redirect INT10 output to console" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Let INT10 (i.e. character output) calls print messages to debug output. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_INTERRUPTS |
| bool "Log intXX calls" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Print messages related to interrupt handling. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_CHECK_VMEM_ACCESS |
| bool "Log special memory accesses" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Print messages related to accesses to certain areas of the virtual |
| memory (e.g. BDA (BIOS Data Area) or interrupt vectors) |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_MEM |
| bool "Log all memory accesses" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Print memory accesses made by option ROM. |
| Note: This also includes accesses to fetch instructions. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_IO |
| bool "Log IO accesses" |
| default n |
| depends on X86EMU_DEBUG |
| help |
| Print I/O accesses made by option ROM. |
| |
| Note: This option will increase the size of the coreboot image. |
| |
| If unsure, say N. |
| |
| config X86EMU_DEBUG_TIMINGS |
| bool "Output timing information" |
| default n |
| depends on X86EMU_DEBUG && UDELAY_LAPIC && HAVE_MONOTONIC_TIMER |
| help |
| Print timing information needed by i915tool. |
| |
| If unsure, say N. |
| |
| config DEBUG_TPM |
| bool "Output verbose TPM debug messages" |
| default n |
| depends on TPM || TPM2 |
| help |
| This option enables additional TPM related debug messages. |
| |
| config DEBUG_SPI_FLASH |
| bool "Output verbose SPI flash debug messages" |
| default n |
| depends on SPI_FLASH |
| help |
| This option enables additional SPI flash related debug messages. |
| |
| config DEBUG_USBDEBUG |
| bool "Output verbose USB 2.0 EHCI debug dongle messages" |
| default n |
| depends on USBDEBUG |
| help |
| This option enables additional USB 2.0 debug dongle related messages. |
| |
| Select this to debug the connection of usbdebug dongle. Note that |
| you need some other working console to receive the messages. |
| |
| if SOUTHBRIDGE_INTEL_BD82X6X && DEFAULT_CONSOLE_LOGLEVEL_8 |
| # Only visible with the right southbridge and loglevel. |
| config DEBUG_INTEL_ME |
| bool "Verbose logging for Intel Management Engine" |
| default n |
| help |
| Enable verbose logging for Intel Management Engine driver that |
| is present on Intel 6-series chipsets. |
| endif |
| |
| config TRACE |
| bool "Trace function calls" |
| default n |
| help |
| If enabled, every function will print information to console once |
| the function is entered. The syntax is ~0xaaaabbbb(0xccccdddd) |
| the 0xaaaabbbb is the actual function and 0xccccdddd is EIP |
| of calling function. Please note some printk related functions |
| are omitted from trace to have good looking console dumps. |
| |
| config DEBUG_COVERAGE |
| bool "Debug code coverage" |
| default n |
| depends on COVERAGE |
| help |
| If enabled, the code coverage hooks in coreboot will output some |
| information about the coverage data that is dumped. |
| |
| config DEBUG_BOOT_STATE |
| bool "Debug boot state machine" |
| default n |
| help |
| Control debugging of the boot state machine. When selected displays |
| the state boundaries in ramstage. |
| |
| config DEBUG_PRINT_PAGE_TABLES |
| bool "Print the page tables after construction" |
| default n |
| depends on ARCH_RISCV |
| help |
| After the page tables have been built, print them on the debug |
| console. |
| |
| config DEBUG_ADA_CODE |
| bool "Compile debug code in Ada sources" |
| default n |
| help |
| Add the compiler switch `-gnata` to compile code guarded by |
| `pragma Debug`. |
| |
| endmenu |
| |
| |
| ############################################################################### |
| # Set variables with no prompt - these can be set anywhere, and putting at |
| # the end of this file gives the most flexibility. |
| |
| source "src/lib/Kconfig" |
| |
| config ENABLE_APIC_EXT_ID |
| bool |
| default n |
| |
| config WARNINGS_ARE_ERRORS |
| bool |
| default y |
| |
| # The four POWER_BUTTON_DEFAULT_ENABLE, POWER_BUTTON_DEFAULT_DISABLE, |
| # POWER_BUTTON_FORCE_ENABLE and POWER_BUTTON_FORCE_DISABLE options are |
| # mutually exclusive. One of these options must be selected in the |
| # mainboard Kconfig if the chipset supports enabling and disabling of |
| # the power button. Chipset code uses the ENABLE_POWER_BUTTON option set |
| # in mainboard/Kconfig to know if the button should be enabled or not. |
| |
| config POWER_BUTTON_DEFAULT_ENABLE |
| def_bool n |
| help |
| Select when the board has a power button which can optionally be |
| disabled by the user. |
| |
| config POWER_BUTTON_DEFAULT_DISABLE |
| def_bool n |
| help |
| Select when the board has a power button which can optionally be |
| enabled by the user, e.g. when the board ships with a jumper over |
| the power switch contacts. |
| |
| config POWER_BUTTON_FORCE_ENABLE |
| def_bool n |
| help |
| Select when the board requires that the power button is always |
| enabled. |
| |
| config POWER_BUTTON_FORCE_DISABLE |
| def_bool n |
| help |
| Select when the board requires that the power button is always |
| disabled, e.g. when it has been hardwired to ground. |
| |
| config POWER_BUTTON_IS_OPTIONAL |
| bool |
| default y if POWER_BUTTON_DEFAULT_ENABLE || POWER_BUTTON_DEFAULT_DISABLE |
| default n if !(POWER_BUTTON_DEFAULT_ENABLE || POWER_BUTTON_DEFAULT_DISABLE) |
| help |
| Internal option that controls ENABLE_POWER_BUTTON visibility. |
| |
| config REG_SCRIPT |
| bool |
| default n |
| help |
| Internal option that controls whether we compile in register scripts. |
| |
| config MAX_REBOOT_CNT |
| int |
| default 3 |
| help |
| Internal option that sets the maximum number of bootblock executions allowed |
| with the normal image enabled before assuming the normal image is defective |
| and switching to the fallback image. |
| |
| config CREATE_BOARD_CHECKLIST |
| bool |
| default n |
| help |
| When selected, creates a webpage showing the implementation status for |
| the board. Routines highlighted in green are complete, yellow are |
| optional and red are required and must be implemented. A table is |
| produced for each stage of the boot process except the bootblock. The |
| red items may be used as an implementation checklist for the board. |
| |
| config MAKE_CHECKLIST_PUBLIC |
| bool |
| default n |
| help |
| When selected, build/$(CONFIG_MAINBOARD_PART_NUMBER)_checklist.html |
| is copied into the Documentation/$(CONFIG_MAINBOARD_VENDOR)/Board |
| directory. |
| |
| config CHECKLIST_DATA_FILE_LOCATION |
| string |
| help |
| Location of the <stage>_complete.dat and <stage>_optional.dat files |
| that are consumed during checklist processing. <stage>_complete.dat |
| contains the symbols that are expected to be in the resulting image. |
| <stage>_optional.dat is a subset of <stage>_complete.dat and contains |
| a list of weak symbols which the resulting image may consume. Other |
| symbols contained only in <stage>_complete.dat will be flagged as |
| required and not implemented if a weak implementation is found in the |
| resulting image. |
| |
| config UNCOMPRESSED_RAMSTAGE |
| bool |
| |
| config NO_XIP_EARLY_STAGES |
| bool |
| default n if ARCH_X86 |
| default y |
| help |
| Identify if early stages are eXecute-In-Place(XIP). |
| |
| config EARLY_CBMEM_INIT |
| def_bool !LATE_CBMEM_INIT |
| |
| config EARLY_CBMEM_LIST |
| bool |
| default n |
| help |
| Enable display of CBMEM during romstage and postcar. |
| |
| config RELOCATABLE_MODULES |
| bool |
| help |
| If RELOCATABLE_MODULES is selected then support is enabled for |
| building relocatable modules in the RAM stage. Those modules can be |
| loaded anywhere and all the relocations are handled automatically. |
| |
| config NO_STAGE_CACHE |
| bool |
| help |
| Do not save any component in stage cache for resume path. On resume, |
| all components would be read back from CBFS again. |
| |
| config GENERIC_GPIO_LIB |
| bool |
| help |
| If enabled, compile the generic GPIO library. A "generic" GPIO |
| implies configurability usually found on SoCs, particularly the |
| ability to control internal pull resistors. |
| |
| config GENERIC_SPD_BIN |
| bool |
| help |
| If enabled, add support for adding spd.hex files in cbfs as spd.bin |
| and locating it runtime to load SPD. Additionally provide provision to |
| fetch SPD over SMBus. |
| |
| config DIMM_MAX |
| int |
| default 4 |
| depends on GENERIC_SPD_BIN |
| help |
| Total number of memory DIMM slots available on motherboard. |
| It is multiplication of number of channel to number of DIMMs per |
| channel |
| |
| config DIMM_SPD_SIZE |
| int |
| default 256 |
| help |
| Total SPD size that will be used for DIMM. |
| Ex: DDR3 256, DDR4 512. |
| |
| config BOARD_ID_AUTO |
| bool |
| default n |
| help |
| Mainboards that can read a board ID from the hardware straps |
| (ie. GPIO) select this configuration option. |
| |
| config BOARD_ID_MANUAL |
| bool |
| default n |
| depends on !BOARD_ID_AUTO |
| help |
| If you want to maintain a board ID, but the hardware does not |
| have straps to automatically determine the ID, you can say Y |
| here and add a file named 'board_id' to CBFS. If you don't know |
| what this is about, say N. |
| |
| config BOOTBLOCK_CUSTOM |
| # To be selected by arch, SoC or mainboard if it does not want use the normal |
| # src/lib/bootblock.c#main() C entry point. |
| bool |
| |
| config C_ENVIRONMENT_BOOTBLOCK |
| # To be selected by arch or platform if a C environment is available during the |
| # bootblock. Normally this signifies availability of RW memory (e.g. SRAM). |
| bool |
| |
| ############################################################################### |
| # Set default values for symbols created before mainboards. This allows the |
| # option to be displayed in the general menu, but the default to be loaded in |
| # the mainboard if desired. |
| config COMPRESS_RAMSTAGE |
| default y if !UNCOMPRESSED_RAMSTAGE |
| |
| config COMPRESS_PRERAM_STAGES |
| depends on !ARCH_X86 |
| default y |
| |
| config INCLUDE_CONFIG_FILE |
| default y |
| |
| config BOARD_ID_STRING |
| default "(none)" |
| depends on BOARD_ID_MANUAL |
| |
| config BOOTSPLASH_FILE |
| depends on BOOTSPLASH_IMAGE |
| default "bootsplash.jpg" |
| |
| config CBFS_SIZE |
| default ROM_SIZE |