qdev: remove parse/print methods for mac properties

Reviewed-by: Anthony Liguori <aliguori@us.ibm.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
Paolo Bonzini 2012-02-02 17:08:47 +01:00
parent 1ce0512557
commit e39e5d60c9

View File

@ -848,46 +848,69 @@ PropertyInfo qdev_prop_ptr = {
* 01:02:03:04:05:06 * 01:02:03:04:05:06
* 01-02-03-04-05-06 * 01-02-03-04-05-06
*/ */
static int parse_mac(DeviceState *dev, Property *prop, const char *str) static void get_mac(Object *obj, Visitor *v, void *opaque,
const char *name, Error **errp)
{ {
DeviceState *dev = DEVICE(obj);
Property *prop = opaque;
MACAddr *mac = qdev_get_prop_ptr(dev, prop); MACAddr *mac = qdev_get_prop_ptr(dev, prop);
char buffer[2 * 6 + 5 + 1];
char *p = buffer;
snprintf(buffer, sizeof(buffer), "%02x:%02x:%02x:%02x:%02x:%02x",
mac->a[0], mac->a[1], mac->a[2],
mac->a[3], mac->a[4], mac->a[5]);
visit_type_str(v, &p, name, errp);
}
static void set_mac(Object *obj, Visitor *v, void *opaque,
const char *name, Error **errp)
{
DeviceState *dev = DEVICE(obj);
Property *prop = opaque;
MACAddr *mac = qdev_get_prop_ptr(dev, prop);
Error *local_err = NULL;
int i, pos; int i, pos;
char *p; char *str, *p;
if (dev->state != DEV_STATE_CREATED) {
error_set(errp, QERR_PERMISSION_DENIED);
return;
}
visit_type_str(v, &str, name, &local_err);
if (local_err) {
error_propagate(errp, local_err);
return;
}
for (i = 0, pos = 0; i < 6; i++, pos += 3) { for (i = 0, pos = 0; i < 6; i++, pos += 3) {
if (!qemu_isxdigit(str[pos])) if (!qemu_isxdigit(str[pos]))
return -EINVAL; goto inval;
if (!qemu_isxdigit(str[pos+1])) if (!qemu_isxdigit(str[pos+1]))
return -EINVAL; goto inval;
if (i == 5) { if (i == 5) {
if (str[pos+2] != '\0') if (str[pos+2] != '\0')
return -EINVAL; goto inval;
} else { } else {
if (str[pos+2] != ':' && str[pos+2] != '-') if (str[pos+2] != ':' && str[pos+2] != '-')
return -EINVAL; goto inval;
} }
mac->a[i] = strtol(str+pos, &p, 16); mac->a[i] = strtol(str+pos, &p, 16);
} }
return 0; return;
}
static int print_mac(DeviceState *dev, Property *prop, char *dest, size_t len) inval:
{ error_set_from_qdev_prop_error(errp, EINVAL, dev, prop, str);
MACAddr *mac = qdev_get_prop_ptr(dev, prop);
return snprintf(dest, len, "%02x:%02x:%02x:%02x:%02x:%02x",
mac->a[0], mac->a[1], mac->a[2],
mac->a[3], mac->a[4], mac->a[5]);
} }
PropertyInfo qdev_prop_macaddr = { PropertyInfo qdev_prop_macaddr = {
.name = "macaddr", .name = "macaddr",
.type = PROP_TYPE_MACADDR, .type = PROP_TYPE_MACADDR,
.size = sizeof(MACAddr), .size = sizeof(MACAddr),
.parse = parse_mac, .get = get_mac,
.print = print_mac, .set = set_mac,
.get = get_generic,
.set = set_generic,
}; };