diff options
Diffstat (limited to 'debian/patches/ihash0001-libihash-fix-index-computation.patch')
-rw-r--r-- | debian/patches/ihash0001-libihash-fix-index-computation.patch | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/debian/patches/ihash0001-libihash-fix-index-computation.patch b/debian/patches/ihash0001-libihash-fix-index-computation.patch new file mode 100644 index 00000000..4ba9f9da --- /dev/null +++ b/debian/patches/ihash0001-libihash-fix-index-computation.patch @@ -0,0 +1,44 @@ +From f318ac5b55327ba8787d675b3f2470644b7a81e8 Mon Sep 17 00:00:00 2001 +From: Justus Winter <justus@gnupg.org> +Date: Thu, 28 Apr 2016 23:59:26 +0200 +Subject: [PATCH hurd 1/3] libihash: fix index computation + +Previously, find_index would return a suboptimal slot if a tombstone +was in the optimal slot. + +* libihash/ihash.c (find_index): Fix index computation. +--- + libihash/ihash.c | 7 +------ + 1 file changed, 1 insertion(+), 6 deletions(-) + +diff --git a/libihash/ihash.c b/libihash/ihash.c +index 4bc54fd..01ba23b 100644 +--- a/libihash/ihash.c ++++ b/libihash/ihash.c +@@ -81,15 +81,9 @@ find_index (hurd_ihash_t ht, hurd_ihash_key_t key) + + idx = hash (ht, key) & mask; + +- if (ht->items[idx].value == _HURD_IHASH_EMPTY +- || compare (ht, ht->items[idx].key, key)) +- return idx; +- + up_idx = idx; +- + do + { +- up_idx = (up_idx + 1) & mask; + if (ht->items[up_idx].value == _HURD_IHASH_EMPTY) + return first_deleted_set ? first_deleted : up_idx; + if (compare (ht, ht->items[up_idx].key, key)) +@@ -97,6 +91,7 @@ find_index (hurd_ihash_t ht, hurd_ihash_key_t key) + if (! first_deleted_set + && ht->items[up_idx].value == _HURD_IHASH_DELETED) + first_deleted = up_idx, first_deleted_set = 1; ++ up_idx = (up_idx + 1) & mask; + } + while (up_idx != idx); + +-- +2.1.4 + |