From: Kirill Batuzov Date: Thu, 24 Apr 2014 14:15:56 +0000 (+0400) Subject: acpi/pcihp.c: Rewrite acpi_pcihp_get_bsel using object_property_get_int X-Git-Tag: qemu-xen-4.6.0-rc1~471^2~10 X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=7c38ecd09763107513bacc791856fdbb582a107c;p=qemu-upstream-4.6-testing.git acpi/pcihp.c: Rewrite acpi_pcihp_get_bsel using object_property_get_int acpi_pcihp_get_bsel implements functionality of object_property_get_int for specific property named ACPI_PCIHP_PROP_BSEL, but fails to decrement object's reference counter properly. Rewriting it using generic object_property_get_int serves two purposes: reducing code duplication and fixing memory leak. Signed-off-by: Kirill Batuzov Reviewed-by: Michael S. Tsirkin Signed-off-by: Michael S. Tsirkin --- diff --git a/hw/acpi/pcihp.c b/hw/acpi/pcihp.c index f80c48008..3b143b371 100644 --- a/hw/acpi/pcihp.c +++ b/hw/acpi/pcihp.c @@ -63,16 +63,18 @@ typedef struct AcpiPciHpFind { static int acpi_pcihp_get_bsel(PCIBus *bus) { - QObject *o = object_property_get_qobject(OBJECT(bus), - ACPI_PCIHP_PROP_BSEL, NULL); - int64_t bsel = -1; - if (o) { - bsel = qint_get_int(qobject_to_qint(o)); - } - if (bsel < 0) { + Error *local_err = NULL; + int64_t bsel = object_property_get_int(OBJECT(bus), ACPI_PCIHP_PROP_BSEL, + &local_err); + + if (local_err || bsel < 0 || bsel >= ACPI_PCIHP_MAX_HOTPLUG_BUS) { + if (local_err) { + error_free(local_err); + } return -1; + } else { + return bsel; } - return bsel; } static void acpi_pcihp_test_hotplug_bus(PCIBus *bus, void *opaque)