mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-18 15:42:09 -06:00
hw/arm/aspeed: Move AspeedSoCState::armv7m to Aspeed10x0SoCState
The v7-M core is specific to the Aspeed 10x0 series, remove it from the common AspeedSoCState. Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Reviewed-by: Cédric Le Goater <clg@kaod.org> Signed-off-by: Cédric Le Goater <clg@kaod.org>
This commit is contained in:
parent
24a88476ff
commit
a0c2103070
3 changed files with 25 additions and 20 deletions
|
@ -101,13 +101,15 @@ static const int aspeed_soc_ast1030_irqmap[] = {
|
||||||
|
|
||||||
static qemu_irq aspeed_soc_ast1030_get_irq(AspeedSoCState *s, int dev)
|
static qemu_irq aspeed_soc_ast1030_get_irq(AspeedSoCState *s, int dev)
|
||||||
{
|
{
|
||||||
|
Aspeed10x0SoCState *a = ASPEED10X0_SOC(s);
|
||||||
AspeedSoCClass *sc = ASPEED_SOC_GET_CLASS(s);
|
AspeedSoCClass *sc = ASPEED_SOC_GET_CLASS(s);
|
||||||
|
|
||||||
return qdev_get_gpio_in(DEVICE(&s->armv7m), sc->irqmap[dev]);
|
return qdev_get_gpio_in(DEVICE(&a->armv7m), sc->irqmap[dev]);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void aspeed_soc_ast1030_init(Object *obj)
|
static void aspeed_soc_ast1030_init(Object *obj)
|
||||||
{
|
{
|
||||||
|
Aspeed10x0SoCState *a = ASPEED10X0_SOC(obj);
|
||||||
AspeedSoCState *s = ASPEED_SOC(obj);
|
AspeedSoCState *s = ASPEED_SOC(obj);
|
||||||
AspeedSoCClass *sc = ASPEED_SOC_GET_CLASS(s);
|
AspeedSoCClass *sc = ASPEED_SOC_GET_CLASS(s);
|
||||||
char socname[8];
|
char socname[8];
|
||||||
|
@ -118,7 +120,7 @@ static void aspeed_soc_ast1030_init(Object *obj)
|
||||||
g_assert_not_reached();
|
g_assert_not_reached();
|
||||||
}
|
}
|
||||||
|
|
||||||
object_initialize_child(obj, "armv7m", &s->armv7m, TYPE_ARMV7M);
|
object_initialize_child(obj, "armv7m", &a->armv7m, TYPE_ARMV7M);
|
||||||
|
|
||||||
s->sysclk = qdev_init_clock_in(DEVICE(s), "sysclk", NULL, NULL, 0);
|
s->sysclk = qdev_init_clock_in(DEVICE(s), "sysclk", NULL, NULL, 0);
|
||||||
|
|
||||||
|
@ -185,6 +187,7 @@ static void aspeed_soc_ast1030_init(Object *obj)
|
||||||
|
|
||||||
static void aspeed_soc_ast1030_realize(DeviceState *dev_soc, Error **errp)
|
static void aspeed_soc_ast1030_realize(DeviceState *dev_soc, Error **errp)
|
||||||
{
|
{
|
||||||
|
Aspeed10x0SoCState *a = ASPEED10X0_SOC(dev_soc);
|
||||||
AspeedSoCState *s = ASPEED_SOC(dev_soc);
|
AspeedSoCState *s = ASPEED_SOC(dev_soc);
|
||||||
AspeedSoCClass *sc = ASPEED_SOC_GET_CLASS(s);
|
AspeedSoCClass *sc = ASPEED_SOC_GET_CLASS(s);
|
||||||
DeviceState *armv7m;
|
DeviceState *armv7m;
|
||||||
|
@ -206,17 +209,17 @@ static void aspeed_soc_ast1030_realize(DeviceState *dev_soc, Error **errp)
|
||||||
0x40000);
|
0x40000);
|
||||||
|
|
||||||
/* AST1030 CPU Core */
|
/* AST1030 CPU Core */
|
||||||
armv7m = DEVICE(&s->armv7m);
|
armv7m = DEVICE(&a->armv7m);
|
||||||
qdev_prop_set_uint32(armv7m, "num-irq", 256);
|
qdev_prop_set_uint32(armv7m, "num-irq", 256);
|
||||||
qdev_prop_set_string(armv7m, "cpu-type", sc->cpu_type);
|
qdev_prop_set_string(armv7m, "cpu-type", sc->cpu_type);
|
||||||
qdev_connect_clock_in(armv7m, "cpuclk", s->sysclk);
|
qdev_connect_clock_in(armv7m, "cpuclk", s->sysclk);
|
||||||
object_property_set_link(OBJECT(&s->armv7m), "memory",
|
object_property_set_link(OBJECT(&a->armv7m), "memory",
|
||||||
OBJECT(s->memory), &error_abort);
|
OBJECT(s->memory), &error_abort);
|
||||||
sysbus_realize(SYS_BUS_DEVICE(&s->armv7m), &error_abort);
|
sysbus_realize(SYS_BUS_DEVICE(&a->armv7m), &error_abort);
|
||||||
|
|
||||||
/* Internal SRAM */
|
/* Internal SRAM */
|
||||||
sram_name = g_strdup_printf("aspeed.sram.%d",
|
sram_name = g_strdup_printf("aspeed.sram.%d",
|
||||||
CPU(s->armv7m.cpu)->cpu_index);
|
CPU(a->armv7m.cpu)->cpu_index);
|
||||||
memory_region_init_ram(&s->sram, OBJECT(s), sram_name, sc->sram_size, &err);
|
memory_region_init_ram(&s->sram, OBJECT(s), sram_name, sc->sram_size, &err);
|
||||||
if (err != NULL) {
|
if (err != NULL) {
|
||||||
error_propagate(errp, err);
|
error_propagate(errp, err);
|
||||||
|
@ -249,7 +252,7 @@ static void aspeed_soc_ast1030_realize(DeviceState *dev_soc, Error **errp)
|
||||||
}
|
}
|
||||||
aspeed_mmio_map(s, SYS_BUS_DEVICE(&s->i2c), 0, sc->memmap[ASPEED_DEV_I2C]);
|
aspeed_mmio_map(s, SYS_BUS_DEVICE(&s->i2c), 0, sc->memmap[ASPEED_DEV_I2C]);
|
||||||
for (i = 0; i < ASPEED_I2C_GET_CLASS(&s->i2c)->num_busses; i++) {
|
for (i = 0; i < ASPEED_I2C_GET_CLASS(&s->i2c)->num_busses; i++) {
|
||||||
qemu_irq irq = qdev_get_gpio_in(DEVICE(&s->armv7m),
|
qemu_irq irq = qdev_get_gpio_in(DEVICE(&a->armv7m),
|
||||||
sc->irqmap[ASPEED_DEV_I2C] + i);
|
sc->irqmap[ASPEED_DEV_I2C] + i);
|
||||||
/* The AST1030 I2C controller has one IRQ per bus. */
|
/* The AST1030 I2C controller has one IRQ per bus. */
|
||||||
sysbus_connect_irq(SYS_BUS_DEVICE(&s->i2c.busses[i]), 0, irq);
|
sysbus_connect_irq(SYS_BUS_DEVICE(&s->i2c.busses[i]), 0, irq);
|
||||||
|
@ -261,7 +264,7 @@ static void aspeed_soc_ast1030_realize(DeviceState *dev_soc, Error **errp)
|
||||||
}
|
}
|
||||||
aspeed_mmio_map(s, SYS_BUS_DEVICE(&s->i3c), 0, sc->memmap[ASPEED_DEV_I3C]);
|
aspeed_mmio_map(s, SYS_BUS_DEVICE(&s->i3c), 0, sc->memmap[ASPEED_DEV_I3C]);
|
||||||
for (i = 0; i < ASPEED_I3C_NR_DEVICES; i++) {
|
for (i = 0; i < ASPEED_I3C_NR_DEVICES; i++) {
|
||||||
qemu_irq irq = qdev_get_gpio_in(DEVICE(&s->armv7m),
|
qemu_irq irq = qdev_get_gpio_in(DEVICE(&a->armv7m),
|
||||||
sc->irqmap[ASPEED_DEV_I3C] + i);
|
sc->irqmap[ASPEED_DEV_I3C] + i);
|
||||||
/* The AST1030 I3C controller has one IRQ per bus. */
|
/* The AST1030 I3C controller has one IRQ per bus. */
|
||||||
sysbus_connect_irq(SYS_BUS_DEVICE(&s->i3c.devices[i]), 0, irq);
|
sysbus_connect_irq(SYS_BUS_DEVICE(&s->i3c.devices[i]), 0, irq);
|
||||||
|
@ -290,19 +293,19 @@ static void aspeed_soc_ast1030_realize(DeviceState *dev_soc, Error **errp)
|
||||||
* On the AST1030 LPC subdevice IRQs are connected straight to the GIC.
|
* On the AST1030 LPC subdevice IRQs are connected straight to the GIC.
|
||||||
*/
|
*/
|
||||||
sysbus_connect_irq(SYS_BUS_DEVICE(&s->lpc), 1 + aspeed_lpc_kcs_1,
|
sysbus_connect_irq(SYS_BUS_DEVICE(&s->lpc), 1 + aspeed_lpc_kcs_1,
|
||||||
qdev_get_gpio_in(DEVICE(&s->armv7m),
|
qdev_get_gpio_in(DEVICE(&a->armv7m),
|
||||||
sc->irqmap[ASPEED_DEV_KCS] + aspeed_lpc_kcs_1));
|
sc->irqmap[ASPEED_DEV_KCS] + aspeed_lpc_kcs_1));
|
||||||
|
|
||||||
sysbus_connect_irq(SYS_BUS_DEVICE(&s->lpc), 1 + aspeed_lpc_kcs_2,
|
sysbus_connect_irq(SYS_BUS_DEVICE(&s->lpc), 1 + aspeed_lpc_kcs_2,
|
||||||
qdev_get_gpio_in(DEVICE(&s->armv7m),
|
qdev_get_gpio_in(DEVICE(&a->armv7m),
|
||||||
sc->irqmap[ASPEED_DEV_KCS] + aspeed_lpc_kcs_2));
|
sc->irqmap[ASPEED_DEV_KCS] + aspeed_lpc_kcs_2));
|
||||||
|
|
||||||
sysbus_connect_irq(SYS_BUS_DEVICE(&s->lpc), 1 + aspeed_lpc_kcs_3,
|
sysbus_connect_irq(SYS_BUS_DEVICE(&s->lpc), 1 + aspeed_lpc_kcs_3,
|
||||||
qdev_get_gpio_in(DEVICE(&s->armv7m),
|
qdev_get_gpio_in(DEVICE(&a->armv7m),
|
||||||
sc->irqmap[ASPEED_DEV_KCS] + aspeed_lpc_kcs_3));
|
sc->irqmap[ASPEED_DEV_KCS] + aspeed_lpc_kcs_3));
|
||||||
|
|
||||||
sysbus_connect_irq(SYS_BUS_DEVICE(&s->lpc), 1 + aspeed_lpc_kcs_4,
|
sysbus_connect_irq(SYS_BUS_DEVICE(&s->lpc), 1 + aspeed_lpc_kcs_4,
|
||||||
qdev_get_gpio_in(DEVICE(&s->armv7m),
|
qdev_get_gpio_in(DEVICE(&a->armv7m),
|
||||||
sc->irqmap[ASPEED_DEV_KCS] + aspeed_lpc_kcs_4));
|
sc->irqmap[ASPEED_DEV_KCS] + aspeed_lpc_kcs_4));
|
||||||
|
|
||||||
/* UART */
|
/* UART */
|
||||||
|
|
|
@ -28,7 +28,7 @@ struct Fby35State {
|
||||||
Clock *bic_sysclk;
|
Clock *bic_sysclk;
|
||||||
|
|
||||||
AspeedSoCState bmc;
|
AspeedSoCState bmc;
|
||||||
AspeedSoCState bic;
|
Aspeed10x0SoCState bic;
|
||||||
|
|
||||||
bool mmio_exec;
|
bool mmio_exec;
|
||||||
};
|
};
|
||||||
|
@ -114,10 +114,13 @@ static void fby35_bmc_init(Fby35State *s)
|
||||||
|
|
||||||
static void fby35_bic_init(Fby35State *s)
|
static void fby35_bic_init(Fby35State *s)
|
||||||
{
|
{
|
||||||
|
AspeedSoCState *soc;
|
||||||
|
|
||||||
s->bic_sysclk = clock_new(OBJECT(s), "SYSCLK");
|
s->bic_sysclk = clock_new(OBJECT(s), "SYSCLK");
|
||||||
clock_set_hz(s->bic_sysclk, 200000000ULL);
|
clock_set_hz(s->bic_sysclk, 200000000ULL);
|
||||||
|
|
||||||
object_initialize_child(OBJECT(s), "bic", &s->bic, "ast1030-a1");
|
object_initialize_child(OBJECT(s), "bic", &s->bic, "ast1030-a1");
|
||||||
|
soc = ASPEED_SOC(&s->bic);
|
||||||
|
|
||||||
memory_region_init(&s->bic_memory, OBJECT(&s->bic), "bic-memory",
|
memory_region_init(&s->bic_memory, OBJECT(&s->bic), "bic-memory",
|
||||||
UINT64_MAX);
|
UINT64_MAX);
|
||||||
|
@ -125,12 +128,12 @@ static void fby35_bic_init(Fby35State *s)
|
||||||
qdev_connect_clock_in(DEVICE(&s->bic), "sysclk", s->bic_sysclk);
|
qdev_connect_clock_in(DEVICE(&s->bic), "sysclk", s->bic_sysclk);
|
||||||
object_property_set_link(OBJECT(&s->bic), "memory", OBJECT(&s->bic_memory),
|
object_property_set_link(OBJECT(&s->bic), "memory", OBJECT(&s->bic_memory),
|
||||||
&error_abort);
|
&error_abort);
|
||||||
aspeed_soc_uart_set_chr(&s->bic, ASPEED_DEV_UART5, serial_hd(1));
|
aspeed_soc_uart_set_chr(soc, ASPEED_DEV_UART5, serial_hd(1));
|
||||||
qdev_realize(DEVICE(&s->bic), NULL, &error_abort);
|
qdev_realize(DEVICE(&s->bic), NULL, &error_abort);
|
||||||
|
|
||||||
aspeed_board_init_flashes(&s->bic.fmc, "sst25vf032b", 2, 2);
|
aspeed_board_init_flashes(&soc->fmc, "sst25vf032b", 2, 2);
|
||||||
aspeed_board_init_flashes(&s->bic.spi[0], "sst25vf032b", 2, 4);
|
aspeed_board_init_flashes(&soc->spi[0], "sst25vf032b", 2, 4);
|
||||||
aspeed_board_init_flashes(&s->bic.spi[1], "sst25vf032b", 2, 6);
|
aspeed_board_init_flashes(&soc->spi[1], "sst25vf032b", 2, 6);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void fby35_init(MachineState *machine)
|
static void fby35_init(MachineState *machine)
|
||||||
|
|
|
@ -47,13 +47,10 @@
|
||||||
#define ASPEED_JTAG_NUM 2
|
#define ASPEED_JTAG_NUM 2
|
||||||
|
|
||||||
struct AspeedSoCState {
|
struct AspeedSoCState {
|
||||||
/*< private >*/
|
|
||||||
DeviceState parent;
|
DeviceState parent;
|
||||||
|
|
||||||
/*< public >*/
|
|
||||||
ARMCPU cpu[ASPEED_CPUS_NUM];
|
ARMCPU cpu[ASPEED_CPUS_NUM];
|
||||||
A15MPPrivState a7mpcore;
|
A15MPPrivState a7mpcore;
|
||||||
ARMv7MState armv7m;
|
|
||||||
MemoryRegion *memory;
|
MemoryRegion *memory;
|
||||||
MemoryRegion *dram_mr;
|
MemoryRegion *dram_mr;
|
||||||
MemoryRegion dram_container;
|
MemoryRegion dram_container;
|
||||||
|
@ -117,6 +114,8 @@ OBJECT_DECLARE_SIMPLE_TYPE(Aspeed2600SoCState, ASPEED2600_SOC)
|
||||||
|
|
||||||
struct Aspeed10x0SoCState {
|
struct Aspeed10x0SoCState {
|
||||||
AspeedSoCState parent;
|
AspeedSoCState parent;
|
||||||
|
|
||||||
|
ARMv7MState armv7m;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define TYPE_ASPEED10X0_SOC "aspeed10x0-soc"
|
#define TYPE_ASPEED10X0_SOC "aspeed10x0-soc"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue