This patch changes several cache-related pieces to be cleaner, faster or more correct. The largest point is removing the old arm_invalidate_caches() function and surrounding bootblock code to initialize SCTLR and replace it with an all-assembly function that takes care of cache and SCTLR initialization to bring the system to a known state. It runs without stack and before coreboot makes any write accesses to be as compatible as possible with whatever state the system was left in by preceeding code. This also finally fixes the dreaded icache bug that wasted hundreds of milliseconds during boot. Old-Change-Id: I7bb4995af8184f6383f8e3b1b870b0662bde8bd4 Signed-off-by: Julius Werner <jwerner@chromium.org> Reviewed-on: https://chromium-review.googlesource.com/183890 (cherry picked from commit 07a35925dc957919bf88dfc90515971a36e81b97) nyan_big: apply cache-related changes from nyan This applies the same changes from 07a3592 that were applied to nyan. Old-Change-Id: Idcbe85436d7a2f65fcd751954012eb5f4bec0b6c Reviewed-on: https://chromium-review.googlesource.com/184551 Commit-Queue: David Hendricks <dhendrix@chromium.org> Tested-by: David Hendricks <dhendrix@chromium.org> Reviewed-by: David Hendricks <dhendrix@chromium.org> (cherry picked from commit 4af27f02614da41c611aee2c6d175b1b948428ea) Squashed the followup patch for nyan_big into the original patch. Change-Id: Id14aef7846355ea2da496e55da227b635aca409e Signed-off-by: Isaac Christensen <isaac.christensen@se-eng.com> (cherry picked from commit 4cbf25f8eca3a12bbfec5b015953c0fc2b69c877) Signed-off-by: Marc Jones <marc.jones@se-eng.com> Reviewed-on: http://review.coreboot.org/6993 Tested-by: build bot (Jenkins) Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
105 lines
3.1 KiB
ArmAsm
105 lines
3.1 KiB
ArmAsm
/*
|
|
* Early initialization code for ARMv7 architecture.
|
|
*
|
|
* This file is based off of the OMAP3530/ARM Cortex start.S file from Das
|
|
* U-Boot, which itself got the file from armboot.
|
|
*
|
|
* Copyright (c) 2004 Texas Instruments <r-woodruff2@ti.com>
|
|
* Copyright (c) 2001 Marius Gröger <mag@sysgo.de>
|
|
* Copyright (c) 2002 Alex Züpke <azu@sysgo.de>
|
|
* Copyright (c) 2002 Gary Jennejohn <garyj@denx.de>
|
|
* Copyright (c) 2003 Richard Woodruff <r-woodruff2@ti.com>
|
|
* Copyright (c) 2003 Kshitij <kshitij@ti.com>
|
|
* Copyright (c) 2006-2008 Syed Mohammed Khasim <x0khasim@ti.com>
|
|
* Copyright (c) 2013 The Chromium OS Authors
|
|
*
|
|
* 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.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
* MA 02111-1307 USA
|
|
*/
|
|
|
|
#include <arch/asm.h>
|
|
|
|
.section ".start", "a", %progbits
|
|
.arm
|
|
ENTRY(_start)
|
|
/*
|
|
* Set the cpu to System mode with IRQ and FIQ disabled. Prefetch/Data
|
|
* aborts may happen early and crash before the abort handlers are
|
|
* installed, but at least the problem will show up near the code that
|
|
* causes it.
|
|
*/
|
|
msr cpsr_cxf, #0xdf
|
|
bl _thumb_start
|
|
ENDPROC(_start)
|
|
|
|
.thumb
|
|
ENTRY(_thumb_start)
|
|
bl arm_init_caches
|
|
|
|
/*
|
|
* From Cortex-A Series Programmer's Guide:
|
|
* Only CPU 0 performs initialization. Other CPUs go into WFI
|
|
* to do this, first work out which CPU this is
|
|
* this code typically is run before any other initialization step
|
|
*/
|
|
mrc p15, 0, r1, c0, c0, 5 @ Read Multiprocessor Affinity Register
|
|
and r1, r1, #0x3 @ Extract CPU ID bits
|
|
cmp r1, #0
|
|
bne wait_for_interrupt @ If this is not core0, wait
|
|
|
|
/*
|
|
* Initialize the stack to a known value. This is used to check for
|
|
* stack overflow later in the boot process.
|
|
*/
|
|
ldr r0, .Stack
|
|
ldr r1, .Stack_size
|
|
sub r0, r0, r1
|
|
ldr r1, .Stack
|
|
ldr r2, =0xdeadbeef
|
|
init_stack_loop:
|
|
str r2, [r0]
|
|
add r0, #4
|
|
cmp r0, r1
|
|
bne init_stack_loop
|
|
|
|
/* Set stackpointer in internal RAM to call bootblock main() */
|
|
call_bootblock:
|
|
ldr sp, .Stack /* Set up stack pointer */
|
|
ldr r0,=0x00000000
|
|
/*
|
|
* The current design of cpu_info places the struct at the top of the
|
|
* stack. Free enough space to accomodate for that, but make sure it's
|
|
* 8-byte aligned for ABI compliance.
|
|
*/
|
|
sub sp, sp, #16
|
|
bl main
|
|
|
|
wait_for_interrupt:
|
|
wfi
|
|
mov pc, lr @ back to my caller
|
|
ENDPROC(_thumb_start)
|
|
|
|
/* we do it this way because it's a 32-bit constant and
|
|
* in some cases too far away to be loaded as just an offset
|
|
* from IP
|
|
*/
|
|
.align 2
|
|
.Stack:
|
|
.word CONFIG_STACK_TOP
|
|
.align 2
|
|
/* create this size the same way we do in coreboot_ram.ld: top-bottom */
|
|
.Stack_size:
|
|
.word CONFIG_STACK_TOP - CONFIG_STACK_BOTTOM
|