提交 3cb75a7c 编写于 作者: P Paolo Bonzini 提交者: Andreas Färber

qdev: Move bus properties to a separate global

Simple code movement in order to simplify future refactoring.
Signed-off-by: NPaolo Bonzini <pbonzini@redhat.com>
Signed-off-by: NAndreas Färber <afaerber@suse.de>
上级 2f262e06
...@@ -17,13 +17,15 @@ struct i2c_bus ...@@ -17,13 +17,15 @@ struct i2c_bus
uint8_t saved_address; uint8_t saved_address;
}; };
static Property i2c_props[] = {
DEFINE_PROP_UINT8("address", struct I2CSlave, address, 0),
DEFINE_PROP_END_OF_LIST(),
};
static struct BusInfo i2c_bus_info = { static struct BusInfo i2c_bus_info = {
.name = "I2C", .name = "I2C",
.size = sizeof(i2c_bus), .size = sizeof(i2c_bus),
.props = (Property[]) { .props = i2c_props,
DEFINE_PROP_UINT8("address", struct I2CSlave, address, 0),
DEFINE_PROP_END_OF_LIST(),
}
}; };
static void i2c_bus_pre_save(void *opaque) static void i2c_bus_pre_save(void *opaque)
......
...@@ -27,14 +27,16 @@ ...@@ -27,14 +27,16 @@
static char *idebus_get_fw_dev_path(DeviceState *dev); static char *idebus_get_fw_dev_path(DeviceState *dev);
static Property ide_props[] = {
DEFINE_PROP_UINT32("unit", IDEDevice, unit, -1),
DEFINE_PROP_END_OF_LIST(),
};
static struct BusInfo ide_bus_info = { static struct BusInfo ide_bus_info = {
.name = "IDE", .name = "IDE",
.size = sizeof(IDEBus), .size = sizeof(IDEBus),
.get_fw_dev_path = idebus_get_fw_dev_path, .get_fw_dev_path = idebus_get_fw_dev_path,
.props = (Property[]) { .props = ide_props,
DEFINE_PROP_UINT32("unit", IDEDevice, unit, -1),
DEFINE_PROP_END_OF_LIST(),
},
}; };
void ide_bus_new(IDEBus *idebus, DeviceState *dev, int bus_id) void ide_bus_new(IDEBus *idebus, DeviceState *dev, int bus_id)
......
...@@ -29,13 +29,15 @@ ...@@ -29,13 +29,15 @@
/* --------------------------------------------------------------------- */ /* --------------------------------------------------------------------- */
/* hda bus */ /* hda bus */
static Property hda_props[] = {
DEFINE_PROP_UINT32("cad", HDACodecDevice, cad, -1),
DEFINE_PROP_END_OF_LIST()
};
static struct BusInfo hda_codec_bus_info = { static struct BusInfo hda_codec_bus_info = {
.name = "HDA", .name = "HDA",
.size = sizeof(HDACodecBus), .size = sizeof(HDACodecBus),
.props = (Property[]) { .props = hda_props,
DEFINE_PROP_UINT32("cad", HDACodecDevice, cad, -1),
DEFINE_PROP_END_OF_LIST()
}
}; };
void hda_codec_bus_init(DeviceState *dev, HDACodecBus *bus, void hda_codec_bus_init(DeviceState *dev, HDACodecBus *bus,
......
...@@ -44,14 +44,7 @@ static char *pcibus_get_dev_path(DeviceState *dev); ...@@ -44,14 +44,7 @@ static char *pcibus_get_dev_path(DeviceState *dev);
static char *pcibus_get_fw_dev_path(DeviceState *dev); static char *pcibus_get_fw_dev_path(DeviceState *dev);
static int pcibus_reset(BusState *qbus); static int pcibus_reset(BusState *qbus);
struct BusInfo pci_bus_info = { static Property pci_props[] = {
.name = "PCI",
.size = sizeof(PCIBus),
.print_dev = pcibus_dev_print,
.get_dev_path = pcibus_get_dev_path,
.get_fw_dev_path = pcibus_get_fw_dev_path,
.reset = pcibus_reset,
.props = (Property[]) {
DEFINE_PROP_PCI_DEVFN("addr", PCIDevice, devfn, -1), DEFINE_PROP_PCI_DEVFN("addr", PCIDevice, devfn, -1),
DEFINE_PROP_STRING("romfile", PCIDevice, romfile), DEFINE_PROP_STRING("romfile", PCIDevice, romfile),
DEFINE_PROP_UINT32("rombar", PCIDevice, rom_bar, 1), DEFINE_PROP_UINT32("rombar", PCIDevice, rom_bar, 1),
...@@ -60,7 +53,16 @@ struct BusInfo pci_bus_info = { ...@@ -60,7 +53,16 @@ struct BusInfo pci_bus_info = {
DEFINE_PROP_BIT("command_serr_enable", PCIDevice, cap_present, DEFINE_PROP_BIT("command_serr_enable", PCIDevice, cap_present,
QEMU_PCI_CAP_SERR_BITNR, true), QEMU_PCI_CAP_SERR_BITNR, true),
DEFINE_PROP_END_OF_LIST() DEFINE_PROP_END_OF_LIST()
} };
struct BusInfo pci_bus_info = {
.name = "PCI",
.size = sizeof(PCIBus),
.print_dev = pcibus_dev_print,
.get_dev_path = pcibus_get_dev_path,
.get_fw_dev_path = pcibus_get_fw_dev_path,
.reset = pcibus_reset,
.props = pci_props,
}; };
static PCIBus *pci_find_bus_nr(PCIBus *bus, int bus_num); static PCIBus *pci_find_bus_nr(PCIBus *bus, int bus_num);
......
...@@ -12,17 +12,19 @@ static char *scsibus_get_fw_dev_path(DeviceState *dev); ...@@ -12,17 +12,19 @@ static char *scsibus_get_fw_dev_path(DeviceState *dev);
static int scsi_req_parse(SCSICommand *cmd, SCSIDevice *dev, uint8_t *buf); static int scsi_req_parse(SCSICommand *cmd, SCSIDevice *dev, uint8_t *buf);
static void scsi_req_dequeue(SCSIRequest *req); static void scsi_req_dequeue(SCSIRequest *req);
static Property scsi_props[] = {
DEFINE_PROP_UINT32("channel", SCSIDevice, channel, 0),
DEFINE_PROP_UINT32("scsi-id", SCSIDevice, id, -1),
DEFINE_PROP_UINT32("lun", SCSIDevice, lun, -1),
DEFINE_PROP_END_OF_LIST(),
};
static struct BusInfo scsi_bus_info = { static struct BusInfo scsi_bus_info = {
.name = "SCSI", .name = "SCSI",
.size = sizeof(SCSIBus), .size = sizeof(SCSIBus),
.get_dev_path = scsibus_get_dev_path, .get_dev_path = scsibus_get_dev_path,
.get_fw_dev_path = scsibus_get_fw_dev_path, .get_fw_dev_path = scsibus_get_fw_dev_path,
.props = (Property[]) { .props = scsi_props,
DEFINE_PROP_UINT32("channel", SCSIDevice, channel, 0),
DEFINE_PROP_UINT32("scsi-id", SCSIDevice, id, -1),
DEFINE_PROP_UINT32("lun", SCSIDevice, lun, -1),
DEFINE_PROP_END_OF_LIST(),
},
}; };
static int next_scsi_bus; static int next_scsi_bus;
......
...@@ -49,13 +49,15 @@ ...@@ -49,13 +49,15 @@
do { } while (0) do { } while (0)
#endif #endif
static Property spapr_vio_props[] = {
DEFINE_PROP_UINT32("irq", VIOsPAPRDevice, vio_irq_num, 0), \
DEFINE_PROP_END_OF_LIST(),
};
static struct BusInfo spapr_vio_bus_info = { static struct BusInfo spapr_vio_bus_info = {
.name = "spapr-vio", .name = "spapr-vio",
.size = sizeof(VIOsPAPRBus), .size = sizeof(VIOsPAPRBus),
.props = (Property[]) { .props = spapr_vio_props,
DEFINE_PROP_UINT32("irq", VIOsPAPRDevice, vio_irq_num, 0), \
DEFINE_PROP_END_OF_LIST(),
},
}; };
VIOsPAPRDevice *spapr_vio_find_by_reg(VIOsPAPRBus *bus, uint32_t reg) VIOsPAPRDevice *spapr_vio_find_by_reg(VIOsPAPRBus *bus, uint32_t reg)
......
...@@ -11,19 +11,22 @@ static char *usb_get_dev_path(DeviceState *dev); ...@@ -11,19 +11,22 @@ static char *usb_get_dev_path(DeviceState *dev);
static char *usb_get_fw_dev_path(DeviceState *qdev); static char *usb_get_fw_dev_path(DeviceState *qdev);
static int usb_qdev_exit(DeviceState *qdev); static int usb_qdev_exit(DeviceState *qdev);
static Property usb_props[] = {
DEFINE_PROP_STRING("port", USBDevice, port_path),
DEFINE_PROP_BIT("full-path", USBDevice, flags,
USB_DEV_FLAG_FULL_PATH, true),
DEFINE_PROP_END_OF_LIST()
};
static struct BusInfo usb_bus_info = { static struct BusInfo usb_bus_info = {
.name = "USB", .name = "USB",
.size = sizeof(USBBus), .size = sizeof(USBBus),
.print_dev = usb_bus_dev_print, .print_dev = usb_bus_dev_print,
.get_dev_path = usb_get_dev_path, .get_dev_path = usb_get_dev_path,
.get_fw_dev_path = usb_get_fw_dev_path, .get_fw_dev_path = usb_get_fw_dev_path,
.props = (Property[]) { .props = usb_props,
DEFINE_PROP_STRING("port", USBDevice, port_path),
DEFINE_PROP_BIT("full-path", USBDevice, flags,
USB_DEV_FLAG_FULL_PATH, true),
DEFINE_PROP_END_OF_LIST()
},
}; };
static int next_usb_bus = 0; static int next_usb_bus = 0;
static QTAILQ_HEAD(, USBBus) busses = QTAILQ_HEAD_INITIALIZER(busses); static QTAILQ_HEAD(, USBBus) busses = QTAILQ_HEAD_INITIALIZER(busses);
......
...@@ -1055,13 +1055,15 @@ static Answer *ccid_peek_next_answer(USBCCIDState *s) ...@@ -1055,13 +1055,15 @@ static Answer *ccid_peek_next_answer(USBCCIDState *s)
: &s->pending_answers[s->pending_answers_start % PENDING_ANSWERS_NUM]; : &s->pending_answers[s->pending_answers_start % PENDING_ANSWERS_NUM];
} }
static Property ccid_props[] = {
DEFINE_PROP_UINT32("slot", struct CCIDCardState, slot, 0),
DEFINE_PROP_END_OF_LIST(),
};
static struct BusInfo ccid_bus_info = { static struct BusInfo ccid_bus_info = {
.name = "ccid-bus", .name = "ccid-bus",
.size = sizeof(CCIDBus), .size = sizeof(CCIDBus),
.props = (Property[]) { .props = ccid_props,
DEFINE_PROP_UINT32("slot", struct CCIDCardState, slot, 0),
DEFINE_PROP_END_OF_LIST(),
}
}; };
void ccid_card_send_apdu_to_guest(CCIDCardState *card, void ccid_card_send_apdu_to_guest(CCIDCardState *card,
......
...@@ -728,15 +728,17 @@ static int virtio_serial_load(QEMUFile *f, void *opaque, int version_id) ...@@ -728,15 +728,17 @@ static int virtio_serial_load(QEMUFile *f, void *opaque, int version_id)
static void virtser_bus_dev_print(Monitor *mon, DeviceState *qdev, int indent); static void virtser_bus_dev_print(Monitor *mon, DeviceState *qdev, int indent);
static Property virtser_props[] = {
DEFINE_PROP_UINT32("nr", VirtIOSerialPort, id, VIRTIO_CONSOLE_BAD_ID),
DEFINE_PROP_STRING("name", VirtIOSerialPort, name),
DEFINE_PROP_END_OF_LIST()
};
static struct BusInfo virtser_bus_info = { static struct BusInfo virtser_bus_info = {
.name = "virtio-serial-bus", .name = "virtio-serial-bus",
.size = sizeof(VirtIOSerialBus), .size = sizeof(VirtIOSerialBus),
.print_dev = virtser_bus_dev_print, .print_dev = virtser_bus_dev_print,
.props = (Property[]) { .props = virtser_props,
DEFINE_PROP_UINT32("nr", VirtIOSerialPort, id, VIRTIO_CONSOLE_BAD_ID),
DEFINE_PROP_STRING("name", VirtIOSerialPort, name),
DEFINE_PROP_END_OF_LIST()
}
}; };
static void virtser_bus_dev_print(Monitor *mon, DeviceState *qdev, int indent) static void virtser_bus_dev_print(Monitor *mon, DeviceState *qdev, int indent)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册