/ src / bench / poly1305.cpp
poly1305.cpp
 1  // Copyright (c) 2019-present The Bitcoin Core developers
 2  // Distributed under the MIT software license, see the accompanying
 3  // file COPYING or http://www.opensource.org/licenses/mit-license.php.
 4  
 5  
 6  #include <bench/bench.h>
 7  #include <crypto/poly1305.h>
 8  #include <span.h>
 9  
10  #include <cstddef>
11  #include <cstdint>
12  #include <vector>
13  
14  /* Number of bytes to process per iteration */
15  static constexpr uint64_t BUFFER_SIZE_TINY  = 64;
16  static constexpr uint64_t BUFFER_SIZE_SMALL = 256;
17  static constexpr uint64_t BUFFER_SIZE_LARGE = 1024*1024;
18  
19  static void POLY1305(benchmark::Bench& bench, size_t buffersize)
20  {
21      std::vector<std::byte> tag(Poly1305::TAGLEN, {});
22      std::vector<std::byte> key(Poly1305::KEYLEN, {});
23      std::vector<std::byte> in(buffersize, {});
24      bench.batch(in.size()).unit("byte").run([&] {
25          Poly1305{key}.Update(in).Finalize(tag);
26      });
27  }
28  
29  static void POLY1305_64BYTES(benchmark::Bench& bench)
30  {
31      POLY1305(bench, BUFFER_SIZE_TINY);
32  }
33  
34  static void POLY1305_256BYTES(benchmark::Bench& bench)
35  {
36      POLY1305(bench, BUFFER_SIZE_SMALL);
37  }
38  
39  static void POLY1305_1MB(benchmark::Bench& bench)
40  {
41      POLY1305(bench, BUFFER_SIZE_LARGE);
42  }
43  
44  BENCHMARK(POLY1305_64BYTES);
45  BENCHMARK(POLY1305_256BYTES);
46  BENCHMARK(POLY1305_1MB);