2 * Xtensa Secondary Processors startup code.
4 * This file is subject to the terms and conditions of the GNU General Public
5 * License. See the file "COPYING" in the main directory of this archive
8 * Copyright (C) 2001 - 2013 Tensilica Inc.
10 * Joe Taylor <joe@tensilica.com>
11 * Chris Zankel <chris@zankel.net>
12 * Marc Gauthier <marc@tensilica.com, marc@alumni.uwaterloo.ca>
13 * Pete Delaney <piet@tensilica.com>
16 #include <linux/linkage.h>
18 #include <asm/cacheasm.h>
19 #include <asm/initialize_mmu.h>
20 #include <asm/mxregs.h>
24 .section .SecondaryResetVector.text, "ax"
27 ENTRY(_SecondaryResetVector)
30 .begin no-absolute-literals
35 * Initialize WB, WS, and clear PS.EXCM (to allow loop instructions).
36 * Set Interrupt Level just below XCHAL_DEBUGLEVEL to allow
37 * xt-gdb to single step via DEBUG exceptions received directly
51 Offset = _SetupMMU - _SecondaryResetVector
53 #ifdef CONFIG_INITIALIZE_XTENSA_MMU_INSIDE_VMLINUX
58 * Start Secondary Processors with NULL pointer to boot params.
60 movi a2, 0 # a2 == NULL
64 .end no-absolute-literals
67 .section .SecondaryResetVector.remapped_text, "ax"
68 .global _RemappedSecondaryResetVector
70 .org 0 # Need to do org before literals
72 _RemappedSecondaryResetVector:
73 .begin no-absolute-literals
77 . = _RemappedSecondaryResetVector + Offset
81 #ifdef CONFIG_INITIALIZE_XTENSA_MMU_INSIDE_VMLINUX
85 .end no-absolute-literals