aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Gibson <david@gibson.dropbear.id.au>2011-11-13 17:18:58 +0000
committerAlexander Graf <agraf@suse.de>2011-11-18 14:22:45 +0100
commit5435352ce6abfb8a7540ae7d47e981d329120cca (patch)
treea05e6df0b43eeefc37c73e36711ffe77f131568a
parent92c93a816a8c04071264f9fb47cbc90a5e1ae5d8 (diff)
downloadqemu-5435352ce6abfb8a7540ae7d47e981d329120cca.zip
qemu-5435352ce6abfb8a7540ae7d47e981d329120cca.tar.gz
qemu-5435352ce6abfb8a7540ae7d47e981d329120cca.tar.bz2
pseries: Fix buggy spapr_vio_find_by_reg()
The spapr_vio_find_by_reg() function in hw/spapr_vio.c is supposed to find the device structure for a PAPR virtual IO device with the given reg value, and return NULL if none exists. It does the first ok, but if no device with that reg exists, it just returns the last device traversed in the list. This patch fixes it. Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Alexander Graf <agraf@suse.de>
-rw-r--r--hw/spapr_vio.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/hw/spapr_vio.c b/hw/spapr_vio.c
index 25cfc9d..b7b3ddd 100644
--- a/hw/spapr_vio.c
+++ b/hw/spapr_vio.c
@@ -66,11 +66,11 @@ VIOsPAPRDevice *spapr_vio_find_by_reg(VIOsPAPRBus *bus, uint32_t reg)
QTAILQ_FOREACH(qdev, &bus->bus.children, sibling) {
dev = (VIOsPAPRDevice *)qdev;
if (dev->reg == reg) {
- break;
+ return dev;
}
}
- return dev;
+ return NULL;
}
#ifdef CONFIG_FDT