blob: 9ac96291b707e615ee7e54de9473fda5ce88678f [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Stefan Roesec6bc1db2012-01-03 16:49:01 +01002/*
3 * armboot - Startup Code for ARM926EJS CPU-core
4 *
5 * Copyright (c) 2003 Texas Instruments
6 *
7 * ----- Adapted for OMAP1610 OMAP730 from ARM925t code ------
8 *
9 * Copyright (c) 2001 Marius Gröger <mag@sysgo.de>
10 * Copyright (c) 2002 Alex Züpke <azu@sysgo.de>
11 * Copyright (c) 2002 Gary Jennejohn <garyj@denx.de>
12 * Copyright (c) 2003 Richard Woodruff <r-woodruff2@ti.com>
13 * Copyright (c) 2003 Kshitij <kshitij@ti.com>
Stefan Roesec6bc1db2012-01-03 16:49:01 +010014 */
15
16
17#include <config.h>
18
Stefan Roesec6bc1db2012-01-03 16:49:01 +010019/*
20 *************************************************************************
21 *
22 * Startup Code (reset vector)
23 *
Miquel Raynaldf5b5812019-05-07 14:18:47 +020024 * The BootROM already initialized its own stack in the [0-0xb00] reserved
25 * range of the SRAM. The SPL (in _main) will update the stack pointer to
26 * its own SRAM area (right before the gd section).
Stefan Roesec6bc1db2012-01-03 16:49:01 +010027 *
28 *************************************************************************
29 */
30
Albert ARIBAUD9852cc62014-04-15 16:13:51 +020031 .globl reset
Miquel Raynalf8c5c782019-05-07 14:18:52 +020032 .globl back_to_bootrom
Stefan Roesec6bc1db2012-01-03 16:49:01 +010033
34reset:
Miquel Raynalbeefd492019-05-07 14:18:48 +020035 /*
36 * SPL has to return back to BootROM in a few cases (eg. Ethernet boot,
Miquel Raynalf8c5c782019-05-07 14:18:52 +020037 * UART boot, USB boot): save registers in BootROM's stack and then the
38 * BootROM's stack pointer in the SPL's data section.
Miquel Raynalbeefd492019-05-07 14:18:48 +020039 */
Miquel Raynal787e5b92019-05-07 14:18:50 +020040 push {r0-r12,lr}
Miquel Raynalf8c5c782019-05-07 14:18:52 +020041 ldr r0, =bootrom_stash_sp
42 str sp, [r0]
Stefan Roesec6bc1db2012-01-03 16:49:01 +010043
Stefan Roesec6bc1db2012-01-03 16:49:01 +010044 /*
Miquel Raynalbeefd492019-05-07 14:18:48 +020045 * Flush v4 I/D caches
Stefan Roesec6bc1db2012-01-03 16:49:01 +010046 */
47 mov r0, #0
Miquel Raynalbeefd492019-05-07 14:18:48 +020048 mcr p15, 0, r0, c7, c7, 0 /* Flush v3/v4 cache */
49 mcr p15, 0, r0, c8, c7, 0 /* Flush v4 TLB */
Stefan Roesec6bc1db2012-01-03 16:49:01 +010050
51 /*
Miquel Raynalbeefd492019-05-07 14:18:48 +020052 * Enable instruction cache
Stefan Roesec6bc1db2012-01-03 16:49:01 +010053 */
54 mrc p15, 0, r0, c1, c0, 0
55 orr r0, r0, #0x00001000 /* set bit 12 (I) I-Cache */
56 mcr p15, 0, r0, c1, c0, 0
57
58 /*
59 * Go setup Memory and board specific bits prior to relocation.
Miquel Raynal710d1c12019-05-07 14:18:53 +020060 * This call is not supposed to return.
Stefan Roesec6bc1db2012-01-03 16:49:01 +010061 */
Miquel Raynal710d1c12019-05-07 14:18:53 +020062 b _main /* _main will call board_init_f */
Miquel Raynal06ad1eb2019-05-07 14:18:51 +020063
Miquel Raynalf8c5c782019-05-07 14:18:52 +020064back_to_bootrom:
Miquel Raynal06ad1eb2019-05-07 14:18:51 +020065 pop {r0-r12,pc}