summaryrefslogtreecommitdiff
path: root/debian/patches/ihash0001-libihash-fix-index-computation.patch
diff options
context:
space:
mode:
Diffstat (limited to 'debian/patches/ihash0001-libihash-fix-index-computation.patch')
-rw-r--r--debian/patches/ihash0001-libihash-fix-index-computation.patch44
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
+