20 static const uint8_t
k1[32] = {0};
21 static const uint8_t
k2[32] = {0};
26 bool include_decryption) {
27 std::vector<uint8_t> in(
29 std::vector<uint8_t> out(
31 uint64_t seqnr_payload = 0;
32 uint64_t seqnr_aad = 0;
37 assert(aead.
Crypt(seqnr_payload, seqnr_aad, aad_pos, out.data(),
38 out.size(), in.data(), buffersize,
true));
40 if (include_decryption) {
42 assert(aead.
GetLength(&len, seqnr_aad, aad_pos, in.data()));
43 assert(aead.
Crypt(seqnr_payload, seqnr_aad, aad_pos, out.data(),
44 out.size(), in.data(), buffersize,
true));
55 if (seqnr_payload + 1 == std::numeric_limits<uint64_t>::max()) {
97 std::vector<uint8_t> in(buffersize, 0);
static void HASH_256BYTES(benchmark::State &state)
static void CHACHA20_POLY1305_AEAD_64BYTES_ONLY_ENCRYPT(benchmark::State &state)
bool GetLength(uint32_t *len24_out, uint64_t seqnr_aad, int aad_pos, const uint8_t *ciphertext)
decrypts the 3 bytes AAD data and decodes it into a uint32_t field
static void HASH(benchmark::State &state, size_t buffersize)
static constexpr uint64_t BUFFER_SIZE_LARGE
static void CHACHA20_POLY1305_AEAD_1MB_ONLY_ENCRYPT(benchmark::State &state)
A hasher class for Bitcoin's 256-bit hash (double SHA-256).
static void CHACHA20_POLY1305_AEAD_64BYTES_ENCRYPT_DECRYPT(benchmark::State &state)
static void CHACHA20_POLY1305_AEAD_1MB_ENCRYPT_DECRYPT(benchmark::State &state)
BENCHMARK(CHACHA20_POLY1305_AEAD_64BYTES_ONLY_ENCRYPT, 500000)
static constexpr int CHACHA20_POLY1305_AEAD_AAD_LEN
static void CHACHA20_POLY1305_AEAD_256BYTES_ONLY_ENCRYPT(benchmark::State &state)
bool Crypt(uint64_t seqnr_payload, uint64_t seqnr_aad, int aad_pos, uint8_t *dest, size_t dest_len, const uint8_t *src, size_t src_len, bool is_encrypt)
Encrypts/decrypts a packet.
static void HASH_64BYTES(benchmark::State &state)
static const uint8_t k1[32]
CHash256 & Write(const uint8_t *data, size_t len)
static void HASH_1MB(benchmark::State &state)
static void CHACHA20_POLY1305_AEAD_256BYTES_ENCRYPT_DECRYPT(benchmark::State &state)
static constexpr uint64_t BUFFER_SIZE_SMALL
static void CHACHA20_POLY1305_AEAD(benchmark::State &state, size_t buffersize, bool include_decryption)
static const size_t OUTPUT_SIZE
static ChaCha20Poly1305AEAD aead(k1, 32, k2, 32)
static constexpr uint64_t BUFFER_SIZE_TINY
static constexpr int CHACHA20_ROUND_OUTPUT
static const uint8_t k2[32]