From: Anthony Liguori <anthony@codemonkey.ws>
To: Alon Levy <alevy@redhat.com>
Cc: qemu-devel@nongnu.org, Gerd Hoffmann <kraxel@redhat.com>
Subject: Re: [Qemu-devel] [PATCH 03/20] qdev-properties: add PROP_TYPE_ENUM
Date: Thu, 03 Feb 2011 10:44:13 -0600 [thread overview]
Message-ID: <4D4ADB5D.1010005@codemonkey.ws> (raw)
In-Reply-To: <1296678500-19497-4-git-send-email-alevy@redhat.com>
On 02/02/2011 02:28 PM, Alon Levy wrote:
> Example usage:
>
> EnumTable foo_enum_table[] = {
> {"bar", 1},
> {"buz", 2},
> {NULL, 0},
> };
>
> DEFINE_PROP_ENUM("foo", State, foo, 1, foo_enum_table)
>
> When using qemu -device foodev,? it will appear as:
> foodev.foo=bar/buz
> ---
> hw/qdev-properties.c | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++
> hw/qdev.h | 15 ++++++++++++
> 2 files changed, 75 insertions(+), 0 deletions(-)
>
Missing Signed-off-by.
Is it really necessary to introduce this in this series? There's a lot
missing here like the ability to determine which values are valid for an
enum through QMP.
I think this will also unexpected break the device_add QMP interface
since there's some special logic to handle types. It's unclear to me
whether we should be sending the symbolic name or the value through QMP.
Regards,
Anthony Liguori
> diff --git a/hw/qdev-properties.c b/hw/qdev-properties.c
> index a493087..3157721 100644
> --- a/hw/qdev-properties.c
> +++ b/hw/qdev-properties.c
> @@ -63,6 +63,66 @@ PropertyInfo qdev_prop_bit = {
> .print = print_bit,
> };
>
> +/* --- Enumeration --- */
> +/* Example usage:
> +EnumTable foo_enum_table[] = {
> + {"bar", 1},
> + {"buz", 2},
> + {NULL, 0},
> +};
> +DEFINE_PROP_ENUM("foo", State, foo, 1, foo_enum_table),
> + */
> +static int parse_enum(DeviceState *dev, Property *prop, const char *str)
> +{
> + uint8_t *ptr = qdev_get_prop_ptr(dev, prop);
> + EnumTable *option = (EnumTable*)prop->data;
> +
> + while (option->name != NULL) {
> + if (!strncmp(str, option->name, strlen(option->name))) {
> + *ptr = option->value;
> + return 0;
> + }
> + option++;
> + }
> + return -EINVAL;
> +}
> +
> +static int print_enum(DeviceState *dev, Property *prop, char *dest, size_t len)
> +{
> + uint32_t *p = qdev_get_prop_ptr(dev, prop);
> + EnumTable *option = (EnumTable*)prop->data;
> + while (option->name != NULL) {
> + if (*p == option->value) {
> + return snprintf(dest, len, "%s", option->name);
> + }
> + option++;
> + }
> + return 0;
> +}
> +
> +static int print_enum_options(DeviceInfo *info, Property *prop, char *dest, size_t len)
> +{
> + int ret = 0;
> + EnumTable *option = (EnumTable*)prop->data;
> + while (option->name != NULL) {
> + ret += snprintf(dest + ret, len - ret, "%s", option->name);
> + if (option[1].name != NULL) {
> + ret += snprintf(dest + ret, len - ret, "/");
> + }
> + option++;
> + }
> + return ret;
> +}
> +
> +PropertyInfo qdev_prop_enum = {
> + .name = "enum",
> + .type = PROP_TYPE_ENUM,
> + .size = sizeof(uint32_t),
> + .parse = parse_enum,
> + .print = print_enum,
> + .print_options = print_enum_options,
> +};
> +
> /* --- 8bit integer --- */
>
> static int parse_uint8(DeviceState *dev, Property *prop, const char *str)
> diff --git a/hw/qdev.h b/hw/qdev.h
> index 3d9acd7..3701d83 100644
> --- a/hw/qdev.h
> +++ b/hw/qdev.h
> @@ -102,6 +102,7 @@ enum PropertyType {
> PROP_TYPE_VLAN,
> PROP_TYPE_PTR,
> PROP_TYPE_BIT,
> + PROP_TYPE_ENUM,
> };
>
> struct PropertyInfo {
> @@ -121,6 +122,11 @@ typedef struct GlobalProperty {
> QTAILQ_ENTRY(GlobalProperty) next;
> } GlobalProperty;
>
> +typedef struct EnumTable {
> + const char *name;
> + uint32_t value;
> +} EnumTable;
> +
> /*** Board API. This should go away once we have a machine config file. ***/
>
> DeviceState *qdev_create(BusState *bus, const char *name);
> @@ -235,6 +241,7 @@ extern PropertyInfo qdev_prop_drive;
> extern PropertyInfo qdev_prop_netdev;
> extern PropertyInfo qdev_prop_vlan;
> extern PropertyInfo qdev_prop_pci_devfn;
> +extern PropertyInfo qdev_prop_enum;
>
> #define DEFINE_PROP(_name, _state, _field, _prop, _type) { \
> .name = (_name), \
> @@ -257,6 +264,14 @@ extern PropertyInfo qdev_prop_pci_devfn;
> + type_check(uint32_t,typeof_field(_state, _field)), \
> .defval = (bool[]) { (_defval) }, \
> }
> +#define DEFINE_PROP_ENUM(_name, _state, _field, _defval, _options) { \
> + .name = (_name), \
> + .info =&(qdev_prop_enum), \
> + .offset = offsetof(_state, _field) \
> + + type_check(uint32_t,typeof_field(_state, _field)), \
> + .defval = (uint32_t[]) { (_defval) }, \
> + .data = (void*)(_options), \
> + }
>
> #define DEFINE_PROP_UINT8(_n, _s, _f, _d) \
> DEFINE_PROP_DEFAULT(_n, _s, _f, _d, qdev_prop_uint8, uint8_t)
>
next prev parent reply other threads:[~2011-02-03 16:44 UTC|newest]
Thread overview: 30+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-02-02 20:28 [Qemu-devel] [PATCH 00/20] usb-ccid (v16) Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 01/20] qdev: add print_options callback Alon Levy
2011-02-03 16:39 ` Anthony Liguori
2011-02-03 20:54 ` Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 02/20] qdev: add data pointer to Property Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 03/20] qdev-properties: add PROP_TYPE_ENUM Alon Levy
2011-02-03 16:44 ` Anthony Liguori [this message]
2011-02-03 20:59 ` Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 04/20] qdev-properties: parse_enum: don't cast a void* Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 05/20] usb-ccid: add CCID bus Alon Levy
2011-02-03 16:46 ` Anthony Liguori
2011-02-03 18:53 ` Alon Levy
2011-02-03 19:29 ` Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 06/20] usb-ccid: review fixes (v15-v16) Alon Levy
2011-02-03 16:48 ` Anthony Liguori
2011-02-03 18:53 ` Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 07/20] introduce libcacard/vscard_common.h Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 08/20] libcacard/vscard_common.h update (v15->v16) Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 09/20] ccid: add passthru card device Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 10/20] ccid-card-passthru: review fixes (v15->v16) Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 11/20] libcacard: initial commit after coding style fixes Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 12/20] libcacard: fixes from review (v15->v16) Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 13/20] ccid: add ccid-card-emulated device (v2) Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 14/20] ccid-card-emulated: use PROP_TYPE_ENUM for backend Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 15/20] ccid-card-emulated: review fixes (v15->v16) Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 16/20] ccid: add docs Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 17/20] ccid: configure: add --enable/disable and nss only disable Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 18/20] ccid: add qdev description strings Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 19/20] smartcard, configure: add --enable-smartcard-nss, report only nss Alon Levy
2011-02-02 20:28 ` [Qemu-devel] [PATCH 20/20] smartcard,configure: " Alon Levy
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4D4ADB5D.1010005@codemonkey.ws \
--to=anthony@codemonkey.ws \
--cc=alevy@redhat.com \
--cc=kraxel@redhat.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).