| /**************************************************************************** |
| * include/crypto/chachapoly.h |
| * |
| * SPDX-License-Identifier: ISC |
| * SPDX-FileCopyrightText:2015 Mike Belopuhov |
| * |
| * Permission to use, copy, modify, and distribute this software for any |
| * purpose with or without fee is hereby granted, provided that the above |
| * copyright notice and this permission notice appear in all copies. |
| * |
| * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
| * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
| * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
| * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
| * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
| * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
| * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
| ****************************************************************************/ |
| |
| #ifndef __INCLUDE_CRYPTO_CHACHAPOLY_H |
| #define __INCLUDE_CRYPTO_CHACHAPOLY_H |
| |
| #define CHACHA20_KEYSIZE 32 |
| #define CHACHA20_CTR 4 |
| #define CHACHA20_SALT 4 |
| #define CHACHA20_NONCE 8 |
| #define CHACHA20_BLOCK_LEN 64 |
| |
| struct chacha20_ctx |
| { |
| uint8_t block[CHACHA20_BLOCK_LEN]; |
| uint8_t nonce[CHACHA20_NONCE]; |
| }; |
| |
| int chacha20_setkey(FAR void *, FAR uint8_t *, int); |
| void chacha20_reinit(caddr_t, FAR uint8_t *); |
| void chacha20_crypt(caddr_t, FAR uint8_t *); |
| |
| #define POLY1305_KEYLEN 32 |
| #define POLY1305_TAGLEN 16 |
| #define POLY1305_BLOCK_LEN 16 |
| |
| struct poly1305_ctx |
| { |
| /* r, h, pad, leftover */ |
| |
| unsigned long state[5 + 5 + 4]; |
| size_t leftover; |
| unsigned char buffer[POLY1305_BLOCK_LEN]; |
| unsigned char final; |
| }; |
| |
| typedef struct |
| { |
| uint8_t key[POLY1305_KEYLEN]; |
| |
| /* counter, salt */ |
| |
| uint8_t nonce[CHACHA20_NONCE]; |
| struct chacha20_ctx chacha; |
| struct poly1305_ctx poly; |
| } |
| CHACHA20_POLY1305_CTX; |
| |
| void chacha20_poly1305_init(FAR void *); |
| void chacha20_poly1305_setkey(FAR void *, FAR const uint8_t *, uint16_t); |
| void chacha20_poly1305_reinit(FAR void *, FAR const uint8_t *, uint16_t); |
| int chacha20_poly1305_update(FAR void *, FAR const uint8_t *, size_t); |
| void chacha20_poly1305_final(FAR uint8_t *, FAR void *); |
| |
| /* WireGuard crypto */ |
| |
| #define CHACHA20POLY1305_KEY_SIZE CHACHA20_KEYSIZE |
| #define CHACHA20POLY1305_AUTHTAG_SIZE POLY1305_TAGLEN |
| #define XCHACHA20POLY1305_NONCE_SIZE 24 |
| |
| void chacha20poly1305_encrypt( |
| FAR uint8_t *, FAR const uint8_t *, const size_t, |
| FAR const uint8_t *, const size_t, const uint64_t, |
| FAR const uint8_t *); |
| |
| int chacha20poly1305_decrypt( |
| FAR uint8_t *, FAR const uint8_t *, const size_t, |
| FAR const uint8_t *, const size_t, const uint64_t, |
| FAR const uint8_t *); |
| |
| void xchacha20poly1305_encrypt( |
| FAR uint8_t *, FAR const uint8_t *, const size_t, |
| FAR const uint8_t *, const size_t, |
| FAR const uint8_t *, |
| FAR const uint8_t *); |
| |
| int xchacha20poly1305_decrypt( |
| FAR uint8_t *, FAR const uint8_t *, const size_t, |
| FAR const uint8_t *, const size_t, |
| FAR const uint8_t *, |
| FAR const uint8_t *); |
| |
| #endif /* __INCLUDE_CRYPTO_CHACHAPOLY_H */ |