|
Mark McLoughlin |
48e123 |
From 0ce1af6e7d4b1e2ffa4dedf6d415c4d86a1af490 Mon Sep 17 00:00:00 2001
|
|
Mark McLoughlin |
48e123 |
From: Markus Armbruster <armbru@redhat.com>
|
|
Mark McLoughlin |
48e123 |
Date: Fri, 25 Sep 2009 03:53:50 +0200
|
|
Mark McLoughlin |
48e123 |
Subject: [PATCH] Make it obvious that pci_nic_init() can't fail
|
|
Mark McLoughlin |
48e123 |
|
|
Mark McLoughlin |
48e123 |
Before this patch, pci_nic_init() returns NULL when it can't find the
|
|
Mark McLoughlin |
48e123 |
model in pci_nic_models[]. Except this can't happen, because
|
|
Mark McLoughlin |
48e123 |
qemu_check_nic_model_list() just searched for model in
|
|
Mark McLoughlin |
48e123 |
pci_nic_models[], and terminated the program on failure.
|
|
Mark McLoughlin |
48e123 |
|
|
Mark McLoughlin |
48e123 |
Repeating the search here is pointless. Instead, change
|
|
Mark McLoughlin |
48e123 |
qemu_check_nic_model_list() to return the model's array index.
|
|
Mark McLoughlin |
48e123 |
|
|
Mark McLoughlin |
48e123 |
Signed-off-by: Markus Armbruster <armbru@redhat.com>
|
|
Mark McLoughlin |
48e123 |
Signed-off-by: Mark McLoughlin
|
|
Mark McLoughlin |
48e123 |
Fedora-patch: qemu-do-not-exit-on-pci-hotplug-invalid-nic1.patch
|
|
Mark McLoughlin |
48e123 |
---
|
|
Mark McLoughlin |
48e123 |
hw/pci.c | 25 +++++++++----------------
|
|
Mark McLoughlin |
48e123 |
net.c | 6 +++---
|
|
Mark McLoughlin |
48e123 |
net.h | 4 ++--
|
|
Mark McLoughlin |
48e123 |
3 files changed, 14 insertions(+), 21 deletions(-)
|
|
Mark McLoughlin |
48e123 |
|
|
Mark McLoughlin |
48e123 |
diff --git a/hw/pci.c b/hw/pci.c
|
|
Mark McLoughlin |
48e123 |
index a575d4a..eb990f9 100644
|
|
Mark McLoughlin |
48e123 |
--- a/hw/pci.c
|
|
Mark McLoughlin |
48e123 |
+++ b/hw/pci.c
|
|
Mark McLoughlin |
48e123 |
@@ -937,22 +937,15 @@ PCIDevice *pci_nic_init(NICInfo *nd, const char *default_model,
|
|
Mark McLoughlin |
48e123 |
DeviceState *dev;
|
|
Mark McLoughlin |
48e123 |
int i;
|
|
Mark McLoughlin |
48e123 |
|
|
Mark McLoughlin |
48e123 |
- qemu_check_nic_model_list(nd, pci_nic_models, default_model);
|
|
Mark McLoughlin |
48e123 |
-
|
|
Mark McLoughlin |
48e123 |
- for (i = 0; pci_nic_models[i]; i++) {
|
|
Mark McLoughlin |
48e123 |
- if (strcmp(nd->model, pci_nic_models[i]) == 0) {
|
|
Mark McLoughlin |
48e123 |
- pci_dev = pci_create(pci_nic_names[i], devaddr);
|
|
Mark McLoughlin |
48e123 |
- dev = &pci_dev->qdev;
|
|
Mark McLoughlin |
48e123 |
- if (nd->id)
|
|
Mark McLoughlin |
48e123 |
- dev->id = qemu_strdup(nd->id);
|
|
Mark McLoughlin |
48e123 |
- dev->nd = nd;
|
|
Mark McLoughlin |
48e123 |
- qdev_init(dev);
|
|
Mark McLoughlin |
48e123 |
- nd->private = dev;
|
|
Mark McLoughlin |
48e123 |
- return pci_dev;
|
|
Mark McLoughlin |
48e123 |
- }
|
|
Mark McLoughlin |
48e123 |
- }
|
|
Mark McLoughlin |
48e123 |
-
|
|
Mark McLoughlin |
48e123 |
- return NULL;
|
|
Mark McLoughlin |
48e123 |
+ i = qemu_check_nic_model_list(nd, pci_nic_models, default_model);
|
|
Mark McLoughlin |
48e123 |
+ pci_dev = pci_create(pci_nic_names[i], devaddr);
|
|
Mark McLoughlin |
48e123 |
+ dev = &pci_dev->qdev;
|
|
Mark McLoughlin |
48e123 |
+ if (nd->id)
|
|
Mark McLoughlin |
48e123 |
+ dev->id = qemu_strdup(nd->id);
|
|
Mark McLoughlin |
48e123 |
+ dev->nd = nd;
|
|
Mark McLoughlin |
48e123 |
+ qdev_init(dev);
|
|
Mark McLoughlin |
48e123 |
+ nd->private = dev;
|
|
Mark McLoughlin |
48e123 |
+ return pci_dev;
|
|
Mark McLoughlin |
48e123 |
}
|
|
Mark McLoughlin |
48e123 |
|
|
Mark McLoughlin |
48e123 |
typedef struct {
|
|
Mark McLoughlin |
48e123 |
diff --git a/net.c b/net.c
|
|
Mark McLoughlin |
48e123 |
index da2f428..047e72e 100644
|
|
Mark McLoughlin |
48e123 |
--- a/net.c
|
|
Mark McLoughlin |
48e123 |
+++ b/net.c
|
|
Mark McLoughlin |
48e123 |
@@ -2553,8 +2553,8 @@ void qemu_check_nic_model(NICInfo *nd, const char *model)
|
|
Mark McLoughlin |
48e123 |
qemu_check_nic_model_list(nd, models, model);
|
|
Mark McLoughlin |
48e123 |
}
|
|
Mark McLoughlin |
48e123 |
|
|
Mark McLoughlin |
48e123 |
-void qemu_check_nic_model_list(NICInfo *nd, const char * const *models,
|
|
Mark McLoughlin |
48e123 |
- const char *default_model)
|
|
Mark McLoughlin |
48e123 |
+int qemu_check_nic_model_list(NICInfo *nd, const char * const *models,
|
|
Mark McLoughlin |
48e123 |
+ const char *default_model)
|
|
Mark McLoughlin |
48e123 |
{
|
|
Mark McLoughlin |
48e123 |
int i, exit_status = 0;
|
|
Mark McLoughlin |
48e123 |
|
|
Mark McLoughlin |
48e123 |
@@ -2564,7 +2564,7 @@ void qemu_check_nic_model_list(NICInfo *nd, const char * const *models,
|
|
Mark McLoughlin |
48e123 |
if (strcmp(nd->model, "?") != 0) {
|
|
Mark McLoughlin |
48e123 |
for (i = 0 ; models[i]; i++)
|
|
Mark McLoughlin |
48e123 |
if (strcmp(nd->model, models[i]) == 0)
|
|
Mark McLoughlin |
48e123 |
- return;
|
|
Mark McLoughlin |
48e123 |
+ return i;
|
|
Mark McLoughlin |
48e123 |
|
|
Mark McLoughlin |
48e123 |
fprintf(stderr, "qemu: Unsupported NIC model: %s\n", nd->model);
|
|
Mark McLoughlin |
48e123 |
exit_status = 1;
|
|
Mark McLoughlin |
48e123 |
diff --git a/net.h b/net.h
|
|
Mark McLoughlin |
48e123 |
index 94db0d7..9662988 100644
|
|
Mark McLoughlin |
48e123 |
--- a/net.h
|
|
Mark McLoughlin |
48e123 |
+++ b/net.h
|
|
Mark McLoughlin |
48e123 |
@@ -80,8 +80,8 @@ void qemu_purge_queued_packets(VLANClientState *vc);
|
|
Mark McLoughlin |
48e123 |
void qemu_flush_queued_packets(VLANClientState *vc);
|
|
Mark McLoughlin |
48e123 |
void qemu_format_nic_info_str(VLANClientState *vc, uint8_t macaddr[6]);
|
|
Mark McLoughlin |
48e123 |
void qemu_check_nic_model(NICInfo *nd, const char *model);
|
|
Mark McLoughlin |
48e123 |
-void qemu_check_nic_model_list(NICInfo *nd, const char * const *models,
|
|
Mark McLoughlin |
48e123 |
- const char *default_model);
|
|
Mark McLoughlin |
48e123 |
+int qemu_check_nic_model_list(NICInfo *nd, const char * const *models,
|
|
Mark McLoughlin |
48e123 |
+ const char *default_model);
|
|
Mark McLoughlin |
48e123 |
void qemu_handler_true(void *opaque);
|
|
Mark McLoughlin |
48e123 |
|
|
Mark McLoughlin |
48e123 |
void do_info_network(Monitor *mon);
|
|
Mark McLoughlin |
48e123 |
--
|
|
Mark McLoughlin |
48e123 |
1.6.2.5
|
|
Mark McLoughlin |
48e123 |
|