diff options
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 | ||
