This improves firmware boot time substantially. Because cbmem isn't available yet, we need to allocate some space in sram for the ttb. Doing cache initialization in the bootblock means we can implement this once per CPU instead of once per mainboard. Old-Change-Id: Iad339de24df8ec2e23f91fe7bf57744e4cc766c5 Signed-off-by: Gabe Black <gabeblack@google.com> Reviewed-on: https://gerrit.chromium.org/gerrit/65938 Reviewed-by: David Hendricks <dhendrix@chromium.org> Commit-Queue: Gabe Black <gabeblack@chromium.org> Tested-by: Gabe Black <gabeblack@chromium.org> (cherry picked from commit c32b9b32ad933e627b9ea98434b392239b1fea73) exynos5420: flush caches and disable MMU in resume path This patch flushes the caches and disables the MMU before resuming. c32b9b3 ("Set up caching in the bootblock.") had a bug where the dcache and MMU remained enabled in the resume path. This caused the machine to hang on resume. However, other bugs were preventing us from testing this properly earlier on so it went unnoticed until now. Signed-off-by: David Hendricks <dhendrix@chromium.org> Old-Change-Id: Ib1774f09d286a4d659da9fc2dad1d7a6fc1ebe5e Reviewed-on: https://chromium-review.googlesource.com/67007 Reviewed-by: ron minnich <rminnich@chromium.org> Commit-Queue: David Hendricks <dhendrix@chromium.org> Tested-by: David Hendricks <dhendrix@chromium.org> (cherry picked from commit 4fdf9763d25f70fd1e3591f6ff9785f78dd6170d) Squashed two related commits. Change-Id: Ibd42b28bb06930159248130e5ceaddb3b4b6cc2a Signed-off-by: Isaac Christensen <isaac.christensen@se-eng.com> Reviewed-on: http://review.coreboot.org/6511 Tested-by: build bot (Jenkins) Reviewed-by: Ronald G. Minnich <rminnich@gmail.com> Reviewed-by: Edward O'Callaghan <eocallaghan@alterapraxis.com>
102 lines
2.1 KiB
Plaintext
102 lines
2.1 KiB
Plaintext
config CPU_SAMSUNG_EXYNOS5250
|
|
select ARCH_BOOTBLOCK_ARMV7
|
|
select ARCH_ROMSTAGE_ARMV7
|
|
select ARCH_RAMSTAGE_ARMV7
|
|
select HAVE_MONOTONIC_TIMER
|
|
select HAVE_UART_SPECIAL
|
|
select DYNAMIC_CBMEM
|
|
bool
|
|
default n
|
|
|
|
if CPU_SAMSUNG_EXYNOS5250
|
|
|
|
config BOOTBLOCK_CPU_INIT
|
|
string
|
|
default "cpu/samsung/exynos5250/bootblock.c"
|
|
help
|
|
CPU/SoC-specific bootblock code. This is useful if the
|
|
bootblock must load microcode or copy data from ROM before
|
|
searching for the bootblock.
|
|
|
|
# ROM image layout.
|
|
#
|
|
# 0x0000: vendor-provided BL1 (8k).
|
|
# 0x2000: bootblock
|
|
# 0x2010-0x2090: reserved for CBFS master header.
|
|
# 0xA000: Free for CBFS data.
|
|
|
|
config BOOTBLOCK_ROM_OFFSET
|
|
hex
|
|
default 0x2000
|
|
|
|
config CBFS_HEADER_ROM_OFFSET
|
|
hex "offset of master CBFS header in ROM"
|
|
default 0x2010
|
|
|
|
config CBFS_ROM_OFFSET
|
|
# Calculated by BOOTBLOCK_ROM_OFFSET + max bootblock size.
|
|
hex "offset of CBFS data in ROM"
|
|
default 0x0A000
|
|
|
|
|
|
# Example SRAM/iRAM map for Exynos5250 platform:
|
|
#
|
|
# 0x0202_0000: vendor-provided BL1
|
|
# 0x0202_3400: bootblock, assume up to 32KB in size
|
|
# 0x0203_0000: romstage, assume up to 128KB in size.
|
|
# 0x0207_8000: stack pointer
|
|
|
|
config BOOTBLOCK_BASE
|
|
hex
|
|
default 0x02023400
|
|
|
|
config ROMSTAGE_BASE
|
|
hex
|
|
default 0x02030000
|
|
|
|
config ROMSTAGE_SIZE
|
|
hex
|
|
default 0x10000
|
|
|
|
# Stack may reside in either IRAM or DRAM. We will define it to live
|
|
# at the top of IRAM for now.
|
|
#
|
|
# Stack grows downward, push operation stores register contents in
|
|
# consecutive memory locations ending just below SP
|
|
config STACK_TOP
|
|
hex
|
|
default 0x02078000
|
|
|
|
config STACK_BOTTOM
|
|
hex
|
|
default 0x02074000
|
|
|
|
config STACK_SIZE
|
|
hex
|
|
default 0x4000
|
|
|
|
# TODO We may probably move this to board-specific implementation files instead
|
|
# of KConfig values.
|
|
config CBFS_CACHE_ADDRESS
|
|
hex "memory address to put CBFS cache data"
|
|
default 0x0205c000
|
|
|
|
config CBFS_CACHE_SIZE
|
|
hex "size of CBFS cache data"
|
|
default 0x00018000
|
|
|
|
# TTB needs to be aligned to 16KB.
|
|
config TTB_BUFFER
|
|
hex "memory address of the TTB buffer"
|
|
default 0x02058000
|
|
|
|
config TTB_SIZE
|
|
hex "size of the TTB buffer"
|
|
default 0x4000
|
|
|
|
config SYS_SDRAM_BASE
|
|
hex
|
|
default 0x40000000
|
|
|
|
endif
|