Change references to serial_hds[] to serial_hd()
Change all the uses of serial_hds[] to go via the new serial_hd() function. Code change produced with: find hw -name '*.[ch]' | xargs sed -i -e 's/serial_hds\[\([^]]*\)\]/serial_hd(\1)/g' Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Thomas Huth <thuth@redhat.com> Message-id: 20180420145249.32435-8-peter.maydell@linaro.org
This commit is contained in:
parent
a8d78cd0ab
commit
9bca0edb28
@ -108,9 +108,9 @@ static void aw_a10_realize(DeviceState *dev, Error **errp)
|
|||||||
sysbus_mmio_map(SYS_BUS_DEVICE(&s->sata), 0, AW_A10_SATA_BASE);
|
sysbus_mmio_map(SYS_BUS_DEVICE(&s->sata), 0, AW_A10_SATA_BASE);
|
||||||
sysbus_connect_irq(SYS_BUS_DEVICE(&s->sata), 0, s->irq[56]);
|
sysbus_connect_irq(SYS_BUS_DEVICE(&s->sata), 0, s->irq[56]);
|
||||||
|
|
||||||
/* FIXME use a qdev chardev prop instead of serial_hds[] */
|
/* FIXME use a qdev chardev prop instead of serial_hd() */
|
||||||
serial_mm_init(get_system_memory(), AW_A10_UART0_REG_BASE, 2, s->irq[1],
|
serial_mm_init(get_system_memory(), AW_A10_UART0_REG_BASE, 2, s->irq[1],
|
||||||
115200, serial_hds[0], DEVICE_NATIVE_ENDIAN);
|
115200, serial_hd(0), DEVICE_NATIVE_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void aw_a10_class_init(ObjectClass *oc, void *data)
|
static void aw_a10_class_init(ObjectClass *oc, void *data)
|
||||||
|
@ -228,11 +228,11 @@ static void aspeed_soc_realize(DeviceState *dev, Error **errp)
|
|||||||
sysbus_mmio_map(SYS_BUS_DEVICE(&s->scu), 0, ASPEED_SOC_SCU_BASE);
|
sysbus_mmio_map(SYS_BUS_DEVICE(&s->scu), 0, ASPEED_SOC_SCU_BASE);
|
||||||
|
|
||||||
/* UART - attach an 8250 to the IO space as our UART5 */
|
/* UART - attach an 8250 to the IO space as our UART5 */
|
||||||
if (serial_hds[0]) {
|
if (serial_hd(0)) {
|
||||||
qemu_irq uart5 = qdev_get_gpio_in(DEVICE(&s->vic), uart_irqs[4]);
|
qemu_irq uart5 = qdev_get_gpio_in(DEVICE(&s->vic), uart_irqs[4]);
|
||||||
serial_mm_init(get_system_memory(),
|
serial_mm_init(get_system_memory(),
|
||||||
ASPEED_SOC_IOMEM_BASE + ASPEED_SOC_UART_5_BASE, 2,
|
ASPEED_SOC_IOMEM_BASE + ASPEED_SOC_UART_5_BASE, 2,
|
||||||
uart5, 38400, serial_hds[0], DEVICE_LITTLE_ENDIAN);
|
uart5, 38400, serial_hd(0), DEVICE_LITTLE_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* I2C */
|
/* I2C */
|
||||||
|
@ -166,7 +166,7 @@ static void bcm2835_peripherals_realize(DeviceState *dev, Error **errp)
|
|||||||
sysbus_pass_irq(SYS_BUS_DEVICE(s), SYS_BUS_DEVICE(&s->ic));
|
sysbus_pass_irq(SYS_BUS_DEVICE(s), SYS_BUS_DEVICE(&s->ic));
|
||||||
|
|
||||||
/* UART0 */
|
/* UART0 */
|
||||||
qdev_prop_set_chr(DEVICE(s->uart0), "chardev", serial_hds[0]);
|
qdev_prop_set_chr(DEVICE(s->uart0), "chardev", serial_hd(0));
|
||||||
object_property_set_bool(OBJECT(s->uart0), true, "realized", &err);
|
object_property_set_bool(OBJECT(s->uart0), true, "realized", &err);
|
||||||
if (err) {
|
if (err) {
|
||||||
error_propagate(errp, err);
|
error_propagate(errp, err);
|
||||||
@ -179,7 +179,7 @@ static void bcm2835_peripherals_realize(DeviceState *dev, Error **errp)
|
|||||||
qdev_get_gpio_in_named(DEVICE(&s->ic), BCM2835_IC_GPU_IRQ,
|
qdev_get_gpio_in_named(DEVICE(&s->ic), BCM2835_IC_GPU_IRQ,
|
||||||
INTERRUPT_UART));
|
INTERRUPT_UART));
|
||||||
/* AUX / UART1 */
|
/* AUX / UART1 */
|
||||||
qdev_prop_set_chr(DEVICE(&s->aux), "chardev", serial_hds[1]);
|
qdev_prop_set_chr(DEVICE(&s->aux), "chardev", serial_hd(1));
|
||||||
|
|
||||||
object_property_set_bool(OBJECT(&s->aux), true, "realized", &err);
|
object_property_set_bool(OBJECT(&s->aux), true, "realized", &err);
|
||||||
if (err) {
|
if (err) {
|
||||||
|
@ -85,7 +85,7 @@ static void digic_realize(DeviceState *dev, Error **errp)
|
|||||||
sysbus_mmio_map(sbd, 0, DIGIC4_TIMER_BASE(i));
|
sysbus_mmio_map(sbd, 0, DIGIC4_TIMER_BASE(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
qdev_prop_set_chr(DEVICE(&s->uart), "chardev", serial_hds[0]);
|
qdev_prop_set_chr(DEVICE(&s->uart), "chardev", serial_hd(0));
|
||||||
object_property_set_bool(OBJECT(&s->uart), true, "realized", &err);
|
object_property_set_bool(OBJECT(&s->uart), true, "realized", &err);
|
||||||
if (err != NULL) {
|
if (err != NULL) {
|
||||||
error_propagate(errp, err);
|
error_propagate(errp, err);
|
||||||
|
@ -118,7 +118,7 @@ static void fsl_imx25_realize(DeviceState *dev, Error **errp)
|
|||||||
};
|
};
|
||||||
|
|
||||||
if (i < MAX_SERIAL_PORTS) {
|
if (i < MAX_SERIAL_PORTS) {
|
||||||
qdev_prop_set_chr(DEVICE(&s->uart[i]), "chardev", serial_hds[i]);
|
qdev_prop_set_chr(DEVICE(&s->uart[i]), "chardev", serial_hd(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
object_property_set_bool(OBJECT(&s->uart[i]), true, "realized", &err);
|
object_property_set_bool(OBJECT(&s->uart[i]), true, "realized", &err);
|
||||||
|
@ -107,7 +107,7 @@ static void fsl_imx31_realize(DeviceState *dev, Error **errp)
|
|||||||
};
|
};
|
||||||
|
|
||||||
if (i < MAX_SERIAL_PORTS) {
|
if (i < MAX_SERIAL_PORTS) {
|
||||||
qdev_prop_set_chr(DEVICE(&s->uart[i]), "chardev", serial_hds[i]);
|
qdev_prop_set_chr(DEVICE(&s->uart[i]), "chardev", serial_hd(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
object_property_set_bool(OBJECT(&s->uart[i]), true, "realized", &err);
|
object_property_set_bool(OBJECT(&s->uart[i]), true, "realized", &err);
|
||||||
|
@ -189,7 +189,7 @@ static void fsl_imx6_realize(DeviceState *dev, Error **errp)
|
|||||||
};
|
};
|
||||||
|
|
||||||
if (i < MAX_SERIAL_PORTS) {
|
if (i < MAX_SERIAL_PORTS) {
|
||||||
qdev_prop_set_chr(DEVICE(&s->uart[i]), "chardev", serial_hds[i]);
|
qdev_prop_set_chr(DEVICE(&s->uart[i]), "chardev", serial_hd(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
object_property_set_bool(OBJECT(&s->uart[i]), true, "realized", &err);
|
object_property_set_bool(OBJECT(&s->uart[i]), true, "realized", &err);
|
||||||
@ -438,7 +438,7 @@ static void fsl_imx6_class_init(ObjectClass *oc, void *data)
|
|||||||
|
|
||||||
dc->realize = fsl_imx6_realize;
|
dc->realize = fsl_imx6_realize;
|
||||||
dc->desc = "i.MX6 SOC";
|
dc->desc = "i.MX6 SOC";
|
||||||
/* Reason: Uses serial_hds[] in the realize() function */
|
/* Reason: Uses serial_hd() in the realize() function */
|
||||||
dc->user_creatable = false;
|
dc->user_creatable = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -391,7 +391,7 @@ static void fsl_imx7_realize(DeviceState *dev, Error **errp)
|
|||||||
|
|
||||||
|
|
||||||
if (i < MAX_SERIAL_PORTS) {
|
if (i < MAX_SERIAL_PORTS) {
|
||||||
qdev_prop_set_chr(DEVICE(&s->uart[i]), "chardev", serial_hds[i]);
|
qdev_prop_set_chr(DEVICE(&s->uart[i]), "chardev", serial_hd(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
object_property_set_bool(OBJECT(&s->uart[i]), true, "realized",
|
object_property_set_bool(OBJECT(&s->uart[i]), true, "realized",
|
||||||
|
@ -342,7 +342,7 @@ static void calxeda_init(MachineState *machine, enum cxmachines machine_id)
|
|||||||
busdev = SYS_BUS_DEVICE(dev);
|
busdev = SYS_BUS_DEVICE(dev);
|
||||||
sysbus_mmio_map(busdev, 0, 0xfff34000);
|
sysbus_mmio_map(busdev, 0, 0xfff34000);
|
||||||
sysbus_connect_irq(busdev, 0, pic[18]);
|
sysbus_connect_irq(busdev, 0, pic[18]);
|
||||||
pl011_create(0xfff36000, pic[20], serial_hds[0]);
|
pl011_create(0xfff36000, pic[20], serial_hd(0));
|
||||||
|
|
||||||
dev = qdev_create(NULL, TYPE_HIGHBANK_REGISTERS);
|
dev = qdev_create(NULL, TYPE_HIGHBANK_REGISTERS);
|
||||||
qdev_init_nofail(dev);
|
qdev_init_nofail(dev);
|
||||||
|
@ -631,8 +631,8 @@ static void integratorcp_init(MachineState *machine)
|
|||||||
sysbus_create_varargs("integrator_pit", 0x13000000,
|
sysbus_create_varargs("integrator_pit", 0x13000000,
|
||||||
pic[5], pic[6], pic[7], NULL);
|
pic[5], pic[6], pic[7], NULL);
|
||||||
sysbus_create_simple("pl031", 0x15000000, pic[8]);
|
sysbus_create_simple("pl031", 0x15000000, pic[8]);
|
||||||
pl011_create(0x16000000, pic[1], serial_hds[0]);
|
pl011_create(0x16000000, pic[1], serial_hd(0));
|
||||||
pl011_create(0x17000000, pic[2], serial_hds[1]);
|
pl011_create(0x17000000, pic[2], serial_hd(1));
|
||||||
icp = sysbus_create_simple(TYPE_ICP_CONTROL_REGS, 0xcb000000,
|
icp = sysbus_create_simple(TYPE_ICP_CONTROL_REGS, 0xcb000000,
|
||||||
qdev_get_gpio_in(sic, 3));
|
qdev_get_gpio_in(sic, 3));
|
||||||
sysbus_create_simple("pl050_keyboard", 0x18000000, pic[3]);
|
sysbus_create_simple("pl050_keyboard", 0x18000000, pic[3]);
|
||||||
|
@ -121,10 +121,10 @@ static void kzm_init(MachineState *machine)
|
|||||||
qdev_get_gpio_in(DEVICE(&s->soc.avic), 52));
|
qdev_get_gpio_in(DEVICE(&s->soc.avic), 52));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (serial_hds[2]) { /* touchscreen */
|
if (serial_hd(2)) { /* touchscreen */
|
||||||
serial_mm_init(get_system_memory(), KZM_FPGA_ADDR+0x10, 0,
|
serial_mm_init(get_system_memory(), KZM_FPGA_ADDR+0x10, 0,
|
||||||
qdev_get_gpio_in(DEVICE(&s->soc.avic), 52),
|
qdev_get_gpio_in(DEVICE(&s->soc.avic), 52),
|
||||||
14745600, serial_hds[2], DEVICE_NATIVE_ENDIAN);
|
14745600, serial_hd(2), DEVICE_NATIVE_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
kzm_binfo.ram_size = machine->ram_size;
|
kzm_binfo.ram_size = machine->ram_size;
|
||||||
|
@ -172,7 +172,7 @@ static MemoryRegion *make_uart(MPS2TZMachineState *mms, void *opaque,
|
|||||||
{
|
{
|
||||||
CMSDKAPBUART *uart = opaque;
|
CMSDKAPBUART *uart = opaque;
|
||||||
int i = uart - &mms->uart[0];
|
int i = uart - &mms->uart[0];
|
||||||
Chardev *uartchr = i < MAX_SERIAL_PORTS ? serial_hds[i] : NULL;
|
Chardev *uartchr = i < MAX_SERIAL_PORTS ? serial_hd(i) : NULL;
|
||||||
int rxirqno = i * 2;
|
int rxirqno = i * 2;
|
||||||
int txirqno = i * 2 + 1;
|
int txirqno = i * 2 + 1;
|
||||||
int combirqno = i + 10;
|
int combirqno = i + 10;
|
||||||
|
@ -230,7 +230,7 @@ static void mps2_common_init(MachineState *machine)
|
|||||||
static const hwaddr uartbase[] = {0x40004000, 0x40005000,
|
static const hwaddr uartbase[] = {0x40004000, 0x40005000,
|
||||||
0x40006000, 0x40007000,
|
0x40006000, 0x40007000,
|
||||||
0x40009000};
|
0x40009000};
|
||||||
Chardev *uartchr = i < MAX_SERIAL_PORTS ? serial_hds[i] : NULL;
|
Chardev *uartchr = i < MAX_SERIAL_PORTS ? serial_hd(i) : NULL;
|
||||||
/* RX irq number; TX irq is always one greater */
|
/* RX irq number; TX irq is always one greater */
|
||||||
static const int uartirq[] = {0, 2, 4, 18, 20};
|
static const int uartirq[] = {0, 2, 4, 18, 20};
|
||||||
qemu_irq txovrint = NULL, rxovrint = NULL;
|
qemu_irq txovrint = NULL, rxovrint = NULL;
|
||||||
@ -270,7 +270,7 @@ static void mps2_common_init(MachineState *machine)
|
|||||||
static const hwaddr uartbase[] = {0x40004000, 0x40005000,
|
static const hwaddr uartbase[] = {0x40004000, 0x40005000,
|
||||||
0x4002c000, 0x4002d000,
|
0x4002c000, 0x4002d000,
|
||||||
0x4002e000};
|
0x4002e000};
|
||||||
Chardev *uartchr = i < MAX_SERIAL_PORTS ? serial_hds[i] : NULL;
|
Chardev *uartchr = i < MAX_SERIAL_PORTS ? serial_hd(i) : NULL;
|
||||||
Object *txrx_orgate;
|
Object *txrx_orgate;
|
||||||
DeviceState *txrx_orgate_dev;
|
DeviceState *txrx_orgate_dev;
|
||||||
|
|
||||||
|
@ -138,10 +138,10 @@ static void m2sxxx_soc_realize(DeviceState *dev_soc, Error **errp)
|
|||||||
system_clock_scale = NANOSECONDS_PER_SECOND / s->m3clk;
|
system_clock_scale = NANOSECONDS_PER_SECOND / s->m3clk;
|
||||||
|
|
||||||
for (i = 0; i < MSF2_NUM_UARTS; i++) {
|
for (i = 0; i < MSF2_NUM_UARTS; i++) {
|
||||||
if (serial_hds[i]) {
|
if (serial_hd(i)) {
|
||||||
serial_mm_init(get_system_memory(), uart_addr[i], 2,
|
serial_mm_init(get_system_memory(), uart_addr[i], 2,
|
||||||
qdev_get_gpio_in(armv7m, uart_irq[i]),
|
qdev_get_gpio_in(armv7m, uart_irq[i]),
|
||||||
115200, serial_hds[i], DEVICE_NATIVE_ENDIAN);
|
115200, serial_hd(i), DEVICE_NATIVE_ENDIAN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1610,13 +1610,13 @@ static void musicpal_init(MachineState *machine)
|
|||||||
pic[MP_TIMER2_IRQ], pic[MP_TIMER3_IRQ],
|
pic[MP_TIMER2_IRQ], pic[MP_TIMER3_IRQ],
|
||||||
pic[MP_TIMER4_IRQ], NULL);
|
pic[MP_TIMER4_IRQ], NULL);
|
||||||
|
|
||||||
if (serial_hds[0]) {
|
if (serial_hd(0)) {
|
||||||
serial_mm_init(address_space_mem, MP_UART1_BASE, 2, pic[MP_UART1_IRQ],
|
serial_mm_init(address_space_mem, MP_UART1_BASE, 2, pic[MP_UART1_IRQ],
|
||||||
1825000, serial_hds[0], DEVICE_NATIVE_ENDIAN);
|
1825000, serial_hd(0), DEVICE_NATIVE_ENDIAN);
|
||||||
}
|
}
|
||||||
if (serial_hds[1]) {
|
if (serial_hd(1)) {
|
||||||
serial_mm_init(address_space_mem, MP_UART2_BASE, 2, pic[MP_UART2_IRQ],
|
serial_mm_init(address_space_mem, MP_UART2_BASE, 2, pic[MP_UART2_IRQ],
|
||||||
1825000, serial_hds[1], DEVICE_NATIVE_ENDIAN);
|
1825000, serial_hd(1), DEVICE_NATIVE_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Register flash */
|
/* Register flash */
|
||||||
|
@ -3963,21 +3963,21 @@ struct omap_mpu_state_s *omap310_mpu_init(MemoryRegion *system_memory,
|
|||||||
omap_findclk(s, "uart1_ck"),
|
omap_findclk(s, "uart1_ck"),
|
||||||
s->drq[OMAP_DMA_UART1_TX], s->drq[OMAP_DMA_UART1_RX],
|
s->drq[OMAP_DMA_UART1_TX], s->drq[OMAP_DMA_UART1_RX],
|
||||||
"uart1",
|
"uart1",
|
||||||
serial_hds[0]);
|
serial_hd(0));
|
||||||
s->uart[1] = omap_uart_init(0xfffb0800,
|
s->uart[1] = omap_uart_init(0xfffb0800,
|
||||||
qdev_get_gpio_in(s->ih[1], OMAP_INT_UART2),
|
qdev_get_gpio_in(s->ih[1], OMAP_INT_UART2),
|
||||||
omap_findclk(s, "uart2_ck"),
|
omap_findclk(s, "uart2_ck"),
|
||||||
omap_findclk(s, "uart2_ck"),
|
omap_findclk(s, "uart2_ck"),
|
||||||
s->drq[OMAP_DMA_UART2_TX], s->drq[OMAP_DMA_UART2_RX],
|
s->drq[OMAP_DMA_UART2_TX], s->drq[OMAP_DMA_UART2_RX],
|
||||||
"uart2",
|
"uart2",
|
||||||
serial_hds[0] ? serial_hds[1] : NULL);
|
serial_hd(0) ? serial_hd(1) : NULL);
|
||||||
s->uart[2] = omap_uart_init(0xfffb9800,
|
s->uart[2] = omap_uart_init(0xfffb9800,
|
||||||
qdev_get_gpio_in(s->ih[0], OMAP_INT_UART3),
|
qdev_get_gpio_in(s->ih[0], OMAP_INT_UART3),
|
||||||
omap_findclk(s, "uart3_ck"),
|
omap_findclk(s, "uart3_ck"),
|
||||||
omap_findclk(s, "uart3_ck"),
|
omap_findclk(s, "uart3_ck"),
|
||||||
s->drq[OMAP_DMA_UART3_TX], s->drq[OMAP_DMA_UART3_RX],
|
s->drq[OMAP_DMA_UART3_TX], s->drq[OMAP_DMA_UART3_RX],
|
||||||
"uart3",
|
"uart3",
|
||||||
serial_hds[0] && serial_hds[1] ? serial_hds[2] : NULL);
|
serial_hd(0) && serial_hd(1) ? serial_hd(2) : NULL);
|
||||||
|
|
||||||
s->dpll[0] = omap_dpll_init(system_memory, 0xfffecf00,
|
s->dpll[0] = omap_dpll_init(system_memory, 0xfffecf00,
|
||||||
omap_findclk(s, "dpll1"));
|
omap_findclk(s, "dpll1"));
|
||||||
|
@ -2349,7 +2349,7 @@ struct omap_mpu_state_s *omap2420_mpu_init(MemoryRegion *sysmem,
|
|||||||
s->drq[OMAP24XX_DMA_UART1_TX],
|
s->drq[OMAP24XX_DMA_UART1_TX],
|
||||||
s->drq[OMAP24XX_DMA_UART1_RX],
|
s->drq[OMAP24XX_DMA_UART1_RX],
|
||||||
"uart1",
|
"uart1",
|
||||||
serial_hds[0]);
|
serial_hd(0));
|
||||||
s->uart[1] = omap2_uart_init(sysmem, omap_l4ta(s->l4, 20),
|
s->uart[1] = omap2_uart_init(sysmem, omap_l4ta(s->l4, 20),
|
||||||
qdev_get_gpio_in(s->ih[0],
|
qdev_get_gpio_in(s->ih[0],
|
||||||
OMAP_INT_24XX_UART2_IRQ),
|
OMAP_INT_24XX_UART2_IRQ),
|
||||||
@ -2358,7 +2358,7 @@ struct omap_mpu_state_s *omap2420_mpu_init(MemoryRegion *sysmem,
|
|||||||
s->drq[OMAP24XX_DMA_UART2_TX],
|
s->drq[OMAP24XX_DMA_UART2_TX],
|
||||||
s->drq[OMAP24XX_DMA_UART2_RX],
|
s->drq[OMAP24XX_DMA_UART2_RX],
|
||||||
"uart2",
|
"uart2",
|
||||||
serial_hds[0] ? serial_hds[1] : NULL);
|
serial_hd(0) ? serial_hd(1) : NULL);
|
||||||
s->uart[2] = omap2_uart_init(sysmem, omap_l4ta(s->l4, 21),
|
s->uart[2] = omap2_uart_init(sysmem, omap_l4ta(s->l4, 21),
|
||||||
qdev_get_gpio_in(s->ih[0],
|
qdev_get_gpio_in(s->ih[0],
|
||||||
OMAP_INT_24XX_UART3_IRQ),
|
OMAP_INT_24XX_UART3_IRQ),
|
||||||
@ -2367,7 +2367,7 @@ struct omap_mpu_state_s *omap2420_mpu_init(MemoryRegion *sysmem,
|
|||||||
s->drq[OMAP24XX_DMA_UART3_TX],
|
s->drq[OMAP24XX_DMA_UART3_TX],
|
||||||
s->drq[OMAP24XX_DMA_UART3_RX],
|
s->drq[OMAP24XX_DMA_UART3_RX],
|
||||||
"uart3",
|
"uart3",
|
||||||
serial_hds[0] && serial_hds[1] ? serial_hds[2] : NULL);
|
serial_hd(0) && serial_hd(1) ? serial_hd(2) : NULL);
|
||||||
|
|
||||||
s->gptimer[0] = omap_gp_timer_init(omap_l4ta(s->l4, 7),
|
s->gptimer[0] = omap_gp_timer_init(omap_l4ta(s->l4, 7),
|
||||||
qdev_get_gpio_in(s->ih[0], OMAP_INT_24XX_GPTIMER1),
|
qdev_get_gpio_in(s->ih[0], OMAP_INT_24XX_GPTIMER1),
|
||||||
@ -2519,8 +2519,8 @@ struct omap_mpu_state_s *omap2420_mpu_init(MemoryRegion *sysmem,
|
|||||||
omap_sti_init(omap_l4ta(s->l4, 18), sysmem, 0x54000000,
|
omap_sti_init(omap_l4ta(s->l4, 18), sysmem, 0x54000000,
|
||||||
qdev_get_gpio_in(s->ih[0], OMAP_INT_24XX_STI),
|
qdev_get_gpio_in(s->ih[0], OMAP_INT_24XX_STI),
|
||||||
omap_findclk(s, "emul_ck"),
|
omap_findclk(s, "emul_ck"),
|
||||||
serial_hds[0] && serial_hds[1] && serial_hds[2] ?
|
serial_hd(0) && serial_hd(1) && serial_hd(2) ?
|
||||||
serial_hds[3] : NULL);
|
serial_hd(3) : NULL);
|
||||||
|
|
||||||
s->eac = omap_eac_init(omap_l4ta(s->l4, 32),
|
s->eac = omap_eac_init(omap_l4ta(s->l4, 32),
|
||||||
qdev_get_gpio_in(s->ih[0], OMAP_INT_24XX_EAC_IRQ),
|
qdev_get_gpio_in(s->ih[0], OMAP_INT_24XX_EAC_IRQ),
|
||||||
|
@ -2106,21 +2106,21 @@ PXA2xxState *pxa270_init(MemoryRegion *address_space,
|
|||||||
qdev_get_gpio_in(s->dma, PXA2XX_TX_RQ_MMCI));
|
qdev_get_gpio_in(s->dma, PXA2XX_TX_RQ_MMCI));
|
||||||
|
|
||||||
for (i = 0; pxa270_serial[i].io_base; i++) {
|
for (i = 0; pxa270_serial[i].io_base; i++) {
|
||||||
if (serial_hds[i]) {
|
if (serial_hd(i)) {
|
||||||
serial_mm_init(address_space, pxa270_serial[i].io_base, 2,
|
serial_mm_init(address_space, pxa270_serial[i].io_base, 2,
|
||||||
qdev_get_gpio_in(s->pic, pxa270_serial[i].irqn),
|
qdev_get_gpio_in(s->pic, pxa270_serial[i].irqn),
|
||||||
14857000 / 16, serial_hds[i],
|
14857000 / 16, serial_hd(i),
|
||||||
DEVICE_NATIVE_ENDIAN);
|
DEVICE_NATIVE_ENDIAN);
|
||||||
} else {
|
} else {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (serial_hds[i])
|
if (serial_hd(i))
|
||||||
s->fir = pxa2xx_fir_init(address_space, 0x40800000,
|
s->fir = pxa2xx_fir_init(address_space, 0x40800000,
|
||||||
qdev_get_gpio_in(s->pic, PXA2XX_PIC_ICP),
|
qdev_get_gpio_in(s->pic, PXA2XX_PIC_ICP),
|
||||||
qdev_get_gpio_in(s->dma, PXA2XX_RX_RQ_ICP),
|
qdev_get_gpio_in(s->dma, PXA2XX_RX_RQ_ICP),
|
||||||
qdev_get_gpio_in(s->dma, PXA2XX_TX_RQ_ICP),
|
qdev_get_gpio_in(s->dma, PXA2XX_TX_RQ_ICP),
|
||||||
serial_hds[i]);
|
serial_hd(i));
|
||||||
|
|
||||||
s->lcd = pxa2xx_lcdc_init(address_space, 0x44000000,
|
s->lcd = pxa2xx_lcdc_init(address_space, 0x44000000,
|
||||||
qdev_get_gpio_in(s->pic, PXA2XX_PIC_LCD));
|
qdev_get_gpio_in(s->pic, PXA2XX_PIC_LCD));
|
||||||
@ -2231,21 +2231,21 @@ PXA2xxState *pxa255_init(MemoryRegion *address_space, unsigned int sdram_size)
|
|||||||
qdev_get_gpio_in(s->dma, PXA2XX_TX_RQ_MMCI));
|
qdev_get_gpio_in(s->dma, PXA2XX_TX_RQ_MMCI));
|
||||||
|
|
||||||
for (i = 0; pxa255_serial[i].io_base; i++) {
|
for (i = 0; pxa255_serial[i].io_base; i++) {
|
||||||
if (serial_hds[i]) {
|
if (serial_hd(i)) {
|
||||||
serial_mm_init(address_space, pxa255_serial[i].io_base, 2,
|
serial_mm_init(address_space, pxa255_serial[i].io_base, 2,
|
||||||
qdev_get_gpio_in(s->pic, pxa255_serial[i].irqn),
|
qdev_get_gpio_in(s->pic, pxa255_serial[i].irqn),
|
||||||
14745600 / 16, serial_hds[i],
|
14745600 / 16, serial_hd(i),
|
||||||
DEVICE_NATIVE_ENDIAN);
|
DEVICE_NATIVE_ENDIAN);
|
||||||
} else {
|
} else {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (serial_hds[i])
|
if (serial_hd(i))
|
||||||
s->fir = pxa2xx_fir_init(address_space, 0x40800000,
|
s->fir = pxa2xx_fir_init(address_space, 0x40800000,
|
||||||
qdev_get_gpio_in(s->pic, PXA2XX_PIC_ICP),
|
qdev_get_gpio_in(s->pic, PXA2XX_PIC_ICP),
|
||||||
qdev_get_gpio_in(s->dma, PXA2XX_RX_RQ_ICP),
|
qdev_get_gpio_in(s->dma, PXA2XX_RX_RQ_ICP),
|
||||||
qdev_get_gpio_in(s->dma, PXA2XX_TX_RQ_ICP),
|
qdev_get_gpio_in(s->dma, PXA2XX_TX_RQ_ICP),
|
||||||
serial_hds[i]);
|
serial_hd(i));
|
||||||
|
|
||||||
s->lcd = pxa2xx_lcdc_init(address_space, 0x44000000,
|
s->lcd = pxa2xx_lcdc_init(address_space, 0x44000000,
|
||||||
qdev_get_gpio_in(s->pic, PXA2XX_PIC_LCD));
|
qdev_get_gpio_in(s->pic, PXA2XX_PIC_LCD));
|
||||||
|
@ -195,10 +195,10 @@ static void realview_init(MachineState *machine,
|
|||||||
sysbus_create_simple("pl050_keyboard", 0x10006000, pic[20]);
|
sysbus_create_simple("pl050_keyboard", 0x10006000, pic[20]);
|
||||||
sysbus_create_simple("pl050_mouse", 0x10007000, pic[21]);
|
sysbus_create_simple("pl050_mouse", 0x10007000, pic[21]);
|
||||||
|
|
||||||
pl011_create(0x10009000, pic[12], serial_hds[0]);
|
pl011_create(0x10009000, pic[12], serial_hd(0));
|
||||||
pl011_create(0x1000a000, pic[13], serial_hds[1]);
|
pl011_create(0x1000a000, pic[13], serial_hd(1));
|
||||||
pl011_create(0x1000b000, pic[14], serial_hds[2]);
|
pl011_create(0x1000b000, pic[14], serial_hd(2));
|
||||||
pl011_create(0x1000c000, pic[15], serial_hds[3]);
|
pl011_create(0x1000c000, pic[15], serial_hd(3));
|
||||||
|
|
||||||
/* DMA controller is optional, apparently. */
|
/* DMA controller is optional, apparently. */
|
||||||
sysbus_create_simple("pl081", 0x10030000, pic[24]);
|
sysbus_create_simple("pl081", 0x10030000, pic[24]);
|
||||||
|
@ -1353,7 +1353,7 @@ static void stellaris_init(MachineState *ms, stellaris_board_info *board)
|
|||||||
if (board->dc2 & (1 << i)) {
|
if (board->dc2 & (1 << i)) {
|
||||||
pl011_luminary_create(0x4000c000 + i * 0x1000,
|
pl011_luminary_create(0x4000c000 + i * 0x1000,
|
||||||
qdev_get_gpio_in(nvic, uart_irq[i]),
|
qdev_get_gpio_in(nvic, uart_irq[i]),
|
||||||
serial_hds[i]);
|
serial_hd(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (board->dc2 & (1 << 4)) {
|
if (board->dc2 & (1 << 4)) {
|
||||||
|
@ -136,7 +136,7 @@ static void stm32f205_soc_realize(DeviceState *dev_soc, Error **errp)
|
|||||||
for (i = 0; i < STM_NUM_USARTS; i++) {
|
for (i = 0; i < STM_NUM_USARTS; i++) {
|
||||||
dev = DEVICE(&(s->usart[i]));
|
dev = DEVICE(&(s->usart[i]));
|
||||||
qdev_prop_set_chr(dev, "chardev",
|
qdev_prop_set_chr(dev, "chardev",
|
||||||
i < MAX_SERIAL_PORTS ? serial_hds[i] : NULL);
|
i < MAX_SERIAL_PORTS ? serial_hd(i) : NULL);
|
||||||
object_property_set_bool(OBJECT(&s->usart[i]), true, "realized", &err);
|
object_property_set_bool(OBJECT(&s->usart[i]), true, "realized", &err);
|
||||||
if (err != NULL) {
|
if (err != NULL) {
|
||||||
error_propagate(errp, err);
|
error_propagate(errp, err);
|
||||||
|
@ -1622,7 +1622,7 @@ StrongARMState *sa1110_init(MemoryRegion *sysmem,
|
|||||||
|
|
||||||
for (i = 0; sa_serial[i].io_base; i++) {
|
for (i = 0; sa_serial[i].io_base; i++) {
|
||||||
DeviceState *dev = qdev_create(NULL, TYPE_STRONGARM_UART);
|
DeviceState *dev = qdev_create(NULL, TYPE_STRONGARM_UART);
|
||||||
qdev_prop_set_chr(dev, "chardev", serial_hds[i]);
|
qdev_prop_set_chr(dev, "chardev", serial_hd(i));
|
||||||
qdev_init_nofail(dev);
|
qdev_init_nofail(dev);
|
||||||
sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0,
|
sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0,
|
||||||
sa_serial[i].io_base);
|
sa_serial[i].io_base);
|
||||||
|
@ -283,10 +283,10 @@ static void versatile_init(MachineState *machine, int board_id)
|
|||||||
n--;
|
n--;
|
||||||
}
|
}
|
||||||
|
|
||||||
pl011_create(0x101f1000, pic[12], serial_hds[0]);
|
pl011_create(0x101f1000, pic[12], serial_hd(0));
|
||||||
pl011_create(0x101f2000, pic[13], serial_hds[1]);
|
pl011_create(0x101f2000, pic[13], serial_hd(1));
|
||||||
pl011_create(0x101f3000, pic[14], serial_hds[2]);
|
pl011_create(0x101f3000, pic[14], serial_hd(2));
|
||||||
pl011_create(0x10009000, sic[6], serial_hds[3]);
|
pl011_create(0x10009000, sic[6], serial_hd(3));
|
||||||
|
|
||||||
sysbus_create_simple("pl080", 0x10130000, pic[17]);
|
sysbus_create_simple("pl080", 0x10130000, pic[17]);
|
||||||
sysbus_create_simple("sp804", 0x101e2000, pic[4]);
|
sysbus_create_simple("sp804", 0x101e2000, pic[4]);
|
||||||
|
@ -622,10 +622,10 @@ static void vexpress_common_init(MachineState *machine)
|
|||||||
sysbus_create_simple("pl050_keyboard", map[VE_KMI0], pic[12]);
|
sysbus_create_simple("pl050_keyboard", map[VE_KMI0], pic[12]);
|
||||||
sysbus_create_simple("pl050_mouse", map[VE_KMI1], pic[13]);
|
sysbus_create_simple("pl050_mouse", map[VE_KMI1], pic[13]);
|
||||||
|
|
||||||
pl011_create(map[VE_UART0], pic[5], serial_hds[0]);
|
pl011_create(map[VE_UART0], pic[5], serial_hd(0));
|
||||||
pl011_create(map[VE_UART1], pic[6], serial_hds[1]);
|
pl011_create(map[VE_UART1], pic[6], serial_hd(1));
|
||||||
pl011_create(map[VE_UART2], pic[7], serial_hds[2]);
|
pl011_create(map[VE_UART2], pic[7], serial_hd(2));
|
||||||
pl011_create(map[VE_UART3], pic[8], serial_hds[3]);
|
pl011_create(map[VE_UART3], pic[8], serial_hd(3));
|
||||||
|
|
||||||
sysbus_create_simple("sp804", map[VE_TIMER01], pic[2]);
|
sysbus_create_simple("sp804", map[VE_TIMER01], pic[2]);
|
||||||
sysbus_create_simple("sp804", map[VE_TIMER23], pic[3]);
|
sysbus_create_simple("sp804", map[VE_TIMER23], pic[3]);
|
||||||
|
@ -1371,11 +1371,11 @@ static void machvirt_init(MachineState *machine)
|
|||||||
|
|
||||||
fdt_add_pmu_nodes(vms);
|
fdt_add_pmu_nodes(vms);
|
||||||
|
|
||||||
create_uart(vms, pic, VIRT_UART, sysmem, serial_hds[0]);
|
create_uart(vms, pic, VIRT_UART, sysmem, serial_hd(0));
|
||||||
|
|
||||||
if (vms->secure) {
|
if (vms->secure) {
|
||||||
create_secure_ram(vms, secure_sysmem);
|
create_secure_ram(vms, secure_sysmem);
|
||||||
create_uart(vms, pic, VIRT_SECURE_UART, secure_sysmem, serial_hds[1]);
|
create_uart(vms, pic, VIRT_SECURE_UART, secure_sysmem, serial_hd(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
create_rtc(vms, pic);
|
create_rtc(vms, pic);
|
||||||
|
@ -236,8 +236,8 @@ static void zynq_init(MachineState *machine)
|
|||||||
sysbus_create_simple("xlnx,ps7-usb", 0xE0002000, pic[53-IRQ_OFFSET]);
|
sysbus_create_simple("xlnx,ps7-usb", 0xE0002000, pic[53-IRQ_OFFSET]);
|
||||||
sysbus_create_simple("xlnx,ps7-usb", 0xE0003000, pic[76-IRQ_OFFSET]);
|
sysbus_create_simple("xlnx,ps7-usb", 0xE0003000, pic[76-IRQ_OFFSET]);
|
||||||
|
|
||||||
cadence_uart_create(0xE0000000, pic[59 - IRQ_OFFSET], serial_hds[0]);
|
cadence_uart_create(0xE0000000, pic[59 - IRQ_OFFSET], serial_hd(0));
|
||||||
cadence_uart_create(0xE0001000, pic[82 - IRQ_OFFSET], serial_hds[1]);
|
cadence_uart_create(0xE0001000, pic[82 - IRQ_OFFSET], serial_hd(1));
|
||||||
|
|
||||||
sysbus_create_varargs("cadence_ttc", 0xF8001000,
|
sysbus_create_varargs("cadence_ttc", 0xF8001000,
|
||||||
pic[42-IRQ_OFFSET], pic[43-IRQ_OFFSET], pic[44-IRQ_OFFSET], NULL);
|
pic[42-IRQ_OFFSET], pic[43-IRQ_OFFSET], pic[44-IRQ_OFFSET], NULL);
|
||||||
|
@ -374,7 +374,7 @@ static void xlnx_zynqmp_realize(DeviceState *dev, Error **errp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < XLNX_ZYNQMP_NUM_UARTS; i++) {
|
for (i = 0; i < XLNX_ZYNQMP_NUM_UARTS; i++) {
|
||||||
qdev_prop_set_chr(DEVICE(&s->uart[i]), "chardev", serial_hds[i]);
|
qdev_prop_set_chr(DEVICE(&s->uart[i]), "chardev", serial_hd(i));
|
||||||
object_property_set_bool(OBJECT(&s->uart[i]), true, "realized", &err);
|
object_property_set_bool(OBJECT(&s->uart[i]), true, "realized", &err);
|
||||||
if (err) {
|
if (err) {
|
||||||
error_propagate(errp, err);
|
error_propagate(errp, err);
|
||||||
|
@ -600,7 +600,7 @@ DeviceState *exynos4210_uart_create(hwaddr addr,
|
|||||||
MAX_SERIAL_PORTS);
|
MAX_SERIAL_PORTS);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
chr = serial_hds[channel];
|
chr = serial_hd(channel);
|
||||||
if (!chr) {
|
if (!chr) {
|
||||||
snprintf(label, ARRAY_SIZE(label), "%s%d", chr_name, channel);
|
snprintf(label, ARRAY_SIZE(label), "%s%d", chr_name, channel);
|
||||||
chr = qemu_chr_new(label, "null");
|
chr = qemu_chr_new(label, "null");
|
||||||
|
@ -141,8 +141,8 @@ void serial_hds_isa_init(ISABus *bus, int from, int to)
|
|||||||
assert(to <= MAX_SERIAL_PORTS);
|
assert(to <= MAX_SERIAL_PORTS);
|
||||||
|
|
||||||
for (i = from; i < to; ++i) {
|
for (i = from; i < to; ++i) {
|
||||||
if (serial_hds[i]) {
|
if (serial_hd(i)) {
|
||||||
serial_isa_init(bus, i, serial_hds[i]);
|
serial_isa_init(bus, i, serial_hd(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -201,7 +201,7 @@ static int con_init(struct XenDevice *xendev)
|
|||||||
/* no Xen override, use qemu output device */
|
/* no Xen override, use qemu output device */
|
||||||
if (output == NULL) {
|
if (output == NULL) {
|
||||||
if (con->xendev.dev) {
|
if (con->xendev.dev) {
|
||||||
qemu_chr_fe_init(&con->chr, serial_hds[con->xendev.dev],
|
qemu_chr_fe_init(&con->chr, serial_hd(con->xendev.dev),
|
||||||
&error_abort);
|
&error_abort);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -337,7 +337,7 @@ void axisdev88_init(MachineState *machine)
|
|||||||
sysbus_create_varargs("etraxfs,timer", 0x3005e000, irq[0x1b], nmi[1], NULL);
|
sysbus_create_varargs("etraxfs,timer", 0x3005e000, irq[0x1b], nmi[1], NULL);
|
||||||
|
|
||||||
for (i = 0; i < 4; i++) {
|
for (i = 0; i < 4; i++) {
|
||||||
etraxfs_ser_create(0x30026000 + i * 0x2000, irq[0x14 + i], serial_hds[i]);
|
etraxfs_ser_create(0x30026000 + i * 0x2000, irq[0x14 + i], serial_hd(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (kernel_filename) {
|
if (kernel_filename) {
|
||||||
|
@ -108,10 +108,10 @@ static void machine_hppa_init(MachineState *machine)
|
|||||||
mc146818_rtc_init(isa_bus, 2000, rtc_irq);
|
mc146818_rtc_init(isa_bus, 2000, rtc_irq);
|
||||||
|
|
||||||
/* Serial code setup. */
|
/* Serial code setup. */
|
||||||
if (serial_hds[0]) {
|
if (serial_hd(0)) {
|
||||||
uint32_t addr = DINO_UART_HPA + 0x800;
|
uint32_t addr = DINO_UART_HPA + 0x800;
|
||||||
serial_mm_init(addr_space, addr, 0, serial_irq,
|
serial_mm_init(addr_space, addr, 0, serial_irq,
|
||||||
115200, serial_hds[0], DEVICE_BIG_ENDIAN);
|
115200, serial_hd(0), DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* SCSI disk setup. */
|
/* SCSI disk setup. */
|
||||||
|
@ -81,8 +81,8 @@ static void isa_superio_realize(DeviceState *dev, Error **errp)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (!k->serial.is_enabled || k->serial.is_enabled(sio, i)) {
|
if (!k->serial.is_enabled || k->serial.is_enabled(sio, i)) {
|
||||||
/* FIXME use a qdev chardev prop instead of serial_hds[] */
|
/* FIXME use a qdev chardev prop instead of serial_hd() */
|
||||||
chr = serial_hds[i];
|
chr = serial_hd(i);
|
||||||
if (chr == NULL || chr->be) {
|
if (chr == NULL || chr->be) {
|
||||||
name = g_strdup_printf("discarding-serial%d", i);
|
name = g_strdup_printf("discarding-serial%d", i);
|
||||||
chr = qemu_chr_new(name, "null");
|
chr = qemu_chr_new(name, "null");
|
||||||
|
@ -125,12 +125,12 @@ static void lm32_evr_init(MachineState *machine)
|
|||||||
irq[i] = qdev_get_gpio_in(env->pic_state, i);
|
irq[i] = qdev_get_gpio_in(env->pic_state, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
lm32_uart_create(uart0_base, irq[uart0_irq], serial_hds[0]);
|
lm32_uart_create(uart0_base, irq[uart0_irq], serial_hd(0));
|
||||||
sysbus_create_simple("lm32-timer", timer0_base, irq[timer0_irq]);
|
sysbus_create_simple("lm32-timer", timer0_base, irq[timer0_irq]);
|
||||||
sysbus_create_simple("lm32-timer", timer1_base, irq[timer1_irq]);
|
sysbus_create_simple("lm32-timer", timer1_base, irq[timer1_irq]);
|
||||||
|
|
||||||
/* make sure juart isn't the first chardev */
|
/* make sure juart isn't the first chardev */
|
||||||
env->juart_state = lm32_juart_init(serial_hds[1]);
|
env->juart_state = lm32_juart_init(serial_hd(1));
|
||||||
|
|
||||||
reset_info->bootstrap_pc = flash_base;
|
reset_info->bootstrap_pc = flash_base;
|
||||||
|
|
||||||
@ -217,13 +217,13 @@ static void lm32_uclinux_init(MachineState *machine)
|
|||||||
irq[i] = qdev_get_gpio_in(env->pic_state, i);
|
irq[i] = qdev_get_gpio_in(env->pic_state, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
lm32_uart_create(uart0_base, irq[uart0_irq], serial_hds[0]);
|
lm32_uart_create(uart0_base, irq[uart0_irq], serial_hd(0));
|
||||||
sysbus_create_simple("lm32-timer", timer0_base, irq[timer0_irq]);
|
sysbus_create_simple("lm32-timer", timer0_base, irq[timer0_irq]);
|
||||||
sysbus_create_simple("lm32-timer", timer1_base, irq[timer1_irq]);
|
sysbus_create_simple("lm32-timer", timer1_base, irq[timer1_irq]);
|
||||||
sysbus_create_simple("lm32-timer", timer2_base, irq[timer2_irq]);
|
sysbus_create_simple("lm32-timer", timer2_base, irq[timer2_irq]);
|
||||||
|
|
||||||
/* make sure juart isn't the first chardev */
|
/* make sure juart isn't the first chardev */
|
||||||
env->juart_state = lm32_juart_init(serial_hds[1]);
|
env->juart_state = lm32_juart_init(serial_hd(1));
|
||||||
|
|
||||||
reset_info->bootstrap_pc = flash_base;
|
reset_info->bootstrap_pc = flash_base;
|
||||||
|
|
||||||
|
@ -151,7 +151,7 @@ milkymist_init(MachineState *machine)
|
|||||||
}
|
}
|
||||||
g_free(bios_filename);
|
g_free(bios_filename);
|
||||||
|
|
||||||
milkymist_uart_create(0x60000000, irq[0], serial_hds[0]);
|
milkymist_uart_create(0x60000000, irq[0], serial_hd(0));
|
||||||
milkymist_sysctl_create(0x60001000, irq[1], irq[2], irq[3],
|
milkymist_sysctl_create(0x60001000, irq[1], irq[2], irq[3],
|
||||||
80000000, 0x10014d31, 0x0000041f, 0x00000001);
|
80000000, 0x10014d31, 0x0000041f, 0x00000001);
|
||||||
milkymist_hpdmc_create(0x60002000);
|
milkymist_hpdmc_create(0x60002000);
|
||||||
@ -167,7 +167,7 @@ milkymist_init(MachineState *machine)
|
|||||||
0x20000000, 0x1000, 0x20020000, 0x2000);
|
0x20000000, 0x1000, 0x20020000, 0x2000);
|
||||||
|
|
||||||
/* make sure juart isn't the first chardev */
|
/* make sure juart isn't the first chardev */
|
||||||
env->juart_state = lm32_juart_init(serial_hds[1]);
|
env->juart_state = lm32_juart_init(serial_hd(1));
|
||||||
|
|
||||||
if (kernel_filename) {
|
if (kernel_filename) {
|
||||||
uint64_t entry;
|
uint64_t entry;
|
||||||
|
@ -543,8 +543,8 @@ qemu_irq *mcf5206_init(MemoryRegion *sysmem, uint32_t base, M68kCPU *cpu)
|
|||||||
pic = qemu_allocate_irqs(m5206_mbar_set_irq, s, 14);
|
pic = qemu_allocate_irqs(m5206_mbar_set_irq, s, 14);
|
||||||
s->timer[0] = m5206_timer_init(pic[9]);
|
s->timer[0] = m5206_timer_init(pic[9]);
|
||||||
s->timer[1] = m5206_timer_init(pic[10]);
|
s->timer[1] = m5206_timer_init(pic[10]);
|
||||||
s->uart[0] = mcf_uart_init(pic[12], serial_hds[0]);
|
s->uart[0] = mcf_uart_init(pic[12], serial_hd(0));
|
||||||
s->uart[1] = mcf_uart_init(pic[13], serial_hds[1]);
|
s->uart[1] = mcf_uart_init(pic[13], serial_hd(1));
|
||||||
s->cpu = cpu;
|
s->cpu = cpu;
|
||||||
|
|
||||||
m5206_mbar_reset(s);
|
m5206_mbar_reset(s);
|
||||||
|
@ -247,9 +247,9 @@ static void mcf5208evb_init(MachineState *machine)
|
|||||||
/* Internal peripherals. */
|
/* Internal peripherals. */
|
||||||
pic = mcf_intc_init(address_space_mem, 0xfc048000, cpu);
|
pic = mcf_intc_init(address_space_mem, 0xfc048000, cpu);
|
||||||
|
|
||||||
mcf_uart_mm_init(0xfc060000, pic[26], serial_hds[0]);
|
mcf_uart_mm_init(0xfc060000, pic[26], serial_hd(0));
|
||||||
mcf_uart_mm_init(0xfc064000, pic[27], serial_hds[1]);
|
mcf_uart_mm_init(0xfc064000, pic[27], serial_hd(1));
|
||||||
mcf_uart_mm_init(0xfc068000, pic[28], serial_hds[2]);
|
mcf_uart_mm_init(0xfc068000, pic[28], serial_hd(2));
|
||||||
|
|
||||||
mcf5208_sys_init(address_space_mem, pic);
|
mcf5208_sys_init(address_space_mem, pic);
|
||||||
|
|
||||||
|
@ -125,7 +125,7 @@ petalogix_ml605_init(MachineState *machine)
|
|||||||
}
|
}
|
||||||
|
|
||||||
serial_mm_init(address_space_mem, UART16550_BASEADDR + 0x1000, 2,
|
serial_mm_init(address_space_mem, UART16550_BASEADDR + 0x1000, 2,
|
||||||
irq[UART16550_IRQ], 115200, serial_hds[0],
|
irq[UART16550_IRQ], 115200, serial_hd(0),
|
||||||
DEVICE_LITTLE_ENDIAN);
|
DEVICE_LITTLE_ENDIAN);
|
||||||
|
|
||||||
/* 2 timers at irq 2 @ 100 Mhz. */
|
/* 2 timers at irq 2 @ 100 Mhz. */
|
||||||
|
@ -103,7 +103,7 @@ petalogix_s3adsp1800_init(MachineState *machine)
|
|||||||
}
|
}
|
||||||
|
|
||||||
xilinx_uartlite_create(UARTLITE_BASEADDR, irq[UARTLITE_IRQ],
|
xilinx_uartlite_create(UARTLITE_BASEADDR, irq[UARTLITE_IRQ],
|
||||||
serial_hds[0]);
|
serial_hd(0));
|
||||||
|
|
||||||
/* 2 timers at irq 2 @ 62 Mhz. */
|
/* 2 timers at irq 2 @ 62 Mhz. */
|
||||||
dev = qdev_create(NULL, "xlnx.xps-timer");
|
dev = qdev_create(NULL, "xlnx.xps-timer");
|
||||||
|
@ -507,7 +507,7 @@ static void boston_mach_init(MachineState *machine)
|
|||||||
|
|
||||||
s->uart = serial_mm_init(sys_mem, 0x17ffe000, 2,
|
s->uart = serial_mm_init(sys_mem, 0x17ffe000, 2,
|
||||||
get_cps_irq(s->cps, 3), 10000000,
|
get_cps_irq(s->cps, 3), 10000000,
|
||||||
serial_hds[0], DEVICE_NATIVE_ENDIAN);
|
serial_hd(0), DEVICE_NATIVE_ENDIAN);
|
||||||
|
|
||||||
lcd = g_new(MemoryRegion, 1);
|
lcd = g_new(MemoryRegion, 1);
|
||||||
memory_region_init_io(lcd, NULL, &boston_lcd_ops, s, "boston-lcd", 0x8);
|
memory_region_init_io(lcd, NULL, &boston_lcd_ops, s, "boston-lcd", 0x8);
|
||||||
|
@ -303,15 +303,15 @@ static void mips_jazz_init(MachineState *machine,
|
|||||||
memory_region_add_subregion(address_space, 0x80005000, i8042);
|
memory_region_add_subregion(address_space, 0x80005000, i8042);
|
||||||
|
|
||||||
/* Serial ports */
|
/* Serial ports */
|
||||||
if (serial_hds[0]) {
|
if (serial_hd(0)) {
|
||||||
serial_mm_init(address_space, 0x80006000, 0,
|
serial_mm_init(address_space, 0x80006000, 0,
|
||||||
qdev_get_gpio_in(rc4030, 8), 8000000/16,
|
qdev_get_gpio_in(rc4030, 8), 8000000/16,
|
||||||
serial_hds[0], DEVICE_NATIVE_ENDIAN);
|
serial_hd(0), DEVICE_NATIVE_ENDIAN);
|
||||||
}
|
}
|
||||||
if (serial_hds[1]) {
|
if (serial_hd(1)) {
|
||||||
serial_mm_init(address_space, 0x80007000, 0,
|
serial_mm_init(address_space, 0x80007000, 0,
|
||||||
qdev_get_gpio_in(rc4030, 9), 8000000/16,
|
qdev_get_gpio_in(rc4030, 9), 8000000/16,
|
||||||
serial_hds[1], DEVICE_NATIVE_ENDIAN);
|
serial_hd(1), DEVICE_NATIVE_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Parallel port */
|
/* Parallel port */
|
||||||
|
@ -1057,7 +1057,7 @@ void mips_malta_init(MachineState *machine)
|
|||||||
/* FPGA */
|
/* FPGA */
|
||||||
|
|
||||||
/* The CBUS UART is attached to the MIPS CPU INT2 pin, ie interrupt 4 */
|
/* The CBUS UART is attached to the MIPS CPU INT2 pin, ie interrupt 4 */
|
||||||
malta_fpga_init(system_memory, FPGA_ADDRESS, cbus_irq, serial_hds[2]);
|
malta_fpga_init(system_memory, FPGA_ADDRESS, cbus_irq, serial_hd(2));
|
||||||
|
|
||||||
/* Load firmware in flash / BIOS. */
|
/* Load firmware in flash / BIOS. */
|
||||||
dinfo = drive_get(IF_PFLASH, 0, fl_idx);
|
dinfo = drive_get(IF_PFLASH, 0, fl_idx);
|
||||||
|
@ -213,8 +213,8 @@ mips_mipssim_init(MachineState *machine)
|
|||||||
|
|
||||||
/* A single 16450 sits at offset 0x3f8. It is attached to
|
/* A single 16450 sits at offset 0x3f8. It is attached to
|
||||||
MIPS CPU INT2, which is interrupt 4. */
|
MIPS CPU INT2, which is interrupt 4. */
|
||||||
if (serial_hds[0])
|
if (serial_hd(0))
|
||||||
serial_init(0x3f8, env->irq[4], 115200, serial_hds[0],
|
serial_init(0x3f8, env->irq[4], 115200, serial_hd(0),
|
||||||
get_system_io());
|
get_system_io());
|
||||||
|
|
||||||
if (nd_table[0].used)
|
if (nd_table[0].used)
|
||||||
|
@ -118,8 +118,8 @@ static void macio_common_realize(PCIDevice *d, Error **errp)
|
|||||||
qdev_prop_set_uint32(DEVICE(&s->escc), "disabled", 0);
|
qdev_prop_set_uint32(DEVICE(&s->escc), "disabled", 0);
|
||||||
qdev_prop_set_uint32(DEVICE(&s->escc), "frequency", ESCC_CLOCK);
|
qdev_prop_set_uint32(DEVICE(&s->escc), "frequency", ESCC_CLOCK);
|
||||||
qdev_prop_set_uint32(DEVICE(&s->escc), "it_shift", 4);
|
qdev_prop_set_uint32(DEVICE(&s->escc), "it_shift", 4);
|
||||||
qdev_prop_set_chr(DEVICE(&s->escc), "chrA", serial_hds[0]);
|
qdev_prop_set_chr(DEVICE(&s->escc), "chrA", serial_hd(0));
|
||||||
qdev_prop_set_chr(DEVICE(&s->escc), "chrB", serial_hds[1]);
|
qdev_prop_set_chr(DEVICE(&s->escc), "chrB", serial_hd(1));
|
||||||
qdev_prop_set_uint32(DEVICE(&s->escc), "chnBtype", escc_serial);
|
qdev_prop_set_uint32(DEVICE(&s->escc), "chnBtype", escc_serial);
|
||||||
qdev_prop_set_uint32(DEVICE(&s->escc), "chnAtype", escc_serial);
|
qdev_prop_set_uint32(DEVICE(&s->escc), "chnAtype", escc_serial);
|
||||||
object_property_set_bool(OBJECT(&s->escc), true, "realized", &err);
|
object_property_set_bool(OBJECT(&s->escc), true, "realized", &err);
|
||||||
|
@ -141,9 +141,9 @@ static void moxiesim_init(MachineState *machine)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* A single 16450 sits at offset 0x3f8. */
|
/* A single 16450 sits at offset 0x3f8. */
|
||||||
if (serial_hds[0]) {
|
if (serial_hd(0)) {
|
||||||
serial_mm_init(address_space_mem, 0x3f8, 0, env->irq[4],
|
serial_mm_init(address_space_mem, 0x3f8, 0, env->irq[4],
|
||||||
8000000/16, serial_hds[0], DEVICE_LITTLE_ENDIAN);
|
8000000/16, serial_hd(0), DEVICE_LITTLE_ENDIAN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -92,7 +92,7 @@ static void nios2_10m50_ghrd_init(MachineState *machine)
|
|||||||
|
|
||||||
/* Register: Altera 16550 UART */
|
/* Register: Altera 16550 UART */
|
||||||
serial_mm_init(address_space_mem, 0xf8001600, 2, irq[1], 115200,
|
serial_mm_init(address_space_mem, 0xf8001600, 2, irq[1], 115200,
|
||||||
serial_hds[0], DEVICE_NATIVE_ENDIAN);
|
serial_hd(0), DEVICE_NATIVE_ENDIAN);
|
||||||
|
|
||||||
/* Register: Timer sys_clk_timer */
|
/* Register: Timer sys_clk_timer */
|
||||||
dev = qdev_create(NULL, "ALTR.timer");
|
dev = qdev_create(NULL, "ALTR.timer");
|
||||||
|
@ -164,7 +164,7 @@ static void openrisc_sim_init(MachineState *machine)
|
|||||||
}
|
}
|
||||||
|
|
||||||
serial_mm_init(get_system_memory(), 0x90000000, 0, serial_irq,
|
serial_mm_init(get_system_memory(), 0x90000000, 0, serial_irq,
|
||||||
115200, serial_hds[0], DEVICE_NATIVE_ENDIAN);
|
115200, serial_hd(0), DEVICE_NATIVE_ENDIAN);
|
||||||
|
|
||||||
openrisc_load_kernel(ram_size, kernel_filename);
|
openrisc_load_kernel(ram_size, kernel_filename);
|
||||||
}
|
}
|
||||||
|
@ -456,12 +456,12 @@ static int ppce500_load_device_tree(MachineState *machine,
|
|||||||
* device it finds in the dt as serial output device. And we generate
|
* device it finds in the dt as serial output device. And we generate
|
||||||
* devices in reverse order to the dt.
|
* devices in reverse order to the dt.
|
||||||
*/
|
*/
|
||||||
if (serial_hds[1]) {
|
if (serial_hd(1)) {
|
||||||
dt_serial_create(fdt, MPC8544_SERIAL1_REGS_OFFSET,
|
dt_serial_create(fdt, MPC8544_SERIAL1_REGS_OFFSET,
|
||||||
soc, mpic, "serial1", 1, false);
|
soc, mpic, "serial1", 1, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (serial_hds[0]) {
|
if (serial_hd(0)) {
|
||||||
dt_serial_create(fdt, MPC8544_SERIAL0_REGS_OFFSET,
|
dt_serial_create(fdt, MPC8544_SERIAL0_REGS_OFFSET,
|
||||||
soc, mpic, "serial0", 0, true);
|
soc, mpic, "serial0", 0, true);
|
||||||
}
|
}
|
||||||
@ -875,16 +875,16 @@ void ppce500_init(MachineState *machine, PPCE500Params *params)
|
|||||||
mpicdev = ppce500_init_mpic(machine, params, ccsr_addr_space, irqs);
|
mpicdev = ppce500_init_mpic(machine, params, ccsr_addr_space, irqs);
|
||||||
|
|
||||||
/* Serial */
|
/* Serial */
|
||||||
if (serial_hds[0]) {
|
if (serial_hd(0)) {
|
||||||
serial_mm_init(ccsr_addr_space, MPC8544_SERIAL0_REGS_OFFSET,
|
serial_mm_init(ccsr_addr_space, MPC8544_SERIAL0_REGS_OFFSET,
|
||||||
0, qdev_get_gpio_in(mpicdev, 42), 399193,
|
0, qdev_get_gpio_in(mpicdev, 42), 399193,
|
||||||
serial_hds[0], DEVICE_BIG_ENDIAN);
|
serial_hd(0), DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (serial_hds[1]) {
|
if (serial_hd(1)) {
|
||||||
serial_mm_init(ccsr_addr_space, MPC8544_SERIAL1_REGS_OFFSET,
|
serial_mm_init(ccsr_addr_space, MPC8544_SERIAL1_REGS_OFFSET,
|
||||||
0, qdev_get_gpio_in(mpicdev, 42), 399193,
|
0, qdev_get_gpio_in(mpicdev, 42), 399193,
|
||||||
serial_hds[1], DEVICE_BIG_ENDIAN);
|
serial_hd(1), DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* General Utility device */
|
/* General Utility device */
|
||||||
|
@ -1660,14 +1660,14 @@ CPUPPCState *ppc405cr_init(MemoryRegion *address_space_mem,
|
|||||||
dma_irqs[3] = pic[23];
|
dma_irqs[3] = pic[23];
|
||||||
ppc405_dma_init(env, dma_irqs);
|
ppc405_dma_init(env, dma_irqs);
|
||||||
/* Serial ports */
|
/* Serial ports */
|
||||||
if (serial_hds[0] != NULL) {
|
if (serial_hd(0) != NULL) {
|
||||||
serial_mm_init(address_space_mem, 0xef600300, 0, pic[0],
|
serial_mm_init(address_space_mem, 0xef600300, 0, pic[0],
|
||||||
PPC_SERIAL_MM_BAUDBASE, serial_hds[0],
|
PPC_SERIAL_MM_BAUDBASE, serial_hd(0),
|
||||||
DEVICE_BIG_ENDIAN);
|
DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
if (serial_hds[1] != NULL) {
|
if (serial_hd(1) != NULL) {
|
||||||
serial_mm_init(address_space_mem, 0xef600400, 0, pic[1],
|
serial_mm_init(address_space_mem, 0xef600400, 0, pic[1],
|
||||||
PPC_SERIAL_MM_BAUDBASE, serial_hds[1],
|
PPC_SERIAL_MM_BAUDBASE, serial_hd(1),
|
||||||
DEVICE_BIG_ENDIAN);
|
DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
/* IIC controller */
|
/* IIC controller */
|
||||||
@ -2023,14 +2023,14 @@ CPUPPCState *ppc405ep_init(MemoryRegion *address_space_mem,
|
|||||||
/* GPIO */
|
/* GPIO */
|
||||||
ppc405_gpio_init(0xef600700);
|
ppc405_gpio_init(0xef600700);
|
||||||
/* Serial ports */
|
/* Serial ports */
|
||||||
if (serial_hds[0] != NULL) {
|
if (serial_hd(0) != NULL) {
|
||||||
serial_mm_init(address_space_mem, 0xef600300, 0, pic[0],
|
serial_mm_init(address_space_mem, 0xef600300, 0, pic[0],
|
||||||
PPC_SERIAL_MM_BAUDBASE, serial_hds[0],
|
PPC_SERIAL_MM_BAUDBASE, serial_hd(0),
|
||||||
DEVICE_BIG_ENDIAN);
|
DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
if (serial_hds[1] != NULL) {
|
if (serial_hd(1) != NULL) {
|
||||||
serial_mm_init(address_space_mem, 0xef600400, 0, pic[1],
|
serial_mm_init(address_space_mem, 0xef600400, 0, pic[1],
|
||||||
PPC_SERIAL_MM_BAUDBASE, serial_hds[1],
|
PPC_SERIAL_MM_BAUDBASE, serial_hd(1),
|
||||||
DEVICE_BIG_ENDIAN);
|
DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
/* OCM */
|
/* OCM */
|
||||||
|
@ -238,14 +238,14 @@ static void bamboo_init(MachineState *machine)
|
|||||||
get_system_io(), 0, PPC440EP_PCI_IOLEN);
|
get_system_io(), 0, PPC440EP_PCI_IOLEN);
|
||||||
memory_region_add_subregion(get_system_memory(), PPC440EP_PCI_IO, isa);
|
memory_region_add_subregion(get_system_memory(), PPC440EP_PCI_IO, isa);
|
||||||
|
|
||||||
if (serial_hds[0] != NULL) {
|
if (serial_hd(0) != NULL) {
|
||||||
serial_mm_init(address_space_mem, 0xef600300, 0, pic[0],
|
serial_mm_init(address_space_mem, 0xef600300, 0, pic[0],
|
||||||
PPC_SERIAL_MM_BAUDBASE, serial_hds[0],
|
PPC_SERIAL_MM_BAUDBASE, serial_hd(0),
|
||||||
DEVICE_BIG_ENDIAN);
|
DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
if (serial_hds[1] != NULL) {
|
if (serial_hd(1) != NULL) {
|
||||||
serial_mm_init(address_space_mem, 0xef600400, 0, pic[1],
|
serial_mm_init(address_space_mem, 0xef600400, 0, pic[1],
|
||||||
PPC_SERIAL_MM_BAUDBASE, serial_hds[1],
|
PPC_SERIAL_MM_BAUDBASE, serial_hd(1),
|
||||||
DEVICE_BIG_ENDIAN);
|
DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -522,14 +522,14 @@ static void sam460ex_init(MachineState *machine)
|
|||||||
|
|
||||||
/* SoC has 4 UARTs
|
/* SoC has 4 UARTs
|
||||||
* but board has only one wired and two are present in fdt */
|
* but board has only one wired and two are present in fdt */
|
||||||
if (serial_hds[0] != NULL) {
|
if (serial_hd(0) != NULL) {
|
||||||
serial_mm_init(address_space_mem, 0x4ef600300, 0, uic[1][1],
|
serial_mm_init(address_space_mem, 0x4ef600300, 0, uic[1][1],
|
||||||
PPC_SERIAL_MM_BAUDBASE, serial_hds[0],
|
PPC_SERIAL_MM_BAUDBASE, serial_hd(0),
|
||||||
DEVICE_BIG_ENDIAN);
|
DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
if (serial_hds[1] != NULL) {
|
if (serial_hd(1) != NULL) {
|
||||||
serial_mm_init(address_space_mem, 0x4ef600400, 0, uic[0][1],
|
serial_mm_init(address_space_mem, 0x4ef600400, 0, uic[0][1],
|
||||||
PPC_SERIAL_MM_BAUDBASE, serial_hds[1],
|
PPC_SERIAL_MM_BAUDBASE, serial_hd(1),
|
||||||
DEVICE_BIG_ENDIAN);
|
DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2590,8 +2590,8 @@ static void spapr_machine_init(MachineState *machine)
|
|||||||
spapr->vio_bus = spapr_vio_bus_init();
|
spapr->vio_bus = spapr_vio_bus_init();
|
||||||
|
|
||||||
for (i = 0; i < MAX_SERIAL_PORTS; i++) {
|
for (i = 0; i < MAX_SERIAL_PORTS; i++) {
|
||||||
if (serial_hds[i]) {
|
if (serial_hd(i)) {
|
||||||
spapr_vty_create(spapr->vio_bus, serial_hds[i]);
|
spapr_vty_create(spapr->vio_bus, serial_hd(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -251,7 +251,7 @@ static void virtex_init(MachineState *machine)
|
|||||||
}
|
}
|
||||||
|
|
||||||
serial_mm_init(address_space_mem, UART16550_BASEADDR, 2, irq[UART16550_IRQ],
|
serial_mm_init(address_space_mem, UART16550_BASEADDR, 2, irq[UART16550_IRQ],
|
||||||
115200, serial_hds[0], DEVICE_LITTLE_ENDIAN);
|
115200, serial_hd(0), DEVICE_LITTLE_ENDIAN);
|
||||||
|
|
||||||
/* 2 timers at irq 2 @ 62 Mhz. */
|
/* 2 timers at irq 2 @ 62 Mhz. */
|
||||||
dev = qdev_create(NULL, "xlnx.xps-timer");
|
dev = qdev_create(NULL, "xlnx.xps-timer");
|
||||||
|
@ -162,13 +162,13 @@ static void riscv_sifive_e_init(MachineState *machine)
|
|||||||
sifive_mmio_emulate(sys_mem, "riscv.sifive.e.gpio0",
|
sifive_mmio_emulate(sys_mem, "riscv.sifive.e.gpio0",
|
||||||
memmap[SIFIVE_E_GPIO0].base, memmap[SIFIVE_E_GPIO0].size);
|
memmap[SIFIVE_E_GPIO0].base, memmap[SIFIVE_E_GPIO0].size);
|
||||||
sifive_uart_create(sys_mem, memmap[SIFIVE_E_UART0].base,
|
sifive_uart_create(sys_mem, memmap[SIFIVE_E_UART0].base,
|
||||||
serial_hds[0], SIFIVE_PLIC(s->plic)->irqs[SIFIVE_E_UART0_IRQ]);
|
serial_hd(0), SIFIVE_PLIC(s->plic)->irqs[SIFIVE_E_UART0_IRQ]);
|
||||||
sifive_mmio_emulate(sys_mem, "riscv.sifive.e.qspi0",
|
sifive_mmio_emulate(sys_mem, "riscv.sifive.e.qspi0",
|
||||||
memmap[SIFIVE_E_QSPI0].base, memmap[SIFIVE_E_QSPI0].size);
|
memmap[SIFIVE_E_QSPI0].base, memmap[SIFIVE_E_QSPI0].size);
|
||||||
sifive_mmio_emulate(sys_mem, "riscv.sifive.e.pwm0",
|
sifive_mmio_emulate(sys_mem, "riscv.sifive.e.pwm0",
|
||||||
memmap[SIFIVE_E_PWM0].base, memmap[SIFIVE_E_PWM0].size);
|
memmap[SIFIVE_E_PWM0].base, memmap[SIFIVE_E_PWM0].size);
|
||||||
/* sifive_uart_create(sys_mem, memmap[SIFIVE_E_UART1].base,
|
/* sifive_uart_create(sys_mem, memmap[SIFIVE_E_UART1].base,
|
||||||
serial_hds[1], SIFIVE_PLIC(s->plic)->irqs[SIFIVE_E_UART1_IRQ]); */
|
serial_hd(1), SIFIVE_PLIC(s->plic)->irqs[SIFIVE_E_UART1_IRQ]); */
|
||||||
sifive_mmio_emulate(sys_mem, "riscv.sifive.e.qspi1",
|
sifive_mmio_emulate(sys_mem, "riscv.sifive.e.qspi1",
|
||||||
memmap[SIFIVE_E_QSPI1].base, memmap[SIFIVE_E_QSPI1].size);
|
memmap[SIFIVE_E_QSPI1].base, memmap[SIFIVE_E_QSPI1].size);
|
||||||
sifive_mmio_emulate(sys_mem, "riscv.sifive.e.pwm1",
|
sifive_mmio_emulate(sys_mem, "riscv.sifive.e.pwm1",
|
||||||
|
@ -296,9 +296,9 @@ static void riscv_sifive_u_init(MachineState *machine)
|
|||||||
SIFIVE_U_PLIC_CONTEXT_STRIDE,
|
SIFIVE_U_PLIC_CONTEXT_STRIDE,
|
||||||
memmap[SIFIVE_U_PLIC].size);
|
memmap[SIFIVE_U_PLIC].size);
|
||||||
sifive_uart_create(sys_memory, memmap[SIFIVE_U_UART0].base,
|
sifive_uart_create(sys_memory, memmap[SIFIVE_U_UART0].base,
|
||||||
serial_hds[0], SIFIVE_PLIC(s->plic)->irqs[SIFIVE_U_UART0_IRQ]);
|
serial_hd(0), SIFIVE_PLIC(s->plic)->irqs[SIFIVE_U_UART0_IRQ]);
|
||||||
/* sifive_uart_create(sys_memory, memmap[SIFIVE_U_UART1].base,
|
/* sifive_uart_create(sys_memory, memmap[SIFIVE_U_UART1].base,
|
||||||
serial_hds[1], SIFIVE_PLIC(s->plic)->irqs[SIFIVE_U_UART1_IRQ]); */
|
serial_hd(1), SIFIVE_PLIC(s->plic)->irqs[SIFIVE_U_UART1_IRQ]); */
|
||||||
sifive_clint_create(memmap[SIFIVE_U_CLINT].base,
|
sifive_clint_create(memmap[SIFIVE_U_CLINT].base,
|
||||||
memmap[SIFIVE_U_CLINT].size, smp_cpus,
|
memmap[SIFIVE_U_CLINT].size, smp_cpus,
|
||||||
SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE);
|
SIFIVE_SIP_BASE, SIFIVE_TIMECMP_BASE, SIFIVE_TIME_BASE);
|
||||||
|
@ -233,7 +233,7 @@ static void spike_v1_10_0_board_init(MachineState *machine)
|
|||||||
s->fdt, s->fdt_size);
|
s->fdt, s->fdt_size);
|
||||||
|
|
||||||
/* initialize HTIF using symbols found in load_kernel */
|
/* initialize HTIF using symbols found in load_kernel */
|
||||||
htif_mm_init(system_memory, boot_rom, &s->soc.harts[0].env, serial_hds[0]);
|
htif_mm_init(system_memory, boot_rom, &s->soc.harts[0].env, serial_hd(0));
|
||||||
|
|
||||||
/* Core Local Interruptor (timer and IPI) */
|
/* Core Local Interruptor (timer and IPI) */
|
||||||
sifive_clint_create(memmap[SPIKE_CLINT].base, memmap[SPIKE_CLINT].size,
|
sifive_clint_create(memmap[SPIKE_CLINT].base, memmap[SPIKE_CLINT].size,
|
||||||
@ -330,7 +330,7 @@ static void spike_v1_09_1_board_init(MachineState *machine)
|
|||||||
config_string, config_string_len);
|
config_string, config_string_len);
|
||||||
|
|
||||||
/* initialize HTIF using symbols found in load_kernel */
|
/* initialize HTIF using symbols found in load_kernel */
|
||||||
htif_mm_init(system_memory, boot_rom, &s->soc.harts[0].env, serial_hds[0]);
|
htif_mm_init(system_memory, boot_rom, &s->soc.harts[0].env, serial_hd(0));
|
||||||
|
|
||||||
/* Core Local Interruptor (timer and IPI) */
|
/* Core Local Interruptor (timer and IPI) */
|
||||||
sifive_clint_create(memmap[SPIKE_CLINT].base, memmap[SPIKE_CLINT].size,
|
sifive_clint_create(memmap[SPIKE_CLINT].base, memmap[SPIKE_CLINT].size,
|
||||||
|
@ -382,7 +382,7 @@ static void riscv_virt_board_init(MachineState *machine)
|
|||||||
|
|
||||||
serial_mm_init(system_memory, memmap[VIRT_UART0].base,
|
serial_mm_init(system_memory, memmap[VIRT_UART0].base,
|
||||||
0, SIFIVE_PLIC(s->plic)->irqs[UART0_IRQ], 399193,
|
0, SIFIVE_PLIC(s->plic)->irqs[UART0_IRQ], 399193,
|
||||||
serial_hds[0], DEVICE_LITTLE_ENDIAN);
|
serial_hd(0), DEVICE_LITTLE_ENDIAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int riscv_virt_board_sysbus_device_init(SysBusDevice *sysbusdev)
|
static int riscv_virt_board_sysbus_device_init(SysBusDevice *sysbusdev)
|
||||||
|
@ -271,7 +271,7 @@ static void r2d_init(MachineState *machine)
|
|||||||
busdev = SYS_BUS_DEVICE(dev);
|
busdev = SYS_BUS_DEVICE(dev);
|
||||||
qdev_prop_set_uint32(dev, "vram-size", SM501_VRAM_SIZE);
|
qdev_prop_set_uint32(dev, "vram-size", SM501_VRAM_SIZE);
|
||||||
qdev_prop_set_uint32(dev, "base", 0x10000000);
|
qdev_prop_set_uint32(dev, "base", 0x10000000);
|
||||||
qdev_prop_set_ptr(dev, "chr-state", serial_hds[2]);
|
qdev_prop_set_ptr(dev, "chr-state", serial_hd(2));
|
||||||
qdev_init_nofail(dev);
|
qdev_init_nofail(dev);
|
||||||
sysbus_mmio_map(busdev, 0, 0x10000000);
|
sysbus_mmio_map(busdev, 0, 0x10000000);
|
||||||
sysbus_mmio_map(busdev, 1, 0x13e00000);
|
sysbus_mmio_map(busdev, 1, 0x13e00000);
|
||||||
|
@ -773,7 +773,7 @@ SH7750State *sh7750_init(SuperHCPU *cpu, MemoryRegion *sysmem)
|
|||||||
cpu->env.intc_handle = &s->intc;
|
cpu->env.intc_handle = &s->intc;
|
||||||
|
|
||||||
sh_serial_init(sysmem, 0x1fe00000,
|
sh_serial_init(sysmem, 0x1fe00000,
|
||||||
0, s->periph_freq, serial_hds[0],
|
0, s->periph_freq, serial_hd(0),
|
||||||
s->intc.irqs[SCI1_ERI],
|
s->intc.irqs[SCI1_ERI],
|
||||||
s->intc.irqs[SCI1_RXI],
|
s->intc.irqs[SCI1_RXI],
|
||||||
s->intc.irqs[SCI1_TXI],
|
s->intc.irqs[SCI1_TXI],
|
||||||
@ -781,7 +781,7 @@ SH7750State *sh7750_init(SuperHCPU *cpu, MemoryRegion *sysmem)
|
|||||||
NULL);
|
NULL);
|
||||||
sh_serial_init(sysmem, 0x1fe80000,
|
sh_serial_init(sysmem, 0x1fe80000,
|
||||||
SH_SERIAL_FEAT_SCIF,
|
SH_SERIAL_FEAT_SCIF,
|
||||||
s->periph_freq, serial_hds[1],
|
s->periph_freq, serial_hd(1),
|
||||||
s->intc.irqs[SCIF_ERI],
|
s->intc.irqs[SCIF_ERI],
|
||||||
s->intc.irqs[SCIF_RXI],
|
s->intc.irqs[SCIF_RXI],
|
||||||
s->intc.irqs[SCIF_TXI],
|
s->intc.irqs[SCIF_TXI],
|
||||||
|
@ -206,8 +206,8 @@ static void leon3_generic_hw_init(MachineState *machine)
|
|||||||
grlib_gptimer_create(0x80000300, 2, CPU_CLK, cpu_irqs, 6);
|
grlib_gptimer_create(0x80000300, 2, CPU_CLK, cpu_irqs, 6);
|
||||||
|
|
||||||
/* Allocate uart */
|
/* Allocate uart */
|
||||||
if (serial_hds[0]) {
|
if (serial_hd(0)) {
|
||||||
grlib_apbuart_create(0x80000100, serial_hds[0], cpu_irqs[3]);
|
grlib_apbuart_create(0x80000100, serial_hd(0), cpu_irqs[3]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -943,8 +943,8 @@ static void sun4m_hw_init(const struct sun4m_hwdef *hwdef,
|
|||||||
qdev_prop_set_uint32(dev, "disabled", 0);
|
qdev_prop_set_uint32(dev, "disabled", 0);
|
||||||
qdev_prop_set_uint32(dev, "frequency", ESCC_CLOCK);
|
qdev_prop_set_uint32(dev, "frequency", ESCC_CLOCK);
|
||||||
qdev_prop_set_uint32(dev, "it_shift", 1);
|
qdev_prop_set_uint32(dev, "it_shift", 1);
|
||||||
qdev_prop_set_chr(dev, "chrB", serial_hds[1]);
|
qdev_prop_set_chr(dev, "chrB", serial_hd(1));
|
||||||
qdev_prop_set_chr(dev, "chrA", serial_hds[0]);
|
qdev_prop_set_chr(dev, "chrA", serial_hd(0));
|
||||||
qdev_prop_set_uint32(dev, "chnBtype", escc_serial);
|
qdev_prop_set_uint32(dev, "chnBtype", escc_serial);
|
||||||
qdev_prop_set_uint32(dev, "chnAtype", escc_serial);
|
qdev_prop_set_uint32(dev, "chnAtype", escc_serial);
|
||||||
qdev_init_nofail(dev);
|
qdev_init_nofail(dev);
|
||||||
|
@ -156,9 +156,9 @@ static void niagara_init(MachineState *machine)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (serial_hds[0]) {
|
if (serial_hd(0)) {
|
||||||
serial_mm_init(sysmem, NIAGARA_UART_BASE, 0, NULL, 115200,
|
serial_mm_init(sysmem, NIAGARA_UART_BASE, 0, NULL, 115200,
|
||||||
serial_hds[0], DEVICE_BIG_ENDIAN);
|
serial_hd(0), DEVICE_BIG_ENDIAN);
|
||||||
}
|
}
|
||||||
empty_slot_init(NIAGARA_IOBBASE, NIAGARA_IOBSIZE);
|
empty_slot_init(NIAGARA_IOBBASE, NIAGARA_IOBSIZE);
|
||||||
sun4v_rtc_init(NIAGARA_RTC_BASE);
|
sun4v_rtc_init(NIAGARA_RTC_BASE);
|
||||||
|
@ -295,7 +295,7 @@ static void ebus_realize(PCIDevice *pci_dev, Error **errp)
|
|||||||
i = 0;
|
i = 0;
|
||||||
if (s->console_serial_base) {
|
if (s->console_serial_base) {
|
||||||
serial_mm_init(pci_address_space(pci_dev), s->console_serial_base,
|
serial_mm_init(pci_address_space(pci_dev), s->console_serial_base,
|
||||||
0, NULL, 115200, serial_hds[i], DEVICE_BIG_ENDIAN);
|
0, NULL, 115200, serial_hd(i), DEVICE_BIG_ENDIAN);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
serial_hds_isa_init(s->isa_bus, i, MAX_SERIAL_PORTS);
|
serial_hds_isa_init(s->isa_bus, i, MAX_SERIAL_PORTS);
|
||||||
|
@ -90,8 +90,8 @@ static void xtensa_sim_init(MachineState *machine)
|
|||||||
get_system_memory());
|
get_system_memory());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (serial_hds[0]) {
|
if (serial_hd(0)) {
|
||||||
xtensa_sim_open_console(serial_hds[0]);
|
xtensa_sim_open_console(serial_hd(0));
|
||||||
}
|
}
|
||||||
if (kernel_filename) {
|
if (kernel_filename) {
|
||||||
uint64_t elf_entry;
|
uint64_t elf_entry;
|
||||||
|
@ -279,7 +279,7 @@ static void xtfpga_init(const XtfpgaBoardDesc *board, MachineState *machine)
|
|||||||
}
|
}
|
||||||
|
|
||||||
serial_mm_init(system_io, 0x0d050020, 2, xtensa_get_extint(env, 0),
|
serial_mm_init(system_io, 0x0d050020, 2, xtensa_get_extint(env, 0),
|
||||||
115200, serial_hds[0], DEVICE_NATIVE_ENDIAN);
|
115200, serial_hd(0), DEVICE_NATIVE_ENDIAN);
|
||||||
|
|
||||||
dinfo = drive_get(IF_PFLASH, 0, 0);
|
dinfo = drive_get(IF_PFLASH, 0, 0);
|
||||||
if (dinfo) {
|
if (dinfo) {
|
||||||
|
Loading…
Reference in New Issue
Block a user