aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/openssl/include/crypto/chacha.h
blob: 5142658a34f6bfdac014e50992e147ed4bc6bb89 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/* 
 * Copyright 2015-2018 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 
 */ 
 
#ifndef OSSL_CRYPTO_CHACHA_H
#define OSSL_CRYPTO_CHACHA_H
 
#include <stddef.h> 
 
/* 
 * ChaCha20_ctr32 encrypts |len| bytes from |inp| with the given key and 
 * nonce and writes the result to |out|, which may be equal to |inp|. 
 * The |key| is not 32 bytes of verbatim key material though, but the 
 * said material collected into 8 32-bit elements array in host byte 
 * order. Same approach applies to nonce: the |counter| argument is 
 * pointer to concatenated nonce and counter values collected into 4 
 * 32-bit elements. This, passing crypto material collected into 32-bit 
 * elements as opposite to passing verbatim byte vectors, is chosen for 
 * efficiency in multi-call scenarios. 
 */ 
void ChaCha20_ctr32(unsigned char *out, const unsigned char *inp, 
                    size_t len, const unsigned int key[8], 
                    const unsigned int counter[4]); 
/* 
 * You can notice that there is no key setup procedure. Because it's 
 * as trivial as collecting bytes into 32-bit elements, it's reckoned 
 * that below macro is sufficient. 
 */ 
#define CHACHA_U8TOU32(p)  ( \ 
                ((unsigned int)(p)[0])     | ((unsigned int)(p)[1]<<8) | \ 
                ((unsigned int)(p)[2]<<16) | ((unsigned int)(p)[3]<<24)  ) 
 
#define CHACHA_KEY_SIZE		32 
#define CHACHA_CTR_SIZE		16 
#define CHACHA_BLK_SIZE		64 
 
#endif