提交 0a78d7eb 编写于 作者: P Peter Maydell

hw/misc/iotkit-secctl: Support 4 internal MPCs

The SSE-200 has 4 banks of SRAM, each with its own internal
Memory Protection Controller. The interrupt status for these
extra MPCs appears in the same security controller SECMPCINTSTATUS
register as the MPC for the IoTKit's single SRAM bank. Enhance the
iotkit-secctl device to allow 4 MPCs. (If the particular IoTKit/SSE
variant in use does not have all 4 MPCs then the unused inputs will
simply result in the SECMPCINTSTATUS bits being zero as required.)

The hardcoded constant "1"s in armsse.c indicate the actual number
of SRAM MPCs the IoTKit has, and will be replaced in the following
commit.
Signed-off-by: NPeter Maydell <peter.maydell@linaro.org>
Reviewed-by: NRichard Henderson <richard.henderson@linaro.org>
Message-id: 20190121185118.18550-9-peter.maydell@linaro.org
上级 6eee5d24
...@@ -138,7 +138,7 @@ static void armsse_init(Object *obj) ...@@ -138,7 +138,7 @@ static void armsse_init(Object *obj)
sizeof(s->mpc_irq_orgate), TYPE_OR_IRQ, sizeof(s->mpc_irq_orgate), TYPE_OR_IRQ,
&error_abort, NULL); &error_abort, NULL);
for (i = 0; i < ARRAY_SIZE(s->mpc_irq_splitter); i++) { for (i = 0; i < IOTS_NUM_EXP_MPC + 1; i++) {
char *name = g_strdup_printf("mpc-irq-splitter-%d", i); char *name = g_strdup_printf("mpc-irq-splitter-%d", i);
SplitIRQ *splitter = &s->mpc_irq_splitter[i]; SplitIRQ *splitter = &s->mpc_irq_splitter[i];
...@@ -363,7 +363,7 @@ static void armsse_realize(DeviceState *dev, Error **errp) ...@@ -363,7 +363,7 @@ static void armsse_realize(DeviceState *dev, Error **errp)
/* We must OR together lines from the MPC splitters to go to the NVIC */ /* We must OR together lines from the MPC splitters to go to the NVIC */
object_property_set_int(OBJECT(&s->mpc_irq_orgate), object_property_set_int(OBJECT(&s->mpc_irq_orgate),
IOTS_NUM_EXP_MPC + IOTS_NUM_MPC, "num-lines", &err); IOTS_NUM_EXP_MPC + 1, "num-lines", &err);
if (err) { if (err) {
error_propagate(errp, err); error_propagate(errp, err);
return; return;
...@@ -636,7 +636,7 @@ static void armsse_realize(DeviceState *dev, Error **errp) ...@@ -636,7 +636,7 @@ static void armsse_realize(DeviceState *dev, Error **errp)
} }
/* Wire up the splitters for the MPC IRQs */ /* Wire up the splitters for the MPC IRQs */
for (i = 0; i < IOTS_NUM_EXP_MPC + IOTS_NUM_MPC; i++) { for (i = 0; i < IOTS_NUM_EXP_MPC + 1; i++) {
SplitIRQ *splitter = &s->mpc_irq_splitter[i]; SplitIRQ *splitter = &s->mpc_irq_splitter[i];
DeviceState *dev_splitter = DEVICE(splitter); DeviceState *dev_splitter = DEVICE(splitter);
......
...@@ -600,7 +600,7 @@ static void iotkit_secctl_mpc_status(void *opaque, int n, int level) ...@@ -600,7 +600,7 @@ static void iotkit_secctl_mpc_status(void *opaque, int n, int level)
{ {
IoTKitSecCtl *s = IOTKIT_SECCTL(opaque); IoTKitSecCtl *s = IOTKIT_SECCTL(opaque);
s->mpcintstatus = deposit32(s->mpcintstatus, 0, 1, !!level); s->mpcintstatus = deposit32(s->mpcintstatus, n, 1, !!level);
} }
static void iotkit_secctl_mpcexp_status(void *opaque, int n, int level) static void iotkit_secctl_mpcexp_status(void *opaque, int n, int level)
...@@ -686,7 +686,8 @@ static void iotkit_secctl_init(Object *obj) ...@@ -686,7 +686,8 @@ static void iotkit_secctl_init(Object *obj)
qdev_init_gpio_out_named(dev, &s->sec_resp_cfg, "sec_resp_cfg", 1); qdev_init_gpio_out_named(dev, &s->sec_resp_cfg, "sec_resp_cfg", 1);
qdev_init_gpio_out_named(dev, &s->nsc_cfg_irq, "nsc_cfg", 1); qdev_init_gpio_out_named(dev, &s->nsc_cfg_irq, "nsc_cfg", 1);
qdev_init_gpio_in_named(dev, iotkit_secctl_mpc_status, "mpc_status", 1); qdev_init_gpio_in_named(dev, iotkit_secctl_mpc_status, "mpc_status",
IOTS_NUM_MPC);
qdev_init_gpio_in_named(dev, iotkit_secctl_mpcexp_status, qdev_init_gpio_in_named(dev, iotkit_secctl_mpcexp_status,
"mpcexp_status", IOTS_NUM_EXP_MPC); "mpcexp_status", IOTS_NUM_EXP_MPC);
......
...@@ -40,8 +40,8 @@ ...@@ -40,8 +40,8 @@
* + named GPIO outputs ahb_ppcexp{0,1,2,3}_irq_enable * + named GPIO outputs ahb_ppcexp{0,1,2,3}_irq_enable
* + named GPIO outputs ahb_ppcexp{0,1,2,3}_irq_clear * + named GPIO outputs ahb_ppcexp{0,1,2,3}_irq_clear
* + named GPIO inputs ahb_ppcexp{0,1,2,3}_irq_status * + named GPIO inputs ahb_ppcexp{0,1,2,3}_irq_status
* Controlling the MPC in the IoTKit: * Controlling the (up to) 4 MPCs in the IoTKit/SSE:
* + named GPIO input mpc_status * + named GPIO inputs mpc_status[0..3]
* Controlling each of the 16 expansion MPCs which a system using the IoTKit * Controlling each of the 16 expansion MPCs which a system using the IoTKit
* might provide: * might provide:
* + named GPIO inputs mpcexp_status[0..15] * + named GPIO inputs mpcexp_status[0..15]
...@@ -67,7 +67,7 @@ ...@@ -67,7 +67,7 @@
#define IOTS_NUM_APB_EXP_PPC 4 #define IOTS_NUM_APB_EXP_PPC 4
#define IOTS_NUM_AHB_EXP_PPC 4 #define IOTS_NUM_AHB_EXP_PPC 4
#define IOTS_NUM_EXP_MPC 16 #define IOTS_NUM_EXP_MPC 16
#define IOTS_NUM_MPC 1 #define IOTS_NUM_MPC 4
#define IOTS_NUM_EXP_MSC 16 #define IOTS_NUM_EXP_MSC 16
typedef struct IoTKitSecCtl IoTKitSecCtl; typedef struct IoTKitSecCtl IoTKitSecCtl;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册