libctf: fix hash removal
authorNick Alcock <nick.alcock@oracle.com>
Fri, 28 Jun 2019 20:58:31 +0000 (21:58 +0100)
committerNick Alcock <nick.alcock@oracle.com>
Mon, 1 Jul 2019 10:05:59 +0000 (11:05 +0100)
We must call htab_remove_elt with an element (in this case, a mocked-up
one with only the key populated, since no reasonable hash function will
need the other fields), not with the key alone.

libctf/
* ctf-hash.c (ctf_dynhash_remove): Call with a mocked-up element.

libctf/ChangeLog
libctf/ctf-hash.c

index d91abd2..dd3113b 100644 (file)
@@ -1,5 +1,9 @@
 2019-06-28  Nick Alcock <nick.alcock@oracle.com>
 
+       * ctf-hash.c (ctf_dynhash_remove): Call with a mocked-up element.
+
+2019-06-28  Nick Alcock <nick.alcock@oracle.com>
+
        * ctf-dump.c (ctf_dump_format_type): Prefix hex strings with 0x.
        (ctf_dump_funcs): Likewise.
 
index adfe93e..03a398e 100644 (file)
@@ -176,7 +176,8 @@ ctf_dynhash_insert (ctf_dynhash_t *hp, void *key, void *value)
 void
 ctf_dynhash_remove (ctf_dynhash_t *hp, const void *key)
 {
-  htab_remove_elt (hp->htab, (void *) key);
+  ctf_helem_t hep = { (void *) key, NULL, NULL, NULL };
+  htab_remove_elt (hp->htab, &hep);
 }
 
 void *