Linux 4.2.2
[linux/fpc-iii.git] / arch / xtensa / kernel / mxhead.S
blob77a161a112c543759b1ef0f641eeb53b5cc58d08
1 /*
2  * Xtensa Secondary Processors startup code.
3  *
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
6  * for more details.
7  *
8  * Copyright (C) 2001 - 2013 Tensilica Inc.
9  *
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>
14  */
16 #include <linux/linkage.h>
18 #include <asm/cacheasm.h>
19 #include <asm/initialize_mmu.h>
20 #include <asm/mxregs.h>
21 #include <asm/regs.h>
24         .section .SecondaryResetVector.text, "ax"
27 ENTRY(_SecondaryResetVector)
28         _j _SetupOCD
30         .begin  no-absolute-literals
31         .literal_position
33 _SetupOCD:
34         /*
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
38          * by ocd.
39          */
40         movi    a1, 1
41         movi    a0, 0
42         wsr     a1, windowstart
43         wsr     a0, windowbase
44         rsync
46         movi    a1, LOCKLEVEL
47         wsr     a1, ps
48         rsync
50 _SetupMMU:
51         Offset = _SetupMMU - _SecondaryResetVector
53 #ifdef CONFIG_INITIALIZE_XTENSA_MMU_INSIDE_VMLINUX
54         initialize_mmu
55 #endif
57         /*
58          * Start Secondary Processors with NULL pointer to boot params.
59          */
60         movi    a2, 0                           #  a2 == NULL
61         movi    a3, _startup
62         jx      a3
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
74         .literal_position
76         _j      _RemappedSetupMMU
77         . = _RemappedSecondaryResetVector + Offset
79 _RemappedSetupMMU:
81 #ifdef CONFIG_INITIALIZE_XTENSA_MMU_INSIDE_VMLINUX
82         initialize_mmu
83 #endif
85         .end    no-absolute-literals