]> xenbits.xensource.com Git - qemu-xen.git/commitdiff
qdev: fix 64 bit properties
authorCornelia Huck <cornelia.huck@de.ibm.com>
Thu, 9 Jul 2015 11:01:14 +0000 (13:01 +0200)
committerMichael S. Tsirkin <mst@redhat.com>
Mon, 13 Jul 2015 11:42:24 +0000 (14:42 +0300)
64 bit props used 32 bit callbacks in two places, leading to broken
feature bits on virtio (example: got 0x31000000000006d4 which is
obviously bogus). Fix this.

Fixes: fdba6d96 ("qdev: add 64bit properties")
Signed-off-by: Cornelia Huck <cornelia.huck@de.ibm.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Tested-by: Christian Borntraeger <borntraeger@de.ibm.com>
Acked-by: Paolo Bonzini <pbonzini@redhat.com>
hw/core/qdev-properties.c
include/hw/qdev-properties.h

index e9e686f26034c8290f8ec702d0f8a7079aecce7f..04fd80a4de3a088c4847ee45f587a0c5efcda59f 100644 (file)
@@ -130,7 +130,7 @@ PropertyInfo qdev_prop_bit = {
 
 static uint64_t qdev_get_prop_mask64(Property *prop)
 {
-    assert(prop->info == &qdev_prop_bit);
+    assert(prop->info == &qdev_prop_bit64);
     return 0x1ull << prop->bitnr;
 }
 
index 0cfff1c77cf0177a06fbd80eb4eb394cfc56ec4e..77538a8ca22a7a860543de47423dc637648932fa 100644 (file)
@@ -53,7 +53,7 @@ extern PropertyInfo qdev_prop_arraylen;
         }
 #define DEFINE_PROP_BIT64(_name, _state, _field, _bit, _defval) {       \
         .name      = (_name),                                           \
-        .info      = &(qdev_prop_bit),                                  \
+        .info      = &(qdev_prop_bit64),                                \
         .bitnr    = (_bit),                                             \
         .offset    = offsetof(_state, _field)                           \
             + type_check(uint64_t, typeof_field(_state, _field)),       \