>-Original Message-
>From: mesa-dev [mailto:mesa-dev-boun...@lists.freedesktop.org] On Behalf Of
>Lionel Landwerlin
>Sent: Monday, October 17, 2016 1:57 PM
>To: mesa-dev@lists.freedesktop.org
>Cc: Landwerlin, Lionel G <lionel.g.landwer...@intel.com>
>Subject: [Mesa-dev] [PATCH 2/3] intel: aubinator: load fields values from xml
>data
>
>Signed-off-by: Lionel Landwerlin <lionel.g.landwer...@intel.com>
>---
> src/intel/tools/decoder.c | 31 +++
>src/intel/tools/decoder.h | 9 +
> 2 files changed, 40 insertions(+)
>
>diff --git a/src/intel/tools/decoder.c b/src/intel/tools/decoder.c index
>cab5271..88ba5c0 100644
>--- a/src/intel/tools/decoder.c
>+++ b/src/intel/tools/decoder.c
>@@ -303,6 +303,21 @@ create_field(struct parser_context *ctx, const char
>**atts)
>return field;
> }
>
>+static struct gen_value *
>+create_value(struct parser_context *ctx, const char **atts) {
>+ struct gen_value *value = xzalloc(sizeof(*value));
>+
>+ for (int i = 0; atts[i]; i += 2) {
>+ if (strcmp(atts[i], "name") == 0)
>+ value->name = xstrdup(atts[i + 1]);
>+ else if (strcmp(atts[i], "value") == 0)
>+ value->value = strtoul(atts[i + 1], NULL, 0);
>+ }
>+
>+ return value;
>+}
>+
> static void
> start_element(void *data, const char *element_name, const char **atts) { @@
>-352,6 +367,22 @@ start_element(void *data, const char *element_name, const
>char **atts)
> } while (ctx->group->group_count > 0);
>} else if (strcmp(element_name, "enum") == 0) {
>} else if (strcmp(element_name, "value") == 0) {
>+ if (ctx->nfields > 0) {
>+ struct gen_field *field = ctx->fields[ctx->nfields - 1];
>+ if (field->n_allocated_values <= field->n_values) {
>+if (field->n_allocated_values == 0) {
>+ field->n_allocated_values = 2;
>+ field->values =
>+ xzalloc(sizeof(field->values[0]) *
>field->n_allocated_values);
>+} else {
>+ field->n_allocated_values *= 2;
>+ field->values =
>+ realloc(field->values,
>+ sizeof(field->values[0]) *
>field->n_allocated_values);
>+}
>+ }
>+ field->values[field->n_values++] = create_value(ctx, atts);
>+ }
>}
> }
>
>diff --git a/src/intel/tools/decoder.h b/src/intel/tools/decoder.h index
>9a677be..ecc9ff1 100644
>--- a/src/intel/tools/decoder.h
>+++ b/src/intel/tools/decoder.h
>@@ -99,6 +99,15 @@ struct gen_field {
>struct gen_type type;
>bool has_default;
>uint32_t default_value;
>+
>+ struct gen_value **values;
>+ uint32_t n_values;
>+ uint32_t n_allocated_values;
>+};
>+
>+struct gen_value {
>+ char *name;
>+ uint64_t value;
> };
>
> void gen_field_iterator_init(struct gen_field_iterator *iter,
>--
>2.9.3
>
[SG] Works for me
Reviewed-by: Sirisha Gandikota <sirisha.gandik...@intel.com>
>___
>mesa-dev mailing list
>mesa-dev@lists.freedesktop.org
>https://lists.freedesktop.org/mailman/listinfo/mesa-dev
___
mesa-dev mailing list
mesa-dev@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/mesa-dev