[Mesa-dev] [PATCH 1/2] util: Implement a hash table cloning function

Emil Velikov emil.l.velikov at gmail.com
Mon Mar 12 18:48:47 UTC 2018


Hi Thomas,

On 12 March 2018 at 17:55, Thomas Helland <thomashelland90 at gmail.com> wrote:
> V2: Don't rzalloc; we are about to rewrite the whole thing (Vladislav)
> ---
>  src/util/hash_table.c | 22 ++++++++++++++++++++++
>  src/util/hash_table.h |  2 ++
>  2 files changed, 24 insertions(+)
>
> diff --git a/src/util/hash_table.c b/src/util/hash_table.c
> index b7421a0144..f8d5d0f88a 100644
> --- a/src/util/hash_table.c
> +++ b/src/util/hash_table.c
> @@ -141,6 +141,28 @@ _mesa_hash_table_create(void *mem_ctx,
>     return ht;
>  }
>
> +struct hash_table *
> +_mesa_hash_table_clone(struct hash_table *src, void *dst_mem_ctx)
> +{
> +   struct hash_table *ht;
> +
> +   ht = ralloc(dst_mem_ctx, struct hash_table);
> +   if (ht == NULL)
> +      return NULL;
> +
> +   memcpy(ht, src, sizeof(struct hash_table));
> +
> +   ht->table = ralloc_array(ht, struct hash_entry, ht->size);
> +   if (ht->table == NULL) {
> +      ralloc_free(ht);
> +      return NULL;
> +   }
> +
> +   memcpy(ht->table, src->table, ht->size * sizeof(struct hash_entry));
> +
Thinking out loud:

I'm wondering if it won't make sense to reuse _mesa_hash_table_create,
instead of open-coding it?

-Emil


More information about the mesa-dev mailing list