2 * Copyright (C) 2017, STMicroelectronics - All Rights Reserved
3 * Author(s): Vikas Manocha, <vikas.manocha@st.com> for STMicroelectronics.
5 * SPDX-License-Identifier: GPL-2.0+
8 #include <linux/bitops.h>
9 #include <asm/armv7m.h>
10 #include <asm/armv7m_mpu.h>
13 #define V7M_MPU_CTRL_ENABLE BIT(0)
14 #define V7M_MPU_CTRL_DISABLE (0 << 0)
15 #define V7M_MPU_CTRL_HFNMIENA BIT(1)
16 #define V7M_MPU_CTRL_PRIVDEFENA BIT(2)
17 #define VALID_REGION BIT(4)
19 #define ENABLE_REGION BIT(0)
27 #define REGION_SIZE_SHIFT 1
29 #define CACHEABLE (1 << C_SHIFT)
30 #define BUFFERABLE (1 << B_SHIFT)
31 #define SHAREABLE (1 << S_SHIFT)
33 void disable_mpu(void)
35 writel(0, &V7M_MPU->ctrl);
40 writel(V7M_MPU_CTRL_ENABLE | V7M_MPU_CTRL_PRIVDEFENA, &V7M_MPU->ctrl);
42 /* Make sure new mpu config is effective for next memory access */
44 isb(); /* Make sure instruction stream sees it */
47 void mpu_config(struct mpu_region_config *reg_config)
51 switch (reg_config->mr_attr) {
55 case SHARED_WRITE_BUFFERED:
58 case O_I_WT_NO_WR_ALLOC:
61 case O_I_WB_NO_WR_ALLOC:
62 attr = CACHEABLE | BUFFERABLE;
64 case O_I_NON_CACHEABLE:
65 attr = 1 << TEX_SHIFT;
67 case O_I_WB_RD_WR_ALLOC:
68 attr = (1 << TEX_SHIFT) | CACHEABLE | BUFFERABLE;
70 case DEVICE_NON_SHARED:
71 attr = (2 << TEX_SHIFT) | BUFFERABLE;
74 attr = 0; /* strongly ordered */
78 writel(reg_config->start_addr | VALID_REGION | reg_config->region_no,
81 writel(reg_config->xn << XN_SHIFT | reg_config->ap << AP_SHIFT | attr
82 | reg_config->reg_size << REGION_SIZE_SHIFT | ENABLE_REGION