aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2018-04-28 13:38:11 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2018-04-28 13:38:11 +0100
commit12da94dc1d36900e16d336c766bfde1cbbcf90ff (patch)
tree79dc7bf55c8640d79d2df5dd540b07607a41eb36 /src
parent7852bacad4e123ba4309182a0bc77f6b5884c4b4 (diff)
downloadrspamd-12da94dc1d36900e16d336c766bfde1cbbcf90ff.tar.gz
rspamd-12da94dc1d36900e16d336c766bfde1cbbcf90ff.zip
[Feature] Upgrade t1ha distribution
Diffstat (limited to 'src')
-rw-r--r--src/libcryptobox/cryptobox.c73
-rw-r--r--src/libcryptobox/cryptobox.h2
2 files changed, 12 insertions, 63 deletions
diff --git a/src/libcryptobox/cryptobox.c b/src/libcryptobox/cryptobox.c
index d99dd912d..5f8b2eca4 100644
--- a/src/libcryptobox/cryptobox.c
+++ b/src/libcryptobox/cryptobox.c
@@ -1477,78 +1477,31 @@ void rspamd_cryptobox_hash (guchar *out,
rspamd_cryptobox_hash_final (&st, out);
}
-/* MUST be 64 bytes at maximum */
-struct rspamd_cryptobox_fast_hash_state_real {
- guint64 h; /* current hash value */
- guint64 pos; /* pos in bytes in the buf */
- guint64 buf;
-};
+G_STATIC_ASSERT (sizeof (t1ha_context_t) ==
+ sizeof (rspamd_cryptobox_fast_hash_state_t));
void
rspamd_cryptobox_fast_hash_init (rspamd_cryptobox_fast_hash_state_t *st,
guint64 seed)
{
- struct rspamd_cryptobox_fast_hash_state_real *rst =
- (struct rspamd_cryptobox_fast_hash_state_real *)st;
-
- memset (rst, 0, sizeof (*rst));
- rst->h = seed;
+ t1ha_context_t *rst = (t1ha_context_t *)st;
+ t1ha2_init (rst, seed, 0);
}
void
rspamd_cryptobox_fast_hash_update (rspamd_cryptobox_fast_hash_state_t *st,
const void *data, gsize len)
{
- struct rspamd_cryptobox_fast_hash_state_real *rst =
- (struct rspamd_cryptobox_fast_hash_state_real *)st;
- const guchar *d = data;
- guint leftover;
- guint64 n;
-
- leftover = rst->pos;
-
- if (leftover > 0 && len + leftover >= 8) {
- n = sizeof (rst->buf) - leftover;
- memcpy (((guchar *)&rst->buf) + leftover, d, n);
- d += n;
- len -= n;
- rst->h = mum_hash_step (rst->h, rst->buf);
- rst->buf = 0;
- rst->pos = 0;
- }
-
- while (len > 8) {
-#ifdef _MUM_UNALIGNED_ACCESS
- rst->h = mum_hash_step (rst->h, *(guint64 *)d);
-#else
- memcpy (&n, d, sizeof (n));
- rst->h = mum_hash_step (rst->h, n);
-#endif
- len -= 8;
- d += 8;
- }
-
- if (len > 0 && rst->pos + len <= 8) {
- memcpy (((guchar *)&rst->buf) + rst->pos, d, len);
- rst->pos += len;
- }
+ t1ha_context_t *rst = (t1ha_context_t *)st;
+ t1ha2_update (rst, data, len);
}
guint64
rspamd_cryptobox_fast_hash_final (rspamd_cryptobox_fast_hash_state_t *st)
{
- struct rspamd_cryptobox_fast_hash_state_real *rst =
- (struct rspamd_cryptobox_fast_hash_state_real *)st;
- guint leftover;
+ t1ha_context_t *rst = (t1ha_context_t *)st;
- leftover = rst->pos;
-
- if (leftover > 0) {
- memset (((guchar *)&rst->buf) + leftover, 0, sizeof (rst->buf) - leftover);
- rst->h = mum_hash_step (rst->h, rst->buf);
- }
-
- return mum_hash_finish (rst->h);
+ return t1ha2_final (rst, NULL);
}
/**
@@ -1558,18 +1511,14 @@ static inline guint64
rspamd_cryptobox_fast_hash_machdep (const void *data,
gsize len, guint64 seed)
{
-#if defined(__LP64__) || defined(_LP64)
- return t1ha (data, len, seed);
-#else
- return t1ha32 (data, len, seed);
-#endif
+ return t1ha0 (data, len, seed);
}
static inline guint64
rspamd_cryptobox_fast_hash_indep (const void *data,
gsize len, guint64 seed)
{
- return t1ha (data, len, seed);
+ return t1ha2_atonce (data, len, seed);
}
guint64
@@ -1593,7 +1542,7 @@ rspamd_cryptobox_fast_hash_specific (
case RSPAMD_CRYPTOBOX_MUMHASH:
return mum_hash (data, len, seed);
case RSPAMD_CRYPTOBOX_T1HA:
- return t1ha (data, len, seed);
+ return t1ha2_atonce (data, len, seed);
case RSPAMD_CRYPTOBOX_HASHFAST_INDEPENDENT:
return rspamd_cryptobox_fast_hash_indep (data, len, seed);
case RSPAMD_CRYPTOBOX_HASHFAST:
diff --git a/src/libcryptobox/cryptobox.h b/src/libcryptobox/cryptobox.h
index 82438b788..05ad85a04 100644
--- a/src/libcryptobox/cryptobox.h
+++ b/src/libcryptobox/cryptobox.h
@@ -344,7 +344,7 @@ void rspamd_cryptobox_hash (guchar *out,
/* Non crypto hash IUF interface */
typedef struct RSPAMD_ALIGNED(32) rspamd_cryptobox_fast_hash_state_s {
- unsigned char opaque[64];
+ unsigned char opaque[64 + sizeof (size_t) + sizeof (uint64_t)];
} rspamd_cryptobox_fast_hash_state_t;
/**