qdev: make the non-legacy pci address property accept an integer
PCI addresses are set with qdev_prop_uint32. Thus we make the QOM property accept a device and function encoded in an 8-bit integer, instead of the magic dd.f hex string. Reviewed-by: Anthony Liguori <aliguori@us.ibm.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
e39e5d60c9
commit
b403298adb
@ -999,30 +999,20 @@ static int print_pci_devfn(DeviceState *dev, Property *prop, char *dest, size_t
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void get_pci_devfn(Object *obj, Visitor *v, void *opaque,
|
|
||||||
const char *name, Error **errp)
|
|
||||||
{
|
|
||||||
DeviceState *dev = DEVICE(obj);
|
|
||||||
Property *prop = opaque;
|
|
||||||
uint32_t *ptr = qdev_get_prop_ptr(dev, prop);
|
|
||||||
char buffer[32];
|
|
||||||
char *p = buffer;
|
|
||||||
|
|
||||||
buffer[0] = 0;
|
|
||||||
if (*ptr != -1) {
|
|
||||||
snprintf(buffer, sizeof(buffer), "%02x.%x", *ptr >> 3, *ptr & 7);
|
|
||||||
}
|
|
||||||
visit_type_str(v, &p, name, errp);
|
|
||||||
}
|
|
||||||
|
|
||||||
PropertyInfo qdev_prop_pci_devfn = {
|
PropertyInfo qdev_prop_pci_devfn = {
|
||||||
.name = "pci-devfn",
|
.name = "int32",
|
||||||
|
.legacy_name = "pci-devfn",
|
||||||
.type = PROP_TYPE_UINT32,
|
.type = PROP_TYPE_UINT32,
|
||||||
.size = sizeof(uint32_t),
|
.size = sizeof(uint32_t),
|
||||||
.parse = parse_pci_devfn,
|
.parse = parse_pci_devfn,
|
||||||
.print = print_pci_devfn,
|
.print = print_pci_devfn,
|
||||||
.get = get_pci_devfn,
|
.get = get_int32,
|
||||||
.set = set_generic,
|
.set = set_int32,
|
||||||
|
/* FIXME: this should be -1...255, but the address is stored
|
||||||
|
* into an uint32_t rather than int32_t.
|
||||||
|
*/
|
||||||
|
.min = 0,
|
||||||
|
.max = 0xFFFFFFFFULL,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* --- public helpers --- */
|
/* --- public helpers --- */
|
||||||
|
Loading…
Reference in New Issue
Block a user