packaging: release out (3.8.3)
[profile/ivi/kernel-adaptation-intel-automotive.git] / arch / xtensa / include / asm / initialize_mmu.h
1 /*
2  * arch/xtensa/include/asm/initialize_mmu.h
3  *
4  * Initializes MMU:
5  *
6  *      For the new V3 MMU we remap the TLB from virtual == physical
7  *      to the standard Linux mapping used in earlier MMU's.
8  *
9  *      The the MMU we also support a new configuration register that
10  *      specifies how the S32C1I instruction operates with the cache
11  *      controller.
12  *
13  * This file is subject to the terms and conditions of the GNU General
14  * Public License.  See the file "COPYING" in the main directory of
15  * this archive for more details.
16  *
17  * Copyright (C) 2008 - 2012 Tensilica, Inc.
18  *
19  *   Marc Gauthier <marc@tensilica.com>
20  *   Pete Delaney <piet@tensilica.com>
21  */
22
23 #ifndef _XTENSA_INITIALIZE_MMU_H
24 #define _XTENSA_INITIALIZE_MMU_H
25
26 #ifdef __ASSEMBLY__
27
28 #define XTENSA_HWVERSION_RC_2009_0 230000
29
30         .macro  initialize_mmu
31
32 #if XCHAL_HAVE_S32C1I && (XCHAL_HW_MIN_VERSION >= XTENSA_HWVERSION_RC_2009_0)
33 /*
34  * We Have Atomic Operation Control (ATOMCTL) Register; Initialize it.
35  * For details see Documentation/xtensa/atomctl.txt
36  */
37 #if XCHAL_DCACHE_IS_COHERENT
38         movi    a3, 0x25        /* For SMP/MX -- internal for writeback,
39                                  * RCW otherwise
40                                  */
41 #else
42         movi    a3, 0x29        /* non-MX -- Most cores use Std Memory
43                                  * Controlers which usually can't use RCW
44                                  */
45 #endif
46         wsr     a3, atomctl
47 #endif  /* XCHAL_HAVE_S32C1I &&
48          * (XCHAL_HW_MIN_VERSION >= XTENSA_HWVERSION_RC_2009_0)
49          */
50
51         .endm
52
53 #endif /*__ASSEMBLY__*/
54
55 #endif /* _XTENSA_INITIALIZE_MMU_H */