xlat_mmu_helpers.h 3.11 KB
Newer Older
1
/*
2
 * Copyright (c) 2014-2018, ARM Limited and Contributors. All rights reserved.
3
 *
dp-arm's avatar
dp-arm committed
4
 * SPDX-License-Identifier: BSD-3-Clause
5
6
 */

Antonio Nino Diaz's avatar
Antonio Nino Diaz committed
7
8
#ifndef XLAT_MMU_HELPERS_H
#define XLAT_MMU_HELPERS_H
9

10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
/*
 * The following flags are passed to enable_mmu_xxx() to override the default
 * values used to program system registers while enabling the MMU.
 */

/*
 * When this flag is used, all data access to Normal memory from this EL and all
 * Normal memory accesses to the translation tables of this EL are non-cacheable
 * for all levels of data and unified cache until the caches are enabled by
 * setting the bit SCTLR_ELx.C.
 */
#define DISABLE_DCACHE			(U(1) << 0)

/*
 * Mark the translation tables as non-cacheable for the MMU table walker, which
 * is a different observer from the PE/CPU. If the flag is not specified, the
 * tables are cacheable for the MMU table walker.
 *
 * Note that, as far as the PE/CPU observer is concerned, the attributes used
 * are the ones specified in the translation tables themselves. The MAIR
 * register specifies the cacheability through the field AttrIndx of the lower
 * attributes of the translation tables. The shareability is specified in the SH
 * field of the lower attributes.
 *
 * The MMU table walker uses the attributes specified in the fields ORGNn, IRGNn
 * and SHn of the TCR register to access the translation tables.
 *
 * The attributes specified in the TCR register and the tables can be different
 * as there are no checks to prevent that. Special care must be taken to ensure
 * that there aren't mismatches. The behaviour in that case is described in the
 * sections 'Mismatched memory attributes' in the ARMv8 ARM.
 */
#define XLAT_TABLE_NC			(U(1) << 1)

44
45
46
47
48
49
50
51
52
/*
 * Offsets into a mmu_cfg_params array generated by setup_mmu_cfg(). All
 * parameters are 64 bits wide.
 */
#define MMU_CFG_MAIR		0
#define MMU_CFG_TCR		1
#define MMU_CFG_TTBR0		2
#define MMU_CFG_PARAM_MAX	3

53
#ifndef __ASSEMBLER__
54

55
#include <stdbool.h>
Antonio Nino Diaz's avatar
Antonio Nino Diaz committed
56
#include <stdint.h>
57
#include <string.h>
58

59
60
#include <arch_helpers.h>

61
62
63
64
65
66
67
68
69
/*
 * Return the values that the MMU configuration registers must contain for the
 * specified translation context. `params` must be a pointer to array of size
 * MMU_CFG_PARAM_MAX.
 */
void setup_mmu_cfg(uint64_t *params, unsigned int flags,
		   const uint64_t *base_table, unsigned long long max_pa,
		   uintptr_t max_va, int xlat_regime);

70
#ifdef __aarch64__
71
72
/* AArch64 specific translation table APIs */
void enable_mmu_el1(unsigned int flags);
73
void enable_mmu_el2(unsigned int flags);
74
void enable_mmu_el3(unsigned int flags);
75
void enable_mmu(unsigned int flags);
76
77

void enable_mmu_direct_el1(unsigned int flags);
78
void enable_mmu_direct_el2(unsigned int flags);
79
void enable_mmu_direct_el3(unsigned int flags);
80
81
82
83
84
85
86
87
#else
/* AArch32 specific translation table API */
void enable_mmu_svc_mon(unsigned int flags);
void enable_mmu_hyp(unsigned int flags);

void enable_mmu_direct_svc_mon(unsigned int flags);
void enable_mmu_direct_hyp(unsigned int flags);
#endif /* __aarch64__ */
88

89
bool xlat_arch_is_granule_size_supported(size_t size);
90
91
size_t xlat_arch_get_max_supported_granule_size(void);

92
#endif /* __ASSEMBLER__ */
93

Antonio Nino Diaz's avatar
Antonio Nino Diaz committed
94
#endif /* XLAT_MMU_HELPERS_H */