Cortex-A address environments: Fix issue with page privileges
This commit is contained in:
parent
709654673b
commit
0c7f07e344
@ -361,7 +361,7 @@ int up_addrenv_create(size_t textsize, size_t datasize,
|
|||||||
|
|
||||||
ret = up_addrenv_create_region(addrenv->text, ARCH_TEXT_NSECTS,
|
ret = up_addrenv_create_region(addrenv->text, ARCH_TEXT_NSECTS,
|
||||||
CONFIG_ARCH_TEXT_VBASE, textsize,
|
CONFIG_ARCH_TEXT_VBASE, textsize,
|
||||||
MMU_L2_TEXTFLAGS);
|
MMU_L2_UTEXTFLAGS);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
bdbg("ERROR: Failed to create .text region: %d\n", ret);
|
bdbg("ERROR: Failed to create .text region: %d\n", ret);
|
||||||
@ -372,7 +372,7 @@ int up_addrenv_create(size_t textsize, size_t datasize,
|
|||||||
|
|
||||||
ret = up_addrenv_create_region(addrenv->data, ARCH_DATA_NSECTS,
|
ret = up_addrenv_create_region(addrenv->data, ARCH_DATA_NSECTS,
|
||||||
CONFIG_ARCH_DATA_VBASE, datasize,
|
CONFIG_ARCH_DATA_VBASE, datasize,
|
||||||
MMU_L2_DATAFLAGS);
|
MMU_L2_UDATAFLAGS);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
bdbg("ERROR: Failed to create .bss/.data region: %d\n", ret);
|
bdbg("ERROR: Failed to create .bss/.data region: %d\n", ret);
|
||||||
|
@ -343,7 +343,15 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef CONFIG_AFE_ENABLE
|
#ifdef CONFIG_AFE_ENABLE
|
||||||
/* AP[2:1] access permissions model. AP[0] is used as an access flag: */
|
/* AP[2:1] access permissions model. AP[0] is used as an access flag:
|
||||||
|
*
|
||||||
|
* AP[2] AP[1] PL1 PL0 Description
|
||||||
|
* ----- ----- ----------- ---------- --------------------------------
|
||||||
|
* 0 0 Read/write No access Access only at PL1
|
||||||
|
* 0 1 Read/write Read/write Full access
|
||||||
|
* 1 0 Read-only No access Read-only for PL1
|
||||||
|
* 1 1 Read-only Read-only Read-only at any privilege level
|
||||||
|
*/
|
||||||
|
|
||||||
# define PMD_SECT_AP_RW1 (0)
|
# define PMD_SECT_AP_RW1 (0)
|
||||||
# define PMD_SECT_AP_RW01 (PMD_SECT_AP1)
|
# define PMD_SECT_AP_RW01 (PMD_SECT_AP1)
|
||||||
@ -351,7 +359,19 @@
|
|||||||
# define PMD_SECT_AP_R01 (PMD_SECT_AP1 | PMD_SECT_AP2)
|
# define PMD_SECT_AP_R01 (PMD_SECT_AP1 | PMD_SECT_AP2)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/* AP[2:0] access permissions control, Short-descriptor format only */
|
/* AP[2:0] access permissions control, Short-descriptor format only:
|
||||||
|
*
|
||||||
|
* AP[2] AP[1] AP[0] PL1/2 PL0 Description
|
||||||
|
* ----- ----- ----- ----------- ---------- --------------------------------
|
||||||
|
* 0 0 0 No access No access All accesses generate faults
|
||||||
|
* 0 0 1 Read/write No access Access only at PL1 and higher
|
||||||
|
* 0 1 0 Read/write Read-only Writes at PL0 generate faults
|
||||||
|
* 0 1 1 Read/write Read/write Full access
|
||||||
|
* 1 0 0 ---- --- Reserved
|
||||||
|
* 1 0 1 Read-only No access Read-only for PL1 and higher
|
||||||
|
* 1 1 0 Read-only Read-only (deprecated)
|
||||||
|
* 1 1 1 Read-only Read-only Read-only at any privilege level
|
||||||
|
*/
|
||||||
|
|
||||||
# define PMD_SECT_AP_NONE (0)
|
# define PMD_SECT_AP_NONE (0)
|
||||||
# define PMD_SECT_AP_RW12 (PMD_SECT_AP0)
|
# define PMD_SECT_AP_RW12 (PMD_SECT_AP0)
|
||||||
@ -429,7 +449,15 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef CONFIG_AFE_ENABLE
|
#ifdef CONFIG_AFE_ENABLE
|
||||||
/* AP[2:1] access permissions model. AP[0] is used as an access flag: */
|
/* AP[2:1] access permissions model. AP[0] is used as an access flag:
|
||||||
|
*
|
||||||
|
* AP[2] AP[1] PL1 PL0 Description
|
||||||
|
* ----- ----- ----------- ---------- --------------------------------
|
||||||
|
* 0 0 Read/write No access Access only at PL1
|
||||||
|
* 0 1 Read/write Read/write Full access
|
||||||
|
* 1 0 Read-only No access Read-only for PL1
|
||||||
|
* 1 1 Read-only Read-only Read-only at any privilege level
|
||||||
|
*/
|
||||||
|
|
||||||
# define PTE_AP_RW1 (0)
|
# define PTE_AP_RW1 (0)
|
||||||
# define PTE_AP_RW01 (PTE_AP1)
|
# define PTE_AP_RW01 (PTE_AP1)
|
||||||
@ -437,7 +465,19 @@
|
|||||||
# define PTE_AP_R01 (PTE_AP1 | PTE_AP2)
|
# define PTE_AP_R01 (PTE_AP1 | PTE_AP2)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/* AP[2:0] access permissions control, Short-descriptor format only */
|
/* AP[2:0] access permissions control, Short-descriptor format only:
|
||||||
|
*
|
||||||
|
* AP[2] AP[1] AP[0] PL1/2 PL0 Description
|
||||||
|
* ----- ----- ----- ----------- ---------- --------------------------------
|
||||||
|
* 0 0 0 No access No access All accesses generate faults
|
||||||
|
* 0 0 1 Read/write No access Access only at PL1 and higher
|
||||||
|
* 0 1 0 Read/write Read-only Writes at PL0 generate faults
|
||||||
|
* 0 1 1 Read/write Read/write Full access
|
||||||
|
* 1 0 0 ---- --- Reserved
|
||||||
|
* 1 0 1 Read-only No access Read-only for PL1 and higher
|
||||||
|
* 1 1 0 Read-only Read-only (deprecated)
|
||||||
|
* 1 1 1 Read-only Read-only Read-only at any privilege level
|
||||||
|
*/
|
||||||
|
|
||||||
# define PTE_AP_NONE (0)
|
# define PTE_AP_NONE (0)
|
||||||
# define PTE_AP_RW12 (PTE_AP0)
|
# define PTE_AP_RW12 (PTE_AP0)
|
||||||
@ -543,11 +583,19 @@
|
|||||||
/* MMU Flags for each type memory region (level 1 and 2) */
|
/* MMU Flags for each type memory region (level 1 and 2) */
|
||||||
|
|
||||||
#define MMU_L1_TEXTFLAGS (PMD_TYPE_PTE | PMD_PTE_DOM(0))
|
#define MMU_L1_TEXTFLAGS (PMD_TYPE_PTE | PMD_PTE_DOM(0))
|
||||||
#define MMU_L2_TEXTFLAGS (PTE_TYPE_SMALL | PTE_WRITE_BACK | PTE_AP_R1)
|
|
||||||
|
#define MMU_L2_KTEXTFLAGS (PTE_TYPE_SMALL | PTE_WRITE_BACK | PTE_AP_R1)
|
||||||
|
#ifdef CONFIG_AFE_ENABLE
|
||||||
|
# define MMU_L2_UTEXTFLAGS (PTE_TYPE_SMALL | PTE_WRITE_BACK | PTE_AP_RW01)
|
||||||
|
#else
|
||||||
|
# define MMU_L2_UTEXTFLAGS (PTE_TYPE_SMALL | PTE_WRITE_BACK | PTE_AP_RW12_R0)
|
||||||
|
#endif
|
||||||
|
|
||||||
#define MMU_L1_DATAFLAGS (PMD_TYPE_PTE | PMD_PTE_PXN | PMD_PTE_DOM(0))
|
#define MMU_L1_DATAFLAGS (PMD_TYPE_PTE | PMD_PTE_PXN | PMD_PTE_DOM(0))
|
||||||
#define MMU_L2_DATAFLAGS (PTE_TYPE_SMALL | PTE_WRITE_BACK | PTE_AP_RW1)
|
#define MMU_L2_UDATAFLAGS (PTE_TYPE_SMALL | PTE_WRITE_BACK | PTE_AP_RW01)
|
||||||
#define MMU_L2_ALLOCFLAGS (PTE_TYPE_SMALL | PTE_WRITE_BACK | PTE_AP_RW1)
|
#define MMU_L2_KDATAFLAGS (PTE_TYPE_SMALL | PTE_WRITE_BACK | PTE_AP_RW1)
|
||||||
|
#define MMU_L2_UALLOCFLAGS (PTE_TYPE_SMALL | PTE_WRITE_BACK | PTE_AP_RW01)
|
||||||
|
#define MMU_L2_KALLOCFLAGS (PTE_TYPE_SMALL | PTE_WRITE_BACK | PTE_AP_RW1)
|
||||||
|
|
||||||
#define MMU_L1_PGTABFLAGS (PMD_TYPE_PTE | PMD_PTE_PXN | PTE_WRITE_THROUGH | \
|
#define MMU_L1_PGTABFLAGS (PMD_TYPE_PTE | PMD_PTE_PXN | PTE_WRITE_THROUGH | \
|
||||||
PMD_PTE_DOM(0))
|
PMD_PTE_DOM(0))
|
||||||
|
Loading…
Reference in New Issue
Block a user