summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2021-05-18 08:40:09 -0400
committerNick Mathewson <nickm@torproject.org>2021-05-18 08:40:09 -0400
commit4c06c619faceb5d158a725d97fda45cadb2cf9c9 (patch)
tree071aac150da74aabbf72ddcdb968459220c2ad4a /src
parente2c1ac214c0ae77282709b50fb9fbdde50dd7a1f (diff)
downloadtor-4c06c619faceb5d158a725d97fda45cadb2cf9c9.tar.gz
tor-4c06c619faceb5d158a725d97fda45cadb2cf9c9.zip
Use a more secure hash function for the circuitmux hashtable.
Fixes bug 40931; bugfix on 0.2.4.4-alpha. Also tracked as TROVE-2021-005. This issue was reported by Jann Horn from Google's Project Zero.
Diffstat (limited to 'src')
-rw-r--r--src/core/or/circuitmux.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/core/or/circuitmux.c b/src/core/or/circuitmux.c
index 88f9ac7923..e7309553c4 100644
--- a/src/core/or/circuitmux.c
+++ b/src/core/or/circuitmux.c
@@ -216,9 +216,10 @@ chanid_circid_entries_eq(chanid_circid_muxinfo_t *a,
static inline unsigned int
chanid_circid_entry_hash(chanid_circid_muxinfo_t *a)
{
- return (((unsigned int)(a->circ_id) << 8) ^
- ((unsigned int)((a->chan_id >> 32) & 0xffffffff)) ^
- ((unsigned int)(a->chan_id & 0xffffffff)));
+ uint8_t data[8 + 4];
+ set_uint64(data, a->chan_id);
+ set_uint32(data + 8, a->circ_id);
+ return (unsigned) siphash24g(data, sizeof(data));
}
/* Declare the struct chanid_circid_muxinfo_map type */
@@ -1361,4 +1362,3 @@ circuitmux_compare_muxes, (circuitmux_t *cmux_1, circuitmux_t *cmux_2))
return 0;
}
}
-