2014-01-24 15:41:33 +00:00
|
|
|
/*
|
2017-03-08 14:40:23 +00:00
|
|
|
* Copyright (c) 2017, ARM Limited and Contributors. All rights reserved.
|
2014-01-24 15:41:33 +00:00
|
|
|
*
|
2017-05-03 09:38:09 +01:00
|
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
2014-01-24 15:41:33 +00:00
|
|
|
*/
|
|
|
|
|
2017-03-08 14:40:23 +00:00
|
|
|
#ifndef __XLAT_TABLES_V2_H__
|
|
|
|
#define __XLAT_TABLES_V2_H__
|
2016-03-22 15:51:08 +00:00
|
|
|
|
2017-03-08 14:40:23 +00:00
|
|
|
#include <xlat_tables_defs.h>
|
2014-06-26 08:59:07 +01:00
|
|
|
|
|
|
|
#ifndef __ASSEMBLY__
|
2016-03-22 15:51:08 +00:00
|
|
|
#include <stddef.h>
|
2014-01-24 15:41:33 +00:00
|
|
|
#include <stdint.h>
|
2017-03-08 14:40:23 +00:00
|
|
|
#include <xlat_mmu_helpers.h>
|
2014-01-24 15:41:33 +00:00
|
|
|
|
2014-09-03 17:48:44 +01:00
|
|
|
/* Helper macro to define entries for mmap_region_t. It creates
|
|
|
|
* identity mappings for each region.
|
|
|
|
*/
|
|
|
|
#define MAP_REGION_FLAT(adr, sz, attr) MAP_REGION(adr, adr, sz, attr)
|
|
|
|
|
|
|
|
/* Helper macro to define entries for mmap_region_t. It allows to
|
|
|
|
* re-map address mappings from 'pa' to 'va' for each region.
|
|
|
|
*/
|
|
|
|
#define MAP_REGION(pa, va, sz, attr) {(pa), (va), (sz), (attr)}
|
|
|
|
|
2014-01-24 15:41:33 +00:00
|
|
|
/*
|
Extend memory attributes to map non-cacheable memory
At the moment, the memory translation library allows to create memory
mappings of 2 types:
- Device nGnRE memory (named MT_DEVICE in the library);
- Normal, Inner Write-back non-transient, Outer Write-back
non-transient memory (named MT_MEMORY in the library).
As a consequence, the library code treats the memory type field as a
boolean: everything that is not device memory is normal memory and
vice-versa.
In reality, the ARMv8 architecture allows up to 8 types of memory to
be used at a single time for a given exception level. This patch
reworks the memory attributes such that the memory type is now defined
as an integer ranging from 0 to 7 instead of a boolean. This makes it
possible to extend the list of memory types supported by the memory
translation library.
The priority system dictating memory attributes for overlapping
memory regions has been extended to cope with these changes but the
algorithm at its core has been preserved. When a memory region is
re-mapped with different memory attributes, the memory translation
library examines the former attributes and updates them only if
the new attributes create a more restrictive mapping. This behaviour
is unchanged, only the manipulation of the value has been modified
to cope with the new format.
This patch also introduces a new type of memory mapping in the memory
translation library: MT_NON_CACHEABLE, meaning Normal, Inner
Non-cacheable, Outer Non-cacheable memory. This can be useful to map
a non-cacheable memory region, such as a DMA buffer for example.
The rules around the Execute-Never (XN) bit in a translation table
for an MT_NON_CACHEABLE memory mapping have been aligned on the rules
used for MT_MEMORY mappings:
- If the memory is read-only then it is also executable (XN = 0);
- If the memory is read-write then it is not executable (XN = 1).
The shareability field for MT_NON_CACHEABLE mappings is always set as
'Outer-Shareable'. Note that this is not strictly needed since
shareability is only relevant if the memory is a Normal Cacheable
memory type, but this is to align with the existing device memory
mappings setup. All Device and Normal Non-cacheable memory regions
are always treated as Outer Shareable, regardless of the translation
table shareability attributes.
This patch also removes the 'ATTR_SO' and 'ATTR_SO_INDEX' #defines.
They were introduced to map memory as Device nGnRnE (formerly called
"Strongly-Ordered" memory in the ARMv7 architecture) but were not
used anywhere in the code base. Removing them avoids any confusion
about the memory types supported by the library.
Upstream platforms do not currently use the MT_NON_CACHEABLE memory
type.
NOTE: THIS CHANGE IS SOURCE COMPATIBLE BUT PLATFORMS THAT RELY ON THE
BINARY VALUES OF `mmap_attr_t` or the `attr` argument of
`mmap_add_region()` MAY BE BROKEN.
Change-Id: I717d6ed79b4c845a04e34132432f98b93d661d79
2016-03-01 14:01:03 +00:00
|
|
|
* Shifts and masks to access fields of an mmap_attr_t
|
|
|
|
*/
|
2017-03-08 14:40:23 +00:00
|
|
|
#define MT_TYPE_MASK 0x7
|
|
|
|
#define MT_TYPE(_attr) ((_attr) & MT_TYPE_MASK)
|
Extend memory attributes to map non-cacheable memory
At the moment, the memory translation library allows to create memory
mappings of 2 types:
- Device nGnRE memory (named MT_DEVICE in the library);
- Normal, Inner Write-back non-transient, Outer Write-back
non-transient memory (named MT_MEMORY in the library).
As a consequence, the library code treats the memory type field as a
boolean: everything that is not device memory is normal memory and
vice-versa.
In reality, the ARMv8 architecture allows up to 8 types of memory to
be used at a single time for a given exception level. This patch
reworks the memory attributes such that the memory type is now defined
as an integer ranging from 0 to 7 instead of a boolean. This makes it
possible to extend the list of memory types supported by the memory
translation library.
The priority system dictating memory attributes for overlapping
memory regions has been extended to cope with these changes but the
algorithm at its core has been preserved. When a memory region is
re-mapped with different memory attributes, the memory translation
library examines the former attributes and updates them only if
the new attributes create a more restrictive mapping. This behaviour
is unchanged, only the manipulation of the value has been modified
to cope with the new format.
This patch also introduces a new type of memory mapping in the memory
translation library: MT_NON_CACHEABLE, meaning Normal, Inner
Non-cacheable, Outer Non-cacheable memory. This can be useful to map
a non-cacheable memory region, such as a DMA buffer for example.
The rules around the Execute-Never (XN) bit in a translation table
for an MT_NON_CACHEABLE memory mapping have been aligned on the rules
used for MT_MEMORY mappings:
- If the memory is read-only then it is also executable (XN = 0);
- If the memory is read-write then it is not executable (XN = 1).
The shareability field for MT_NON_CACHEABLE mappings is always set as
'Outer-Shareable'. Note that this is not strictly needed since
shareability is only relevant if the memory is a Normal Cacheable
memory type, but this is to align with the existing device memory
mappings setup. All Device and Normal Non-cacheable memory regions
are always treated as Outer Shareable, regardless of the translation
table shareability attributes.
This patch also removes the 'ATTR_SO' and 'ATTR_SO_INDEX' #defines.
They were introduced to map memory as Device nGnRnE (formerly called
"Strongly-Ordered" memory in the ARMv7 architecture) but were not
used anywhere in the code base. Removing them avoids any confusion
about the memory types supported by the library.
Upstream platforms do not currently use the MT_NON_CACHEABLE memory
type.
NOTE: THIS CHANGE IS SOURCE COMPATIBLE BUT PLATFORMS THAT RELY ON THE
BINARY VALUES OF `mmap_attr_t` or the `attr` argument of
`mmap_add_region()` MAY BE BROKEN.
Change-Id: I717d6ed79b4c845a04e34132432f98b93d661d79
2016-03-01 14:01:03 +00:00
|
|
|
/* Access permissions (RO/RW) */
|
2017-03-08 14:40:23 +00:00
|
|
|
#define MT_PERM_SHIFT 3
|
Extend memory attributes to map non-cacheable memory
At the moment, the memory translation library allows to create memory
mappings of 2 types:
- Device nGnRE memory (named MT_DEVICE in the library);
- Normal, Inner Write-back non-transient, Outer Write-back
non-transient memory (named MT_MEMORY in the library).
As a consequence, the library code treats the memory type field as a
boolean: everything that is not device memory is normal memory and
vice-versa.
In reality, the ARMv8 architecture allows up to 8 types of memory to
be used at a single time for a given exception level. This patch
reworks the memory attributes such that the memory type is now defined
as an integer ranging from 0 to 7 instead of a boolean. This makes it
possible to extend the list of memory types supported by the memory
translation library.
The priority system dictating memory attributes for overlapping
memory regions has been extended to cope with these changes but the
algorithm at its core has been preserved. When a memory region is
re-mapped with different memory attributes, the memory translation
library examines the former attributes and updates them only if
the new attributes create a more restrictive mapping. This behaviour
is unchanged, only the manipulation of the value has been modified
to cope with the new format.
This patch also introduces a new type of memory mapping in the memory
translation library: MT_NON_CACHEABLE, meaning Normal, Inner
Non-cacheable, Outer Non-cacheable memory. This can be useful to map
a non-cacheable memory region, such as a DMA buffer for example.
The rules around the Execute-Never (XN) bit in a translation table
for an MT_NON_CACHEABLE memory mapping have been aligned on the rules
used for MT_MEMORY mappings:
- If the memory is read-only then it is also executable (XN = 0);
- If the memory is read-write then it is not executable (XN = 1).
The shareability field for MT_NON_CACHEABLE mappings is always set as
'Outer-Shareable'. Note that this is not strictly needed since
shareability is only relevant if the memory is a Normal Cacheable
memory type, but this is to align with the existing device memory
mappings setup. All Device and Normal Non-cacheable memory regions
are always treated as Outer Shareable, regardless of the translation
table shareability attributes.
This patch also removes the 'ATTR_SO' and 'ATTR_SO_INDEX' #defines.
They were introduced to map memory as Device nGnRnE (formerly called
"Strongly-Ordered" memory in the ARMv7 architecture) but were not
used anywhere in the code base. Removing them avoids any confusion
about the memory types supported by the library.
Upstream platforms do not currently use the MT_NON_CACHEABLE memory
type.
NOTE: THIS CHANGE IS SOURCE COMPATIBLE BUT PLATFORMS THAT RELY ON THE
BINARY VALUES OF `mmap_attr_t` or the `attr` argument of
`mmap_add_region()` MAY BE BROKEN.
Change-Id: I717d6ed79b4c845a04e34132432f98b93d661d79
2016-03-01 14:01:03 +00:00
|
|
|
/* Security state (SECURE/NS) */
|
2017-03-08 14:40:23 +00:00
|
|
|
#define MT_SEC_SHIFT 4
|
2016-06-14 16:31:09 +01:00
|
|
|
/* Access permissions for instruction execution (EXECUTE/EXECUTE_NEVER) */
|
|
|
|
#define MT_EXECUTE_SHIFT 5
|
2017-02-27 17:23:54 +00:00
|
|
|
/* All other bits are reserved */
|
Extend memory attributes to map non-cacheable memory
At the moment, the memory translation library allows to create memory
mappings of 2 types:
- Device nGnRE memory (named MT_DEVICE in the library);
- Normal, Inner Write-back non-transient, Outer Write-back
non-transient memory (named MT_MEMORY in the library).
As a consequence, the library code treats the memory type field as a
boolean: everything that is not device memory is normal memory and
vice-versa.
In reality, the ARMv8 architecture allows up to 8 types of memory to
be used at a single time for a given exception level. This patch
reworks the memory attributes such that the memory type is now defined
as an integer ranging from 0 to 7 instead of a boolean. This makes it
possible to extend the list of memory types supported by the memory
translation library.
The priority system dictating memory attributes for overlapping
memory regions has been extended to cope with these changes but the
algorithm at its core has been preserved. When a memory region is
re-mapped with different memory attributes, the memory translation
library examines the former attributes and updates them only if
the new attributes create a more restrictive mapping. This behaviour
is unchanged, only the manipulation of the value has been modified
to cope with the new format.
This patch also introduces a new type of memory mapping in the memory
translation library: MT_NON_CACHEABLE, meaning Normal, Inner
Non-cacheable, Outer Non-cacheable memory. This can be useful to map
a non-cacheable memory region, such as a DMA buffer for example.
The rules around the Execute-Never (XN) bit in a translation table
for an MT_NON_CACHEABLE memory mapping have been aligned on the rules
used for MT_MEMORY mappings:
- If the memory is read-only then it is also executable (XN = 0);
- If the memory is read-write then it is not executable (XN = 1).
The shareability field for MT_NON_CACHEABLE mappings is always set as
'Outer-Shareable'. Note that this is not strictly needed since
shareability is only relevant if the memory is a Normal Cacheable
memory type, but this is to align with the existing device memory
mappings setup. All Device and Normal Non-cacheable memory regions
are always treated as Outer Shareable, regardless of the translation
table shareability attributes.
This patch also removes the 'ATTR_SO' and 'ATTR_SO_INDEX' #defines.
They were introduced to map memory as Device nGnRnE (formerly called
"Strongly-Ordered" memory in the ARMv7 architecture) but were not
used anywhere in the code base. Removing them avoids any confusion
about the memory types supported by the library.
Upstream platforms do not currently use the MT_NON_CACHEABLE memory
type.
NOTE: THIS CHANGE IS SOURCE COMPATIBLE BUT PLATFORMS THAT RELY ON THE
BINARY VALUES OF `mmap_attr_t` or the `attr` argument of
`mmap_add_region()` MAY BE BROKEN.
Change-Id: I717d6ed79b4c845a04e34132432f98b93d661d79
2016-03-01 14:01:03 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Memory mapping attributes
|
2014-01-24 15:41:33 +00:00
|
|
|
*/
|
|
|
|
typedef enum {
|
Extend memory attributes to map non-cacheable memory
At the moment, the memory translation library allows to create memory
mappings of 2 types:
- Device nGnRE memory (named MT_DEVICE in the library);
- Normal, Inner Write-back non-transient, Outer Write-back
non-transient memory (named MT_MEMORY in the library).
As a consequence, the library code treats the memory type field as a
boolean: everything that is not device memory is normal memory and
vice-versa.
In reality, the ARMv8 architecture allows up to 8 types of memory to
be used at a single time for a given exception level. This patch
reworks the memory attributes such that the memory type is now defined
as an integer ranging from 0 to 7 instead of a boolean. This makes it
possible to extend the list of memory types supported by the memory
translation library.
The priority system dictating memory attributes for overlapping
memory regions has been extended to cope with these changes but the
algorithm at its core has been preserved. When a memory region is
re-mapped with different memory attributes, the memory translation
library examines the former attributes and updates them only if
the new attributes create a more restrictive mapping. This behaviour
is unchanged, only the manipulation of the value has been modified
to cope with the new format.
This patch also introduces a new type of memory mapping in the memory
translation library: MT_NON_CACHEABLE, meaning Normal, Inner
Non-cacheable, Outer Non-cacheable memory. This can be useful to map
a non-cacheable memory region, such as a DMA buffer for example.
The rules around the Execute-Never (XN) bit in a translation table
for an MT_NON_CACHEABLE memory mapping have been aligned on the rules
used for MT_MEMORY mappings:
- If the memory is read-only then it is also executable (XN = 0);
- If the memory is read-write then it is not executable (XN = 1).
The shareability field for MT_NON_CACHEABLE mappings is always set as
'Outer-Shareable'. Note that this is not strictly needed since
shareability is only relevant if the memory is a Normal Cacheable
memory type, but this is to align with the existing device memory
mappings setup. All Device and Normal Non-cacheable memory regions
are always treated as Outer Shareable, regardless of the translation
table shareability attributes.
This patch also removes the 'ATTR_SO' and 'ATTR_SO_INDEX' #defines.
They were introduced to map memory as Device nGnRnE (formerly called
"Strongly-Ordered" memory in the ARMv7 architecture) but were not
used anywhere in the code base. Removing them avoids any confusion
about the memory types supported by the library.
Upstream platforms do not currently use the MT_NON_CACHEABLE memory
type.
NOTE: THIS CHANGE IS SOURCE COMPATIBLE BUT PLATFORMS THAT RELY ON THE
BINARY VALUES OF `mmap_attr_t` or the `attr` argument of
`mmap_add_region()` MAY BE BROKEN.
Change-Id: I717d6ed79b4c845a04e34132432f98b93d661d79
2016-03-01 14:01:03 +00:00
|
|
|
/*
|
|
|
|
* Memory types supported.
|
|
|
|
* These are organised so that, going down the list, the memory types
|
|
|
|
* are getting weaker; conversely going up the list the memory types are
|
|
|
|
* getting stronger.
|
|
|
|
*/
|
|
|
|
MT_DEVICE,
|
|
|
|
MT_NON_CACHEABLE,
|
|
|
|
MT_MEMORY,
|
|
|
|
/* Values up to 7 are reserved to add new memory types in the future */
|
2014-01-24 15:41:33 +00:00
|
|
|
|
Extend memory attributes to map non-cacheable memory
At the moment, the memory translation library allows to create memory
mappings of 2 types:
- Device nGnRE memory (named MT_DEVICE in the library);
- Normal, Inner Write-back non-transient, Outer Write-back
non-transient memory (named MT_MEMORY in the library).
As a consequence, the library code treats the memory type field as a
boolean: everything that is not device memory is normal memory and
vice-versa.
In reality, the ARMv8 architecture allows up to 8 types of memory to
be used at a single time for a given exception level. This patch
reworks the memory attributes such that the memory type is now defined
as an integer ranging from 0 to 7 instead of a boolean. This makes it
possible to extend the list of memory types supported by the memory
translation library.
The priority system dictating memory attributes for overlapping
memory regions has been extended to cope with these changes but the
algorithm at its core has been preserved. When a memory region is
re-mapped with different memory attributes, the memory translation
library examines the former attributes and updates them only if
the new attributes create a more restrictive mapping. This behaviour
is unchanged, only the manipulation of the value has been modified
to cope with the new format.
This patch also introduces a new type of memory mapping in the memory
translation library: MT_NON_CACHEABLE, meaning Normal, Inner
Non-cacheable, Outer Non-cacheable memory. This can be useful to map
a non-cacheable memory region, such as a DMA buffer for example.
The rules around the Execute-Never (XN) bit in a translation table
for an MT_NON_CACHEABLE memory mapping have been aligned on the rules
used for MT_MEMORY mappings:
- If the memory is read-only then it is also executable (XN = 0);
- If the memory is read-write then it is not executable (XN = 1).
The shareability field for MT_NON_CACHEABLE mappings is always set as
'Outer-Shareable'. Note that this is not strictly needed since
shareability is only relevant if the memory is a Normal Cacheable
memory type, but this is to align with the existing device memory
mappings setup. All Device and Normal Non-cacheable memory regions
are always treated as Outer Shareable, regardless of the translation
table shareability attributes.
This patch also removes the 'ATTR_SO' and 'ATTR_SO_INDEX' #defines.
They were introduced to map memory as Device nGnRnE (formerly called
"Strongly-Ordered" memory in the ARMv7 architecture) but were not
used anywhere in the code base. Removing them avoids any confusion
about the memory types supported by the library.
Upstream platforms do not currently use the MT_NON_CACHEABLE memory
type.
NOTE: THIS CHANGE IS SOURCE COMPATIBLE BUT PLATFORMS THAT RELY ON THE
BINARY VALUES OF `mmap_attr_t` or the `attr` argument of
`mmap_add_region()` MAY BE BROKEN.
Change-Id: I717d6ed79b4c845a04e34132432f98b93d661d79
2016-03-01 14:01:03 +00:00
|
|
|
MT_RO = 0 << MT_PERM_SHIFT,
|
|
|
|
MT_RW = 1 << MT_PERM_SHIFT,
|
2014-01-24 15:41:33 +00:00
|
|
|
|
Extend memory attributes to map non-cacheable memory
At the moment, the memory translation library allows to create memory
mappings of 2 types:
- Device nGnRE memory (named MT_DEVICE in the library);
- Normal, Inner Write-back non-transient, Outer Write-back
non-transient memory (named MT_MEMORY in the library).
As a consequence, the library code treats the memory type field as a
boolean: everything that is not device memory is normal memory and
vice-versa.
In reality, the ARMv8 architecture allows up to 8 types of memory to
be used at a single time for a given exception level. This patch
reworks the memory attributes such that the memory type is now defined
as an integer ranging from 0 to 7 instead of a boolean. This makes it
possible to extend the list of memory types supported by the memory
translation library.
The priority system dictating memory attributes for overlapping
memory regions has been extended to cope with these changes but the
algorithm at its core has been preserved. When a memory region is
re-mapped with different memory attributes, the memory translation
library examines the former attributes and updates them only if
the new attributes create a more restrictive mapping. This behaviour
is unchanged, only the manipulation of the value has been modified
to cope with the new format.
This patch also introduces a new type of memory mapping in the memory
translation library: MT_NON_CACHEABLE, meaning Normal, Inner
Non-cacheable, Outer Non-cacheable memory. This can be useful to map
a non-cacheable memory region, such as a DMA buffer for example.
The rules around the Execute-Never (XN) bit in a translation table
for an MT_NON_CACHEABLE memory mapping have been aligned on the rules
used for MT_MEMORY mappings:
- If the memory is read-only then it is also executable (XN = 0);
- If the memory is read-write then it is not executable (XN = 1).
The shareability field for MT_NON_CACHEABLE mappings is always set as
'Outer-Shareable'. Note that this is not strictly needed since
shareability is only relevant if the memory is a Normal Cacheable
memory type, but this is to align with the existing device memory
mappings setup. All Device and Normal Non-cacheable memory regions
are always treated as Outer Shareable, regardless of the translation
table shareability attributes.
This patch also removes the 'ATTR_SO' and 'ATTR_SO_INDEX' #defines.
They were introduced to map memory as Device nGnRnE (formerly called
"Strongly-Ordered" memory in the ARMv7 architecture) but were not
used anywhere in the code base. Removing them avoids any confusion
about the memory types supported by the library.
Upstream platforms do not currently use the MT_NON_CACHEABLE memory
type.
NOTE: THIS CHANGE IS SOURCE COMPATIBLE BUT PLATFORMS THAT RELY ON THE
BINARY VALUES OF `mmap_attr_t` or the `attr` argument of
`mmap_add_region()` MAY BE BROKEN.
Change-Id: I717d6ed79b4c845a04e34132432f98b93d661d79
2016-03-01 14:01:03 +00:00
|
|
|
MT_SECURE = 0 << MT_SEC_SHIFT,
|
|
|
|
MT_NS = 1 << MT_SEC_SHIFT,
|
2016-06-14 16:31:09 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Access permissions for instruction execution are only relevant for
|
|
|
|
* normal read-only memory, i.e. MT_MEMORY | MT_RO. They are ignored
|
|
|
|
* (and potentially overridden) otherwise:
|
|
|
|
* - Device memory is always marked as execute-never.
|
|
|
|
* - Read-write normal memory is always marked as execute-never.
|
|
|
|
*/
|
|
|
|
MT_EXECUTE = 0 << MT_EXECUTE_SHIFT,
|
|
|
|
MT_EXECUTE_NEVER = 1 << MT_EXECUTE_SHIFT,
|
2014-04-10 15:37:22 +01:00
|
|
|
} mmap_attr_t;
|
2014-01-24 15:41:33 +00:00
|
|
|
|
2016-06-14 16:31:09 +01:00
|
|
|
#define MT_CODE (MT_MEMORY | MT_RO | MT_EXECUTE)
|
|
|
|
#define MT_RO_DATA (MT_MEMORY | MT_RO | MT_EXECUTE_NEVER)
|
|
|
|
|
2014-01-24 15:41:33 +00:00
|
|
|
/*
|
|
|
|
* Structure for specifying a single region of memory.
|
|
|
|
*/
|
2014-04-10 15:37:22 +01:00
|
|
|
typedef struct mmap_region {
|
2016-03-22 15:51:08 +00:00
|
|
|
unsigned long long base_pa;
|
|
|
|
uintptr_t base_va;
|
|
|
|
size_t size;
|
|
|
|
mmap_attr_t attr;
|
2014-04-10 15:37:22 +01:00
|
|
|
} mmap_region_t;
|
2014-01-24 15:41:33 +00:00
|
|
|
|
2016-03-22 15:51:08 +00:00
|
|
|
/* Generic translation table APIs */
|
2014-05-14 12:38:32 +01:00
|
|
|
void init_xlat_tables(void);
|
2017-03-08 14:40:23 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Add a region with defined base PA and base VA. This type of region can only
|
|
|
|
* be added before initializing the MMU and cannot be removed later.
|
|
|
|
*/
|
2016-03-22 15:51:08 +00:00
|
|
|
void mmap_add_region(unsigned long long base_pa, uintptr_t base_va,
|
2017-04-19 14:02:23 +01:00
|
|
|
size_t size, mmap_attr_t attr);
|
2014-01-24 15:41:33 +00:00
|
|
|
|
2017-02-27 17:23:54 +00:00
|
|
|
/*
|
|
|
|
* Add a region with defined base PA and base VA. This type of region can be
|
|
|
|
* added and removed even if the MMU is enabled.
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* 0: Success.
|
|
|
|
* EINVAL: Invalid values were used as arguments.
|
|
|
|
* ERANGE: Memory limits were surpassed.
|
|
|
|
* ENOMEM: Not enough space in the mmap array or not enough free xlat tables.
|
|
|
|
* EPERM: It overlaps another region in an invalid way.
|
|
|
|
*/
|
|
|
|
int mmap_add_dynamic_region(unsigned long long base_pa, uintptr_t base_va,
|
2017-04-19 14:02:23 +01:00
|
|
|
size_t size, mmap_attr_t attr);
|
2017-02-27 17:23:54 +00:00
|
|
|
|
2017-03-08 14:40:23 +00:00
|
|
|
/*
|
|
|
|
* Add an array of static regions with defined base PA and base VA. This type
|
|
|
|
* of region can only be added before initializing the MMU and cannot be
|
|
|
|
* removed later.
|
|
|
|
*/
|
|
|
|
void mmap_add(const mmap_region_t *mm);
|
2014-04-03 13:48:04 +01:00
|
|
|
|
2017-02-27 17:23:54 +00:00
|
|
|
/*
|
|
|
|
* Remove a region with the specified base VA and size. Only dynamic regions can
|
|
|
|
* be removed, and they can be removed even if the MMU is enabled.
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* 0: Success.
|
|
|
|
* EINVAL: The specified region wasn't found.
|
|
|
|
* EPERM: Trying to remove a static region.
|
|
|
|
*/
|
|
|
|
int mmap_remove_dynamic_region(uintptr_t base_va, size_t size);
|
|
|
|
|
2014-06-26 08:59:07 +01:00
|
|
|
#endif /*__ASSEMBLY__*/
|
2017-03-08 14:40:23 +00:00
|
|
|
#endif /* __XLAT_TABLES_V2_H__ */
|