2018-08-26 08:30:00 +05:30
|
|
|
#ifndef CHACHA_H
|
|
|
|
#define CHACHA_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2018-09-11 19:52:28 +05:30
|
|
|
#define CHACHA_KEY_SIZE 32
|
|
|
|
#define CHACHA_IV_SIZE 8
|
|
|
|
|
2018-08-26 08:30:00 +05:30
|
|
|
typedef uint8_t u8;
|
|
|
|
typedef uint32_t u32;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
u32 input[16];
|
|
|
|
} chacha_ctx;
|
|
|
|
|
2018-09-11 19:52:28 +05:30
|
|
|
void chacha_keysetup(chacha_ctx *x,const u8 *k);
|
2018-08-26 08:30:00 +05:30
|
|
|
void chacha_ivsetup(chacha_ctx *x,const u8 *iv);
|
|
|
|
void chacha_keystream_bytes(chacha_ctx *x,u8 *c,u32 bytes);
|
|
|
|
|
|
|
|
#endif
|