aspeed: Introduce a spi_boot region under the SoC
The default boot address of the Aspeed SoCs is 0x0. For this reason, the FMC flash device contents are remapped by HW on the first 256MB of the address space. In QEMU, this is currently done in the machine init with the setup of a region alias. Move this code to the SoC and introduce an extra container to prepare ground for the boot ROM region which will overlap the FMC flash remapping. Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Signed-off-by: Cédric Le Goater <clg@kaod.org>
This commit is contained in:
parent
ef0eb67ec9
commit
5aa281d757
@ -388,18 +388,7 @@ static void aspeed_machine_init(MachineState *machine)
|
|||||||
MemoryRegion *boot_rom = g_new(MemoryRegion, 1);
|
MemoryRegion *boot_rom = g_new(MemoryRegion, 1);
|
||||||
uint64_t size = memory_region_size(&fl->mmio);
|
uint64_t size = memory_region_size(&fl->mmio);
|
||||||
|
|
||||||
/*
|
if (!ASPEED_MACHINE(machine)->mmio_exec) {
|
||||||
* create a ROM region using the default mapping window size of
|
|
||||||
* the flash module. The window size is 64MB for the AST2400
|
|
||||||
* SoC and 128MB for the AST2500 SoC, which is twice as big as
|
|
||||||
* needed by the flash modules of the Aspeed machines.
|
|
||||||
*/
|
|
||||||
if (ASPEED_MACHINE(machine)->mmio_exec) {
|
|
||||||
memory_region_init_alias(boot_rom, NULL, "aspeed.boot_rom",
|
|
||||||
&fl->mmio, 0, size);
|
|
||||||
memory_region_add_subregion(get_system_memory(), FIRMWARE_ADDR,
|
|
||||||
boot_rom);
|
|
||||||
} else {
|
|
||||||
memory_region_init_rom(boot_rom, NULL, "aspeed.boot_rom",
|
memory_region_init_rom(boot_rom, NULL, "aspeed.boot_rom",
|
||||||
size, &error_abort);
|
size, &error_abort);
|
||||||
memory_region_add_subregion(get_system_memory(), FIRMWARE_ADDR,
|
memory_region_add_subregion(get_system_memory(), FIRMWARE_ADDR,
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
#define ASPEED_SOC_DPMCU_SIZE 0x00040000
|
#define ASPEED_SOC_DPMCU_SIZE 0x00040000
|
||||||
|
|
||||||
static const hwaddr aspeed_soc_ast2600_memmap[] = {
|
static const hwaddr aspeed_soc_ast2600_memmap[] = {
|
||||||
|
[ASPEED_DEV_SPI_BOOT] = ASPEED_SOC_SPI_BOOT_ADDR,
|
||||||
[ASPEED_DEV_SRAM] = 0x10000000,
|
[ASPEED_DEV_SRAM] = 0x10000000,
|
||||||
[ASPEED_DEV_DPMCU] = 0x18000000,
|
[ASPEED_DEV_DPMCU] = 0x18000000,
|
||||||
/* 0x16000000 0x17FFFFFF : AHB BUS do LPC Bus bridge */
|
/* 0x16000000 0x17FFFFFF : AHB BUS do LPC Bus bridge */
|
||||||
@ -282,6 +283,12 @@ static void aspeed_soc_ast2600_realize(DeviceState *dev, Error **errp)
|
|||||||
qemu_irq irq;
|
qemu_irq irq;
|
||||||
g_autofree char *sram_name = NULL;
|
g_autofree char *sram_name = NULL;
|
||||||
|
|
||||||
|
/* Default boot region (SPI memory or ROMs) */
|
||||||
|
memory_region_init(&s->spi_boot_container, OBJECT(s),
|
||||||
|
"aspeed.spi_boot_container", 0x10000000);
|
||||||
|
memory_region_add_subregion(s->memory, sc->memmap[ASPEED_DEV_SPI_BOOT],
|
||||||
|
&s->spi_boot_container);
|
||||||
|
|
||||||
/* IO space */
|
/* IO space */
|
||||||
aspeed_mmio_map_unimplemented(s, SYS_BUS_DEVICE(&s->iomem), "aspeed.io",
|
aspeed_mmio_map_unimplemented(s, SYS_BUS_DEVICE(&s->iomem), "aspeed.io",
|
||||||
sc->memmap[ASPEED_DEV_IOMEM],
|
sc->memmap[ASPEED_DEV_IOMEM],
|
||||||
@ -431,6 +438,12 @@ static void aspeed_soc_ast2600_realize(DeviceState *dev, Error **errp)
|
|||||||
sysbus_connect_irq(SYS_BUS_DEVICE(&s->fmc), 0,
|
sysbus_connect_irq(SYS_BUS_DEVICE(&s->fmc), 0,
|
||||||
aspeed_soc_get_irq(s, ASPEED_DEV_FMC));
|
aspeed_soc_get_irq(s, ASPEED_DEV_FMC));
|
||||||
|
|
||||||
|
/* Set up an alias on the FMC CE0 region (boot default) */
|
||||||
|
MemoryRegion *fmc0_mmio = &s->fmc.flashes[0].mmio;
|
||||||
|
memory_region_init_alias(&s->spi_boot, OBJECT(s), "aspeed.spi_boot",
|
||||||
|
fmc0_mmio, 0, memory_region_size(fmc0_mmio));
|
||||||
|
memory_region_add_subregion(&s->spi_boot_container, 0x0, &s->spi_boot);
|
||||||
|
|
||||||
/* SPI */
|
/* SPI */
|
||||||
for (i = 0; i < sc->spis_num; i++) {
|
for (i = 0; i < sc->spis_num; i++) {
|
||||||
object_property_set_link(OBJECT(&s->spi[i]), "dram",
|
object_property_set_link(OBJECT(&s->spi[i]), "dram",
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
#define ASPEED_SOC_IOMEM_SIZE 0x00200000
|
#define ASPEED_SOC_IOMEM_SIZE 0x00200000
|
||||||
|
|
||||||
static const hwaddr aspeed_soc_ast2400_memmap[] = {
|
static const hwaddr aspeed_soc_ast2400_memmap[] = {
|
||||||
|
[ASPEED_DEV_SPI_BOOT] = ASPEED_SOC_SPI_BOOT_ADDR,
|
||||||
[ASPEED_DEV_IOMEM] = 0x1E600000,
|
[ASPEED_DEV_IOMEM] = 0x1E600000,
|
||||||
[ASPEED_DEV_FMC] = 0x1E620000,
|
[ASPEED_DEV_FMC] = 0x1E620000,
|
||||||
[ASPEED_DEV_SPI1] = 0x1E630000,
|
[ASPEED_DEV_SPI1] = 0x1E630000,
|
||||||
@ -59,6 +60,7 @@ static const hwaddr aspeed_soc_ast2400_memmap[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const hwaddr aspeed_soc_ast2500_memmap[] = {
|
static const hwaddr aspeed_soc_ast2500_memmap[] = {
|
||||||
|
[ASPEED_DEV_SPI_BOOT] = ASPEED_SOC_SPI_BOOT_ADDR,
|
||||||
[ASPEED_DEV_IOMEM] = 0x1E600000,
|
[ASPEED_DEV_IOMEM] = 0x1E600000,
|
||||||
[ASPEED_DEV_FMC] = 0x1E620000,
|
[ASPEED_DEV_FMC] = 0x1E620000,
|
||||||
[ASPEED_DEV_SPI1] = 0x1E630000,
|
[ASPEED_DEV_SPI1] = 0x1E630000,
|
||||||
@ -245,6 +247,12 @@ static void aspeed_soc_realize(DeviceState *dev, Error **errp)
|
|||||||
Error *err = NULL;
|
Error *err = NULL;
|
||||||
g_autofree char *sram_name = NULL;
|
g_autofree char *sram_name = NULL;
|
||||||
|
|
||||||
|
/* Default boot region (SPI memory or ROMs) */
|
||||||
|
memory_region_init(&s->spi_boot_container, OBJECT(s),
|
||||||
|
"aspeed.spi_boot_container", 0x10000000);
|
||||||
|
memory_region_add_subregion(s->memory, sc->memmap[ASPEED_DEV_SPI_BOOT],
|
||||||
|
&s->spi_boot_container);
|
||||||
|
|
||||||
/* IO space */
|
/* IO space */
|
||||||
aspeed_mmio_map_unimplemented(s, SYS_BUS_DEVICE(&s->iomem), "aspeed.io",
|
aspeed_mmio_map_unimplemented(s, SYS_BUS_DEVICE(&s->iomem), "aspeed.io",
|
||||||
sc->memmap[ASPEED_DEV_IOMEM],
|
sc->memmap[ASPEED_DEV_IOMEM],
|
||||||
@ -354,6 +362,12 @@ static void aspeed_soc_realize(DeviceState *dev, Error **errp)
|
|||||||
sysbus_connect_irq(SYS_BUS_DEVICE(&s->fmc), 0,
|
sysbus_connect_irq(SYS_BUS_DEVICE(&s->fmc), 0,
|
||||||
aspeed_soc_get_irq(s, ASPEED_DEV_FMC));
|
aspeed_soc_get_irq(s, ASPEED_DEV_FMC));
|
||||||
|
|
||||||
|
/* Set up an alias on the FMC CE0 region (boot default) */
|
||||||
|
MemoryRegion *fmc0_mmio = &s->fmc.flashes[0].mmio;
|
||||||
|
memory_region_init_alias(&s->spi_boot, OBJECT(s), "aspeed.spi_boot",
|
||||||
|
fmc0_mmio, 0, memory_region_size(fmc0_mmio));
|
||||||
|
memory_region_add_subregion(&s->spi_boot_container, 0x0, &s->spi_boot);
|
||||||
|
|
||||||
/* SPI */
|
/* SPI */
|
||||||
for (i = 0; i < sc->spis_num; i++) {
|
for (i = 0; i < sc->spis_num; i++) {
|
||||||
if (!sysbus_realize(SYS_BUS_DEVICE(&s->spi[i]), errp)) {
|
if (!sysbus_realize(SYS_BUS_DEVICE(&s->spi[i]), errp)) {
|
||||||
|
@ -100,13 +100,7 @@ static void fby35_bmc_init(Fby35State *s)
|
|||||||
MemoryRegion *boot_rom = g_new(MemoryRegion, 1);
|
MemoryRegion *boot_rom = g_new(MemoryRegion, 1);
|
||||||
uint64_t size = memory_region_size(&fl->mmio);
|
uint64_t size = memory_region_size(&fl->mmio);
|
||||||
|
|
||||||
if (s->mmio_exec) {
|
if (!s->mmio_exec) {
|
||||||
memory_region_init_alias(boot_rom, NULL, "aspeed.boot_rom",
|
|
||||||
&fl->mmio, 0, size);
|
|
||||||
memory_region_add_subregion(&s->bmc_memory, FBY35_BMC_FIRMWARE_ADDR,
|
|
||||||
boot_rom);
|
|
||||||
} else {
|
|
||||||
|
|
||||||
memory_region_init_rom(boot_rom, NULL, "aspeed.boot_rom",
|
memory_region_init_rom(boot_rom, NULL, "aspeed.boot_rom",
|
||||||
size, &error_abort);
|
size, &error_abort);
|
||||||
memory_region_add_subregion(&s->bmc_memory, FBY35_BMC_FIRMWARE_ADDR,
|
memory_region_add_subregion(&s->bmc_memory, FBY35_BMC_FIRMWARE_ADDR,
|
||||||
|
@ -58,6 +58,8 @@ struct AspeedSoCState {
|
|||||||
MemoryRegion *dram_mr;
|
MemoryRegion *dram_mr;
|
||||||
MemoryRegion dram_container;
|
MemoryRegion dram_container;
|
||||||
MemoryRegion sram;
|
MemoryRegion sram;
|
||||||
|
MemoryRegion spi_boot_container;
|
||||||
|
MemoryRegion spi_boot;
|
||||||
AspeedVICState vic;
|
AspeedVICState vic;
|
||||||
AspeedRtcState rtc;
|
AspeedRtcState rtc;
|
||||||
AspeedTimerCtrlState timerctrl;
|
AspeedTimerCtrlState timerctrl;
|
||||||
@ -120,6 +122,7 @@ struct AspeedSoCClass {
|
|||||||
|
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
ASPEED_DEV_SPI_BOOT,
|
||||||
ASPEED_DEV_IOMEM,
|
ASPEED_DEV_IOMEM,
|
||||||
ASPEED_DEV_UART1,
|
ASPEED_DEV_UART1,
|
||||||
ASPEED_DEV_UART2,
|
ASPEED_DEV_UART2,
|
||||||
@ -190,6 +193,8 @@ enum {
|
|||||||
ASPEED_DEV_JTAG1,
|
ASPEED_DEV_JTAG1,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define ASPEED_SOC_SPI_BOOT_ADDR 0x0
|
||||||
|
|
||||||
qemu_irq aspeed_soc_get_irq(AspeedSoCState *s, int dev);
|
qemu_irq aspeed_soc_get_irq(AspeedSoCState *s, int dev);
|
||||||
bool aspeed_soc_uart_realize(AspeedSoCState *s, Error **errp);
|
bool aspeed_soc_uart_realize(AspeedSoCState *s, Error **errp);
|
||||||
void aspeed_soc_uart_set_chr(AspeedSoCState *s, int dev, Chardev *chr);
|
void aspeed_soc_uart_set_chr(AspeedSoCState *s, int dev, Chardev *chr);
|
||||||
|
Loading…
Reference in New Issue
Block a user