qom: Swap 'name' next to visitor in ObjectPropertyAccessor

Similar to the previous patch, it's nice to have all functions
in the tree that involve a visitor and a name for conversion to
or from QAPI to consistently stick the 'name' parameter next
to the Visitor parameter.

Done by manually changing include/qom/object.h and qom/object.c,
then running this Coccinelle script and touching up the fallout
(Coccinelle insisted on adding some trailing whitespace).

@ rule1 @
identifier fn;
typedef Object, Visitor, Error;
identifier obj, v, opaque, name, errp;
@@
void fn
- (Object *obj, Visitor *v, void *opaque, const char *name,
+ (Object *obj, Visitor *v, const char *name, void *opaque,
Error **errp) { ... }

@@
identifier rule1.fn;
expression obj, v, opaque, name, errp;
@@
fn(obj, v,
- opaque, name,
+ name, opaque,
errp)

Backports commit d7bce9999df85c56c8cb1fcffd944d51bff8ff48 from qemu
This commit is contained in:
Eric Blake 2018-02-19 22:57:03 -05:00 committed by Lioncash
parent 5dd5646a9a
commit 9ec25b4673
No known key found for this signature in database
GPG key ID: 4E3C3CC1031BA9C7
7 changed files with 212 additions and 190 deletions

View file

@ -29,7 +29,7 @@ void qapi_free_DummyForceArrays(DummyForceArrays *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_DummyForceArrays(v, &obj, NULL, NULL); visit_type_DummyForceArrays(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -66,7 +66,7 @@ void qapi_free_X86CPUFeatureWordInfo(X86CPUFeatureWordInfo *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_X86CPUFeatureWordInfo(v, &obj, NULL, NULL); visit_type_X86CPUFeatureWordInfo(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -81,7 +81,7 @@ void qapi_free_X86CPUFeatureWordInfoList(X86CPUFeatureWordInfoList *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_X86CPUFeatureWordInfoList(v, &obj, NULL, NULL); visit_type_X86CPUFeatureWordInfoList(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -108,7 +108,7 @@ void qapi_free_anyList(anyList *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_anyList(v, &obj, NULL, NULL); visit_type_anyList(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -123,7 +123,7 @@ void qapi_free_boolList(boolList *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_boolList(v, &obj, NULL, NULL); visit_type_boolList(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -138,7 +138,7 @@ void qapi_free_int16List(int16List *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_int16List(v, &obj, NULL, NULL); visit_type_int16List(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -153,7 +153,7 @@ void qapi_free_int32List(int32List *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_int32List(v, &obj, NULL, NULL); visit_type_int32List(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -168,7 +168,7 @@ void qapi_free_int64List(int64List *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_int64List(v, &obj, NULL, NULL); visit_type_int64List(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -183,7 +183,7 @@ void qapi_free_int8List(int8List *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_int8List(v, &obj, NULL, NULL); visit_type_int8List(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -198,7 +198,7 @@ void qapi_free_intList(intList *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_intList(v, &obj, NULL, NULL); visit_type_intList(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -213,7 +213,7 @@ void qapi_free_numberList(numberList *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_numberList(v, &obj, NULL, NULL); visit_type_numberList(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -228,7 +228,7 @@ void qapi_free_sizeList(sizeList *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_sizeList(v, &obj, NULL, NULL); visit_type_sizeList(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -243,7 +243,7 @@ void qapi_free_strList(strList *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_strList(v, &obj, NULL, NULL); visit_type_strList(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -258,7 +258,7 @@ void qapi_free_uint16List(uint16List *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_uint16List(v, &obj, NULL, NULL); visit_type_uint16List(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -273,7 +273,7 @@ void qapi_free_uint32List(uint32List *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_uint32List(v, &obj, NULL, NULL); visit_type_uint32List(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -288,7 +288,7 @@ void qapi_free_uint64List(uint64List *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_uint64List(v, &obj, NULL, NULL); visit_type_uint64List(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }
@ -303,6 +303,6 @@ void qapi_free_uint8List(uint8List *obj)
qdv = qapi_dealloc_visitor_new(); qdv = qapi_dealloc_visitor_new();
v = qapi_dealloc_get_visitor(qdv); v = qapi_dealloc_get_visitor(qdv);
visit_type_uint8List(v, &obj, NULL, NULL); visit_type_uint8List(v, NULL, &obj, NULL);
qapi_dealloc_visitor_cleanup(qdv); qapi_dealloc_visitor_cleanup(qdv);
} }

View file

@ -20,7 +20,7 @@ static void visit_type_DummyForceArrays_fields(Visitor *v, DummyForceArrays **ob
{ {
Error *err = NULL; Error *err = NULL;
visit_type_X86CPUFeatureWordInfoList(v, &(*obj)->unused, "unused", &err); visit_type_X86CPUFeatureWordInfoList(v, "unused", &(*obj)->unused, &err);
if (err) { if (err) {
goto out; goto out;
} }
@ -29,11 +29,11 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_DummyForceArrays(Visitor *v, DummyForceArrays **obj, const char *name, Error **errp) void visit_type_DummyForceArrays(Visitor *v, const char *name, DummyForceArrays **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
visit_start_struct(v, (void **)obj, "DummyForceArrays", name, sizeof(DummyForceArrays), &err); visit_start_struct(v, name, (void **)obj, "DummyForceArrays", sizeof(DummyForceArrays), &err);
if (err) { if (err) {
goto out; goto out;
@ -50,17 +50,17 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_QType(Visitor *v, QType *obj, const char *name, Error **errp) void visit_type_QType(Visitor *v, const char *name, QType *obj, Error **errp)
{ {
int value = *obj; int value = *obj;
visit_type_enum(v, &value, QType_lookup, "QType", name, errp); visit_type_enum(v, name, &value, QType_lookup, "QType", errp);
*obj = value; *obj = value;
} }
void visit_type_QapiErrorClass(Visitor *v, QapiErrorClass *obj, const char *name, Error **errp) void visit_type_QapiErrorClass(Visitor *v, const char *name, QapiErrorClass *obj, Error **errp)
{ {
int value = *obj; int value = *obj;
visit_type_enum(v, &value, QapiErrorClass_lookup, "QapiErrorClass", name, errp); visit_type_enum(v, name, &value, QapiErrorClass_lookup, "QapiErrorClass", errp);
*obj = value; *obj = value;
} }
@ -68,21 +68,21 @@ static void visit_type_X86CPUFeatureWordInfo_fields(Visitor *v, X86CPUFeatureWor
{ {
Error *err = NULL; Error *err = NULL;
visit_type_int(v, &(*obj)->cpuid_input_eax, "cpuid-input-eax", &err); visit_type_int(v, "cpuid-input-eax", &(*obj)->cpuid_input_eax, &err);
if (err) { if (err) {
goto out; goto out;
} }
if (visit_optional(v, &(*obj)->has_cpuid_input_ecx, "cpuid-input-ecx")) { if (visit_optional(v, "cpuid-input-ecx", &(*obj)->has_cpuid_input_ecx)) {
visit_type_int(v, &(*obj)->cpuid_input_ecx, "cpuid-input-ecx", &err); visit_type_int(v, "cpuid-input-ecx", &(*obj)->cpuid_input_ecx, &err);
if (err) { if (err) {
goto out; goto out;
} }
} }
visit_type_X86CPURegister32(v, &(*obj)->cpuid_register, "cpuid-register", &err); visit_type_X86CPURegister32(v, "cpuid-register", &(*obj)->cpuid_register, &err);
if (err) { if (err) {
goto out; goto out;
} }
visit_type_int(v, &(*obj)->features, "features", &err); visit_type_int(v, "features", &(*obj)->features, &err);
if (err) { if (err) {
goto out; goto out;
} }
@ -91,11 +91,11 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_X86CPUFeatureWordInfo(Visitor *v, X86CPUFeatureWordInfo **obj, const char *name, Error **errp) void visit_type_X86CPUFeatureWordInfo(Visitor *v, const char *name, X86CPUFeatureWordInfo **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
visit_start_struct(v, (void **)obj, "X86CPUFeatureWordInfo", name, sizeof(X86CPUFeatureWordInfo), &err); visit_start_struct(v, name, (void **)obj, "X86CPUFeatureWordInfo", sizeof(X86CPUFeatureWordInfo), &err);
if (err) { if (err) {
goto out; goto out;
@ -112,7 +112,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_X86CPUFeatureWordInfoList(Visitor *v, X86CPUFeatureWordInfoList **obj, const char *name, Error **errp) void visit_type_X86CPUFeatureWordInfoList(Visitor *v, const char *name, X86CPUFeatureWordInfoList **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -126,7 +126,7 @@ void visit_type_X86CPUFeatureWordInfoList(Visitor *v, X86CPUFeatureWordInfoList
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
X86CPUFeatureWordInfoList *native_i = (X86CPUFeatureWordInfoList *)i; X86CPUFeatureWordInfoList *native_i = (X86CPUFeatureWordInfoList *)i;
visit_type_X86CPUFeatureWordInfo(v, &native_i->value, NULL, &err); visit_type_X86CPUFeatureWordInfo(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -136,14 +136,14 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_X86CPURegister32(Visitor *v, X86CPURegister32 *obj, const char *name, Error **errp) void visit_type_X86CPURegister32(Visitor *v, const char *name, X86CPURegister32 *obj, Error **errp)
{ {
int value = *obj; int value = *obj;
visit_type_enum(v, &value, X86CPURegister32_lookup, "X86CPURegister32", name, errp); visit_type_enum(v, name, &value, X86CPURegister32_lookup, "X86CPURegister32", errp);
*obj = value; *obj = value;
} }
void visit_type_anyList(Visitor *v, anyList **obj, const char *name, Error **errp) void visit_type_anyList(Visitor *v, const char *name, anyList **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -157,7 +157,7 @@ void visit_type_anyList(Visitor *v, anyList **obj, const char *name, Error **err
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
anyList *native_i = (anyList *)i; anyList *native_i = (anyList *)i;
visit_type_any(v, &native_i->value, NULL, &err); visit_type_any(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -167,7 +167,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_boolList(Visitor *v, boolList **obj, const char *name, Error **errp) void visit_type_boolList(Visitor *v, const char *name, boolList **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -181,7 +181,7 @@ void visit_type_boolList(Visitor *v, boolList **obj, const char *name, Error **e
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
boolList *native_i = (boolList *)i; boolList *native_i = (boolList *)i;
visit_type_bool(v, &native_i->value, NULL, &err); visit_type_bool(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -191,7 +191,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_int16List(Visitor *v, int16List **obj, const char *name, Error **errp) void visit_type_int16List(Visitor *v, const char *name, int16List **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -205,7 +205,7 @@ void visit_type_int16List(Visitor *v, int16List **obj, const char *name, Error *
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
int16List *native_i = (int16List *)i; int16List *native_i = (int16List *)i;
visit_type_int16(v, &native_i->value, NULL, &err); visit_type_int16(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -215,7 +215,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_int32List(Visitor *v, int32List **obj, const char *name, Error **errp) void visit_type_int32List(Visitor *v, const char *name, int32List **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -229,7 +229,7 @@ void visit_type_int32List(Visitor *v, int32List **obj, const char *name, Error *
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
int32List *native_i = (int32List *)i; int32List *native_i = (int32List *)i;
visit_type_int32(v, &native_i->value, NULL, &err); visit_type_int32(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -239,7 +239,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_int64List(Visitor *v, int64List **obj, const char *name, Error **errp) void visit_type_int64List(Visitor *v, const char *name, int64List **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -253,7 +253,7 @@ void visit_type_int64List(Visitor *v, int64List **obj, const char *name, Error *
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
int64List *native_i = (int64List *)i; int64List *native_i = (int64List *)i;
visit_type_int64(v, &native_i->value, NULL, &err); visit_type_int64(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -263,7 +263,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_int8List(Visitor *v, int8List **obj, const char *name, Error **errp) void visit_type_int8List(Visitor *v, const char *name, int8List **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -277,7 +277,7 @@ void visit_type_int8List(Visitor *v, int8List **obj, const char *name, Error **e
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
int8List *native_i = (int8List *)i; int8List *native_i = (int8List *)i;
visit_type_int8(v, &native_i->value, NULL, &err); visit_type_int8(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -287,7 +287,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_intList(Visitor *v, intList **obj, const char *name, Error **errp) void visit_type_intList(Visitor *v, const char *name, intList **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -301,7 +301,7 @@ void visit_type_intList(Visitor *v, intList **obj, const char *name, Error **err
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
intList *native_i = (intList *)i; intList *native_i = (intList *)i;
visit_type_int(v, &native_i->value, NULL, &err); visit_type_int(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -311,7 +311,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_numberList(Visitor *v, numberList **obj, const char *name, Error **errp) void visit_type_numberList(Visitor *v, const char *name, numberList **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -325,7 +325,7 @@ void visit_type_numberList(Visitor *v, numberList **obj, const char *name, Error
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
numberList *native_i = (numberList *)i; numberList *native_i = (numberList *)i;
visit_type_number(v, &native_i->value, NULL, &err); visit_type_number(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -335,7 +335,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_sizeList(Visitor *v, sizeList **obj, const char *name, Error **errp) void visit_type_sizeList(Visitor *v, const char *name, sizeList **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -349,7 +349,7 @@ void visit_type_sizeList(Visitor *v, sizeList **obj, const char *name, Error **e
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
sizeList *native_i = (sizeList *)i; sizeList *native_i = (sizeList *)i;
visit_type_size(v, &native_i->value, NULL, &err); visit_type_size(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -359,7 +359,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_strList(Visitor *v, strList **obj, const char *name, Error **errp) void visit_type_strList(Visitor *v, const char *name, strList **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -373,7 +373,7 @@ void visit_type_strList(Visitor *v, strList **obj, const char *name, Error **err
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
strList *native_i = (strList *)i; strList *native_i = (strList *)i;
visit_type_str(v, &native_i->value, NULL, &err); visit_type_str(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -383,7 +383,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_uint16List(Visitor *v, uint16List **obj, const char *name, Error **errp) void visit_type_uint16List(Visitor *v, const char *name, uint16List **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -397,7 +397,7 @@ void visit_type_uint16List(Visitor *v, uint16List **obj, const char *name, Error
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
uint16List *native_i = (uint16List *)i; uint16List *native_i = (uint16List *)i;
visit_type_uint16(v, &native_i->value, NULL, &err); visit_type_uint16(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -407,7 +407,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_uint32List(Visitor *v, uint32List **obj, const char *name, Error **errp) void visit_type_uint32List(Visitor *v, const char *name, uint32List **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -421,7 +421,7 @@ void visit_type_uint32List(Visitor *v, uint32List **obj, const char *name, Error
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
uint32List *native_i = (uint32List *)i; uint32List *native_i = (uint32List *)i;
visit_type_uint32(v, &native_i->value, NULL, &err); visit_type_uint32(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -431,7 +431,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_uint64List(Visitor *v, uint64List **obj, const char *name, Error **errp) void visit_type_uint64List(Visitor *v, const char *name, uint64List **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -445,7 +445,7 @@ void visit_type_uint64List(Visitor *v, uint64List **obj, const char *name, Error
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
uint64List *native_i = (uint64List *)i; uint64List *native_i = (uint64List *)i;
visit_type_uint64(v, &native_i->value, NULL, &err); visit_type_uint64(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);
@ -455,7 +455,7 @@ out:
error_propagate(errp, err); error_propagate(errp, err);
} }
void visit_type_uint8List(Visitor *v, uint8List **obj, const char *name, Error **errp) void visit_type_uint8List(Visitor *v, const char *name, uint8List **obj, Error **errp)
{ {
Error *err = NULL; Error *err = NULL;
GenericList *i, **prev; GenericList *i, **prev;
@ -469,7 +469,7 @@ void visit_type_uint8List(Visitor *v, uint8List **obj, const char *name, Error *
!err && (i = visit_next_list(v, prev)) != NULL; !err && (i = visit_next_list(v, prev)) != NULL;
prev = &i) { prev = &i) {
uint8List *native_i = (uint8List *)i; uint8List *native_i = (uint8List *)i;
visit_type_uint8(v, &native_i->value, NULL, &err); visit_type_uint8(v, NULL, &native_i->value, &err);
} }
error_propagate(errp, err); error_propagate(errp, err);

View file

@ -24,28 +24,28 @@
#ifndef QAPI_VISIT_BUILTIN #ifndef QAPI_VISIT_BUILTIN
#define QAPI_VISIT_BUILTIN #define QAPI_VISIT_BUILTIN
void visit_type_QType(Visitor *v, QType *obj, const char *name, Error **errp); void visit_type_QType(Visitor *v, const char *name, QType *obj, Error **errp);
void visit_type_anyList(Visitor *v, anyList **obj, const char *name, Error **errp); void visit_type_anyList(Visitor *v, const char *name, anyList **obj, Error **errp);
void visit_type_boolList(Visitor *v, boolList **obj, const char *name, Error **errp); void visit_type_boolList(Visitor *v, const char *name, boolList **obj, Error **errp);
void visit_type_int16List(Visitor *v, int16List **obj, const char *name, Error **errp); void visit_type_int16List(Visitor *v, const char *name, int16List **obj, Error **errp);
void visit_type_int32List(Visitor *v, int32List **obj, const char *name, Error **errp); void visit_type_int32List(Visitor *v, const char *name, int32List **obj, Error **errp);
void visit_type_int64List(Visitor *v, int64List **obj, const char *name, Error **errp); void visit_type_int64List(Visitor *v, const char *name, int64List **obj, Error **errp);
void visit_type_int8List(Visitor *v, int8List **obj, const char *name, Error **errp); void visit_type_int8List(Visitor *v, const char *name, int8List **obj, Error **errp);
void visit_type_intList(Visitor *v, intList **obj, const char *name, Error **errp); void visit_type_intList(Visitor *v, const char *name, intList **obj, Error **errp);
void visit_type_numberList(Visitor *v, numberList **obj, const char *name, Error **errp); void visit_type_numberList(Visitor *v, const char *name, numberList **obj, Error **errp);
void visit_type_sizeList(Visitor *v, sizeList **obj, const char *name, Error **errp); void visit_type_sizeList(Visitor *v, const char *name, sizeList **obj, Error **errp);
void visit_type_strList(Visitor *v, strList **obj, const char *name, Error **errp); void visit_type_strList(Visitor *v, const char *name, strList **obj, Error **errp);
void visit_type_uint16List(Visitor *v, uint16List **obj, const char *name, Error **errp); void visit_type_uint16List(Visitor *v, const char *name, uint16List **obj, Error **errp);
void visit_type_uint32List(Visitor *v, uint32List **obj, const char *name, Error **errp); void visit_type_uint32List(Visitor *v, const char *name, uint32List **obj, Error **errp);
void visit_type_uint64List(Visitor *v, uint64List **obj, const char *name, Error **errp); void visit_type_uint64List(Visitor *v, const char *name, uint64List **obj, Error **errp);
void visit_type_uint8List(Visitor *v, uint8List **obj, const char *name, Error **errp); void visit_type_uint8List(Visitor *v, const char *name, uint8List **obj, Error **errp);
#endif /* QAPI_VISIT_BUILTIN */ #endif /* QAPI_VISIT_BUILTIN */
void visit_type_DummyForceArrays(Visitor *v, DummyForceArrays **obj, const char *name, Error **errp); void visit_type_DummyForceArrays(Visitor *v, const char *name, DummyForceArrays **obj, Error **errp);
void visit_type_QapiErrorClass(Visitor *v, QapiErrorClass *obj, const char *name, Error **errp); void visit_type_QapiErrorClass(Visitor *v, const char *name, QapiErrorClass *obj, Error **errp);
void visit_type_X86CPUFeatureWordInfo(Visitor *v, X86CPUFeatureWordInfo **obj, const char *name, Error **errp); void visit_type_X86CPUFeatureWordInfo(Visitor *v, const char *name, X86CPUFeatureWordInfo **obj, Error **errp);
void visit_type_X86CPUFeatureWordInfoList(Visitor *v, X86CPUFeatureWordInfoList **obj, const char *name, Error **errp); void visit_type_X86CPUFeatureWordInfoList(Visitor *v, const char *name, X86CPUFeatureWordInfoList **obj, Error **errp);
void visit_type_X86CPURegister32(Visitor *v, X86CPURegister32 *obj, const char *name, Error **errp); void visit_type_X86CPURegister32(Visitor *v, const char *name, X86CPURegister32 *obj, Error **errp);
#endif #endif

View file

@ -291,21 +291,16 @@ struct uc_struct;
* ObjectPropertyAccessor: * ObjectPropertyAccessor:
* @obj: the object that owns the property * @obj: the object that owns the property
* @v: the visitor that contains the property data * @v: the visitor that contains the property data
* @opaque: the object property opaque
* @name: the name of the property * @name: the name of the property
* @opaque: the object property opaque
* @errp: a pointer to an Error that is filled if getting/setting fails. * @errp: a pointer to an Error that is filled if getting/setting fails.
* *
* Called when trying to get/set a property. * Called when trying to get/set a property.
*/ */
typedef void (ObjectPropertyAccessor)(struct uc_struct *uc, Object *obj, typedef void (ObjectPropertyAccessor)(struct uc_struct *uc, Object *obj,
Visitor *v, Visitor *v,
void *opaque,
const char *name, const char *name,
Error **errp);
typedef int (ObjectPropertySetAccessor)(struct uc_struct *uc, Object *obj,
Visitor *v,
void *opaque, void *opaque,
const char *name,
Error **errp); Error **errp);
/** /**
@ -345,7 +340,7 @@ typedef struct ObjectProperty
gchar *type; gchar *type;
gchar *description; gchar *description;
ObjectPropertyAccessor *get; ObjectPropertyAccessor *get;
ObjectPropertySetAccessor *set; ObjectPropertyAccessor *set;
ObjectPropertyResolve *resolve; ObjectPropertyResolve *resolve;
ObjectPropertyRelease *release; ObjectPropertyRelease *release;
void *opaque; void *opaque;
@ -802,7 +797,7 @@ void object_unref(struct uc_struct *uc, Object *obj);
ObjectProperty *object_property_add(Object *obj, const char *name, ObjectProperty *object_property_add(Object *obj, const char *name,
const char *type, const char *type,
ObjectPropertyAccessor *get, ObjectPropertyAccessor *get,
ObjectPropertySetAccessor *set, ObjectPropertyAccessor *set,
ObjectPropertyRelease *release, ObjectPropertyRelease *release,
void *opaque, Error **errp); void *opaque, Error **errp);

View file

@ -886,8 +886,10 @@ void memory_region_init(struct uc_struct *uc, MemoryRegion *mr,
} }
} }
static void memory_region_get_addr(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void memory_region_get_addr(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
MemoryRegion *mr = MEMORY_REGION(uc, obj); MemoryRegion *mr = MEMORY_REGION(uc, obj);
uint64_t value = mr->addr; uint64_t value = mr->addr;
@ -895,8 +897,10 @@ static void memory_region_get_addr(struct uc_struct *uc, Object *obj, Visitor *v
visit_type_uint64(v, name, &value, errp); visit_type_uint64(v, name, &value, errp);
} }
static void memory_region_get_container(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void memory_region_get_container(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
MemoryRegion *mr = MEMORY_REGION(uc, obj); MemoryRegion *mr = MEMORY_REGION(uc, obj);
gchar *path = (gchar *)""; gchar *path = (gchar *)"";
@ -918,8 +922,10 @@ static Object *memory_region_resolve_container(struct uc_struct *uc, Object *obj
return OBJECT(mr->container); return OBJECT(mr->container);
} }
static void memory_region_get_priority(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void memory_region_get_priority(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
MemoryRegion *mr = MEMORY_REGION(uc, obj); MemoryRegion *mr = MEMORY_REGION(uc, obj);
int32_t value = mr->priority; int32_t value = mr->priority;
@ -934,8 +940,10 @@ static bool memory_region_get_may_overlap(struct uc_struct *uc, Object *obj, Err
return mr->may_overlap; return mr->may_overlap;
} }
static void memory_region_get_size(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void memory_region_get_size(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
MemoryRegion *mr = MEMORY_REGION(uc, obj); MemoryRegion *mr = MEMORY_REGION(uc, obj);
uint64_t value = memory_region_size(mr); uint64_t value = memory_region_size(mr);

View file

@ -738,7 +738,7 @@ void object_unref(struct uc_struct *uc, Object *obj)
ObjectProperty * ObjectProperty *
object_property_add(Object *obj, const char *name, const char *type, object_property_add(Object *obj, const char *name, const char *type,
ObjectPropertyAccessor *get, ObjectPropertyAccessor *get,
ObjectPropertySetAccessor *set, ObjectPropertyAccessor *set,
ObjectPropertyRelease *release, ObjectPropertyRelease *release,
void *opaque, Error **errp) void *opaque, Error **errp)
{ {
@ -857,7 +857,7 @@ void object_property_get(struct uc_struct *uc, Object *obj, Visitor *v, const ch
if (!prop->get) { if (!prop->get) {
error_setg(errp, QERR_PERMISSION_DENIED); error_setg(errp, QERR_PERMISSION_DENIED);
} else { } else {
prop->get(uc, obj, v, prop->opaque, name, errp); prop->get(uc, obj, v, name, prop->opaque, errp);
} }
} }
@ -872,8 +872,7 @@ void object_property_set(struct uc_struct *uc, Object *obj, Visitor *v, const ch
if (!prop->set) { if (!prop->set) {
error_setg(errp, QERR_PERMISSION_DENIED); error_setg(errp, QERR_PERMISSION_DENIED);
} else { } else {
if (prop->set(uc, obj, v, prop->opaque, name, errp)) prop->set(uc, obj, v, name, prop->opaque, errp);
error_setg(errp, QERR_UNDEFINED_ERROR);
} }
} }
@ -1029,8 +1028,8 @@ Object *object_get_root(struct uc_struct *uc)
return uc->root; return uc->root;
} }
static void object_get_child_property(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void object_get_child_property(struct uc_struct *uc, Object *obj, Visitor *v,
const char *name, Error **errp) const char *name, void *opaque, Error **errp)
{ {
Object *child = opaque; Object *child = opaque;
gchar *path; gchar *path;
@ -1098,8 +1097,10 @@ typedef struct {
ObjectPropertyLinkFlags flags; ObjectPropertyLinkFlags flags;
} LinkProperty; } LinkProperty;
static void object_get_link_property(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void object_get_link_property(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
LinkProperty *lprop = opaque; LinkProperty *lprop = opaque;
Object **child = lprop->child; Object **child = lprop->child;
@ -1155,8 +1156,10 @@ static Object *object_resolve_link(struct uc_struct *uc, Object *obj, const char
return target; return target;
} }
static int object_set_link_property(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void object_set_link_property(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
Error *local_err = NULL; Error *local_err = NULL;
LinkProperty *prop = opaque; LinkProperty *prop = opaque;
@ -1174,20 +1177,18 @@ static int object_set_link_property(struct uc_struct *uc, Object *obj, Visitor *
g_free(path); g_free(path);
if (local_err) { if (local_err) {
error_propagate(errp, local_err); error_propagate(errp, local_err);
return -1; return;
} }
prop->check(obj, name, new_target, &local_err); prop->check(obj, name, new_target, &local_err);
if (local_err) { if (local_err) {
error_propagate(errp, local_err); error_propagate(errp, local_err);
return -1; return;
} }
object_ref(new_target); object_ref(new_target);
*child = new_target; *child = new_target;
object_unref(uc, old_target); object_unref(uc, old_target);
return 0;
} }
static Object *object_resolve_link_property(struct uc_struct *uc, Object *parent, void *opaque, const gchar *part) static Object *object_resolve_link_property(struct uc_struct *uc, Object *parent, void *opaque, const gchar *part)
@ -1401,8 +1402,10 @@ typedef struct StringProperty
int (*set)(struct uc_struct *uc, Object *, const char *, Error **); int (*set)(struct uc_struct *uc, Object *, const char *, Error **);
} StringProperty; } StringProperty;
static void property_get_str(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void property_get_str(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
StringProperty *prop = opaque; StringProperty *prop = opaque;
char *value; char *value;
@ -1418,8 +1421,10 @@ static void property_get_str(struct uc_struct *uc, Object *obj, Visitor *v, void
g_free(value); g_free(value);
} }
static int property_set_str(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void property_set_str(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
StringProperty *prop = opaque; StringProperty *prop = opaque;
char *value; char *value;
@ -1428,13 +1433,11 @@ static int property_set_str(struct uc_struct *uc, Object *obj, Visitor *v, void
visit_type_str(v, name, &value, &local_err); visit_type_str(v, name, &value, &local_err);
if (local_err) { if (local_err) {
error_propagate(errp, local_err); error_propagate(errp, local_err);
return -1; return;
} }
prop->set(uc, obj, value, errp); prop->set(uc, obj, value, errp);
g_free(value); g_free(value);
return 0;
} }
static void property_release_str(struct uc_struct *uc, Object *obj, const char *name, static void property_release_str(struct uc_struct *uc, Object *obj, const char *name,
@ -1472,8 +1475,10 @@ typedef struct BoolProperty
int (*set)(struct uc_struct *uc, Object *, bool, Error **); int (*set)(struct uc_struct *uc, Object *, bool, Error **);
} BoolProperty; } BoolProperty;
static void property_get_bool(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void property_get_bool(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
BoolProperty *prop = opaque; BoolProperty *prop = opaque;
bool value; bool value;
@ -1482,8 +1487,10 @@ static void property_get_bool(struct uc_struct *uc, Object *obj, Visitor *v, voi
visit_type_bool(v, name, &value, errp); visit_type_bool(v, name, &value, errp);
} }
static int property_set_bool(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void property_set_bool(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
BoolProperty *prop = opaque; BoolProperty *prop = opaque;
bool value; bool value;
@ -1492,14 +1499,14 @@ static int property_set_bool(struct uc_struct *uc, Object *obj, Visitor *v, void
visit_type_bool(v, name, &value, &local_err); visit_type_bool(v, name, &value, &local_err);
if (local_err) { if (local_err) {
error_propagate(errp, local_err); error_propagate(errp, local_err);
return -1; return;
} }
return prop->set(uc, obj, value, errp); prop->set(uc, obj, value, errp);
} }
static void property_release_bool(struct uc_struct *uc, Object *obj, const char *name, static void property_release_bool(struct uc_struct *uc, Object *obj,
void *opaque) const char *name, void *opaque)
{ {
BoolProperty *prop = opaque; BoolProperty *prop = opaque;
g_free(prop); g_free(prop);
@ -1533,7 +1540,7 @@ static char *qdev_get_type(struct uc_struct *uc, Object *obj, Error **errp)
} }
static void property_get_uint8_ptr(struct uc_struct *uc, Object *obj, Visitor *v, static void property_get_uint8_ptr(struct uc_struct *uc, Object *obj, Visitor *v,
void *opaque, const char *name, const char *name, void *opaque,
Error **errp) Error **errp)
{ {
uint8_t value = *(uint8_t *)opaque; uint8_t value = *(uint8_t *)opaque;
@ -1541,7 +1548,7 @@ static void property_get_uint8_ptr(struct uc_struct *uc, Object *obj, Visitor *v
} }
static void property_get_uint16_ptr(struct uc_struct *uc, Object *obj, Visitor *v, static void property_get_uint16_ptr(struct uc_struct *uc, Object *obj, Visitor *v,
void *opaque, const char *name, const char *name, void *opaque,
Error **errp) Error **errp)
{ {
uint16_t value = *(uint16_t *)opaque; uint16_t value = *(uint16_t *)opaque;
@ -1549,7 +1556,7 @@ static void property_get_uint16_ptr(struct uc_struct *uc, Object *obj, Visitor *
} }
static void property_get_uint32_ptr(struct uc_struct *uc, Object *obj, Visitor *v, static void property_get_uint32_ptr(struct uc_struct *uc, Object *obj, Visitor *v,
void *opaque, const char *name, const char *name, void *opaque,
Error **errp) Error **errp)
{ {
uint32_t value = *(uint32_t *)opaque; uint32_t value = *(uint32_t *)opaque;
@ -1557,7 +1564,7 @@ static void property_get_uint32_ptr(struct uc_struct *uc, Object *obj, Visitor *
} }
static void property_get_uint64_ptr(struct uc_struct *uc, Object *obj, Visitor *v, static void property_get_uint64_ptr(struct uc_struct *uc, Object *obj, Visitor *v,
void *opaque, const char *name, const char *name, void *opaque,
Error **errp) Error **errp)
{ {
uint64_t value = *(uint64_t *)opaque; uint64_t value = *(uint64_t *)opaque;
@ -1597,22 +1604,24 @@ typedef struct {
char *target_name; char *target_name;
} AliasProperty; } AliasProperty;
static void property_get_alias(struct uc_struct *uc, Object *obj, struct Visitor *v, void *opaque, static void property_get_alias(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, struct Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
AliasProperty *prop = opaque; AliasProperty *prop = opaque;
object_property_get(uc, prop->target_obj, v, prop->target_name, errp); object_property_get(uc, prop->target_obj, v, prop->target_name, errp);
} }
static int property_set_alias(struct uc_struct *uc, Object *obj, struct Visitor *v, void *opaque, static void property_set_alias(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, struct Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
AliasProperty *prop = opaque; AliasProperty *prop = opaque;
object_property_set(uc, prop->target_obj, v, prop->target_name, errp); object_property_set(uc, prop->target_obj, v, prop->target_name, errp);
return 0;
} }
static Object *property_resolve_alias(struct uc_struct *uc, Object *obj, void *opaque, static Object *property_resolve_alias(struct uc_struct *uc, Object *obj, void *opaque,

View file

@ -1533,8 +1533,10 @@ static void report_unavailable_features(FeatureWord w, uint32_t mask)
} }
} }
static void x86_cpuid_version_get_family(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void x86_cpuid_version_get_family(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
CPUX86State *env = &cpu->env; CPUX86State *env = &cpu->env;
@ -1547,8 +1549,10 @@ static void x86_cpuid_version_get_family(struct uc_struct *uc, Object *obj, Visi
visit_type_int(v, name, &value, errp); visit_type_int(v, name, &value, errp);
} }
static int x86_cpuid_version_set_family(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void x86_cpuid_version_set_family(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
CPUX86State *env = &cpu->env; CPUX86State *env = &cpu->env;
@ -1560,12 +1564,12 @@ static int x86_cpuid_version_set_family(struct uc_struct *uc, Object *obj, Visit
visit_type_int(v, name, &value, &local_err); visit_type_int(v, name, &value, &local_err);
if (local_err) { if (local_err) {
error_propagate(errp, local_err); error_propagate(errp, local_err);
return -1; return;
} }
if (value < min || value > max) { if (value < min || value > max) {
error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "", error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
name ? name : "null", value, min, max); name ? name : "null", value, min, max);
return -1; return;
} }
env->cpuid_version &= ~0xff00f00; env->cpuid_version &= ~0xff00f00;
@ -1574,12 +1578,12 @@ static int x86_cpuid_version_set_family(struct uc_struct *uc, Object *obj, Visit
} else { } else {
env->cpuid_version |= value << 8; env->cpuid_version |= value << 8;
} }
return 0;
} }
static void x86_cpuid_version_get_model(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void x86_cpuid_version_get_model(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
CPUX86State *env = &cpu->env; CPUX86State *env = &cpu->env;
@ -1590,8 +1594,10 @@ static void x86_cpuid_version_get_model(struct uc_struct *uc, Object *obj, Visit
visit_type_int(v, name, &value, errp); visit_type_int(v, name, &value, errp);
} }
static int x86_cpuid_version_set_model(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void x86_cpuid_version_set_model(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
CPUX86State *env = &cpu->env; CPUX86State *env = &cpu->env;
@ -1603,22 +1609,21 @@ static int x86_cpuid_version_set_model(struct uc_struct *uc, Object *obj, Visito
visit_type_int(v, name, &value, &local_err); visit_type_int(v, name, &value, &local_err);
if (local_err) { if (local_err) {
error_propagate(errp, local_err); error_propagate(errp, local_err);
return -1; return;
} }
if (value < min || value > max) { if (value < min || value > max) {
error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "", error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
name ? name : "null", value, min, max); name ? name : "null", value, min, max);
return -1; return;
} }
env->cpuid_version &= ~0xf00f0; env->cpuid_version &= ~0xf00f0;
env->cpuid_version |= ((value & 0xf) << 4) | ((value >> 4) << 16); env->cpuid_version |= ((value & 0xf) << 4) | ((value >> 4) << 16);
return 0;
} }
static void x86_cpuid_version_get_stepping(struct uc_struct *uc, Object *obj, Visitor *v, static void x86_cpuid_version_get_stepping(struct uc_struct *uc,
void *opaque, const char *name, Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp) Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
@ -1629,8 +1634,9 @@ static void x86_cpuid_version_get_stepping(struct uc_struct *uc, Object *obj, Vi
visit_type_int(v, name, &value, errp); visit_type_int(v, name, &value, errp);
} }
static int x86_cpuid_version_set_stepping(struct uc_struct *uc, Object *obj, Visitor *v, static void x86_cpuid_version_set_stepping(struct uc_struct *uc,
void *opaque, const char *name, Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp) Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
@ -1643,18 +1649,16 @@ static int x86_cpuid_version_set_stepping(struct uc_struct *uc, Object *obj, Vis
visit_type_int(v, name, &value, &local_err); visit_type_int(v, name, &value, &local_err);
if (local_err) { if (local_err) {
error_propagate(errp, local_err); error_propagate(errp, local_err);
return -1; return;
} }
if (value < min || value > max) { if (value < min || value > max) {
error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "", error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
name ? name : "null", value, min, max); name ? name : "null", value, min, max);
return -1; return;
} }
env->cpuid_version &= ~0xf; env->cpuid_version &= ~0xf;
env->cpuid_version |= value & 0xf; env->cpuid_version |= value & 0xf;
return 0;
} }
static char *x86_cpuid_get_vendor(struct uc_struct *uc, Object *obj, Error **errp) static char *x86_cpuid_get_vendor(struct uc_struct *uc, Object *obj, Error **errp)
@ -1669,8 +1673,8 @@ static char *x86_cpuid_get_vendor(struct uc_struct *uc, Object *obj, Error **err
return value; return value;
} }
static int x86_cpuid_set_vendor(struct uc_struct *uc, Object *obj, const char *value, static int x86_cpuid_set_vendor(struct uc_struct *uc, Object *obj,
Error **errp) const char *value, Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
CPUX86State *env = &cpu->env; CPUX86State *env = &cpu->env;
@ -1709,8 +1713,8 @@ static char *x86_cpuid_get_model_id(struct uc_struct *uc, Object *obj, Error **e
return value; return value;
} }
static int x86_cpuid_set_model_id(struct uc_struct *uc, Object *obj, const char *model_id, static int x86_cpuid_set_model_id(struct uc_struct *uc, Object *obj,
Error **errp) const char *model_id, Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
CPUX86State *env = &cpu->env; CPUX86State *env = &cpu->env;
@ -1733,8 +1737,10 @@ static int x86_cpuid_set_model_id(struct uc_struct *uc, Object *obj, const char
return 0; return 0;
} }
static void x86_cpuid_get_tsc_freq(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void x86_cpuid_get_tsc_freq(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
int64_t value; int64_t value;
@ -1743,8 +1749,10 @@ static void x86_cpuid_get_tsc_freq(struct uc_struct *uc, Object *obj, Visitor *v
visit_type_int(v, name, &value, errp); visit_type_int(v, name, &value, errp);
} }
static int x86_cpuid_set_tsc_freq(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void x86_cpuid_set_tsc_freq(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
const int64_t min = 0; const int64_t min = 0;
@ -1755,21 +1763,21 @@ static int x86_cpuid_set_tsc_freq(struct uc_struct *uc, Object *obj, Visitor *v,
visit_type_int(v, name, &value, &local_err); visit_type_int(v, name, &value, &local_err);
if (local_err) { if (local_err) {
error_propagate(errp, local_err); error_propagate(errp, local_err);
return -1; return;
} }
if (value < min || value > max) { if (value < min || value > max) {
error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "", error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, "",
name ? name : "null", value, min, max); name ? name : "null", value, min, max);
return -1; return;
} }
cpu->env.tsc_khz = (int)(value / 1000); cpu->env.tsc_khz = (int)(value / 1000);
return 0;
} }
static void x86_cpuid_get_apic_id(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void x86_cpuid_get_apic_id(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
int64_t value = cpu->apic_id; int64_t value = cpu->apic_id;
@ -1777,8 +1785,10 @@ static void x86_cpuid_get_apic_id(struct uc_struct *uc, Object *obj, Visitor *v,
visit_type_int(v, name, &value, errp); visit_type_int(v, name, &value, errp);
} }
static int x86_cpuid_set_apic_id(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void x86_cpuid_set_apic_id(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
X86CPU *cpu = X86_CPU(uc, obj); X86CPU *cpu = X86_CPU(uc, obj);
DeviceState *dev = DEVICE(uc, obj); DeviceState *dev = DEVICE(uc, obj);
@ -1790,33 +1800,33 @@ static int x86_cpuid_set_apic_id(struct uc_struct *uc, Object *obj, Visitor *v,
if (dev->realized) { if (dev->realized) {
error_setg(errp, "Attempt to set property '%s' on '%s' after " error_setg(errp, "Attempt to set property '%s' on '%s' after "
"it was realized", name, object_get_typename(obj)); "it was realized", name, object_get_typename(obj));
return -1; return;
} }
visit_type_int(v, name, &value, &error); visit_type_int(v, name, &value, &error);
if (error) { if (error) {
error_propagate(errp, error); error_propagate(errp, error);
return -1; return;
} }
if (value < min || value > max) { if (value < min || value > max) {
error_setg(errp, "Property %s.%s doesn't take value %" PRId64 error_setg(errp, "Property %s.%s doesn't take value %" PRId64
" (minimum: %" PRId64 ", maximum: %" PRId64 ")" , " (minimum: %" PRId64 ", maximum: %" PRId64 ")" ,
object_get_typename(obj), name, value, min, max); object_get_typename(obj), name, value, min, max);
return -1; return;
} }
if ((value != cpu->apic_id) && cpu_exists(uc, value)) { if ((value != cpu->apic_id) && cpu_exists(uc, value)) {
error_setg(errp, "CPU with APIC ID %" PRIi64 " exists", value); error_setg(errp, "CPU with APIC ID %" PRIi64 " exists", value);
return -1; return;
} }
cpu->apic_id = (uint32_t)value; cpu->apic_id = (uint32_t)value;
return 0;
} }
/* Generic getter for "feature-words" and "filtered-features" properties */ /* Generic getter for "feature-words" and "filtered-features" properties */
static void x86_cpu_get_feature_words(struct uc_struct *uc, Object *obj, Visitor *v, void *opaque, static void x86_cpu_get_feature_words(struct uc_struct *uc,
const char *name, Error **errp) Object *obj, Visitor *v,
const char *name, void *opaque,
Error **errp)
{ {
uint32_t *array = (uint32_t *)opaque; uint32_t *array = (uint32_t *)opaque;
FeatureWord w; FeatureWord w;