/* * Copyright 2023 NXP * * Based on soc/soc_legacy/arm/nxp_kinetis/ke1xf/nxp_mpu_regions.c, which is: * Copyright (c) 2017 Linaro Limited. * * SPDX-License-Identifier: Apache-2.0 */ #include #include static const struct nxp_mpu_region mpu_regions[] = { /* Region 0 */ MPU_REGION_ENTRY("DEBUGGER", 0, 0xFFFFFFFF, REGION_DEBUGGER_AND_DEVICE_ATTR), /* Region 1 */ MPU_REGION_ENTRY("BACKGROUND_0", 0, CONFIG_SRAM_BASE_ADDRESS-1, REGION_BACKGROUND_ATTR), /* Region 2 */ MPU_REGION_ENTRY("BACKGROUND_1", CONFIG_SRAM_BASE_ADDRESS + (CONFIG_SRAM_SIZE * 1024), 0xFFFFFFFF, REGION_BACKGROUND_ATTR), #if defined(CONFIG_XIP) /* Region 3 */ MPU_REGION_ENTRY("SRAM", CONFIG_SRAM_BASE_ADDRESS, (CONFIG_SRAM_BASE_ADDRESS + (CONFIG_SRAM_SIZE * 1024) - 1), REGION_RAM_ATTR), /* Region 4 */ MPU_REGION_ENTRY("FLASH", CONFIG_FLASH_BASE_ADDRESS, (CONFIG_FLASH_BASE_ADDRESS + (CONFIG_FLASH_SIZE * 1024) - 1), REGION_FLASH_ATTR), #else /* Region 3 */ MPU_REGION_ENTRY("SRAM", CONFIG_SRAM_BASE_ADDRESS, (CONFIG_SRAM_BASE_ADDRESS + (CONFIG_SRAM_SIZE * 1024) - 1), REGION_FLASH_ATTR), #endif }; const struct nxp_mpu_config mpu_config = { .num_regions = ARRAY_SIZE(mpu_regions), .mpu_regions = mpu_regions, .sram_region = 3, };