|
Justin M. Forbes |
fc5c27 |
>From 9e799828d3a805184687792254c379ba4887ec60 Mon Sep 17 00:00:00 2001
|
|
|
3f1f29 |
From: Amit Shah <amit.shah@redhat.com>
|
|
|
3f1f29 |
Date: Mon, 21 Mar 2011 20:31:45 +0100
|
|
Justin M. Forbes |
fc5c27 |
Subject: [PATCH 02/28] char: Add a QemuChrHandlers struct to initialise
|
|
|
3f1f29 |
chardev handlers
|
|
|
3f1f29 |
|
|
|
3f1f29 |
Instead of passing each handler in the qemu_add_handlers() function,
|
|
|
3f1f29 |
create a struct of handlers that can be passed to the function instead.
|
|
|
3f1f29 |
|
|
|
3f1f29 |
Signed-off-by: Amit Shah <amit.shah@redhat.com>
|
|
|
3f1f29 |
---
|
|
|
3f1f29 |
gdbstub.c | 9 +++++++--
|
|
|
3f1f29 |
hw/ccid-card-passthru.c | 11 +++++++----
|
|
|
3f1f29 |
hw/debugcon.c | 2 +-
|
|
|
3f1f29 |
hw/escc.c | 9 +++++++--
|
|
|
3f1f29 |
hw/etraxfs_ser.c | 13 +++++++++----
|
|
|
3f1f29 |
hw/grlib_apbuart.c | 12 +++++++-----
|
|
|
3f1f29 |
hw/ivshmem.c | 28 ++++++++++++++++++++++------
|
|
|
3f1f29 |
hw/lm32_juart.c | 8 +++++++-
|
|
|
3f1f29 |
hw/lm32_uart.c | 8 +++++++-
|
|
|
3f1f29 |
hw/mcf_uart.c | 9 +++++++--
|
|
|
3f1f29 |
hw/milkymist-uart.c | 8 +++++++-
|
|
|
3f1f29 |
hw/pl011.c | 9 +++++++--
|
|
|
3f1f29 |
hw/pxa2xx.c | 13 +++++++++----
|
|
|
3f1f29 |
hw/serial.c | 9 +++++++--
|
|
|
3f1f29 |
hw/sh_serial.c | 12 +++++++++---
|
|
|
3f1f29 |
hw/spapr_vty.c | 8 ++++++--
|
|
|
3f1f29 |
hw/strongarm.c | 12 +++++++-----
|
|
|
3f1f29 |
hw/syborg_serial.c | 9 +++++++--
|
|
|
3f1f29 |
hw/usb-serial.c | 9 +++++++--
|
|
|
3f1f29 |
hw/virtio-console.c | 11 ++++++++---
|
|
|
3f1f29 |
hw/xen_console.c | 16 +++++++++++-----
|
|
|
3f1f29 |
hw/xilinx_uartlite.c | 11 +++++++++--
|
|
|
3f1f29 |
monitor.c | 18 ++++++++++++++----
|
|
|
3f1f29 |
net/slirp.c | 8 ++++++--
|
|
|
3f1f29 |
qemu-char.c | 32 ++++++++++++++++++++++----------
|
|
|
3f1f29 |
qemu-char.h | 13 +++++++++----
|
|
|
3f1f29 |
usb-redir.c | 9 +++++++--
|
|
|
3f1f29 |
27 files changed, 233 insertions(+), 83 deletions(-)
|
|
|
3f1f29 |
|
|
|
3f1f29 |
diff --git a/gdbstub.c b/gdbstub.c
|
|
Justin M. Forbes |
13f703 |
index 27b0cfa..6639849 100644
|
|
|
3f1f29 |
--- a/gdbstub.c
|
|
|
3f1f29 |
+++ b/gdbstub.c
|
|
|
3f1f29 |
@@ -2739,6 +2739,12 @@ static void gdb_sigterm_handler(int signal)
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
#endif
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers gdb_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = gdb_chr_can_receive,
|
|
|
3f1f29 |
+ .fd_read = gdb_chr_receive,
|
|
|
3f1f29 |
+ .fd_event = gdb_chr_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
int gdbserver_start(const char *device)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
GDBState *s;
|
|
|
3f1f29 |
@@ -2768,8 +2774,7 @@ int gdbserver_start(const char *device)
|
|
|
3f1f29 |
if (!chr)
|
|
|
3f1f29 |
return -1;
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- qemu_chr_add_handlers(chr, gdb_chr_can_receive, gdb_chr_receive,
|
|
|
3f1f29 |
- gdb_chr_event, NULL);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(chr, &gdb_handlers, NULL);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
s = gdbserver_state;
|
|
|
3f1f29 |
diff --git a/hw/ccid-card-passthru.c b/hw/ccid-card-passthru.c
|
|
|
3f1f29 |
index 28eb9d1..1dee6f7 100644
|
|
|
3f1f29 |
--- a/hw/ccid-card-passthru.c
|
|
|
3f1f29 |
+++ b/hw/ccid-card-passthru.c
|
|
|
3f1f29 |
@@ -273,6 +273,12 @@ static const uint8_t *passthru_get_atr(CCIDCardState *base, uint32_t *len)
|
|
|
3f1f29 |
return card->atr;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers passthru_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = ccid_card_vscard_can_read,
|
|
|
3f1f29 |
+ .fd_read = ccid_card_vscard_read,
|
|
|
3f1f29 |
+ .fd_event = ccid_card_vscard_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int passthru_initfn(CCIDCardState *base)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
PassthruState *card = DO_UPCAST(PassthruState, base, base);
|
|
|
3f1f29 |
@@ -281,10 +287,7 @@ static int passthru_initfn(CCIDCardState *base)
|
|
|
3f1f29 |
card->vscard_in_hdr = 0;
|
|
|
3f1f29 |
if (card->cs) {
|
|
|
3f1f29 |
DPRINTF(card, D_INFO, "initing chardev\n");
|
|
|
3f1f29 |
- qemu_chr_add_handlers(card->cs,
|
|
|
3f1f29 |
- ccid_card_vscard_can_read,
|
|
|
3f1f29 |
- ccid_card_vscard_read,
|
|
|
3f1f29 |
- ccid_card_vscard_event, card);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(card->cs, &passthru_handlers, card);
|
|
|
3f1f29 |
ccid_card_vscard_send_init(card);
|
|
|
3f1f29 |
} else {
|
|
|
3f1f29 |
error_report("missing chardev");
|
|
|
3f1f29 |
diff --git a/hw/debugcon.c b/hw/debugcon.c
|
|
|
3f1f29 |
index 5ee6821..e79a595 100644
|
|
|
3f1f29 |
--- a/hw/debugcon.c
|
|
|
3f1f29 |
+++ b/hw/debugcon.c
|
|
|
3f1f29 |
@@ -73,7 +73,7 @@ static void debugcon_init_core(DebugconState *s)
|
|
|
3f1f29 |
exit(1);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chr, NULL, NULL, NULL, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chr, NULL, s);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
static int debugcon_isa_initfn(ISADevice *dev)
|
|
|
3f1f29 |
diff --git a/hw/escc.c b/hw/escc.c
|
|
|
3f1f29 |
index f6fd919..dfa329a 100644
|
|
|
3f1f29 |
--- a/hw/escc.c
|
|
|
3f1f29 |
+++ b/hw/escc.c
|
|
|
3f1f29 |
@@ -898,6 +898,12 @@ void slavio_serial_ms_kbd_init(target_phys_addr_t base, qemu_irq irq,
|
|
|
3f1f29 |
sysbus_mmio_map(s, 0, base);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers serial_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = serial_can_receive,
|
|
|
3f1f29 |
+ .fd_read = serial_receive1,
|
|
|
3f1f29 |
+ .fd_event = serial_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int escc_init1(SysBusDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
SerialState *s = FROM_SYSBUS(SerialState, dev);
|
|
|
3f1f29 |
@@ -911,8 +917,7 @@ static int escc_init1(SysBusDevice *dev)
|
|
|
3f1f29 |
s->chn[i].chn = 1 - i;
|
|
|
3f1f29 |
s->chn[i].clock = s->frequency / 2;
|
|
|
3f1f29 |
if (s->chn[i].chr) {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chn[i].chr, serial_can_receive,
|
|
|
3f1f29 |
- serial_receive1, serial_event, &s->chn[i]);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chn[i].chr, &serial_handlers, &s->chn[i]);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
s->chn[0].otherchn = &s->chn[1];
|
|
|
3f1f29 |
diff --git a/hw/etraxfs_ser.c b/hw/etraxfs_ser.c
|
|
|
3f1f29 |
index b917d4d..ebbad77 100644
|
|
|
3f1f29 |
--- a/hw/etraxfs_ser.c
|
|
|
3f1f29 |
+++ b/hw/etraxfs_ser.c
|
|
|
3f1f29 |
@@ -202,6 +202,12 @@ static void etraxfs_ser_reset(DeviceState *d)
|
|
|
3f1f29 |
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers serial_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = serial_can_receive,
|
|
|
3f1f29 |
+ .fd_read = serial_receive,
|
|
|
3f1f29 |
+ .fd_event = serial_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int etraxfs_ser_init(SysBusDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
struct etrax_serial *s = FROM_SYSBUS(typeof (*s), dev);
|
|
|
3f1f29 |
@@ -212,10 +218,9 @@ static int etraxfs_ser_init(SysBusDevice *dev)
|
|
|
3f1f29 |
DEVICE_NATIVE_ENDIAN);
|
|
|
3f1f29 |
sysbus_init_mmio(dev, R_MAX * 4, ser_regs);
|
|
|
3f1f29 |
s->chr = qdev_init_chardev(&dev->qdev);
|
|
|
3f1f29 |
- if (s->chr)
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chr,
|
|
|
3f1f29 |
- serial_can_receive, serial_receive,
|
|
|
3f1f29 |
- serial_event, s);
|
|
|
3f1f29 |
+ if (s->chr) {
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chr, &serial_handlers, s);
|
|
|
3f1f29 |
+ }
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
diff --git a/hw/grlib_apbuart.c b/hw/grlib_apbuart.c
|
|
|
3f1f29 |
index 169a56e..310687b 100644
|
|
|
3f1f29 |
--- a/hw/grlib_apbuart.c
|
|
|
3f1f29 |
+++ b/hw/grlib_apbuart.c
|
|
|
3f1f29 |
@@ -144,16 +144,18 @@ static CPUWriteMemoryFunc * const grlib_apbuart_write[] = {
|
|
|
3f1f29 |
NULL, NULL, grlib_apbuart_writel,
|
|
|
3f1f29 |
};
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers grlib_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = grlib_apbuart_can_receive,
|
|
|
3f1f29 |
+ .fd_read = grlib_apbuart_receive,
|
|
|
3f1f29 |
+ .fd_event = grlib_apbuart_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int grlib_apbuart_init(SysBusDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
UART *uart = FROM_SYSBUS(typeof(*uart), dev);
|
|
|
3f1f29 |
int uart_regs = 0;
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- qemu_chr_add_handlers(uart->chr,
|
|
|
3f1f29 |
- grlib_apbuart_can_receive,
|
|
|
3f1f29 |
- grlib_apbuart_receive,
|
|
|
3f1f29 |
- grlib_apbuart_event,
|
|
|
3f1f29 |
- uart);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(uart->chr, &grlib_handlers, uart);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
sysbus_init_irq(dev, &uart->irq);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
diff --git a/hw/ivshmem.c b/hw/ivshmem.c
|
|
|
3f1f29 |
index 3055dd2..4f59575 100644
|
|
|
3f1f29 |
--- a/hw/ivshmem.c
|
|
|
3f1f29 |
+++ b/hw/ivshmem.c
|
|
|
3f1f29 |
@@ -312,6 +312,18 @@ static void fake_irqfd(void *opaque, const uint8_t *buf, int size) {
|
|
|
3f1f29 |
msix_notify(pdev, entry->vector);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers ivshmem_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = ivshmem_can_receive,
|
|
|
3f1f29 |
+ .fd_read = ivshmem_receive,
|
|
|
3f1f29 |
+ .fd_event = ivshmem_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
+static const QemuChrHandlers ivshmem_msi_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = ivshmem_can_receive,
|
|
|
3f1f29 |
+ .fd_read = fake_irqfd,
|
|
|
3f1f29 |
+ .fd_event = ivshmem_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static CharDriverState* create_eventfd_chr_device(void * opaque, int eventfd,
|
|
|
3f1f29 |
int vector)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
@@ -331,11 +343,10 @@ static CharDriverState* create_eventfd_chr_device(void * opaque, int eventfd,
|
|
|
3f1f29 |
s->eventfd_table[vector].pdev = &s->dev;
|
|
|
3f1f29 |
s->eventfd_table[vector].vector = vector;
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- qemu_chr_add_handlers(chr, ivshmem_can_receive, fake_irqfd,
|
|
|
3f1f29 |
- ivshmem_event, &s->eventfd_table[vector]);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(chr, &ivshmem_msi_handlers,
|
|
|
3f1f29 |
+ &s->eventfd_table[vector]);
|
|
|
3f1f29 |
} else {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(chr, ivshmem_can_receive, ivshmem_receive,
|
|
|
3f1f29 |
- ivshmem_event, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(chr, &ivshmem_handlers, s);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
return chr;
|
|
|
3f1f29 |
@@ -666,6 +677,12 @@ static int ivshmem_load(QEMUFile* f, void *opaque, int version_id)
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers ivshmem_server_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = ivshmem_can_receive,
|
|
|
3f1f29 |
+ .fd_read = ivshmem_read,
|
|
|
3f1f29 |
+ .fd_event = ivshmem_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int pci_ivshmem_init(PCIDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
IVShmemState *s = DO_UPCAST(IVShmemState, dev, dev);
|
|
|
3f1f29 |
@@ -749,8 +766,7 @@ static int pci_ivshmem_init(PCIDevice *dev)
|
|
|
3f1f29 |
|
|
|
3f1f29 |
s->eventfd_chr = qemu_mallocz(s->vectors * sizeof(CharDriverState *));
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->server_chr, ivshmem_can_receive, ivshmem_read,
|
|
|
3f1f29 |
- ivshmem_event, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->server_chr, &ivshmem_server_handlers, s);
|
|
|
3f1f29 |
} else {
|
|
|
3f1f29 |
/* just map the file immediately, we're not using a server */
|
|
|
3f1f29 |
int fd;
|
|
|
3f1f29 |
diff --git a/hw/lm32_juart.c b/hw/lm32_juart.c
|
|
|
3f1f29 |
index fddcf7e..12dd1e8 100644
|
|
|
3f1f29 |
--- a/hw/lm32_juart.c
|
|
|
3f1f29 |
+++ b/hw/lm32_juart.c
|
|
|
3f1f29 |
@@ -110,13 +110,19 @@ static void juart_reset(DeviceState *d)
|
|
|
3f1f29 |
s->jrx = 0;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers juart_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = juart_can_rx,
|
|
|
3f1f29 |
+ .fd_read = juart_rx,
|
|
|
3f1f29 |
+ .fd_event = juart_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int lm32_juart_init(SysBusDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
LM32JuartState *s = FROM_SYSBUS(typeof(*s), dev);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
s->chr = qdev_init_chardev(&dev->qdev);
|
|
|
3f1f29 |
if (s->chr) {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chr, juart_can_rx, juart_rx, juart_event, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chr, juart_handlers, s);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
diff --git a/hw/lm32_uart.c b/hw/lm32_uart.c
|
|
|
3f1f29 |
index 09090e9..5438660 100644
|
|
|
3f1f29 |
--- a/hw/lm32_uart.c
|
|
|
3f1f29 |
+++ b/hw/lm32_uart.c
|
|
|
3f1f29 |
@@ -242,6 +242,12 @@ static void uart_reset(DeviceState *d)
|
|
|
3f1f29 |
s->regs[R_LSR] = LSR_THRE | LSR_TEMT;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers uart_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = uart_can_rx,
|
|
|
3f1f29 |
+ .fd_read = uart_rx,
|
|
|
3f1f29 |
+ .fd_event = uart_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int lm32_uart_init(SysBusDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
LM32UartState *s = FROM_SYSBUS(typeof(*s), dev);
|
|
|
3f1f29 |
@@ -255,7 +261,7 @@ static int lm32_uart_init(SysBusDevice *dev)
|
|
|
3f1f29 |
|
|
|
3f1f29 |
s->chr = qdev_init_chardev(&dev->qdev);
|
|
|
3f1f29 |
if (s->chr) {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chr, uart_can_rx, uart_rx, uart_event, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chr, uart_handlers, s);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
diff --git a/hw/mcf_uart.c b/hw/mcf_uart.c
|
|
Justin M. Forbes |
5e10b1 |
index 905e116..bb5740c 100644
|
|
|
3f1f29 |
--- a/hw/mcf_uart.c
|
|
|
3f1f29 |
+++ b/hw/mcf_uart.c
|
|
|
3f1f29 |
@@ -268,6 +268,12 @@ static void mcf_uart_receive(void *opaque, const uint8_t *buf, int size)
|
|
|
3f1f29 |
mcf_uart_push_byte(s, buf[0]);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers mcf_uart_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = mcf_uart_can_receive,
|
|
|
3f1f29 |
+ .fd_read = mcf_uart_receive,
|
|
|
3f1f29 |
+ .fd_event = mcf_uart_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
void *mcf_uart_init(qemu_irq irq, CharDriverState *chr)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
mcf_uart_state *s;
|
|
|
3f1f29 |
@@ -276,8 +282,7 @@ void *mcf_uart_init(qemu_irq irq, CharDriverState *chr)
|
|
|
3f1f29 |
s->chr = chr;
|
|
|
3f1f29 |
s->irq = irq;
|
|
|
3f1f29 |
if (chr) {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(chr, mcf_uart_can_receive, mcf_uart_receive,
|
|
|
3f1f29 |
- mcf_uart_event, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(chr, &mcf_uart_handlers, s);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
mcf_uart_reset(s);
|
|
|
3f1f29 |
return s;
|
|
|
3f1f29 |
diff --git a/hw/milkymist-uart.c b/hw/milkymist-uart.c
|
|
|
3f1f29 |
index 56c90da..4412b1b 100644
|
|
|
3f1f29 |
--- a/hw/milkymist-uart.c
|
|
|
3f1f29 |
+++ b/hw/milkymist-uart.c
|
|
|
3f1f29 |
@@ -133,6 +133,12 @@ static void milkymist_uart_reset(DeviceState *d)
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers uart_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = uart_can_rx,
|
|
|
3f1f29 |
+ .fd_read = uart_rx,
|
|
|
3f1f29 |
+ .fd_event = uart_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int milkymist_uart_init(SysBusDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
MilkymistUartState *s = FROM_SYSBUS(typeof(*s), dev);
|
|
|
3f1f29 |
@@ -147,7 +153,7 @@ static int milkymist_uart_init(SysBusDevice *dev)
|
|
|
3f1f29 |
|
|
|
3f1f29 |
s->chr = qdev_init_chardev(&dev->qdev);
|
|
|
3f1f29 |
if (s->chr) {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chr, uart_can_rx, uart_rx, uart_event, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chr, uart_handlers, s);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
diff --git a/hw/pl011.c b/hw/pl011.c
|
|
Justin M. Forbes |
5e10b1 |
index 997ce84..37ba7f6 100644
|
|
|
3f1f29 |
--- a/hw/pl011.c
|
|
|
3f1f29 |
+++ b/hw/pl011.c
|
|
|
3f1f29 |
@@ -260,6 +260,12 @@ static const VMStateDescription vmstate_pl011 = {
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
};
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers pl011_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = pl011_can_receive,
|
|
|
3f1f29 |
+ .fd_read = pl011_receive,
|
|
|
3f1f29 |
+ .fd_event = pl011_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int pl011_init(SysBusDevice *dev, const unsigned char *id)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
int iomemtype;
|
|
|
3f1f29 |
@@ -278,8 +284,7 @@ static int pl011_init(SysBusDevice *dev, const unsigned char *id)
|
|
|
3f1f29 |
s->cr = 0x300;
|
|
|
3f1f29 |
s->flags = 0x90;
|
|
|
3f1f29 |
if (s->chr) {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chr, pl011_can_receive, pl011_receive,
|
|
|
3f1f29 |
- pl011_event, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chr, &pl011_handlers, s);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
vmstate_register(&dev->qdev, -1, &vmstate_pl011, s);
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
diff --git a/hw/pxa2xx.c b/hw/pxa2xx.c
|
|
Justin M. Forbes |
5e10b1 |
index cf93110..18bbe48 100644
|
|
|
3f1f29 |
--- a/hw/pxa2xx.c
|
|
|
3f1f29 |
+++ b/hw/pxa2xx.c
|
|
|
3f1f29 |
@@ -2019,6 +2019,12 @@ static int pxa2xx_fir_load(QEMUFile *f, void *opaque, int version_id)
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers pxa2xx_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = pxa2xx_fir_is_empty,
|
|
|
3f1f29 |
+ .fd_read = pxa2xx_fir_rx,
|
|
|
3f1f29 |
+ .fd_event = pxa2xx_fir_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static PXA2xxFIrState *pxa2xx_fir_init(target_phys_addr_t base,
|
|
|
3f1f29 |
qemu_irq irq, qemu_irq rx_dma, qemu_irq tx_dma,
|
|
|
3f1f29 |
CharDriverState *chr)
|
|
|
3f1f29 |
@@ -2038,10 +2044,9 @@ static PXA2xxFIrState *pxa2xx_fir_init(target_phys_addr_t base,
|
|
|
3f1f29 |
pxa2xx_fir_writefn, s, DEVICE_NATIVE_ENDIAN);
|
|
|
3f1f29 |
cpu_register_physical_memory(base, 0x1000, iomemtype);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- if (chr)
|
|
|
3f1f29 |
- qemu_chr_add_handlers(chr, pxa2xx_fir_is_empty,
|
|
|
3f1f29 |
- pxa2xx_fir_rx, pxa2xx_fir_event, s);
|
|
|
3f1f29 |
-
|
|
|
3f1f29 |
+ if (chr) {
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(chr, &pxa2xx_handlers, s);
|
|
|
3f1f29 |
+ }
|
|
|
3f1f29 |
register_savevm(NULL, "pxa2xx_fir", 0, 0, pxa2xx_fir_save,
|
|
|
3f1f29 |
pxa2xx_fir_load, s);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
diff --git a/hw/serial.c b/hw/serial.c
|
|
|
3f1f29 |
index 0ee61dd..d496bcf 100644
|
|
|
3f1f29 |
--- a/hw/serial.c
|
|
|
3f1f29 |
+++ b/hw/serial.c
|
|
|
3f1f29 |
@@ -727,6 +727,12 @@ static void serial_reset(void *opaque)
|
|
|
3f1f29 |
qemu_irq_lower(s->irq);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers serial_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = serial_can_receive1,
|
|
|
3f1f29 |
+ .fd_read = serial_receive1,
|
|
|
3f1f29 |
+ .fd_event = serial_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static void serial_init_core(SerialState *s)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
if (!s->chr) {
|
|
|
3f1f29 |
@@ -741,8 +747,7 @@ static void serial_init_core(SerialState *s)
|
|
|
3f1f29 |
|
|
|
3f1f29 |
qemu_register_reset(serial_reset, s);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chr, serial_can_receive1, serial_receive1,
|
|
|
3f1f29 |
- serial_event, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chr, &serial_handlers, s);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
/* Change the main reference oscillator frequency. */
|
|
|
3f1f29 |
diff --git a/hw/sh_serial.c b/hw/sh_serial.c
|
|
|
3f1f29 |
index 191f4a6..8b6460d 100644
|
|
|
3f1f29 |
--- a/hw/sh_serial.c
|
|
|
3f1f29 |
+++ b/hw/sh_serial.c
|
|
|
3f1f29 |
@@ -350,6 +350,12 @@ static CPUWriteMemoryFunc * const sh_serial_writefn[] = {
|
|
|
3f1f29 |
&sh_serial_write,
|
|
|
3f1f29 |
};
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers sh_serial_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = sh_serial_can_receive1,
|
|
|
3f1f29 |
+ .fd_read = sh_serial_receive1,
|
|
|
3f1f29 |
+ .fd_event = sh_serial_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
void sh_serial_init (target_phys_addr_t base, int feat,
|
|
|
3f1f29 |
uint32_t freq, CharDriverState *chr,
|
|
|
3f1f29 |
qemu_irq eri_source,
|
|
|
3f1f29 |
@@ -389,9 +395,9 @@ void sh_serial_init (target_phys_addr_t base, int feat,
|
|
|
3f1f29 |
|
|
|
3f1f29 |
s->chr = chr;
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- if (chr)
|
|
|
3f1f29 |
- qemu_chr_add_handlers(chr, sh_serial_can_receive1, sh_serial_receive1,
|
|
|
3f1f29 |
- sh_serial_event, s);
|
|
|
3f1f29 |
+ if (chr) {
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(chr, &sh_serial_handlers, s);
|
|
|
3f1f29 |
+ }
|
|
|
3f1f29 |
|
|
|
3f1f29 |
s->eri = eri_source;
|
|
|
3f1f29 |
s->rxi = rxi_source;
|
|
|
3f1f29 |
diff --git a/hw/spapr_vty.c b/hw/spapr_vty.c
|
|
|
3f1f29 |
index 6fc0105..5968d85 100644
|
|
|
3f1f29 |
--- a/hw/spapr_vty.c
|
|
|
3f1f29 |
+++ b/hw/spapr_vty.c
|
|
|
3f1f29 |
@@ -54,12 +54,16 @@ void vty_putchars(VIOsPAPRDevice *sdev, uint8_t *buf, int len)
|
|
|
3f1f29 |
qemu_chr_write(dev->chardev, buf, len);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers vty_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = vty_can_receive,
|
|
|
3f1f29 |
+ .fd_read = vty_receive,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int spapr_vty_init(VIOsPAPRDevice *sdev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
VIOsPAPRVTYDevice *dev = (VIOsPAPRVTYDevice *)sdev;
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- qemu_chr_add_handlers(dev->chardev, vty_can_receive,
|
|
|
3f1f29 |
- vty_receive, NULL, dev);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(dev->chardev, vty_handlers, dev);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
diff --git a/hw/strongarm.c b/hw/strongarm.c
|
|
|
3f1f29 |
index 0e03d61..c2dce95 100644
|
|
|
3f1f29 |
--- a/hw/strongarm.c
|
|
|
3f1f29 |
+++ b/hw/strongarm.c
|
|
|
3f1f29 |
@@ -1188,6 +1188,12 @@ static CPUWriteMemoryFunc * const strongarm_uart_writefn[] = {
|
|
|
3f1f29 |
strongarm_uart_write,
|
|
|
3f1f29 |
};
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers strongarm_uart_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = strongarm_uart_can_receive,
|
|
|
3f1f29 |
+ .fd_read = strongarm_uart_receive,
|
|
|
3f1f29 |
+ .fd_event = strongarm_uart_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int strongarm_uart_init(SysBusDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
StrongARMUARTState *s = FROM_SYSBUS(StrongARMUARTState, dev);
|
|
|
3f1f29 |
@@ -1202,11 +1208,7 @@ static int strongarm_uart_init(SysBusDevice *dev)
|
|
|
3f1f29 |
s->tx_timer = qemu_new_timer_ns(vm_clock, strongarm_uart_tx, s);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
if (s->chr) {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chr,
|
|
|
3f1f29 |
- strongarm_uart_can_receive,
|
|
|
3f1f29 |
- strongarm_uart_receive,
|
|
|
3f1f29 |
- strongarm_uart_event,
|
|
|
3f1f29 |
- s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chr, &strongarm_uart_handlers, s);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
diff --git a/hw/syborg_serial.c b/hw/syborg_serial.c
|
|
|
3f1f29 |
index 2ef7175..ac68022 100644
|
|
|
3f1f29 |
--- a/hw/syborg_serial.c
|
|
|
3f1f29 |
+++ b/hw/syborg_serial.c
|
|
|
3f1f29 |
@@ -292,6 +292,12 @@ static const VMStateDescription vmstate_syborg_serial = {
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
};
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers syborg_serial_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = syborg_serial_can_receive,
|
|
|
3f1f29 |
+ .fd_read = syborg_serial_receive,
|
|
|
3f1f29 |
+ .fd_event = syborg_serial_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int syborg_serial_init(SysBusDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
SyborgSerialState *s = FROM_SYSBUS(SyborgSerialState, dev);
|
|
|
3f1f29 |
@@ -304,8 +310,7 @@ static int syborg_serial_init(SysBusDevice *dev)
|
|
|
3f1f29 |
sysbus_init_mmio(dev, 0x1000, iomemtype);
|
|
|
3f1f29 |
s->chr = qdev_init_chardev(&dev->qdev);
|
|
|
3f1f29 |
if (s->chr) {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chr, syborg_serial_can_receive,
|
|
|
3f1f29 |
- syborg_serial_receive, syborg_serial_event, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chr, &syborg_serial_handlers, s);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
if (s->fifo_size <= 0) {
|
|
|
3f1f29 |
fprintf(stderr, "syborg_serial: fifo too small\n");
|
|
|
3f1f29 |
diff --git a/hw/usb-serial.c b/hw/usb-serial.c
|
|
Justin M. Forbes |
5e10b1 |
index c69c437..45d48ee 100644
|
|
|
3f1f29 |
--- a/hw/usb-serial.c
|
|
|
3f1f29 |
+++ b/hw/usb-serial.c
|
|
|
3f1f29 |
@@ -476,6 +476,12 @@ static void usb_serial_event(void *opaque, int event)
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers usb_serial_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = usb_serial_can_read,
|
|
|
3f1f29 |
+ .fd_read = usb_serial_read,
|
|
|
3f1f29 |
+ .fd_event = usb_serial_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int usb_serial_initfn(USBDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
USBSerialState *s = DO_UPCAST(USBSerialState, dev, dev);
|
|
|
3f1f29 |
@@ -487,8 +493,7 @@ static int usb_serial_initfn(USBDevice *dev)
|
|
|
3f1f29 |
return -1;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->cs, usb_serial_can_read, usb_serial_read,
|
|
|
3f1f29 |
- usb_serial_event, s);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->cs, &usb_serial_handlers, s);
|
|
|
3f1f29 |
usb_serial_handle_reset(dev);
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
diff --git a/hw/virtio-console.c b/hw/virtio-console.c
|
|
Justin M. Forbes |
5e10b1 |
index fe5e188..cfc3087 100644
|
|
|
3f1f29 |
--- a/hw/virtio-console.c
|
|
|
3f1f29 |
+++ b/hw/virtio-console.c
|
|
Justin M. Forbes |
5e10b1 |
@@ -95,6 +95,12 @@ static void chr_event(void *opaque, int event)
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers chr_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = chr_can_read,
|
|
|
3f1f29 |
+ .fd_read = chr_read,
|
|
|
3f1f29 |
+ .fd_event = chr_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int virtconsole_initfn(VirtIOSerialPort *port)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
VirtConsole *vcon = DO_UPCAST(VirtConsole, port, port);
|
|
Justin M. Forbes |
5e10b1 |
@@ -107,8 +113,7 @@ static int virtconsole_initfn(VirtIOSerialPort *port)
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
if (vcon->chr) {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(vcon->chr, chr_can_read, chr_read, chr_event,
|
|
|
3f1f29 |
- vcon);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(vcon->chr, &chr_handlers, vcon);
|
|
|
3f1f29 |
info->have_data = flush_buf;
|
|
|
3f1f29 |
info->guest_open = guest_open;
|
|
|
3f1f29 |
info->guest_close = guest_close;
|
|
Justin M. Forbes |
5e10b1 |
@@ -126,7 +131,7 @@ static int virtconsole_exitfn(VirtIOSerialPort *port)
|
|
|
3f1f29 |
* Instead of closing the chardev, free it so it can be used
|
|
|
3f1f29 |
* for other purposes.
|
|
|
3f1f29 |
*/
|
|
|
3f1f29 |
- qemu_chr_add_handlers(vcon->chr, NULL, NULL, NULL, NULL);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(vcon->chr, NULL, NULL);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
diff --git a/hw/xen_console.c b/hw/xen_console.c
|
|
Justin M. Forbes |
5e10b1 |
index 8ef104c..85e8a22 100644
|
|
|
3f1f29 |
--- a/hw/xen_console.c
|
|
|
3f1f29 |
+++ b/hw/xen_console.c
|
|
Justin M. Forbes |
5e10b1 |
@@ -212,6 +212,11 @@ out:
|
|
Justin M. Forbes |
5e10b1 |
return ret;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers xencons_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = xencons_can_receive,
|
|
|
3f1f29 |
+ .fd_read = xencons_receive,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int con_connect(struct XenDevice *xendev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
struct XenConsole *con = container_of(xendev, struct XenConsole, xendev);
|
|
Justin M. Forbes |
5e10b1 |
@@ -232,9 +237,9 @@ static int con_connect(struct XenDevice *xendev)
|
|
|
3f1f29 |
return -1;
|
|
|
3f1f29 |
|
|
|
3f1f29 |
xen_be_bind_evtchn(&con->xendev);
|
|
|
3f1f29 |
- if (con->chr)
|
|
|
3f1f29 |
- qemu_chr_add_handlers(con->chr, xencons_can_receive, xencons_receive,
|
|
|
3f1f29 |
- NULL, con);
|
|
|
3f1f29 |
+ if (con->chr) {
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(con->chr, &xencons_handlers, con);
|
|
|
3f1f29 |
+ }
|
|
|
3f1f29 |
|
|
|
3f1f29 |
xen_be_printf(xendev, 1, "ring mfn %d, remote port %d, local port %d, limit %zd\n",
|
|
|
3f1f29 |
con->ring_ref,
|
|
Justin M. Forbes |
5e10b1 |
@@ -248,8 +253,9 @@ static void con_disconnect(struct XenDevice *xendev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
struct XenConsole *con = container_of(xendev, struct XenConsole, xendev);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- if (con->chr)
|
|
|
3f1f29 |
- qemu_chr_add_handlers(con->chr, NULL, NULL, NULL, NULL);
|
|
|
3f1f29 |
+ if (con->chr) {
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(con->chr, NULL, NULL);
|
|
|
3f1f29 |
+ }
|
|
|
3f1f29 |
xen_be_unbind_evtchn(&con->xendev);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
if (con->sring) {
|
|
|
3f1f29 |
diff --git a/hw/xilinx_uartlite.c b/hw/xilinx_uartlite.c
|
|
|
3f1f29 |
index 9b94e98..1845577 100644
|
|
|
3f1f29 |
--- a/hw/xilinx_uartlite.c
|
|
|
3f1f29 |
+++ b/hw/xilinx_uartlite.c
|
|
|
3f1f29 |
@@ -193,6 +193,12 @@ static void uart_event(void *opaque, int event)
|
|
|
3f1f29 |
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers uart_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = uart_can_rx,
|
|
|
3f1f29 |
+ .fd_read = uart_rx,
|
|
|
3f1f29 |
+ .fd_event = uart_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int xilinx_uartlite_init(SysBusDevice *dev)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
struct xlx_uartlite *s = FROM_SYSBUS(typeof (*s), dev);
|
|
|
3f1f29 |
@@ -206,8 +212,9 @@ static int xilinx_uartlite_init(SysBusDevice *dev)
|
|
|
3f1f29 |
sysbus_init_mmio(dev, R_MAX * 4, uart_regs);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
s->chr = qdev_init_chardev(&dev->qdev);
|
|
|
3f1f29 |
- if (s->chr)
|
|
|
3f1f29 |
- qemu_chr_add_handlers(s->chr, uart_can_rx, uart_rx, uart_event, s);
|
|
|
3f1f29 |
+ if (s->chr) {
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(s->chr, &uart_handlers, s);
|
|
|
3f1f29 |
+ }
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
diff --git a/monitor.c b/monitor.c
|
|
Justin M. Forbes |
5e10b1 |
index 718935b..5b79dde 100644
|
|
|
3f1f29 |
--- a/monitor.c
|
|
|
3f1f29 |
+++ b/monitor.c
|
|
Justin M. Forbes |
5e10b1 |
@@ -5249,6 +5249,18 @@ static void monitor_event(void *opaque, int event)
|
|
|
3f1f29 |
* End:
|
|
|
3f1f29 |
*/
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers monitor_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = monitor_can_read,
|
|
|
3f1f29 |
+ .fd_read = monitor_read,
|
|
|
3f1f29 |
+ .fd_event = monitor_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
+static const QemuChrHandlers monitor_control_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = monitor_can_read,
|
|
|
3f1f29 |
+ .fd_read = monitor_control_read,
|
|
|
3f1f29 |
+ .fd_event = monitor_control_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
void monitor_init(CharDriverState *chr, int flags)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
static int is_first_init = 1;
|
|
Justin M. Forbes |
5e10b1 |
@@ -5271,12 +5283,10 @@ void monitor_init(CharDriverState *chr, int flags)
|
|
|
3f1f29 |
if (monitor_ctrl_mode(mon)) {
|
|
|
3f1f29 |
mon->mc = qemu_mallocz(sizeof(MonitorControl));
|
|
|
3f1f29 |
/* Control mode requires special handlers */
|
|
|
3f1f29 |
- qemu_chr_add_handlers(chr, monitor_can_read, monitor_control_read,
|
|
|
3f1f29 |
- monitor_control_event, mon);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(chr, &monitor_control_handlers, mon);
|
|
|
3f1f29 |
qemu_chr_set_echo(chr, true);
|
|
|
3f1f29 |
} else {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(chr, monitor_can_read, monitor_read,
|
|
|
3f1f29 |
- monitor_event, mon);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(chr, &monitor_handlers, mon);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
QLIST_INSERT_HEAD(&mon_list, mon, entry);
|
|
|
3f1f29 |
diff --git a/net/slirp.c b/net/slirp.c
|
|
Justin M. Forbes |
5e10b1 |
index 157b80a..8eeec7e 100644
|
|
|
3f1f29 |
--- a/net/slirp.c
|
|
|
3f1f29 |
+++ b/net/slirp.c
|
|
Justin M. Forbes |
5e10b1 |
@@ -577,6 +577,11 @@ static void guestfwd_read(void *opaque, const uint8_t *buf, int size)
|
|
|
3f1f29 |
slirp_socket_recv(fwd->slirp, fwd->server, fwd->port, buf, size);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers guestfwd_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = guestfwd_can_read,
|
|
|
3f1f29 |
+ .fd_read = guestfwd_read,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static int slirp_guestfwd(SlirpState *s, const char *config_str,
|
|
|
3f1f29 |
int legacy_format)
|
|
|
3f1f29 |
{
|
|
Justin M. Forbes |
5e10b1 |
@@ -633,8 +638,7 @@ static int slirp_guestfwd(SlirpState *s, const char *config_str,
|
|
|
3f1f29 |
fwd->port = port;
|
|
|
3f1f29 |
fwd->slirp = s->slirp;
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- qemu_chr_add_handlers(fwd->hd, guestfwd_can_read, guestfwd_read,
|
|
|
3f1f29 |
- NULL, fwd);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(fwd->hd, &guestfwd_handlers, fwd);
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
|
|
|
3f1f29 |
fail_syntax:
|
|
|
3f1f29 |
diff --git a/qemu-char.c b/qemu-char.c
|
|
Justin M. Forbes |
13f703 |
index 5682aea..52bcc0e 100644
|
|
|
3f1f29 |
--- a/qemu-char.c
|
|
|
3f1f29 |
+++ b/qemu-char.c
|
|
Justin M. Forbes |
5e10b1 |
@@ -195,19 +195,26 @@ void qemu_chr_send_event(CharDriverState *s, int event)
|
|
|
3f1f29 |
s->chr_send_event(s, event);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers null_handlers = {
|
|
|
3f1f29 |
+ /* All handlers are initialised to NULL */
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
void qemu_chr_add_handlers(CharDriverState *s,
|
|
|
3f1f29 |
- IOCanReadHandler *fd_can_read,
|
|
|
3f1f29 |
- IOReadHandler *fd_read,
|
|
|
3f1f29 |
- IOEventHandler *fd_event,
|
|
|
3f1f29 |
- void *opaque)
|
|
|
3f1f29 |
+ const QemuChrHandlers *handlers, void *opaque)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
- if (!opaque && !fd_can_read && !fd_read && !fd_event) {
|
|
|
3f1f29 |
+ if (!s) {
|
|
|
3f1f29 |
+ return;
|
|
|
3f1f29 |
+ }
|
|
|
3f1f29 |
+ if (!opaque && !handlers) {
|
|
|
3f1f29 |
/* chr driver being released. */
|
|
|
3f1f29 |
++s->avail_connections;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
- s->chr_can_read = fd_can_read;
|
|
|
3f1f29 |
- s->chr_read = fd_read;
|
|
|
3f1f29 |
- s->chr_event = fd_event;
|
|
|
3f1f29 |
+ if (!handlers) {
|
|
|
3f1f29 |
+ handlers = &null_handlers;
|
|
|
3f1f29 |
+ }
|
|
|
3f1f29 |
+ s->chr_can_read = handlers->fd_can_read;
|
|
|
3f1f29 |
+ s->chr_read = handlers->fd_read;
|
|
|
3f1f29 |
+ s->chr_event = handlers->fd_event;
|
|
|
3f1f29 |
s->handler_opaque = opaque;
|
|
|
3f1f29 |
if (s->chr_update_read_handler)
|
|
|
3f1f29 |
s->chr_update_read_handler(s);
|
|
Justin M. Forbes |
5e10b1 |
@@ -447,6 +454,12 @@ static void mux_chr_event(void *opaque, int event)
|
|
|
3f1f29 |
mux_chr_send_event(d, i, event);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers mux_chr_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = mux_chr_can_read,
|
|
|
3f1f29 |
+ .fd_read = mux_chr_read,
|
|
|
3f1f29 |
+ .fd_event = mux_chr_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
static void mux_chr_update_read_handler(CharDriverState *chr)
|
|
|
3f1f29 |
{
|
|
|
3f1f29 |
MuxDriver *d = chr->opaque;
|
|
Justin M. Forbes |
5e10b1 |
@@ -461,8 +474,7 @@ static void mux_chr_update_read_handler(CharDriverState *chr)
|
|
|
3f1f29 |
d->chr_event[d->mux_cnt] = chr->chr_event;
|
|
|
3f1f29 |
/* Fix up the real driver with mux routines */
|
|
|
3f1f29 |
if (d->mux_cnt == 0) {
|
|
|
3f1f29 |
- qemu_chr_add_handlers(d->drv, mux_chr_can_read, mux_chr_read,
|
|
|
3f1f29 |
- mux_chr_event, chr);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(d->drv, &mux_chr_handlers, chr);
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
if (d->focus != -1) {
|
|
|
3f1f29 |
mux_chr_send_event(d, d->focus, CHR_EVENT_MUX_OUT);
|
|
|
3f1f29 |
diff --git a/qemu-char.h b/qemu-char.h
|
|
Justin M. Forbes |
5e10b1 |
index f361c6d..b8372ea 100644
|
|
|
3f1f29 |
--- a/qemu-char.h
|
|
|
3f1f29 |
+++ b/qemu-char.h
|
|
|
3f1f29 |
@@ -1,6 +1,7 @@
|
|
|
3f1f29 |
#ifndef QEMU_CHAR_H
|
|
|
3f1f29 |
#define QEMU_CHAR_H
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+#include <stdbool.h>
|
|
|
3f1f29 |
#include "qemu-common.h"
|
|
|
3f1f29 |
#include "qemu-queue.h"
|
|
|
3f1f29 |
#include "qemu-option.h"
|
|
Justin M. Forbes |
5e10b1 |
@@ -77,6 +78,13 @@ struct CharDriverState {
|
|
|
3f1f29 |
QTAILQ_ENTRY(CharDriverState) next;
|
|
|
3f1f29 |
};
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+typedef struct QemuChrHandlers {
|
|
|
3f1f29 |
+ IOCanReadHandler *fd_can_read;
|
|
|
3f1f29 |
+ IOReadHandler *fd_read;
|
|
|
3f1f29 |
+ IOHandler *fd_write_unblocked;
|
|
|
3f1f29 |
+ IOEventHandler *fd_event;
|
|
|
3f1f29 |
+} QemuChrHandlers;
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
QemuOpts *qemu_chr_parse_compat(const char *label, const char *filename);
|
|
|
3f1f29 |
CharDriverState *qemu_chr_open_opts(QemuOpts *opts,
|
|
|
3f1f29 |
void (*init)(struct CharDriverState *s));
|
|
Justin M. Forbes |
5e10b1 |
@@ -89,10 +97,7 @@ void qemu_chr_printf(CharDriverState *s, const char *fmt, ...)
|
|
|
3f1f29 |
GCC_FMT_ATTR(2, 3);
|
|
|
3f1f29 |
int qemu_chr_write(CharDriverState *s, const uint8_t *buf, int len);
|
|
|
3f1f29 |
void qemu_chr_send_event(CharDriverState *s, int event);
|
|
|
3f1f29 |
-void qemu_chr_add_handlers(CharDriverState *s,
|
|
|
3f1f29 |
- IOCanReadHandler *fd_can_read,
|
|
|
3f1f29 |
- IOReadHandler *fd_read,
|
|
|
3f1f29 |
- IOEventHandler *fd_event,
|
|
|
3f1f29 |
+void qemu_chr_add_handlers(CharDriverState *s, const QemuChrHandlers *handlers,
|
|
|
3f1f29 |
void *opaque);
|
|
|
3f1f29 |
int qemu_chr_ioctl(CharDriverState *s, int cmd, void *arg);
|
|
|
3f1f29 |
void qemu_chr_generic_open(CharDriverState *s);
|
|
|
3f1f29 |
diff --git a/usb-redir.c b/usb-redir.c
|
|
|
3f1f29 |
index e212993..e2b5a2c 100644
|
|
|
3f1f29 |
--- a/usb-redir.c
|
|
|
3f1f29 |
+++ b/usb-redir.c
|
|
|
3f1f29 |
@@ -782,6 +782,12 @@ static void usbredir_chardev_event(void *opaque, int event)
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
|
|
|
3f1f29 |
+static const QemuChrHandlers usbredir_chr_handlers = {
|
|
|
3f1f29 |
+ .fd_can_read = usbredir_chardev_can_read,
|
|
|
3f1f29 |
+ .fd_read = usbredir_chardev_read,
|
|
|
3f1f29 |
+ .fd_event = usbredir_chardev_event,
|
|
|
3f1f29 |
+};
|
|
|
3f1f29 |
+
|
|
|
3f1f29 |
/*
|
|
|
3f1f29 |
* init + destroy
|
|
|
3f1f29 |
*/
|
|
|
3f1f29 |
@@ -807,8 +813,7 @@ static int usbredir_initfn(USBDevice *udev)
|
|
|
3f1f29 |
/* We'll do the attach once we receive the speed from the usb-host */
|
|
|
3f1f29 |
udev->auto_attach = 0;
|
|
|
3f1f29 |
|
|
|
3f1f29 |
- qemu_chr_add_handlers(dev->cs, usbredir_chardev_can_read,
|
|
|
3f1f29 |
- usbredir_chardev_read, usbredir_chardev_event, dev);
|
|
|
3f1f29 |
+ qemu_chr_add_handlers(dev->cs, &usbredir_chr_handlers, dev);
|
|
|
3f1f29 |
|
|
|
3f1f29 |
return 0;
|
|
|
3f1f29 |
}
|
|
|
3f1f29 |
--
|
|
|
3f1f29 |
1.7.5.1
|
|
|
3f1f29 |
|