Unverified Commit 826469bc authored by Dimitris Papastamos's avatar Dimitris Papastamos Committed by GitHub
Browse files

Merge pull request #1440 from antonio-nino-diaz-arm/an/xlat-enums

xlat: Remove mmap_attr_t enum type
Showing with 110 additions and 110 deletions
+110 -110
...@@ -79,9 +79,9 @@ The region attributes specify the type of memory (for example device or cached ...@@ -79,9 +79,9 @@ The region attributes specify the type of memory (for example device or cached
normal memory) as well as the memory access permissions (read-only or normal memory) as well as the memory access permissions (read-only or
read-write, executable or not, secure or non-secure, and so on). In the case of read-write, executable or not, secure or non-secure, and so on). In the case of
the EL1&0 translation regime, the attributes also specify whether the region is the EL1&0 translation regime, the attributes also specify whether the region is
a User region (EL0) or Privileged region (EL1). See the ``mmap_attr_t`` a User region (EL0) or Privileged region (EL1). See the ``MT_xxx`` definitions
enumeration type in `xlat\_tables\_v2.h`_. Note that for the EL1&0 translation in `xlat\_tables\_v2.h`_. Note that for the EL1&0 translation regime the Execute
regime the Execute Never attribute is set simultaneously for both EL1 and EL0. Never attribute is set simultaneously for both EL1 and EL0.
The granularity controls the translation table level to go down to when mapping The granularity controls the translation table level to go down to when mapping
the region. For example, assuming the MMU has been configured to use a 4KB the region. For example, assuming the MMU has been configured to use a 4KB
......
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
#define MAP_REGION(pa, va, sz, attr) {(pa), (va), (sz), (attr)} #define MAP_REGION(pa, va, sz, attr) {(pa), (va), (sz), (attr)}
/* /*
* Shifts and masks to access fields of an mmap_attr_t * Shifts and masks to access fields of an mmap attribute
*/ */
#define MT_TYPE_MASK U(0x7) #define MT_TYPE_MASK U(0x7)
#define MT_TYPE(_attr) ((_attr) & MT_TYPE_MASK) #define MT_TYPE(_attr) ((_attr) & MT_TYPE_MASK)
...@@ -39,38 +39,42 @@ ...@@ -39,38 +39,42 @@
/* /*
* Memory mapping attributes * Memory mapping attributes
*/ */
typedef enum {
/* /*
* Memory types supported. * Memory types supported.
* These are organised so that, going down the list, the memory types * These are organised so that, going down the list, the memory types are
* are getting weaker; conversely going up the list the memory types are * getting weaker; conversely going up the list the memory types are getting
* getting stronger. * stronger.
*/ */
MT_DEVICE, #define MT_DEVICE U(0)
MT_NON_CACHEABLE, #define MT_NON_CACHEABLE U(1)
MT_MEMORY, #define MT_MEMORY U(2)
/* Values up to 7 are reserved to add new memory types in the future */ /* Values up to 7 are reserved to add new memory types in the future */
MT_RO = U(0) << MT_PERM_SHIFT, #define MT_RO (U(0) << MT_PERM_SHIFT)
MT_RW = U(1) << MT_PERM_SHIFT, #define MT_RW (U(1) << MT_PERM_SHIFT)
MT_SECURE = U(0) << MT_SEC_SHIFT, #define MT_SECURE (U(0) << MT_SEC_SHIFT)
MT_NS = U(1) << MT_SEC_SHIFT, #define MT_NS (U(1) << MT_SEC_SHIFT)
/* /*
* Access permissions for instruction execution are only relevant for * Access permissions for instruction execution are only relevant for normal
* normal read-only memory, i.e. MT_MEMORY | MT_RO. They are ignored * read-only memory, i.e. MT_MEMORY | MT_RO. They are ignored (and potentially
* (and potentially overridden) otherwise: * overridden) otherwise:
* - Device memory is always marked as execute-never. * - Device memory is always marked as execute-never.
* - Read-write normal memory is always marked as execute-never. * - Read-write normal memory is always marked as execute-never.
*/ */
MT_EXECUTE = U(0) << MT_EXECUTE_SHIFT, #define MT_EXECUTE (U(0) << MT_EXECUTE_SHIFT)
MT_EXECUTE_NEVER = U(1) << MT_EXECUTE_SHIFT, #define MT_EXECUTE_NEVER (U(1) << MT_EXECUTE_SHIFT)
} mmap_attr_t;
/* Compound attributes for most common usages */
#define MT_CODE (MT_MEMORY | MT_RO | MT_EXECUTE) #define MT_CODE (MT_MEMORY | MT_RO | MT_EXECUTE)
#define MT_RO_DATA (MT_MEMORY | MT_RO | MT_EXECUTE_NEVER) #define MT_RO_DATA (MT_MEMORY | MT_RO | MT_EXECUTE_NEVER)
#if !ERROR_DEPRECATED
typedef unsigned int mmap_attr_t;
#endif
/* /*
* Structure for specifying a single region of memory. * Structure for specifying a single region of memory.
*/ */
...@@ -78,13 +82,13 @@ typedef struct mmap_region { ...@@ -78,13 +82,13 @@ typedef struct mmap_region {
unsigned long long base_pa; unsigned long long base_pa;
uintptr_t base_va; uintptr_t base_va;
size_t size; size_t size;
mmap_attr_t attr; unsigned int attr;
} mmap_region_t; } mmap_region_t;
/* Generic translation table APIs */ /* Generic translation table APIs */
void init_xlat_tables(void); void init_xlat_tables(void);
void mmap_add_region(unsigned long long base_pa, uintptr_t base_va, void mmap_add_region(unsigned long long base_pa, uintptr_t base_va,
size_t size, mmap_attr_t attr); size_t size, unsigned int attr);
void mmap_add(const mmap_region_t *mm); void mmap_add(const mmap_region_t *mm);
#endif /*__ASSEMBLY__*/ #endif /*__ASSEMBLY__*/
......
...@@ -47,7 +47,7 @@ ...@@ -47,7 +47,7 @@
_MAP_REGION_FULL_SPEC(_pa, _va, _sz, _attr, _gr) _MAP_REGION_FULL_SPEC(_pa, _va, _sz, _attr, _gr)
/* /*
* Shifts and masks to access fields of an mmap_attr_t * Shifts and masks to access fields of an mmap attribute
*/ */
#define MT_TYPE_MASK U(0x7) #define MT_TYPE_MASK U(0x7)
#define MT_TYPE(_attr) ((_attr) & MT_TYPE_MASK) #define MT_TYPE(_attr) ((_attr) & MT_TYPE_MASK)
...@@ -57,58 +57,57 @@ ...@@ -57,58 +57,57 @@
#define MT_SEC_SHIFT U(4) #define MT_SEC_SHIFT U(4)
/* Access permissions for instruction execution (EXECUTE/EXECUTE_NEVER) */ /* Access permissions for instruction execution (EXECUTE/EXECUTE_NEVER) */
#define MT_EXECUTE_SHIFT U(5) #define MT_EXECUTE_SHIFT U(5)
/* /* In the EL1&0 translation regime, User (EL0) or Privileged (EL1). */
* In the EL1&0 translation regime, mark the region as User (EL0) or
* Privileged (EL1). In the EL3 translation regime this has no effect.
*/
#define MT_USER_SHIFT U(6) #define MT_USER_SHIFT U(6)
/* All other bits are reserved */ /* All other bits are reserved */
/* /*
* Memory mapping attributes * Memory mapping attributes
*/ */
typedef enum {
/* /*
* Memory types supported. * Memory types supported.
* These are organised so that, going down the list, the memory types * These are organised so that, going down the list, the memory types are
* are getting weaker; conversely going up the list the memory types are * getting weaker; conversely going up the list the memory types are getting
* getting stronger. * stronger.
*/ */
MT_DEVICE, #define MT_DEVICE U(0)
MT_NON_CACHEABLE, #define MT_NON_CACHEABLE U(1)
MT_MEMORY, #define MT_MEMORY U(2)
/* Values up to 7 are reserved to add new memory types in the future */ /* Values up to 7 are reserved to add new memory types in the future */
MT_RO = U(0) << MT_PERM_SHIFT, #define MT_RO (U(0) << MT_PERM_SHIFT)
MT_RW = U(1) << MT_PERM_SHIFT, #define MT_RW (U(1) << MT_PERM_SHIFT)
MT_SECURE = U(0) << MT_SEC_SHIFT, #define MT_SECURE (U(0) << MT_SEC_SHIFT)
MT_NS = U(1) << MT_SEC_SHIFT, #define MT_NS (U(1) << MT_SEC_SHIFT)
/* /*
* Access permissions for instruction execution are only relevant for * Access permissions for instruction execution are only relevant for normal
* normal read-only memory, i.e. MT_MEMORY | MT_RO. They are ignored * read-only memory, i.e. MT_MEMORY | MT_RO. They are ignored (and potentially
* (and potentially overridden) otherwise: * overridden) otherwise:
* - Device memory is always marked as execute-never. * - Device memory is always marked as execute-never.
* - Read-write normal memory is always marked as execute-never. * - Read-write normal memory is always marked as execute-never.
*/ */
MT_EXECUTE = U(0) << MT_EXECUTE_SHIFT, #define MT_EXECUTE (U(0) << MT_EXECUTE_SHIFT)
MT_EXECUTE_NEVER = U(1) << MT_EXECUTE_SHIFT, #define MT_EXECUTE_NEVER (U(1) << MT_EXECUTE_SHIFT)
/* /*
* When mapping a region at EL0 or EL1, this attribute will be used to * When mapping a region at EL0 or EL1, this attribute will be used to determine
* determine if a User mapping (EL0) will be created or a Privileged * if a User mapping (EL0) will be created or a Privileged mapping (EL1).
* mapping (EL1).
*/ */
MT_USER = U(1) << MT_USER_SHIFT, #define MT_USER (U(1) << MT_USER_SHIFT)
MT_PRIVILEGED = U(0) << MT_USER_SHIFT, #define MT_PRIVILEGED (U(0) << MT_USER_SHIFT)
} mmap_attr_t;
/* Compound attributes for most common usages */ /* Compound attributes for most common usages */
#define MT_CODE (MT_MEMORY | MT_RO | MT_EXECUTE) #define MT_CODE (MT_MEMORY | MT_RO | MT_EXECUTE)
#define MT_RO_DATA (MT_MEMORY | MT_RO | MT_EXECUTE_NEVER) #define MT_RO_DATA (MT_MEMORY | MT_RO | MT_EXECUTE_NEVER)
#define MT_RW_DATA (MT_MEMORY | MT_RW | MT_EXECUTE_NEVER) #define MT_RW_DATA (MT_MEMORY | MT_RW | MT_EXECUTE_NEVER)
#if !ERROR_DEPRECATED
typedef unsigned int mmap_attr_t;
#endif
/* /*
* Structure for specifying a single region of memory. * Structure for specifying a single region of memory.
*/ */
...@@ -116,7 +115,7 @@ typedef struct mmap_region { ...@@ -116,7 +115,7 @@ typedef struct mmap_region {
unsigned long long base_pa; unsigned long long base_pa;
uintptr_t base_va; uintptr_t base_va;
size_t size; size_t size;
mmap_attr_t attr; unsigned int attr;
/* Desired granularity. See the MAP_REGION2() macro for more details. */ /* Desired granularity. See the MAP_REGION2() macro for more details. */
size_t granularity; size_t granularity;
} mmap_region_t; } mmap_region_t;
...@@ -213,7 +212,7 @@ void init_xlat_tables_ctx(xlat_ctx_t *ctx); ...@@ -213,7 +212,7 @@ void init_xlat_tables_ctx(xlat_ctx_t *ctx);
* removed afterwards. * removed afterwards.
*/ */
void mmap_add_region(unsigned long long base_pa, uintptr_t base_va, void mmap_add_region(unsigned long long base_pa, uintptr_t base_va,
size_t size, mmap_attr_t attr); size_t size, unsigned int attr);
void mmap_add_region_ctx(xlat_ctx_t *ctx, const mmap_region_t *mm); void mmap_add_region_ctx(xlat_ctx_t *ctx, const mmap_region_t *mm);
/* /*
...@@ -238,7 +237,7 @@ void mmap_add_ctx(xlat_ctx_t *ctx, const mmap_region_t *mm); ...@@ -238,7 +237,7 @@ void mmap_add_ctx(xlat_ctx_t *ctx, const mmap_region_t *mm);
* EPERM: It overlaps another region in an invalid way. * EPERM: It overlaps another region in an invalid way.
*/ */
int mmap_add_dynamic_region(unsigned long long base_pa, uintptr_t base_va, int mmap_add_dynamic_region(unsigned long long base_pa, uintptr_t base_va,
size_t size, mmap_attr_t attr); size_t size, unsigned int attr);
int mmap_add_dynamic_region_ctx(xlat_ctx_t *ctx, mmap_region_t *mm); int mmap_add_dynamic_region_ctx(xlat_ctx_t *ctx, mmap_region_t *mm);
/* /*
......
...@@ -58,7 +58,7 @@ void clear_map_dyn_mem_regions(mem_region_t *regions, ...@@ -58,7 +58,7 @@ void clear_map_dyn_mem_regions(mem_region_t *regions,
uintptr_t begin; uintptr_t begin;
int r; int r;
size_t size; size_t size;
const mmap_attr_t attr = MT_MEMORY|MT_RW|MT_NS; const unsigned int attr = MT_MEMORY | MT_RW | MT_NS;
assert(regions != NULL); assert(regions != NULL);
assert(nregions > 0 && chunk > 0); assert(nregions > 0 && chunk > 0);
......
...@@ -66,7 +66,7 @@ void print_mmap(void) ...@@ -66,7 +66,7 @@ void print_mmap(void)
} }
void mmap_add_region(unsigned long long base_pa, uintptr_t base_va, void mmap_add_region(unsigned long long base_pa, uintptr_t base_va,
size_t size, mmap_attr_t attr) size_t size, unsigned int attr)
{ {
mmap_region_t *mm = mmap; mmap_region_t *mm = mmap;
mmap_region_t *mm_last = mm + ARRAY_SIZE(mmap) - 1; mmap_region_t *mm_last = mm + ARRAY_SIZE(mmap) - 1;
...@@ -178,7 +178,7 @@ void mmap_add(const mmap_region_t *mm) ...@@ -178,7 +178,7 @@ void mmap_add(const mmap_region_t *mm)
} }
} }
static uint64_t mmap_desc(mmap_attr_t attr, unsigned long long addr_pa, static uint64_t mmap_desc(unsigned int attr, unsigned long long addr_pa,
unsigned int level) unsigned int level)
{ {
uint64_t desc; uint64_t desc;
...@@ -264,7 +264,7 @@ static uint64_t mmap_desc(mmap_attr_t attr, unsigned long long addr_pa, ...@@ -264,7 +264,7 @@ static uint64_t mmap_desc(mmap_attr_t attr, unsigned long long addr_pa,
* value pointed by attr should be ignored by the caller. * value pointed by attr should be ignored by the caller.
*/ */
static int mmap_region_attr(mmap_region_t *mm, uintptr_t base_va, static int mmap_region_attr(mmap_region_t *mm, uintptr_t base_va,
size_t size, mmap_attr_t *attr) size_t size, unsigned int *attr)
{ {
/* Don't assume that the area is contained in the first region */ /* Don't assume that the area is contained in the first region */
int ret = -1; int ret = -1;
...@@ -348,7 +348,7 @@ static mmap_region_t *init_xlation_table_inner(mmap_region_t *mm, ...@@ -348,7 +348,7 @@ static mmap_region_t *init_xlation_table_inner(mmap_region_t *mm,
* there are partially overlapping regions. On success, * there are partially overlapping regions. On success,
* it will return the innermost region's attributes. * it will return the innermost region's attributes.
*/ */
mmap_attr_t attr; unsigned int attr;
int r = mmap_region_attr(mm, base_va, level_size, &attr); int r = mmap_region_attr(mm, base_va, level_size, &attr);
if (!r) { if (!r) {
......
...@@ -823,10 +823,8 @@ void mmap_add_region_ctx(xlat_ctx_t *ctx, const mmap_region_t *mm) ...@@ -823,10 +823,8 @@ void mmap_add_region_ctx(xlat_ctx_t *ctx, const mmap_region_t *mm)
ctx->max_va = end_va; ctx->max_va = end_va;
} }
void mmap_add_region(unsigned long long base_pa, void mmap_add_region(unsigned long long base_pa, uintptr_t base_va, size_t size,
uintptr_t base_va, unsigned int attr)
size_t size,
mmap_attr_t attr)
{ {
mmap_region_t mm = MAP_REGION(base_pa, base_va, size, attr); mmap_region_t mm = MAP_REGION(base_pa, base_va, size, attr);
mmap_add_region_ctx(&tf_xlat_ctx, &mm); mmap_add_region_ctx(&tf_xlat_ctx, &mm);
...@@ -947,8 +945,8 @@ int mmap_add_dynamic_region_ctx(xlat_ctx_t *ctx, mmap_region_t *mm) ...@@ -947,8 +945,8 @@ int mmap_add_dynamic_region_ctx(xlat_ctx_t *ctx, mmap_region_t *mm)
return 0; return 0;
} }
int mmap_add_dynamic_region(unsigned long long base_pa, int mmap_add_dynamic_region(unsigned long long base_pa, uintptr_t base_va,
uintptr_t base_va, size_t size, mmap_attr_t attr) size_t size, unsigned int attr)
{ {
mmap_region_t mm = MAP_REGION(base_pa, base_va, size, attr); mmap_region_t mm = MAP_REGION(base_pa, base_va, size, attr);
return mmap_add_dynamic_region_ctx(&tf_xlat_ctx, &mm); return mmap_add_dynamic_region_ctx(&tf_xlat_ctx, &mm);
......
...@@ -12,27 +12,26 @@ ...@@ -12,27 +12,26 @@
#if PLAT_XLAT_TABLES_DYNAMIC #if PLAT_XLAT_TABLES_DYNAMIC
/* /*
* Shifts and masks to access fields of an mmap_attr_t * Private shifts and masks to access fields of an mmap attribute
*/ */
/* Dynamic or static */ /* Dynamic or static */
#define MT_DYN_SHIFT 30 /* 31 would cause undefined behaviours */ #define MT_DYN_SHIFT U(31)
/* /*
* Memory mapping private attributes * Memory mapping private attributes
* *
* Private attributes not exposed in the mmap_attr_t enum. * Private attributes not exposed in the public header.
*/ */
typedef enum {
/* /*
* Regions mapped before the MMU can't be unmapped dynamically (they are * Regions mapped before the MMU can't be unmapped dynamically (they are
* static) and regions mapped with MMU enabled can be unmapped. This * static) and regions mapped with MMU enabled can be unmapped. This
* behaviour can't be overridden. * behaviour can't be overridden.
* *
* Static regions can overlap each other, dynamic regions can't. * Static regions can overlap each other, dynamic regions can't.
*/ */
MT_STATIC = 0 << MT_DYN_SHIFT, #define MT_STATIC (U(0) << MT_DYN_SHIFT)
MT_DYNAMIC = 1 << MT_DYN_SHIFT #define MT_DYNAMIC (U(1) << MT_DYN_SHIFT)
} mmap_priv_attr_t;
#endif /* PLAT_XLAT_TABLES_DYNAMIC */ #endif /* PLAT_XLAT_TABLES_DYNAMIC */
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment