diff options
author | jsing <> | 2014-05-01 16:06:24 +0000 |
---|---|---|
committer | jsing <> | 2014-05-01 16:06:24 +0000 |
commit | 8adb3dbae070d097e78bcc87a567ccd28d073da5 (patch) | |
tree | 7c3bd1b71964d068f0975d770db3b39f16cf4756 /src/lib/libcrypto/chacha | |
parent | 01bc5de569d5ec2e77fcaec43eae5ce76f9c3800 (diff) | |
download | openbsd-8adb3dbae070d097e78bcc87a567ccd28d073da5.tar.gz openbsd-8adb3dbae070d097e78bcc87a567ccd28d073da5.tar.bz2 openbsd-8adb3dbae070d097e78bcc87a567ccd28d073da5.zip |
Provide an EVP implementation for ChaCha.
ok miod@
Diffstat (limited to 'src/lib/libcrypto/chacha')
-rw-r--r-- | src/lib/libcrypto/chacha/chacha.c | 20 | ||||
-rw-r--r-- | src/lib/libcrypto/chacha/chacha.h | 11 |
2 files changed, 31 insertions, 0 deletions
diff --git a/src/lib/libcrypto/chacha/chacha.c b/src/lib/libcrypto/chacha/chacha.c index d76d64de4a..1bc95f502d 100644 --- a/src/lib/libcrypto/chacha/chacha.c +++ b/src/lib/libcrypto/chacha/chacha.c | |||
@@ -14,9 +14,29 @@ | |||
14 | * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | 14 | * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
15 | */ | 15 | */ |
16 | 16 | ||
17 | #include "chacha.h" | ||
17 | #include "chacha-merged.c" | 18 | #include "chacha-merged.c" |
18 | 19 | ||
19 | void | 20 | void |
21 | ChaCha_set_key(ChaCha_ctx *ctx, const unsigned char *key, uint32_t keybits) | ||
22 | { | ||
23 | chacha_keysetup((chacha_ctx *)ctx, key, keybits); | ||
24 | } | ||
25 | |||
26 | void | ||
27 | ChaCha_set_iv(ChaCha_ctx *ctx, const unsigned char *iv, | ||
28 | const unsigned char *counter) | ||
29 | { | ||
30 | chacha_ivsetup((chacha_ctx *)ctx, iv, counter); | ||
31 | } | ||
32 | |||
33 | void | ||
34 | ChaCha(ChaCha_ctx *ctx, unsigned char *out, const unsigned char *in, size_t len) | ||
35 | { | ||
36 | chacha_encrypt_bytes((chacha_ctx *)ctx, in, out, (uint32_t)len); | ||
37 | } | ||
38 | |||
39 | void | ||
20 | CRYPTO_chacha_20(unsigned char *out, const unsigned char *in, size_t len, | 40 | CRYPTO_chacha_20(unsigned char *out, const unsigned char *in, size_t len, |
21 | const unsigned char key[32], const unsigned char iv[8], size_t counter) | 41 | const unsigned char key[32], const unsigned char iv[8], size_t counter) |
22 | { | 42 | { |
diff --git a/src/lib/libcrypto/chacha/chacha.h b/src/lib/libcrypto/chacha/chacha.h index d66a719ae4..456d960ed9 100644 --- a/src/lib/libcrypto/chacha/chacha.h +++ b/src/lib/libcrypto/chacha/chacha.h | |||
@@ -29,6 +29,17 @@ | |||
29 | extern "C" { | 29 | extern "C" { |
30 | #endif | 30 | #endif |
31 | 31 | ||
32 | typedef struct { | ||
33 | unsigned int input[16]; | ||
34 | } ChaCha_ctx; | ||
35 | |||
36 | void ChaCha_set_key(ChaCha_ctx *ctx, const unsigned char *key, | ||
37 | unsigned int keybits); | ||
38 | void ChaCha_set_iv(ChaCha_ctx *ctx, const unsigned char *iv, | ||
39 | const unsigned char *counter); | ||
40 | void ChaCha(ChaCha_ctx *ctx, unsigned char *out, const unsigned char *in, | ||
41 | size_t len); | ||
42 | |||
32 | void CRYPTO_chacha_20(unsigned char *out, const unsigned char *in, size_t len, | 43 | void CRYPTO_chacha_20(unsigned char *out, const unsigned char *in, size_t len, |
33 | const unsigned char key[32], const unsigned char iv[8], size_t counter); | 44 | const unsigned char key[32], const unsigned char iv[8], size_t counter); |
34 | 45 | ||