mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-03 07:43:54 -06:00
Fix pci_add nic not to exit on bad model
Monitor command "pci_add ADDR nic model=MODEL" uses pci_nic_init() to create the NIC. When MODEL is unknown or "?", this prints to stderr and terminates the program. Change pci_nic_init() not to treat "?" specially, and to return NULL on failure. Switch uses during startup to new convenience wrapper pci_nic_init_nofail(), which behaves just like pci_nic_init() used to do. Bonus bug fix: we now check for qdev_init() failing there. Signed-off-by: Markus Armbruster <armbru@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
9ee05825d9
commit
07caea315a
15 changed files with 71 additions and 32 deletions
33
hw/pci.c
33
hw/pci.c
|
@ -867,21 +867,48 @@ PCIDevice *pci_nic_init(NICInfo *nd, const char *default_model,
|
|||
const char *default_devaddr)
|
||||
{
|
||||
const char *devaddr = nd->devaddr ? nd->devaddr : default_devaddr;
|
||||
PCIBus *bus;
|
||||
int devfn;
|
||||
PCIDevice *pci_dev;
|
||||
DeviceState *dev;
|
||||
int i;
|
||||
|
||||
i = qemu_check_nic_model_list(nd, pci_nic_models, default_model);
|
||||
pci_dev = pci_create(pci_nic_names[i], devaddr);
|
||||
i = qemu_find_nic_model(nd, pci_nic_models, default_model);
|
||||
if (i < 0)
|
||||
return NULL;
|
||||
|
||||
bus = pci_get_bus_devfn(&devfn, devaddr);
|
||||
if (!bus) {
|
||||
qemu_error("Invalid PCI device address %s for device %s\n",
|
||||
devaddr, pci_nic_names[i]);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
pci_dev = pci_create_noinit(bus, devfn, pci_nic_names[i]);
|
||||
dev = &pci_dev->qdev;
|
||||
if (nd->id)
|
||||
dev->id = qemu_strdup(nd->id);
|
||||
dev->nd = nd;
|
||||
qdev_init(dev);
|
||||
if (qdev_init(dev) < 0)
|
||||
return NULL;
|
||||
nd->private = dev;
|
||||
return pci_dev;
|
||||
}
|
||||
|
||||
PCIDevice *pci_nic_init_nofail(NICInfo *nd, const char *default_model,
|
||||
const char *default_devaddr)
|
||||
{
|
||||
PCIDevice *res;
|
||||
|
||||
if (qemu_show_nic_models(nd->model, pci_nic_models))
|
||||
exit(0);
|
||||
|
||||
res = pci_nic_init(nd, default_model, default_devaddr);
|
||||
if (!res)
|
||||
exit(1);
|
||||
return res;
|
||||
}
|
||||
|
||||
typedef struct {
|
||||
PCIDevice dev;
|
||||
PCIBus bus;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue