diff options
author | Vikas Das <vdas@codeaurora.org> | 2014-09-22 17:49:56 -0700 |
---|---|---|
committer | Patrick Georgi <pgeorgi@google.com> | 2015-04-15 21:56:56 +0200 |
commit | 08f249e7d07e7742e202d08305822af2b3ddec78 (patch) | |
tree | ad7403d9915d06d309e1a7227b3af62a00e71dae /src/mainboard | |
parent | 239622677b3e3e20d1de8f79224edf1cc97d7083 (diff) | |
download | coreboot-08f249e7d07e7742e202d08305822af2b3ddec78.tar.xz |
ipq806x: Load TZBSP blob from coreboot ramstage
Read the TZBSP blob from CBFS and run it. A side effect of the blob
execution is switching the processor into User mode.
Starting TZBSP requires processor running in Supervisor mode, TZBSP
code is compiled for ARM. Coreboot is executing in System mode and is
compiled for Thumb. An assembler wrapper switches the execution mode
and interfaces between Thumb and ARM modes.
BUG=chrome-os-partner:34161
BRANCH=Storm
TEST=manual
With the preceeding patches the system successfully loads to
depthcharge in recovery mode.
Change-Id: I812b5cef95ba5562a005e005162d6391e502ecf8
Signed-off-by: Patrick Georgi <pgeorgi@chromium.org>
Original-Commit-Id: 7065cf3d17964a1d9038ec8906b469a08a79c6e2
Original-Change-Id: Ib14dbcbcbe489b595f4247d489d50f76a0e65948
Original-Signed-off-by: Varadarajan Narayanan <varada@qti.qualcomm.com>
Original-Signed-off-by: Vadim Bendebury <vbendeb@chromium.org>
Original-Reviewed-on: https://chromium-review.googlesource.com/229026
Original-Reviewed-by: Aaron Durbin <adurbin@chromium.org>
Reviewed-on: http://review.coreboot.org/9690
Tested-by: build bot (Jenkins)
Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
Diffstat (limited to 'src/mainboard')
-rw-r--r-- | src/mainboard/google/storm/mainboard.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/src/mainboard/google/storm/mainboard.c b/src/mainboard/google/storm/mainboard.c index 3ed2c7fcaf..5abf2f7646 100644 --- a/src/mainboard/google/storm/mainboard.c +++ b/src/mainboard/google/storm/mainboard.c @@ -24,6 +24,7 @@ #include <device/device.h> #include <gpio.h> #include <soc/clock.h> +#include <soc/soc_services.h> #include <soc/usb.h> #include <symbols.h> @@ -109,6 +110,7 @@ static void assert_sw_reset(void) static void mainboard_init(device_t dev) { + start_tzbsp(); setup_mmu(); setup_usb(); assert_sw_reset(); |