On Fri, Jun 2, 2017 at 5:55 PM Markus Armbruster <arm...@redhat.com> wrote:

> Marc-André Lureau <marcandre.lur...@redhat.com> writes:
>
> > Add and use unsigned type for various properties.
> >
> > Signed-off-by: Marc-André Lureau <marcandre.lur...@redhat.com>
>
> The commit message is a bit misleading.  We don't "add unsigned
> properties", we clean up the property code to avoid type casts between
> signed and unsigned.
>

That in itself is imho a good reason for the cleanup :)

>
> I'm not sure that's worth the churn by itself.  But perhaps it helps
> later in this series.  If yes, can you give me a hint?
>

Churn is quite minimal though.


>
> > ---
> >  include/hw/qdev-core.h       |  1 +
> >  include/hw/qdev-properties.h | 51
> +++++++++++++++++++++++++++-----------------
> >  hw/core/qdev-properties.c    | 23 ++++++++++++--------
> >  3 files changed, 46 insertions(+), 29 deletions(-)
> >
> > diff --git a/include/hw/qdev-core.h b/include/hw/qdev-core.h
> > index 784971b8d8..9d7c1c0e9b 100644
> > --- a/include/hw/qdev-core.h
> > +++ b/include/hw/qdev-core.h
> > @@ -228,6 +228,7 @@ struct Property {
> >      uint8_t      bitnr;
> >      union {
> >          int64_t i;
> > +        uint64_t u;
> >      } defval;
> >      int          arrayoffset;
> >      PropertyInfo *arrayinfo;
> > diff --git a/include/hw/qdev-properties.h b/include/hw/qdev-properties.h
> > index 6663a547ea..16d3ada8df 100644
> > --- a/include/hw/qdev-properties.h
> > +++ b/include/hw/qdev-properties.h
> > @@ -37,6 +37,7 @@ extern PropertyInfo qdev_prop_arraylen;
> >          .offset    = offsetof(_state, _field)                    \
> >              + type_check(_type, typeof_field(_state, _field)),   \
> >          }
> > +
> >  #define DEFINE_PROP_INT(_name, _state, _field, _defval, _prop, _type) {
> \
> >          .name      = (_name),
>  \
> >          .info      = &(_prop),
> \
> > @@ -44,29 +45,39 @@ extern PropertyInfo qdev_prop_arraylen;
> >              + type_check(_type,typeof_field(_state, _field)),
>  \
> >          .defval.i  = (_type)_defval,
> \
> >          }
> > -#define DEFINE_PROP_BIT(_name, _state, _field, _bit, _defval) {  \
> > -        .name      = (_name),                                    \
> > -        .info      = &(qdev_prop_bit),                           \
> > -        .bitnr    = (_bit),                                      \
> > -        .offset    = offsetof(_state, _field)                    \
> > -            + type_check(uint32_t,typeof_field(_state, _field)), \
> > -        .defval.i  = (bool)_defval,                              \
> > +
> > +#define DEFINE_PROP_BIT(_name, _state, _field, _bit, _defval) {
>  \
> > +        .name      = (_name),
>  \
> > +        .info      = &(qdev_prop_bit),
> \
> > +        .bitnr    = (_bit),
>  \
> > +        .offset    = offsetof(_state, _field)
>  \
> > +            + type_check(uint32_t, typeof_field(_state, _field)),
>   \
> > +        .defval.u   = (bool)_defval,
> \
> >          }
>
> Let's keep the backslashes where they are to reduce churn.
>
> > +
> > +#define DEFINE_PROP_UINT(_name, _state, _field, _defval, _prop, _type)
> { \
> > +        .name      = (_name),
>  \
> > +        .info      = &(_prop),
> \
> > +        .offset    = offsetof(_state, _field)
>  \
> > +            + type_check(_type, typeof_field(_state, _field)),
> \
> > +        .defval.u  = (_type)_defval,
> \
> > +        }
> > +
> >  #define DEFINE_PROP_BIT64(_name, _state, _field, _bit, _defval) {
>  \
> >          .name      = (_name),
>  \
> >          .info      = &(qdev_prop_bit64),
> \
> >          .bitnr    = (_bit),
>  \
> >          .offset    = offsetof(_state, _field)
>  \
> >              + type_check(uint64_t, typeof_field(_state, _field)),
>  \
> > -        .defval.i  = (bool)_defval,
>  \
> > +        .defval.u  = (bool)_defval,
>  \
> >          }
> >
> > -#define DEFINE_PROP_BOOL(_name, _state, _field, _defval) {       \
> > -        .name      = (_name),                                    \
> > -        .info      = &(qdev_prop_bool),                          \
> > -        .offset    = offsetof(_state, _field)                    \
> > -            + type_check(bool, typeof_field(_state, _field)),    \
> > -        .defval.i  = (bool)_defval,                              \
> > +#define DEFINE_PROP_BOOL(_name, _state, _field, _defval) {      \
> > +        .name      = (_name),                                   \
> > +        .info      = &(qdev_prop_bool),                         \
> > +        .offset    = offsetof(_state, _field)                   \
> > +            + type_check(bool, typeof_field(_state, _field)),   \
> > +        .defval.u    = (bool)_defval,                           \
> >          }
>
> Likewise.
>
> >
> >  #define PROP_ARRAY_LEN_PREFIX "len-"
> > @@ -107,17 +118,17 @@ extern PropertyInfo qdev_prop_arraylen;
> >          }
> >
> >  #define DEFINE_PROP_UINT8(_n, _s, _f, _d)                       \
> > -    DEFINE_PROP_INT(_n, _s, _f, _d, qdev_prop_uint8, uint8_t)
> > +    DEFINE_PROP_UINT(_n, _s, _f, _d, qdev_prop_uint8, uint8_t)
> >  #define DEFINE_PROP_UINT16(_n, _s, _f, _d)                      \
> > -    DEFINE_PROP_INT(_n, _s, _f, _d, qdev_prop_uint16, uint16_t)
> > +    DEFINE_PROP_UINT(_n, _s, _f, _d, qdev_prop_uint16, uint16_t)
> >  #define DEFINE_PROP_UINT32(_n, _s, _f, _d)                      \
> > -    DEFINE_PROP_INT(_n, _s, _f, _d, qdev_prop_uint32, uint32_t)
> > +    DEFINE_PROP_UINT(_n, _s, _f, _d, qdev_prop_uint32, uint32_t)
> >  #define DEFINE_PROP_INT32(_n, _s, _f, _d)                      \
> >      DEFINE_PROP_INT(_n, _s, _f, _d, qdev_prop_int32, int32_t)
> >  #define DEFINE_PROP_UINT64(_n, _s, _f, _d)                      \
> > -    DEFINE_PROP_INT(_n, _s, _f, _d, qdev_prop_uint64, uint64_t)
> > +    DEFINE_PROP_UINT(_n, _s, _f, _d, qdev_prop_uint64, uint64_t)
> >  #define DEFINE_PROP_SIZE(_n, _s, _f, _d)                       \
> > -    DEFINE_PROP_INT(_n, _s, _f, _d, qdev_prop_size, uint64_t)
> > +    DEFINE_PROP_UINT(_n, _s, _f, _d, qdev_prop_size, uint64_t)
> >  #define DEFINE_PROP_PCI_DEVFN(_n, _s, _f, _d)                   \
> >      DEFINE_PROP_INT(_n, _s, _f, _d, qdev_prop_pci_devfn, int32_t)
> >
> > @@ -163,7 +174,7 @@ extern PropertyInfo qdev_prop_arraylen;
> >  #define DEFINE_PROP_BIOS_CHS_TRANS(_n, _s, _f, _d) \
> >      DEFINE_PROP_INT(_n, _s, _f, _d, qdev_prop_bios_chs_trans, int)
> >  #define DEFINE_PROP_BLOCKSIZE(_n, _s, _f) \
> > -    DEFINE_PROP_INT(_n, _s, _f, 0, qdev_prop_blocksize, uint16_t)
> > +    DEFINE_PROP_UINT(_n, _s, _f, 0, qdev_prop_blocksize, uint16_t)
> >  #define DEFINE_PROP_PCI_HOST_DEVADDR(_n, _s, _f) \
> >      DEFINE_PROP(_n, _s, _f, qdev_prop_pci_host_devaddr,
> PCIHostDeviceAddress)
> >
> > diff --git a/hw/core/qdev-properties.c b/hw/core/qdev-properties.c
> > index 952cda7758..92fb43cb0d 100644
> > --- a/hw/core/qdev-properties.c
> > +++ b/hw/core/qdev-properties.c
> > @@ -71,7 +71,7 @@ static void set_enum(Object *obj, Visitor *v, const
> char *name, void *opaque,
> >
> >  static void set_default_value_enum(Object *obj, const Property *prop)
> >  {
> > -    object_property_set_str(obj, prop->info->enum_table[prop->defval.i],
> > +    object_property_set_str(obj, prop->info->enum_table[prop->defval.u],
> >                              prop->name, &error_abort);
> >  }
> >
> > @@ -128,7 +128,7 @@ static void prop_set_bit(Object *obj, Visitor *v,
> const char *name,
> >
> >  static void set_default_value_bool(Object *obj, const Property *prop)
> >  {
> > -    object_property_set_bool(obj, prop->defval.i, prop->name,
> &error_abort);
> > +    object_property_set_bool(obj, prop->defval.u, prop->name,
> &error_abort);
> >  }
> >
> >  PropertyInfo qdev_prop_bit = {
> > @@ -264,11 +264,16 @@ static void set_default_value_int(Object *obj,
> const Property *prop)
> >      object_property_set_int(obj, prop->defval.i, prop->name,
> &error_abort);
> >  }
> >
> > +static void set_default_value_uint(Object *obj, const Property *prop)
> > +{
> > +    object_property_set_uint(obj, prop->defval.u, prop->name,
> &error_abort);
> > +}
> > +
> >  PropertyInfo qdev_prop_uint8 = {
> >      .name  = "uint8",
> >      .get   = get_uint8,
> >      .set   = set_uint8,
> > -    .set_default_value = set_default_value_int,
> > +    .set_default_value = set_default_value_uint,
> >  };
> >
> >  /* --- 16bit integer --- */
> > @@ -302,7 +307,7 @@ PropertyInfo qdev_prop_uint16 = {
> >      .name  = "uint16",
> >      .get   = get_uint16,
> >      .set   = set_uint16,
> > -    .set_default_value = set_default_value_int,
> > +    .set_default_value = set_default_value_uint,
> >  };
> >
> >  /* --- 32bit integer --- */
> > @@ -361,7 +366,7 @@ PropertyInfo qdev_prop_uint32 = {
> >      .name  = "uint32",
> >      .get   = get_uint32,
> >      .set   = set_uint32,
> > -    .set_default_value = set_default_value_int,
> > +    .set_default_value = set_default_value_uint,
> >  };
> >
> >  PropertyInfo qdev_prop_int32 = {
> > @@ -402,7 +407,7 @@ PropertyInfo qdev_prop_uint64 = {
> >      .name  = "uint64",
> >      .get   = get_uint64,
> >      .set   = set_uint64,
> > -    .set_default_value = set_default_value_int,
> > +    .set_default_value = set_default_value_uint,
> >  };
> >
> >  /* --- string --- */
> > @@ -725,7 +730,7 @@ PropertyInfo qdev_prop_blocksize = {
> >      .description = "A power of two between 512 and 32768",
> >      .get   = get_uint16,
> >      .set   = set_blocksize,
> > -    .set_default_value = set_default_value_int,
> > +    .set_default_value = set_default_value_uint,
> >  };
> >
> >  /* --- pci host address --- */
> > @@ -948,7 +953,7 @@ PropertyInfo qdev_prop_arraylen = {
> >      .name = "uint32",
> >      .get = get_uint32,
> >      .set = set_prop_arraylen,
> > -    .set_default_value = set_default_value_int,
> > +    .set_default_value = set_default_value_uint,
> >  };
> >
> >  /* --- public helpers --- */
> > @@ -1185,5 +1190,5 @@ PropertyInfo qdev_prop_size = {
> >      .name  = "size",
> >      .get = get_size,
> >      .set = set_size,
> > -    .set_default_value = set_default_value_int,
> > +    .set_default_value = set_default_value_uint,
> >  };
>
> --
Marc-André Lureau

Reply via email to