| 
									
										
										
										
											2016-01-26 18:17:29 +00:00
										 |  |  | #include "qemu/osdep.h"
 | 
					
						
							| 
									
										
										
										
											2012-10-24 08:43:34 +02:00
										 |  |  | #include "net/net.h"
 | 
					
						
							| 
									
										
										
										
											2019-08-12 07:23:51 +02:00
										 |  |  | #include "hw/qdev-properties.h"
 | 
					
						
							| 
									
										
											  
											
												include/qemu/osdep.h: Don't include qapi/error.h
Commit 57cb38b included qapi/error.h into qemu/osdep.h to get the
Error typedef.  Since then, we've moved to include qemu/osdep.h
everywhere.  Its file comment explains: "To avoid getting into
possible circular include dependencies, this file should not include
any other QEMU headers, with the exceptions of config-host.h,
compiler.h, os-posix.h and os-win32.h, all of which are doing a
similar job to this file and are under similar constraints."
qapi/error.h doesn't do a similar job, and it doesn't adhere to
similar constraints: it includes qapi-types.h.  That's in excess of
100KiB of crap most .c files don't actually need.
Add the typedef to qemu/typedefs.h, and include that instead of
qapi/error.h.  Include qapi/error.h in .c files that need it and don't
get it now.  Include qapi-types.h in qom/object.h for uint16List.
Update scripts/clean-includes accordingly.  Update it further to match
reality: replace config.h by config-target.h, add sysemu/os-posix.h,
sysemu/os-win32.h.  Update the list of includes in the qemu/osdep.h
comment quoted above similarly.
This reduces the number of objects depending on qapi/error.h from "all
of them" to less than a third.  Unfortunately, the number depending on
qapi-types.h shrinks only a little.  More work is needed for that one.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
[Fix compilation without the spice devel packages. - Paolo]
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
											
										 
											2016-03-14 09:01:28 +01:00
										 |  |  | #include "qapi/error.h"
 | 
					
						
							| 
									
										
										
										
											2016-03-09 13:44:19 +01:00
										 |  |  | #include "hw/pci/pci.h"
 | 
					
						
							| 
									
										
										
										
											2019-08-12 07:23:32 +02:00
										 |  |  | #include "qapi/qapi-types-block.h"
 | 
					
						
							|  |  |  | #include "qapi/qapi-types-misc.h"
 | 
					
						
							| 
									
										
										
										
											2012-12-17 18:19:43 +01:00
										 |  |  | #include "qapi/qmp/qerror.h"
 | 
					
						
							| 
									
										
										
										
											2019-05-23 16:35:06 +02:00
										 |  |  | #include "qemu/ctype.h"
 | 
					
						
							| 
									
										
										
										
											2015-03-17 18:29:20 +01:00
										 |  |  | #include "qemu/error-report.h"
 | 
					
						
							| 
									
										
										
										
											2013-02-05 17:06:20 +01:00
										 |  |  | #include "hw/block/block.h"
 | 
					
						
							| 
									
										
										
										
											2012-07-24 16:35:09 +01:00
										 |  |  | #include "net/hub.h"
 | 
					
						
							| 
									
										
										
										
											2012-12-17 18:19:43 +01:00
										 |  |  | #include "qapi/visitor.h"
 | 
					
						
							| 
									
										
										
										
											2017-01-26 17:19:46 +04:00
										 |  |  | #include "chardev/char.h"
 | 
					
						
							| 
									
										
										
										
											2017-11-27 16:05:17 +03:00
										 |  |  | #include "qemu/uuid.h"
 | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  | void qdev_prop_set_after_realize(DeviceState *dev, const char *name, | 
					
						
							|  |  |  |                                   Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (dev->id) { | 
					
						
							|  |  |  |         error_setg(errp, "Attempt to set property '%s' on device '%s' " | 
					
						
							|  |  |  |                    "(type '%s') after it was realized", name, dev->id, | 
					
						
							|  |  |  |                    object_get_typename(OBJECT(dev))); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         error_setg(errp, "Attempt to set property '%s' on anonymous device " | 
					
						
							|  |  |  |                    "(type '%s') after it was realized", name, | 
					
						
							|  |  |  |                    object_get_typename(OBJECT(dev))); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:50 +08:00
										 |  |  | void qdev_prop_allow_set_link_before_realize(const Object *obj, | 
					
						
							|  |  |  |                                              const char *name, | 
					
						
							| 
									
										
										
										
											2014-03-19 08:58:56 +01:00
										 |  |  |                                              Object *val, Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dev->realized) { | 
					
						
							|  |  |  |         error_setg(errp, "Attempt to set link property '%s' on device '%s' " | 
					
						
							|  |  |  |                    "(type '%s') after it was realized", | 
					
						
							|  |  |  |                    name, dev->id, object_get_typename(obj)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | void *qdev_get_prop_ptr(DeviceState *dev, Property *prop) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     void *ptr = dev; | 
					
						
							|  |  |  |     ptr += prop->offset; | 
					
						
							|  |  |  |     return ptr; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_enum(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                      Error **errp) | 
					
						
							| 
									
										
										
										
											2012-07-10 11:12:46 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     int *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-29 06:48:57 -07:00
										 |  |  |     visit_type_enum(v, prop->name, ptr, prop->info->enum_table, errp); | 
					
						
							| 
									
										
										
										
											2012-07-10 11:12:46 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_enum(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                      Error **errp) | 
					
						
							| 
									
										
										
										
											2012-07-10 11:12:46 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     int *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2012-07-10 11:12:46 +02:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-29 06:48:57 -07:00
										 |  |  |     visit_type_enum(v, prop->name, ptr, prop->info->enum_table, errp); | 
					
						
							| 
									
										
										
										
											2012-07-10 11:12:46 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  | static void set_default_value_enum(Object *obj, const Property *prop) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-08-24 10:46:09 +02:00
										 |  |  |     object_property_set_str(obj, | 
					
						
							|  |  |  |                             qapi_enum_lookup(prop->info->enum_table, | 
					
						
							|  |  |  |                                              prop->defval.i), | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |                             prop->name, &error_abort); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-10 11:12:46 +02:00
										 |  |  | /* Bit */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-10 13:52:41 +02:00
										 |  |  | static uint32_t qdev_get_prop_mask(Property *prop) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-02 22:51:09 +01:00
										 |  |  |     assert(prop->info == &qdev_prop_bit); | 
					
						
							| 
									
										
										
										
											2010-01-10 13:52:41 +02:00
										 |  |  |     return 0x1 << prop->bitnr; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void bit_prop_set(DeviceState *dev, Property *props, bool val) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     uint32_t *p = qdev_get_prop_ptr(dev, props); | 
					
						
							|  |  |  |     uint32_t mask = qdev_get_prop_mask(props); | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |     if (val) { | 
					
						
							| 
									
										
										
										
											2010-01-12 21:16:59 +02:00
										 |  |  |         *p |= mask; | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2010-01-10 13:52:41 +02:00
										 |  |  |         *p &= ~mask; | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-01-10 13:52:41 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void prop_get_bit(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                          void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     uint32_t *p = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     bool value = (*p & qdev_get_prop_mask(prop)) != 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_bool(v, name, &value, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void prop_set_bit(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                          void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     Error *local_err = NULL; | 
					
						
							|  |  |  |     bool value; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_bool(v, name, &value, &local_err); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     if (local_err) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     bit_prop_set(dev, prop, value); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  | static void set_default_value_bool(Object *obj, const Property *prop) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-06-07 20:36:09 +04:00
										 |  |  |     object_property_set_bool(obj, prop->defval.u, prop->name, &error_abort); | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_bit = { | 
					
						
							| 
									
										
										
										
											2014-02-08 11:01:56 +01:00
										 |  |  |     .name  = "bool", | 
					
						
							| 
									
										
										
										
											2014-10-07 14:33:20 +08:00
										 |  |  |     .description = "on/off", | 
					
						
							| 
									
										
										
										
											2013-07-29 17:17:43 +03:00
										 |  |  |     .get   = prop_get_bit, | 
					
						
							|  |  |  |     .set   = prop_set_bit, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |     .set_default_value = set_default_value_bool, | 
					
						
							| 
									
										
										
										
											2010-01-10 13:52:41 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-01 10:45:39 +02:00
										 |  |  | /* Bit64 */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static uint64_t qdev_get_prop_mask64(Property *prop) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2015-07-09 13:01:14 +02:00
										 |  |  |     assert(prop->info == &qdev_prop_bit64); | 
					
						
							| 
									
										
										
										
											2015-06-23 09:53:05 +08:00
										 |  |  |     return 0x1ull << prop->bitnr; | 
					
						
							| 
									
										
										
										
											2015-06-01 10:45:39 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void bit64_prop_set(DeviceState *dev, Property *props, bool val) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     uint64_t *p = qdev_get_prop_ptr(dev, props); | 
					
						
							|  |  |  |     uint64_t mask = qdev_get_prop_mask64(props); | 
					
						
							|  |  |  |     if (val) { | 
					
						
							|  |  |  |         *p |= mask; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         *p &= ~mask; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void prop_get_bit64(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                            void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2015-06-01 10:45:39 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     uint64_t *p = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     bool value = (*p & qdev_get_prop_mask64(prop)) != 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_bool(v, name, &value, errp); | 
					
						
							| 
									
										
										
										
											2015-06-01 10:45:39 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void prop_set_bit64(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                            void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2015-06-01 10:45:39 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     Error *local_err = NULL; | 
					
						
							|  |  |  |     bool value; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dev->realized) { | 
					
						
							|  |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_bool(v, name, &value, &local_err); | 
					
						
							| 
									
										
										
										
											2015-06-01 10:45:39 +02:00
										 |  |  |     if (local_err) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     bit64_prop_set(dev, prop, value); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_bit64 = { | 
					
						
							| 
									
										
										
										
											2015-06-01 10:45:39 +02:00
										 |  |  |     .name  = "bool", | 
					
						
							|  |  |  |     .description = "on/off", | 
					
						
							|  |  |  |     .get   = prop_get_bit64, | 
					
						
							|  |  |  |     .set   = prop_set_bit64, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |     .set_default_value = set_default_value_bool, | 
					
						
							| 
									
										
										
										
											2015-06-01 10:45:39 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-07 17:16:18 +01:00
										 |  |  | /* --- bool --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_bool(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                      Error **errp) | 
					
						
							| 
									
										
										
										
											2013-03-07 17:16:18 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     bool *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_bool(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2013-03-07 17:16:18 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_bool(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                      Error **errp) | 
					
						
							| 
									
										
										
										
											2013-03-07 17:16:18 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     bool *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dev->realized) { | 
					
						
							|  |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_bool(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2013-03-07 17:16:18 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_bool = { | 
					
						
							| 
									
										
										
										
											2014-02-08 11:01:56 +01:00
										 |  |  |     .name  = "bool", | 
					
						
							| 
									
										
										
										
											2013-03-07 17:16:18 +01:00
										 |  |  |     .get   = get_bool, | 
					
						
							|  |  |  |     .set   = set_bool, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |     .set_default_value = set_default_value_bool, | 
					
						
							| 
									
										
										
										
											2013-03-07 17:16:18 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-29 22:48:25 +02:00
										 |  |  | /* --- 8bit integer --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_uint8(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                       Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |     uint8_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_uint8(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_uint8(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                       Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-04-12 15:32:26 +02:00
										 |  |  |     uint8_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_uint8(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  | static void set_default_value_int(Object *obj, const Property *prop) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-06-07 20:36:08 +04:00
										 |  |  |     object_property_set_int(obj, prop->defval.i, prop->name, &error_abort); | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-07 20:36:09 +04:00
										 |  |  | static void set_default_value_uint(Object *obj, const Property *prop) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     object_property_set_uint(obj, prop->defval.u, prop->name, &error_abort); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_uint8 = { | 
					
						
							| 
									
										
										
										
											2009-09-29 22:48:25 +02:00
										 |  |  |     .name  = "uint8", | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |     .get   = get_uint8, | 
					
						
							|  |  |  |     .set   = set_uint8, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:36:09 +04:00
										 |  |  |     .set_default_value = set_default_value_uint, | 
					
						
							| 
									
										
										
										
											2009-09-29 22:48:25 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | /* --- 16bit integer --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_uint16(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                        void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |     uint16_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_uint16(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_uint16(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                        void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-04-12 15:32:26 +02:00
										 |  |  |     uint16_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_uint16(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_uint16 = { | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  |     .name  = "uint16", | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |     .get   = get_uint16, | 
					
						
							|  |  |  |     .set   = set_uint16, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:36:09 +04:00
										 |  |  |     .set_default_value = set_default_value_uint, | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* --- 32bit integer --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_uint32(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                        void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-04-12 15:32:26 +02:00
										 |  |  |     uint32_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_uint32(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_uint32(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                        void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-04-12 15:32:26 +02:00
										 |  |  |     uint32_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_uint32(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_int32(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                       Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     int32_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_int32(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_int32(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                       Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-04-12 15:32:26 +02:00
										 |  |  |     int32_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_int32(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_uint32 = { | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  |     .name  = "uint32", | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |     .get   = get_uint32, | 
					
						
							|  |  |  |     .set   = set_uint32, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:36:09 +04:00
										 |  |  |     .set_default_value = set_default_value_uint, | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_int32 = { | 
					
						
							| 
									
										
										
										
											2009-09-10 11:43:25 +02:00
										 |  |  |     .name  = "int32", | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     .get   = get_int32, | 
					
						
							|  |  |  |     .set   = set_int32, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |     .set_default_value = set_default_value_int, | 
					
						
							| 
									
										
										
										
											2009-09-10 11:43:25 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-21 11:10:41 +00:00
										 |  |  | /* --- 64bit integer --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_uint64(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                        void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |     uint64_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_uint64(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_uint64(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                        void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |     uint64_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_uint64(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-18 11:39:01 +08:00
										 |  |  | static void get_int64(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                       void *opaque, Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     int64_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     visit_type_int64(v, name, ptr, errp); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void set_int64(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                       void *opaque, Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     int64_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dev->realized) { | 
					
						
							|  |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     visit_type_int64(v, name, ptr, errp); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_uint64 = { | 
					
						
							| 
									
										
										
										
											2009-07-21 11:10:41 +00:00
										 |  |  |     .name  = "uint64", | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |     .get   = get_uint64, | 
					
						
							|  |  |  |     .set   = set_uint64, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:36:09 +04:00
										 |  |  |     .set_default_value = set_default_value_uint, | 
					
						
							| 
									
										
										
										
											2009-07-21 11:10:41 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-18 11:39:01 +08:00
										 |  |  | const PropertyInfo qdev_prop_int64 = { | 
					
						
							|  |  |  |     .name  = "int64", | 
					
						
							|  |  |  |     .get   = get_int64, | 
					
						
							|  |  |  |     .set   = set_int64, | 
					
						
							|  |  |  |     .set_default_value = set_default_value_int, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-12 17:15:47 +05:30
										 |  |  | /* --- string --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-02 13:08:48 +01:00
										 |  |  | static void release_string(Object *obj, const char *name, void *opaque) | 
					
						
							| 
									
										
										
										
											2010-06-01 20:32:31 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-02 13:08:48 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     g_free(*(char **)qdev_get_prop_ptr(DEVICE(obj), prop)); | 
					
						
							| 
									
										
										
										
											2010-06-01 20:32:31 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_string(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                        void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     char **ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!*ptr) { | 
					
						
							|  |  |  |         char *str = (char *)""; | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |         visit_type_str(v, name, &str, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     } else { | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |         visit_type_str(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_string(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                        void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-30 08:55:55 -06:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     char **ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     Error *local_err = NULL; | 
					
						
							|  |  |  |     char *str; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_str(v, name, &str, &local_err); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     if (local_err) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-08-26 12:17:18 +01:00
										 |  |  |     g_free(*ptr); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     *ptr = str; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_string = { | 
					
						
							| 
									
										
										
										
											2014-02-08 11:01:56 +01:00
										 |  |  |     .name  = "str", | 
					
						
							| 
									
										
										
										
											2012-02-02 13:08:48 +01:00
										 |  |  |     .release = release_string, | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:09 +01:00
										 |  |  |     .get   = get_string, | 
					
						
							|  |  |  |     .set   = set_string, | 
					
						
							| 
									
										
										
										
											2009-10-12 17:15:47 +05:30
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | /* --- pointer --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-19 11:47:06 +01:00
										 |  |  | /* Not a proper property, just for dirty hacks.  TODO Remove it!  */ | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_ptr = { | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  |     .name  = "ptr", | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* --- mac address --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * accepted syntax versions: | 
					
						
							|  |  |  |  *   01:02:03:04:05:06 | 
					
						
							|  |  |  |  *   01-02-03-04-05-06 | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_mac(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                     Error **errp) | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2009-10-21 15:25:23 +02:00
										 |  |  |     MACAddr *mac = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |     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]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_str(v, name, &p, errp); | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_mac(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                     Error **errp) | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     MACAddr *mac = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     Error *local_err = NULL; | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  |     int i, pos; | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |     char *str, *p; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_str(v, name, &str, &local_err); | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |     if (local_err) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (i = 0, pos = 0; i < 6; i++, pos += 3) { | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |         if (!qemu_isxdigit(str[pos])) { | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |             goto inval; | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |         } | 
					
						
							|  |  |  |         if (!qemu_isxdigit(str[pos+1])) { | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |             goto inval; | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-10-21 15:25:23 +02:00
										 |  |  |         if (i == 5) { | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |             if (str[pos+2] != '\0') { | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |                 goto inval; | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2009-10-21 15:25:23 +02:00
										 |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |             if (str[pos+2] != ':' && str[pos+2] != '-') { | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |                 goto inval; | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2009-10-21 15:25:23 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         mac->a[i] = strtol(str+pos, &p, 16); | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-05-18 19:14:13 +08:00
										 |  |  |     g_free(str); | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2009-10-21 15:25:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  | inval: | 
					
						
							|  |  |  |     error_set_from_qdev_prop_error(errp, EINVAL, dev, prop, str); | 
					
						
							| 
									
										
										
										
											2012-05-18 19:14:13 +08:00
										 |  |  |     g_free(str); | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_macaddr = { | 
					
						
							| 
									
										
										
										
											2014-02-08 11:01:56 +01:00
										 |  |  |     .name  = "str", | 
					
						
							| 
									
										
										
										
											2014-10-07 14:33:20 +08:00
										 |  |  |     .description = "Ethernet 6-byte MAC Address, example: 52:54:00:12:34:56", | 
					
						
							| 
									
										
										
										
											2012-02-02 17:08:47 +01:00
										 |  |  |     .get   = get_mac, | 
					
						
							|  |  |  |     .set   = set_mac, | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-15 19:34:49 +01:00
										 |  |  | /* --- on/off/auto --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_on_off_auto = { | 
					
						
							| 
									
										
										
										
											2016-03-15 19:34:49 +01:00
										 |  |  |     .name = "OnOffAuto", | 
					
						
							|  |  |  |     .description = "on/off/auto", | 
					
						
							| 
									
										
										
										
											2017-08-24 10:46:10 +02:00
										 |  |  |     .enum_table = &OnOffAuto_lookup, | 
					
						
							| 
									
										
										
										
											2016-03-15 19:34:49 +01:00
										 |  |  |     .get = get_enum, | 
					
						
							|  |  |  |     .set = set_enum, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |     .set_default_value = set_default_value_enum, | 
					
						
							| 
									
										
										
										
											2016-03-15 19:34:49 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-23 20:15:11 +01:00
										 |  |  | /* --- lost tick policy --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-02 22:09:44 +01:00
										 |  |  | QEMU_BUILD_BUG_ON(sizeof(LostTickPolicy) != sizeof(int)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_losttickpolicy = { | 
					
						
							| 
									
										
										
										
											2012-02-02 22:09:44 +01:00
										 |  |  |     .name  = "LostTickPolicy", | 
					
						
							| 
									
										
										
										
											2017-08-24 10:46:10 +02:00
										 |  |  |     .enum_table  = &LostTickPolicy_lookup, | 
					
						
							| 
									
										
										
										
											2012-02-02 22:09:44 +01:00
										 |  |  |     .get   = get_enum, | 
					
						
							|  |  |  |     .set   = set_enum, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |     .set_default_value = set_default_value_enum, | 
					
						
							| 
									
										
										
										
											2012-01-23 20:15:11 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-29 17:41:35 +02:00
										 |  |  | /* --- Block device error handling policy --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | QEMU_BUILD_BUG_ON(sizeof(BlockdevOnError) != sizeof(int)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_blockdev_on_error = { | 
					
						
							| 
									
										
										
										
											2016-06-29 17:41:35 +02:00
										 |  |  |     .name = "BlockdevOnError", | 
					
						
							|  |  |  |     .description = "Error handling policy, " | 
					
						
							|  |  |  |                    "report/ignore/enospc/stop/auto", | 
					
						
							| 
									
										
										
										
											2017-08-24 10:46:10 +02:00
										 |  |  |     .enum_table = &BlockdevOnError_lookup, | 
					
						
							| 
									
										
										
										
											2016-06-29 17:41:35 +02:00
										 |  |  |     .get = get_enum, | 
					
						
							|  |  |  |     .set = set_enum, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |     .set_default_value = set_default_value_enum, | 
					
						
							| 
									
										
										
										
											2016-06-29 17:41:35 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-10 11:12:47 +02:00
										 |  |  | /* --- BIOS CHS translation */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-08 11:01:55 +01:00
										 |  |  | QEMU_BUILD_BUG_ON(sizeof(BiosAtaTranslation) != sizeof(int)); | 
					
						
							| 
									
										
										
										
											2012-07-10 11:12:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_bios_chs_trans = { | 
					
						
							| 
									
										
										
										
											2014-02-08 11:01:56 +01:00
										 |  |  |     .name = "BiosAtaTranslation", | 
					
						
							| 
									
										
										
										
											2014-10-07 14:33:20 +08:00
										 |  |  |     .description = "Logical CHS translation algorithm, " | 
					
						
							|  |  |  |                    "auto/none/lba/large/rechs", | 
					
						
							| 
									
										
										
										
											2017-08-24 10:46:10 +02:00
										 |  |  |     .enum_table = &BiosAtaTranslation_lookup, | 
					
						
							| 
									
										
										
										
											2012-07-10 11:12:47 +02:00
										 |  |  |     .get = get_enum, | 
					
						
							|  |  |  |     .set = set_enum, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |     .set_default_value = set_default_value_enum, | 
					
						
							| 
									
										
										
										
											2012-07-10 11:12:47 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-22 15:51:00 -05:00
										 |  |  | /* --- FDC default drive types */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_fdc_drive_type = { | 
					
						
							| 
									
										
										
										
											2016-01-22 15:51:00 -05:00
										 |  |  |     .name = "FdcDriveType", | 
					
						
							|  |  |  |     .description = "FDC drive type, " | 
					
						
							|  |  |  |                    "144/288/120/none/auto", | 
					
						
							| 
									
										
										
										
											2017-08-24 10:46:10 +02:00
										 |  |  |     .enum_table = &FloppyDriveType_lookup, | 
					
						
							| 
									
										
										
										
											2016-01-22 15:51:00 -05:00
										 |  |  |     .get = get_enum, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |     .set = set_enum, | 
					
						
							|  |  |  |     .set_default_value = set_default_value_enum, | 
					
						
							| 
									
										
										
										
											2016-01-22 15:51:00 -05:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  | /* --- pci address --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * bus-local address, i.e. "$slot" or "$slot.$fn" | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_pci_devfn(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                           void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-09 09:53:32 +01:00
										 |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-04-12 15:32:26 +02:00
										 |  |  |     int32_t value, *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  |     unsigned int slot, fn, n; | 
					
						
							| 
									
										
										
										
											2012-02-09 09:53:32 +01:00
										 |  |  |     Error *local_err = NULL; | 
					
						
							| 
									
										
										
										
											2012-05-18 19:14:13 +08:00
										 |  |  |     char *str; | 
					
						
							| 
									
										
										
										
											2012-02-09 09:53:32 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2012-02-09 09:53:32 +01:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_str(v, name, &str, &local_err); | 
					
						
							| 
									
										
										
										
											2012-02-09 09:53:32 +01:00
										 |  |  |     if (local_err) { | 
					
						
							| 
									
										
										
										
											2012-04-28 02:32:42 +00:00
										 |  |  |         error_free(local_err); | 
					
						
							| 
									
										
										
										
											2012-04-12 15:32:26 +02:00
										 |  |  |         local_err = NULL; | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |         visit_type_int32(v, name, &value, &local_err); | 
					
						
							| 
									
										
										
										
											2012-04-12 15:32:26 +02:00
										 |  |  |         if (local_err) { | 
					
						
							|  |  |  |             error_propagate(errp, local_err); | 
					
						
							|  |  |  |         } else if (value < -1 || value > 255) { | 
					
						
							| 
									
										
										
										
											2015-03-17 11:54:50 +01:00
										 |  |  |             error_setg(errp, QERR_INVALID_PARAMETER_VALUE, | 
					
						
							|  |  |  |                        name ? name : "null", "pci_devfn"); | 
					
						
							| 
									
										
										
										
											2012-04-12 15:32:26 +02:00
										 |  |  |         } else { | 
					
						
							|  |  |  |             *ptr = value; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return; | 
					
						
							| 
									
										
										
										
											2012-02-09 09:53:32 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (sscanf(str, "%x.%x%n", &slot, &fn, &n) != 2) { | 
					
						
							|  |  |  |         fn = 0; | 
					
						
							|  |  |  |         if (sscanf(str, "%x%n", &slot, &n) != 1) { | 
					
						
							| 
									
										
										
										
											2012-02-09 09:53:32 +01:00
										 |  |  |             goto invalid; | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-02-09 09:53:32 +01:00
										 |  |  |     if (str[n] != '\0' || fn > 7 || slot > 31) { | 
					
						
							|  |  |  |         goto invalid; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  |     *ptr = slot << 3 | fn; | 
					
						
							| 
									
										
										
										
											2012-05-18 19:14:13 +08:00
										 |  |  |     g_free(str); | 
					
						
							| 
									
										
										
										
											2012-02-09 09:53:32 +01:00
										 |  |  |     return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | invalid: | 
					
						
							|  |  |  |     error_set_from_qdev_prop_error(errp, EINVAL, dev, prop, str); | 
					
						
							| 
									
										
										
										
											2012-05-18 19:14:13 +08:00
										 |  |  |     g_free(str); | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  | static int print_pci_devfn(DeviceState *dev, Property *prop, char *dest, | 
					
						
							|  |  |  |                            size_t len) | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-04 13:38:27 -06:00
										 |  |  |     int32_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 19:12:16 +00:00
										 |  |  |     if (*ptr == -1) { | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  |         return snprintf(dest, len, "<unset>"); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         return snprintf(dest, len, "%02x.%x", *ptr >> 3, *ptr & 7); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_pci_devfn = { | 
					
						
							| 
									
										
										
										
											2012-02-02 17:12:19 +01:00
										 |  |  |     .name  = "int32", | 
					
						
							| 
									
										
										
										
											2014-10-07 14:33:20 +08:00
										 |  |  |     .description = "Slot and optional function number, example: 06.0 or 06", | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  |     .print = print_pci_devfn, | 
					
						
							| 
									
										
										
										
											2012-02-02 17:12:19 +01:00
										 |  |  |     .get   = get_int32, | 
					
						
							| 
									
										
										
										
											2012-02-09 09:53:32 +01:00
										 |  |  |     .set   = set_pci_devfn, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:35:53 +04:00
										 |  |  |     .set_default_value = set_default_value_int, | 
					
						
							| 
									
										
										
										
											2009-07-15 13:59:22 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-14 15:57:05 +00:00
										 |  |  | /* --- blocksize --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_blocksize(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                           void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2012-03-14 15:57:05 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |     uint16_t value, *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2012-03-14 15:57:05 +00:00
										 |  |  |     Error *local_err = NULL; | 
					
						
							| 
									
										
										
										
											2012-04-12 15:32:26 +02:00
										 |  |  |     const int64_t min = 512; | 
					
						
							|  |  |  |     const int64_t max = 32768; | 
					
						
							| 
									
										
										
										
											2012-03-14 15:57:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2012-03-14 15:57:05 +00:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_uint16(v, name, &value, &local_err); | 
					
						
							| 
									
										
										
										
											2012-03-14 15:57:05 +00:00
										 |  |  |     if (local_err) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-02-16 12:47:58 +01:00
										 |  |  |     /* value of 0 means "unset" */ | 
					
						
							|  |  |  |     if (value && (value < min || value > max)) { | 
					
						
							| 
									
										
										
										
											2015-03-17 11:54:50 +01:00
										 |  |  |         error_setg(errp, QERR_PROPERTY_VALUE_OUT_OF_RANGE, | 
					
						
							|  |  |  |                    dev->id ? : "", name, (int64_t)value, min, max); | 
					
						
							| 
									
										
										
										
											2012-03-14 15:57:05 +00:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* We rely on power-of-2 blocksizes for bitmasks */ | 
					
						
							|  |  |  |     if ((value & (value - 1)) != 0) { | 
					
						
							| 
									
										
										
										
											2014-03-21 19:42:26 -04:00
										 |  |  |         error_setg(errp, | 
					
						
							|  |  |  |                   "Property %s.%s doesn't take value '%" PRId64 "', it's not a power of 2", | 
					
						
							|  |  |  |                   dev->id ?: "", name, (int64_t)value); | 
					
						
							| 
									
										
										
										
											2012-03-14 15:57:05 +00:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     *ptr = value; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_blocksize = { | 
					
						
							| 
									
										
										
										
											2014-02-08 11:01:56 +01:00
										 |  |  |     .name  = "uint16", | 
					
						
							| 
									
										
										
										
											2014-10-07 14:33:20 +08:00
										 |  |  |     .description = "A power of two between 512 and 32768", | 
					
						
							| 
									
										
										
										
											2012-02-22 12:26:37 -06:00
										 |  |  |     .get   = get_uint16, | 
					
						
							| 
									
										
										
										
											2012-03-14 15:57:05 +00:00
										 |  |  |     .set   = set_blocksize, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:36:09 +04:00
										 |  |  |     .set_default_value = set_default_value_uint, | 
					
						
							| 
									
										
										
										
											2012-03-14 15:57:05 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-21 15:36:23 +00:00
										 |  |  | /* --- pci host address --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_pci_host_devaddr(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                                  void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2012-06-21 15:36:23 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     PCIHostDeviceAddress *addr = qdev_get_prop_ptr(dev, prop); | 
					
						
							| 
									
										
										
										
											2016-11-10 12:42:07 +00:00
										 |  |  |     char buffer[] = "ffff:ff:ff.f"; | 
					
						
							| 
									
										
										
										
											2012-06-21 15:36:23 +00:00
										 |  |  |     char *p = buffer; | 
					
						
							|  |  |  |     int rc = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 12:42:07 +00:00
										 |  |  |     /*
 | 
					
						
							|  |  |  |      * Catch "invalid" device reference from vfio-pci and allow the | 
					
						
							| 
									
										
										
										
											2016-11-19 20:29:26 +01:00
										 |  |  |      * default buffer representing the non-existent device to be used. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:42:07 +00:00
										 |  |  |      */ | 
					
						
							|  |  |  |     if (~addr->domain || ~addr->bus || ~addr->slot || ~addr->function) { | 
					
						
							|  |  |  |         rc = snprintf(buffer, sizeof(buffer), "%04x:%02x:%02x.%0d", | 
					
						
							|  |  |  |                       addr->domain, addr->bus, addr->slot, addr->function); | 
					
						
							|  |  |  |         assert(rc == sizeof(buffer) - 1); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-06-21 15:36:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_str(v, name, &p, errp); | 
					
						
							| 
									
										
										
										
											2012-06-21 15:36:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Parse [<domain>:]<bus>:<slot>.<func> | 
					
						
							|  |  |  |  *   if <domain> is not supplied, it's assumed to be 0. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_pci_host_devaddr(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                                  void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2012-06-21 15:36:23 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     PCIHostDeviceAddress *addr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     Error *local_err = NULL; | 
					
						
							|  |  |  |     char *str, *p; | 
					
						
							|  |  |  |     char *e; | 
					
						
							|  |  |  |     unsigned long val; | 
					
						
							|  |  |  |     unsigned long dom = 0, bus = 0; | 
					
						
							|  |  |  |     unsigned int slot = 0, func = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-09 03:58:10 +01:00
										 |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2012-06-21 15:36:23 +00:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_str(v, name, &str, &local_err); | 
					
						
							| 
									
										
										
										
											2012-06-21 15:36:23 +00:00
										 |  |  |     if (local_err) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     p = str; | 
					
						
							|  |  |  |     val = strtoul(p, &e, 16); | 
					
						
							|  |  |  |     if (e == p || *e != ':') { | 
					
						
							|  |  |  |         goto inval; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     bus = val; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     p = e + 1; | 
					
						
							|  |  |  |     val = strtoul(p, &e, 16); | 
					
						
							|  |  |  |     if (e == p) { | 
					
						
							|  |  |  |         goto inval; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (*e == ':') { | 
					
						
							|  |  |  |         dom = bus; | 
					
						
							|  |  |  |         bus = val; | 
					
						
							|  |  |  |         p = e + 1; | 
					
						
							|  |  |  |         val = strtoul(p, &e, 16); | 
					
						
							|  |  |  |         if (e == p) { | 
					
						
							|  |  |  |             goto inval; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     slot = val; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (*e != '.') { | 
					
						
							|  |  |  |         goto inval; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     p = e + 1; | 
					
						
							|  |  |  |     val = strtoul(p, &e, 10); | 
					
						
							|  |  |  |     if (e == p) { | 
					
						
							|  |  |  |         goto inval; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     func = val; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dom > 0xffff || bus > 0xff || slot > 0x1f || func > 7) { | 
					
						
							|  |  |  |         goto inval; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (*e) { | 
					
						
							|  |  |  |         goto inval; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     addr->domain = dom; | 
					
						
							|  |  |  |     addr->bus = bus; | 
					
						
							|  |  |  |     addr->slot = slot; | 
					
						
							|  |  |  |     addr->function = func; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     g_free(str); | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inval: | 
					
						
							|  |  |  |     error_set_from_qdev_prop_error(errp, EINVAL, dev, prop, str); | 
					
						
							|  |  |  |     g_free(str); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_pci_host_devaddr = { | 
					
						
							| 
									
										
										
										
											2014-02-08 11:01:56 +01:00
										 |  |  |     .name = "str", | 
					
						
							| 
									
										
										
										
											2014-10-07 14:33:20 +08:00
										 |  |  |     .description = "Address (bus/device/function) of " | 
					
						
							|  |  |  |                    "the host device, example: 04:10.0", | 
					
						
							| 
									
										
										
										
											2012-06-21 15:36:23 +00:00
										 |  |  |     .get = get_pci_host_devaddr, | 
					
						
							|  |  |  |     .set = set_pci_host_devaddr, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-27 16:05:17 +03:00
										 |  |  | /* --- UUID --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void get_uuid(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                      Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     QemuUUID *uuid = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     char buffer[UUID_FMT_LEN + 1]; | 
					
						
							|  |  |  |     char *p = buffer; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     qemu_uuid_unparse(uuid, buffer); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     visit_type_str(v, name, &p, errp); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define UUID_VALUE_AUTO        "auto"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void set_uuid(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                     Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     QemuUUID *uuid = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     Error *local_err = NULL; | 
					
						
							|  |  |  |     char *str; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dev->realized) { | 
					
						
							|  |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     visit_type_str(v, name, &str, &local_err); | 
					
						
							|  |  |  |     if (local_err) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!strcmp(str, UUID_VALUE_AUTO)) { | 
					
						
							|  |  |  |         qemu_uuid_generate(uuid); | 
					
						
							|  |  |  |     } else if (qemu_uuid_parse(str, uuid) < 0) { | 
					
						
							|  |  |  |         error_set_from_qdev_prop_error(errp, EINVAL, dev, prop, str); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     g_free(str); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void set_default_uuid_auto(Object *obj, const Property *prop) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     object_property_set_str(obj, UUID_VALUE_AUTO, prop->name, &error_abort); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const PropertyInfo qdev_prop_uuid = { | 
					
						
							|  |  |  |     .name  = "str", | 
					
						
							|  |  |  |     .description = "UUID (aka GUID) or \"" UUID_VALUE_AUTO | 
					
						
							|  |  |  |         "\" for random value (default)", | 
					
						
							|  |  |  |     .get   = get_uuid, | 
					
						
							|  |  |  |     .set   = set_uuid, | 
					
						
							|  |  |  |     .set_default_value = set_default_uuid_auto, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-15 16:41:57 +00:00
										 |  |  | /* --- support for array properties --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Used as an opaque for the object properties we add for each
 | 
					
						
							|  |  |  |  * array element. Note that the struct Property must be first | 
					
						
							|  |  |  |  * in the struct so that a pointer to this works as the opaque | 
					
						
							|  |  |  |  * for the underlying element's property hooks as well as for | 
					
						
							|  |  |  |  * our own release callback. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef struct { | 
					
						
							|  |  |  |     struct Property prop; | 
					
						
							|  |  |  |     char *propname; | 
					
						
							|  |  |  |     ObjectPropertyRelease *release; | 
					
						
							|  |  |  | } ArrayElementProperty; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* object property release callback for array element properties:
 | 
					
						
							|  |  |  |  * we call the underlying element's property release hook, and | 
					
						
							|  |  |  |  * then free the memory we allocated when we added the property. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static void array_element_release(Object *obj, const char *name, void *opaque) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     ArrayElementProperty *p = opaque; | 
					
						
							|  |  |  |     if (p->release) { | 
					
						
							|  |  |  |         p->release(obj, name, opaque); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     g_free(p->propname); | 
					
						
							|  |  |  |     g_free(p); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_prop_arraylen(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                               void *opaque, Error **errp) | 
					
						
							| 
									
										
										
										
											2013-03-15 16:41:57 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     /* Setter for the property which defines the length of a
 | 
					
						
							|  |  |  |      * variable-sized property array. As well as actually setting the | 
					
						
							|  |  |  |      * array-length field in the device struct, we have to create the | 
					
						
							|  |  |  |      * array itself and dynamically add the corresponding properties. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     uint32_t *alenptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     void **arrayptr = (void *)dev + prop->arrayoffset; | 
					
						
							| 
									
										
										
										
											2014-04-25 12:44:22 +02:00
										 |  |  |     Error *local_err = NULL; | 
					
						
							| 
									
										
										
										
											2013-03-15 16:41:57 +00:00
										 |  |  |     void *eltptr; | 
					
						
							|  |  |  |     const char *arrayname; | 
					
						
							|  |  |  |     int i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dev->realized) { | 
					
						
							| 
									
										
										
										
											2013-03-25 13:40:44 +00:00
										 |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							| 
									
										
										
										
											2013-03-15 16:41:57 +00:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (*alenptr) { | 
					
						
							|  |  |  |         error_setg(errp, "array size property %s may not be set more than once", | 
					
						
							|  |  |  |                    name); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_uint32(v, name, alenptr, &local_err); | 
					
						
							| 
									
										
										
										
											2014-04-25 12:44:22 +02:00
										 |  |  |     if (local_err) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							| 
									
										
										
										
											2013-03-15 16:41:57 +00:00
										 |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!*alenptr) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* DEFINE_PROP_ARRAY guarantees that name should start with this prefix;
 | 
					
						
							|  |  |  |      * strip it off so we can get the name of the array itself. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     assert(strncmp(name, PROP_ARRAY_LEN_PREFIX, | 
					
						
							|  |  |  |                    strlen(PROP_ARRAY_LEN_PREFIX)) == 0); | 
					
						
							|  |  |  |     arrayname = name + strlen(PROP_ARRAY_LEN_PREFIX); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Note that it is the responsibility of the individual device's deinit
 | 
					
						
							|  |  |  |      * to free the array proper. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     *arrayptr = eltptr = g_malloc0(*alenptr * prop->arrayfieldsize); | 
					
						
							|  |  |  |     for (i = 0; i < *alenptr; i++, eltptr += prop->arrayfieldsize) { | 
					
						
							|  |  |  |         char *propname = g_strdup_printf("%s[%d]", arrayname, i); | 
					
						
							|  |  |  |         ArrayElementProperty *arrayprop = g_new0(ArrayElementProperty, 1); | 
					
						
							|  |  |  |         arrayprop->release = prop->arrayinfo->release; | 
					
						
							|  |  |  |         arrayprop->propname = propname; | 
					
						
							|  |  |  |         arrayprop->prop.info = prop->arrayinfo; | 
					
						
							|  |  |  |         arrayprop->prop.name = propname; | 
					
						
							|  |  |  |         /* This ugly piece of pointer arithmetic sets up the offset so
 | 
					
						
							|  |  |  |          * that when the underlying get/set hooks call qdev_get_prop_ptr | 
					
						
							|  |  |  |          * they get the right answer despite the array element not actually | 
					
						
							|  |  |  |          * being inside the device struct. | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         arrayprop->prop.offset = eltptr - (void *)dev; | 
					
						
							|  |  |  |         assert(qdev_get_prop_ptr(dev, &arrayprop->prop) == eltptr); | 
					
						
							|  |  |  |         object_property_add(obj, propname, | 
					
						
							|  |  |  |                             arrayprop->prop.info->name, | 
					
						
							|  |  |  |                             arrayprop->prop.info->get, | 
					
						
							|  |  |  |                             arrayprop->prop.info->set, | 
					
						
							|  |  |  |                             array_element_release, | 
					
						
							| 
									
										
										
										
											2014-04-25 12:44:22 +02:00
										 |  |  |                             arrayprop, &local_err); | 
					
						
							|  |  |  |         if (local_err) { | 
					
						
							|  |  |  |             error_propagate(errp, local_err); | 
					
						
							| 
									
										
										
										
											2013-03-15 16:41:57 +00:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_arraylen = { | 
					
						
							| 
									
										
										
										
											2013-03-15 16:41:57 +00:00
										 |  |  |     .name = "uint32", | 
					
						
							|  |  |  |     .get = get_uint32, | 
					
						
							|  |  |  |     .set = set_prop_arraylen, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:36:09 +04:00
										 |  |  |     .set_default_value = set_default_value_uint, | 
					
						
							| 
									
										
										
										
											2013-03-15 16:41:57 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | /* --- public helpers --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Property *qdev_prop_walk(Property *props, const char *name) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |     if (!props) { | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  |         return NULL; | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  |     while (props->name) { | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |         if (strcmp(props->name, name) == 0) { | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  |             return props; | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:10 -02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  |         props++; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Property *qdev_prop_find(DeviceState *dev, const char *name) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-28 18:12:47 +02:00
										 |  |  |     ObjectClass *class; | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  |     Property *prop; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* device properties */ | 
					
						
							| 
									
										
										
										
											2012-03-28 18:12:47 +02:00
										 |  |  |     class = object_get_class(OBJECT(dev)); | 
					
						
							|  |  |  |     do { | 
					
						
							|  |  |  |         prop = qdev_prop_walk(DEVICE_CLASS(class)->props, name); | 
					
						
							|  |  |  |         if (prop) { | 
					
						
							|  |  |  |             return prop; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         class = object_class_get_parent(class); | 
					
						
							|  |  |  |     } while (class != object_class_by_name(TYPE_DEVICE)); | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:07 +01:00
										 |  |  | void error_set_from_qdev_prop_error(Error **errp, int ret, DeviceState *dev, | 
					
						
							|  |  |  |                                     Property *prop, const char *value) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     switch (ret) { | 
					
						
							|  |  |  |     case -EEXIST: | 
					
						
							| 
									
										
										
										
											2014-03-21 19:42:26 -04:00
										 |  |  |         error_setg(errp, "Property '%s.%s' can't take value '%s', it's in use", | 
					
						
							| 
									
										
										
										
											2011-12-04 11:17:51 -06:00
										 |  |  |                   object_get_typename(OBJECT(dev)), prop->name, value); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:07 +01:00
										 |  |  |         break; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |     case -EINVAL: | 
					
						
							| 
									
										
										
										
											2015-03-17 11:54:50 +01:00
										 |  |  |         error_setg(errp, QERR_PROPERTY_VALUE_BAD, | 
					
						
							|  |  |  |                    object_get_typename(OBJECT(dev)), prop->name, value); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:07 +01:00
										 |  |  |         break; | 
					
						
							|  |  |  |     case -ENOENT: | 
					
						
							| 
									
										
										
										
											2014-03-21 19:42:26 -04:00
										 |  |  |         error_setg(errp, "Property '%s.%s' can't find value '%s'", | 
					
						
							| 
									
										
										
										
											2011-12-04 11:17:51 -06:00
										 |  |  |                   object_get_typename(OBJECT(dev)), prop->name, value); | 
					
						
							| 
									
										
										
										
											2011-12-18 17:05:07 +01:00
										 |  |  |         break; | 
					
						
							|  |  |  |     case 0: | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-23 16:15:29 +09:00
										 |  |  | void qdev_prop_set_bit(DeviceState *dev, const char *name, bool value) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-01-01 18:48:08 -08:00
										 |  |  |     object_property_set_bool(OBJECT(dev), value, name, &error_abort); | 
					
						
							| 
									
										
										
										
											2010-06-23 16:15:29 +09:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-29 22:48:25 +02:00
										 |  |  | void qdev_prop_set_uint8(DeviceState *dev, const char *name, uint8_t value) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-01-01 18:48:08 -08:00
										 |  |  |     object_property_set_int(OBJECT(dev), value, name, &error_abort); | 
					
						
							| 
									
										
										
										
											2009-09-29 22:48:25 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | void qdev_prop_set_uint16(DeviceState *dev, const char *name, uint16_t value) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-01-01 18:48:08 -08:00
										 |  |  |     object_property_set_int(OBJECT(dev), value, name, &error_abort); | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void qdev_prop_set_uint32(DeviceState *dev, const char *name, uint32_t value) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-01-01 18:48:08 -08:00
										 |  |  |     object_property_set_int(OBJECT(dev), value, name, &error_abort); | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-10 11:43:25 +02:00
										 |  |  | void qdev_prop_set_int32(DeviceState *dev, const char *name, int32_t value) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-01-01 18:48:08 -08:00
										 |  |  |     object_property_set_int(OBJECT(dev), value, name, &error_abort); | 
					
						
							| 
									
										
										
										
											2009-09-10 11:43:25 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-21 11:10:41 +00:00
										 |  |  | void qdev_prop_set_uint64(DeviceState *dev, const char *name, uint64_t value) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-01-01 18:48:08 -08:00
										 |  |  |     object_property_set_int(OBJECT(dev), value, name, &error_abort); | 
					
						
							| 
									
										
										
										
											2009-07-21 11:10:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-17 15:26:17 +02:00
										 |  |  | void qdev_prop_set_string(DeviceState *dev, const char *name, const char *value) | 
					
						
							| 
									
										
										
										
											2010-06-01 20:32:30 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-01-01 18:48:08 -08:00
										 |  |  |     object_property_set_str(OBJECT(dev), value, name, &error_abort); | 
					
						
							| 
									
										
										
										
											2010-06-01 20:32:30 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-10 22:05:49 +02:00
										 |  |  | void qdev_prop_set_macaddr(DeviceState *dev, const char *name, | 
					
						
							|  |  |  |                            const uint8_t *value) | 
					
						
							| 
									
										
										
										
											2009-10-21 15:25:23 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-02 12:51:44 +01:00
										 |  |  |     char str[2 * 6 + 5 + 1]; | 
					
						
							|  |  |  |     snprintf(str, sizeof(str), "%02x:%02x:%02x:%02x:%02x:%02x", | 
					
						
							|  |  |  |              value[0], value[1], value[2], value[3], value[4], value[5]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-01 18:48:08 -08:00
										 |  |  |     object_property_set_str(OBJECT(dev), str, name, &error_abort); | 
					
						
							| 
									
										
										
										
											2009-10-21 15:25:23 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-02 12:51:44 +01:00
										 |  |  | void qdev_prop_set_enum(DeviceState *dev, const char *name, int value) | 
					
						
							| 
									
										
										
										
											2012-01-23 20:15:11 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-02 12:51:44 +01:00
										 |  |  |     Property *prop; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     prop = qdev_prop_find(dev, name); | 
					
						
							| 
									
										
										
										
											2017-08-24 10:46:09 +02:00
										 |  |  |     object_property_set_str(OBJECT(dev), | 
					
						
							|  |  |  |                             qapi_enum_lookup(prop->info->enum_table, value), | 
					
						
							| 
									
										
										
										
											2014-01-01 18:48:08 -08:00
										 |  |  |                             name, &error_abort); | 
					
						
							| 
									
										
										
										
											2012-01-23 20:15:11 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | void qdev_prop_set_ptr(DeviceState *dev, const char *name, void *value) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-02 16:58:31 +01:00
										 |  |  |     Property *prop; | 
					
						
							|  |  |  |     void **ptr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     prop = qdev_prop_find(dev, name); | 
					
						
							|  |  |  |     assert(prop && prop->info == &qdev_prop_ptr); | 
					
						
							|  |  |  |     ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     *ptr = value; | 
					
						
							| 
									
										
										
										
											2009-07-15 13:43:31 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-07 13:11:25 +04:00
										 |  |  | static GPtrArray *global_props(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     static GPtrArray *gp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!gp) { | 
					
						
							|  |  |  |         gp = g_ptr_array_new(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return gp; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-07-15 13:48:21 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-05 14:49:11 -02:00
										 |  |  | void qdev_prop_register_global(GlobalProperty *prop) | 
					
						
							| 
									
										
										
										
											2009-07-15 13:48:21 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-07 13:11:25 +04:00
										 |  |  |     g_ptr_array_add(global_props(), prop); | 
					
						
							| 
									
										
										
										
											2009-07-15 13:48:21 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-08 16:03:30 -03:00
										 |  |  | int qdev_prop_check_globals(void) | 
					
						
							| 
									
										
										
										
											2014-05-05 14:03:06 -04:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-07 13:11:25 +04:00
										 |  |  |     int i, ret = 0; | 
					
						
							| 
									
										
										
										
											2014-05-05 14:03:06 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-07 13:11:25 +04:00
										 |  |  |     for (i = 0; i < global_props()->len; i++) { | 
					
						
							|  |  |  |         GlobalProperty *prop; | 
					
						
							| 
									
										
										
										
											2014-08-08 16:03:31 -03:00
										 |  |  |         ObjectClass *oc; | 
					
						
							|  |  |  |         DeviceClass *dc; | 
					
						
							| 
									
										
										
										
											2018-11-07 13:11:25 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         prop = g_ptr_array_index(global_props(), i); | 
					
						
							| 
									
										
										
										
											2014-08-08 16:03:31 -03:00
										 |  |  |         if (prop->used) { | 
					
						
							|  |  |  |             continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         oc = object_class_by_name(prop->driver); | 
					
						
							|  |  |  |         oc = object_class_dynamic_cast(oc, TYPE_DEVICE); | 
					
						
							|  |  |  |         if (!oc) { | 
					
						
							| 
									
										
										
										
											2017-07-12 06:57:41 -07:00
										 |  |  |             warn_report("global %s.%s has invalid class name", | 
					
						
							|  |  |  |                         prop->driver, prop->property); | 
					
						
							| 
									
										
										
										
											2014-08-08 16:03:31 -03:00
										 |  |  |             ret = 1; | 
					
						
							|  |  |  |             continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         dc = DEVICE_CLASS(oc); | 
					
						
							|  |  |  |         if (!dc->hotpluggable && !prop->used) { | 
					
						
							| 
									
										
										
										
											2017-07-12 06:57:41 -07:00
										 |  |  |             warn_report("global %s.%s=%s not used", | 
					
						
							|  |  |  |                         prop->driver, prop->property, prop->value); | 
					
						
							| 
									
										
										
										
											2014-08-08 16:03:31 -03:00
										 |  |  |             ret = 1; | 
					
						
							| 
									
										
										
										
											2014-05-05 14:03:06 -04:00
										 |  |  |             continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return ret; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-10 21:43:01 -03:00
										 |  |  | void qdev_prop_set_globals(DeviceState *dev) | 
					
						
							| 
									
										
										
										
											2013-05-01 16:03:19 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-07 15:35:34 +04:00
										 |  |  |     object_apply_global_props(OBJECT(dev), global_props(), | 
					
						
							|  |  |  |                               dev->hotplugged ? NULL : &error_fatal); | 
					
						
							| 
									
										
										
										
											2013-05-01 16:03:19 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-29 16:47:56 +02:00
										 |  |  | /* --- 64bit unsigned int 'size' type --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void get_size(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                      Error **errp) | 
					
						
							| 
									
										
										
										
											2013-07-29 16:47:56 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     uint64_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_size(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2013-07-29 16:47:56 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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)
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-20-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:55 -07:00
										 |  |  | static void set_size(Object *obj, Visitor *v, const char *name, void *opaque, | 
					
						
							|  |  |  |                      Error **errp) | 
					
						
							| 
									
										
										
										
											2013-07-29 16:47:56 +02:00
										 |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     uint64_t *ptr = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												qapi: Swap visit_* arguments for consistent 'name' placement
JSON uses "name":value, but many of our visitor interfaces were
called with visit_type_FOO(v, &value, name, errp).  This can be
a bit confusing to have to mentally swap the parameter order to
match JSON order.  It's particularly bad for visit_start_struct(),
where the 'name' parameter is smack in the middle of the
otherwise-related group of 'obj, kind, size' parameters! It's
time to do a global swap of the parameter ordering, so that the
'name' parameter is always immediately after the Visitor argument.
Additional reason in favor of the swap: the existing include/qjson.h
prefers listing 'name' first in json_prop_*(), and I have plans to
unify that file with the qapi visitors; listing 'name' first in
qapi will minimize churn to the (admittedly few) qjson.h clients.
Later patches will then fix docs, object.h, visitor-impl.h, and
those clients to match.
Done by first patching scripts/qapi*.py by hand to make generated
files do what I want, then by running the following Coccinelle
script to affect the rest of the code base:
 $ spatch --sp-file script `git grep -l '\bvisit_' -- '**/*.[ch]'`
I then had to apply some touchups (Coccinelle insisted on TAB
indentation in visitor.h, and botched the signature of
visit_type_enum() by rewriting 'const char *const strings[]' to
the syntactically invalid 'const char*const[] strings').  The
movement of parameters is sufficient to provoke compiler errors
if any callers were missed.
    // Part 1: Swap declaration order
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_start_struct
    -(TV v, TObj OBJ, T1 ARG1, const char *name, T2 ARG2, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type bool, TV, T1;
    identifier ARG1;
    @@
     bool visit_optional
    -(TV v, T1 ARG1, const char *name)
    +(TV v, const char *name, T1 ARG1)
     { ... }
    @@
    type TV, TErr, TObj, T1;
    identifier OBJ, ARG1;
    @@
     void visit_get_next_type
    -(TV v, TObj OBJ, T1 ARG1, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj, T1, T2;
    identifier OBJ, ARG1, ARG2;
    @@
     void visit_type_enum
    -(TV v, TObj OBJ, T1 ARG1, T2 ARG2, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, T1 ARG1, T2 ARG2, TErr errp)
     { ... }
    @@
    type TV, TErr, TObj;
    identifier OBJ;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
     void VISIT_TYPE
    -(TV v, TObj OBJ, const char *name, TErr errp)
    +(TV v, const char *name, TObj OBJ, TErr errp)
     { ... }
    // Part 2: swap caller order
    @@
    expression V, NAME, OBJ, ARG1, ARG2, ERR;
    identifier VISIT_TYPE =~ "^visit_type_";
    @@
    (
    -visit_start_struct(V, OBJ, ARG1, NAME, ARG2, ERR)
    +visit_start_struct(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -visit_optional(V, ARG1, NAME)
    +visit_optional(V, NAME, ARG1)
    |
    -visit_get_next_type(V, OBJ, ARG1, NAME, ERR)
    +visit_get_next_type(V, NAME, OBJ, ARG1, ERR)
    |
    -visit_type_enum(V, OBJ, ARG1, ARG2, NAME, ERR)
    +visit_type_enum(V, NAME, OBJ, ARG1, ARG2, ERR)
    |
    -VISIT_TYPE(V, OBJ, NAME, ERR)
    +VISIT_TYPE(V, NAME, OBJ, ERR)
    )
Signed-off-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <1454075341-13658-19-git-send-email-eblake@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
											
										 
											2016-01-29 06:48:54 -07:00
										 |  |  |     visit_type_size(v, name, ptr, errp); | 
					
						
							| 
									
										
										
										
											2013-07-29 16:47:56 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_size = { | 
					
						
							| 
									
										
										
										
											2013-07-29 16:47:56 +02:00
										 |  |  |     .name  = "size", | 
					
						
							|  |  |  |     .get = get_size, | 
					
						
							|  |  |  |     .set = set_size, | 
					
						
							| 
									
										
										
										
											2017-06-07 20:36:09 +04:00
										 |  |  |     .set_default_value = set_default_value_uint, | 
					
						
							| 
									
										
										
										
											2013-07-29 16:47:56 +02:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:52 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* --- object link property --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void create_link_property(Object *obj, Property *prop, Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     Object **child = qdev_get_prop_ptr(DEVICE(obj), prop); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     object_property_add_link(obj, prop->name, prop->link_type, | 
					
						
							|  |  |  |                              child, | 
					
						
							|  |  |  |                              qdev_prop_allow_set_link_before_realize, | 
					
						
							| 
									
										
										
										
											2018-05-31 21:51:17 +02:00
										 |  |  |                              OBJ_PROP_LINK_STRONG, | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:52 +08:00
										 |  |  |                              errp); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:54 +08:00
										 |  |  | const PropertyInfo qdev_prop_link = { | 
					
						
							| 
									
										
										
										
											2017-07-14 10:14:52 +08:00
										 |  |  |     .name = "link", | 
					
						
							|  |  |  |     .create = create_link_property, | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2018-02-06 11:08:26 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* --- OffAutoPCIBAR off/auto/bar0/bar1/bar2/bar3/bar4/bar5 --- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const PropertyInfo qdev_prop_off_auto_pcibar = { | 
					
						
							|  |  |  |     .name = "OffAutoPCIBAR", | 
					
						
							|  |  |  |     .description = "off/auto/bar0/bar1/bar2/bar3/bar4/bar5", | 
					
						
							|  |  |  |     .enum_table = &OffAutoPCIBAR_lookup, | 
					
						
							|  |  |  |     .get = get_enum, | 
					
						
							|  |  |  |     .set = set_enum, | 
					
						
							|  |  |  |     .set_default_value = set_default_value_enum, | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2018-12-12 12:39:08 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* --- PCIELinkSpeed 2_5/5/8/16 -- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void get_prop_pcielinkspeed(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                                    void *opaque, Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     PCIExpLinkSpeed *p = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     int speed; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     switch (*p) { | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_2_5GT: | 
					
						
							|  |  |  |         speed = PCIE_LINK_SPEED_2_5; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_5GT: | 
					
						
							|  |  |  |         speed = PCIE_LINK_SPEED_5; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_8GT: | 
					
						
							|  |  |  |         speed = PCIE_LINK_SPEED_8; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_16GT: | 
					
						
							|  |  |  |         speed = PCIE_LINK_SPEED_16; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |         /* Unreachable */ | 
					
						
							|  |  |  |         abort(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     visit_type_enum(v, prop->name, &speed, prop->info->enum_table, errp); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void set_prop_pcielinkspeed(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                                    void *opaque, Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     PCIExpLinkSpeed *p = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     int speed; | 
					
						
							|  |  |  |     Error *local_err = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dev->realized) { | 
					
						
							|  |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     visit_type_enum(v, prop->name, &speed, prop->info->enum_table, &local_err); | 
					
						
							|  |  |  |     if (local_err) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     switch (speed) { | 
					
						
							|  |  |  |     case PCIE_LINK_SPEED_2_5: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_2_5GT; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case PCIE_LINK_SPEED_5: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_5GT; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case PCIE_LINK_SPEED_8: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_8GT; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case PCIE_LINK_SPEED_16: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_16GT; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |         /* Unreachable */ | 
					
						
							|  |  |  |         abort(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const PropertyInfo qdev_prop_pcie_link_speed = { | 
					
						
							|  |  |  |     .name = "PCIELinkSpeed", | 
					
						
							|  |  |  |     .description = "2_5/5/8/16", | 
					
						
							|  |  |  |     .enum_table = &PCIELinkSpeed_lookup, | 
					
						
							|  |  |  |     .get = get_prop_pcielinkspeed, | 
					
						
							|  |  |  |     .set = set_prop_pcielinkspeed, | 
					
						
							|  |  |  |     .set_default_value = set_default_value_enum, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* --- PCIELinkWidth 1/2/4/8/12/16/32 -- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void get_prop_pcielinkwidth(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                                    void *opaque, Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     PCIExpLinkWidth *p = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     int width; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     switch (*p) { | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_X1: | 
					
						
							|  |  |  |         width = PCIE_LINK_WIDTH_1; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_X2: | 
					
						
							|  |  |  |         width = PCIE_LINK_WIDTH_2; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_X4: | 
					
						
							|  |  |  |         width = PCIE_LINK_WIDTH_4; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_X8: | 
					
						
							|  |  |  |         width = PCIE_LINK_WIDTH_8; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_X12: | 
					
						
							|  |  |  |         width = PCIE_LINK_WIDTH_12; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_X16: | 
					
						
							|  |  |  |         width = PCIE_LINK_WIDTH_16; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case QEMU_PCI_EXP_LNK_X32: | 
					
						
							|  |  |  |         width = PCIE_LINK_WIDTH_32; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |         /* Unreachable */ | 
					
						
							|  |  |  |         abort(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     visit_type_enum(v, prop->name, &width, prop->info->enum_table, errp); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void set_prop_pcielinkwidth(Object *obj, Visitor *v, const char *name, | 
					
						
							|  |  |  |                                    void *opaque, Error **errp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     DeviceState *dev = DEVICE(obj); | 
					
						
							|  |  |  |     Property *prop = opaque; | 
					
						
							|  |  |  |     PCIExpLinkWidth *p = qdev_get_prop_ptr(dev, prop); | 
					
						
							|  |  |  |     int width; | 
					
						
							|  |  |  |     Error *local_err = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (dev->realized) { | 
					
						
							|  |  |  |         qdev_prop_set_after_realize(dev, name, errp); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     visit_type_enum(v, prop->name, &width, prop->info->enum_table, &local_err); | 
					
						
							|  |  |  |     if (local_err) { | 
					
						
							|  |  |  |         error_propagate(errp, local_err); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     switch (width) { | 
					
						
							|  |  |  |     case PCIE_LINK_WIDTH_1: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_X1; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case PCIE_LINK_WIDTH_2: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_X2; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case PCIE_LINK_WIDTH_4: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_X4; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case PCIE_LINK_WIDTH_8: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_X8; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case PCIE_LINK_WIDTH_12: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_X12; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case PCIE_LINK_WIDTH_16: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_X16; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     case PCIE_LINK_WIDTH_32: | 
					
						
							|  |  |  |         *p = QEMU_PCI_EXP_LNK_X32; | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |         /* Unreachable */ | 
					
						
							|  |  |  |         abort(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const PropertyInfo qdev_prop_pcie_link_width = { | 
					
						
							|  |  |  |     .name = "PCIELinkWidth", | 
					
						
							|  |  |  |     .description = "1/2/4/8/12/16/32", | 
					
						
							|  |  |  |     .enum_table = &PCIELinkWidth_lookup, | 
					
						
							|  |  |  |     .get = get_prop_pcielinkwidth, | 
					
						
							|  |  |  |     .set = set_prop_pcielinkwidth, | 
					
						
							|  |  |  |     .set_default_value = set_default_value_enum, | 
					
						
							|  |  |  | }; |