• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2014-2018, ARM Limited and Contributors. All rights reserved.
3  *
4  * SPDX-License-Identifier: BSD-3-Clause
5  */
6 
7 #ifndef XLAT_MMU_HELPERS_H
8 #define XLAT_MMU_HELPERS_H
9 
10 /*
11  * The following flags are passed to enable_mmu_xxx() to override the default
12  * values used to program system registers while enabling the MMU.
13  */
14 
15 /*
16  * When this flag is used, all data access to Normal memory from this EL and all
17  * Normal memory accesses to the translation tables of this EL are non-cacheable
18  * for all levels of data and unified cache until the caches are enabled by
19  * setting the bit SCTLR_ELx.C.
20  */
21 #define DISABLE_DCACHE			(U(1) << 0)
22 
23 /*
24  * Mark the translation tables as non-cacheable for the MMU table walker, which
25  * is a different observer from the PE/CPU. If the flag is not specified, the
26  * tables are cacheable for the MMU table walker.
27  *
28  * Note that, as far as the PE/CPU observer is concerned, the attributes used
29  * are the ones specified in the translation tables themselves. The MAIR
30  * register specifies the cacheability through the field AttrIndx of the lower
31  * attributes of the translation tables. The shareability is specified in the SH
32  * field of the lower attributes.
33  *
34  * The MMU table walker uses the attributes specified in the fields ORGNn, IRGNn
35  * and SHn of the TCR register to access the translation tables.
36  *
37  * The attributes specified in the TCR register and the tables can be different
38  * as there are no checks to prevent that. Special care must be taken to ensure
39  * that there aren't mismatches. The behaviour in that case is described in the
40  * sections 'Mismatched memory attributes' in the ARMv8 ARM.
41  */
42 #define XLAT_TABLE_NC			(U(1) << 1)
43 
44 /*
45  * Offsets into a mmu_cfg_params array generated by setup_mmu_cfg(). All
46  * parameters are 64 bits wide.
47  */
48 #define MMU_CFG_MAIR		0
49 #define MMU_CFG_TCR		1
50 #define MMU_CFG_TTBR0		2
51 #define MMU_CFG_PARAM_MAX	3
52 
53 #ifndef __ASSEMBLER__
54 
55 #include <stdbool.h>
56 #include <stdint.h>
57 #include <string.h>
58 
59 /*
60  * Return the values that the MMU configuration registers must contain for the
61  * specified translation context. `params` must be a pointer to array of size
62  * MMU_CFG_PARAM_MAX.
63  */
64 void setup_mmu_cfg(uint64_t *params, unsigned int flags,
65 		   const uint64_t *base_table, unsigned long long max_pa,
66 		   uintptr_t max_va, int xlat_regime);
67 
68 #ifdef __aarch64__
69 /* AArch64 specific translation table APIs */
70 void enable_mmu_el1(unsigned int flags);
71 void enable_mmu_el2(unsigned int flags);
72 void enable_mmu_el3(unsigned int flags);
73 
74 void enable_mmu_direct_el1(unsigned int flags);
75 void enable_mmu_direct_el2(unsigned int flags);
76 void enable_mmu_direct_el3(unsigned int flags);
77 #else
78 /* AArch32 specific translation table API */
79 void enable_mmu_svc_mon(unsigned int flags);
80 void enable_mmu_hyp(unsigned int flags);
81 
82 void enable_mmu_direct_svc_mon(unsigned int flags);
83 void enable_mmu_direct_hyp(unsigned int flags);
84 #endif /* __aarch64__ */
85 
86 bool xlat_arch_is_granule_size_supported(size_t size);
87 size_t xlat_arch_get_max_supported_granule_size(void);
88 
89 #endif /* __ASSEMBLER__ */
90 
91 #endif /* XLAT_MMU_HELPERS_H */
92