summaryrefslogtreecommitdiffstats
path: root/crypto/poly1305/poly1305_local.h
diff options
context:
space:
mode:
authorRichard Levitte <levitte@openssl.org>2016-10-26 00:25:44 +0200
committerRichard Levitte <levitte@openssl.org>2016-11-03 13:13:31 +0100
commitaeac218372239752e79769da8f7d1db16d87307d (patch)
treeef525968098f1c8f7ea915506077e28e92d3cf21 /crypto/poly1305/poly1305_local.h
parent9c89c8460a4dcf828a22e2dfc279b5ea8a80ec60 (diff)
Convert poly1305 selftest into internal test
Reviewed-by: Emilia Käsper <emilia@openssl.org> (Merged from https://github.com/openssl/openssl/pull/1789)
Diffstat (limited to 'crypto/poly1305/poly1305_local.h')
-rw-r--r--crypto/poly1305/poly1305_local.h27
1 files changed, 27 insertions, 0 deletions
diff --git a/crypto/poly1305/poly1305_local.h b/crypto/poly1305/poly1305_local.h
new file mode 100644
index 0000000000..6d4d9dc5b6
--- /dev/null
+++ b/crypto/poly1305/poly1305_local.h
@@ -0,0 +1,27 @@
+/*
+ * Copyright 2015-2016 The OpenSSL Project Authors. All Rights Reserved.
+ *
+ * Licensed under the OpenSSL license (the "License"). You may not use
+ * this file except in compliance with the License. You can obtain a copy
+ * in the file LICENSE in the source distribution or at
+ * https://www.openssl.org/source/license.html
+ */
+
+typedef void (*poly1305_blocks_f) (void *ctx, const unsigned char *inp,
+ size_t len, unsigned int padbit);
+typedef void (*poly1305_emit_f) (void *ctx, unsigned char mac[16],
+ const unsigned int nonce[4]);
+
+struct poly1305_context {
+ double opaque[24]; /* large enough to hold internal state, declared
+ * 'double' to ensure at least 64-bit invariant
+ * alignment across all platforms and
+ * configurations */
+ unsigned int nonce[4];
+ unsigned char data[POLY1305_BLOCK_SIZE];
+ size_t num;
+ struct {
+ poly1305_blocks_f blocks;
+ poly1305_emit_f emit;
+ } func;
+};