Botan 3.4.0
Crypto and TLS for C&
xmss_common_ops.cpp
Go to the documentation of this file.
1/*
2 * XMSS Common Ops
3 * Operations shared by XMSS signature generation and verification operations.
4 * (C) 2016,2017 Matthias Gierlings
5 *
6 * Botan is released under the Simplified BSD License (see license.txt)
7 **/
8
9#include <botan/internal/xmss_common_ops.h>
10
11#include <botan/internal/xmss_hash.h>
12
13namespace Botan {
14
16 const secure_vector<uint8_t>& left,
17 const secure_vector<uint8_t>& right,
18 XMSS_Address& adrs,
19 const secure_vector<uint8_t>& seed,
20 XMSS_Hash& hash,
21 const XMSS_Parameters& params) {
24 hash.prf(key, seed, adrs.bytes());
25
27 secure_vector<uint8_t> bitmask_l;
28 hash.prf(bitmask_l, seed, adrs.bytes());
29
31 secure_vector<uint8_t> bitmask_r;
32 hash.prf(bitmask_r, seed, adrs.bytes());
33
34 BOTAN_ASSERT(bitmask_l.size() == left.size() && bitmask_r.size() == right.size(),
35 "Bitmask size doesn't match node size.");
36
37 secure_vector<uint8_t> concat_xor(params.element_size() * 2);
38 for(size_t i = 0; i < left.size(); i++) {
39 concat_xor[i] = left[i] ^ bitmask_l[i];
40 concat_xor[i + left.size()] = right[i] ^ bitmask_r[i];
41 }
42
43 hash.h(result, key, concat_xor);
44}
45
48 XMSS_Address& adrs,
49 const secure_vector<uint8_t>& seed,
50 XMSS_Hash& hash,
51 const XMSS_Parameters& params) {
52 size_t l = params.len();
53 adrs.set_tree_height(0);
54
55 while(l > 1) {
56 for(size_t i = 0; i < l >> 1; i++) {
57 adrs.set_tree_index(static_cast<uint32_t>(i));
58 randomize_tree_hash(pk[i], pk[2 * i], pk[2 * i + 1], adrs, seed, hash, params);
59 }
60 if(l & 0x01) {
61 pk[l >> 1] = pk[l - 1];
62 }
63 l = (l >> 1) + (l & 0x01);
64 adrs.set_tree_height(adrs.get_tree_height() + 1);
65 }
66 result = pk[0];
67}
68
69} // namespace Botan
#define BOTAN_ASSERT(expr, assertion_made)
Definition assert.h:50
void set_key_mask_mode(Key_Mask value)
uint32_t get_tree_height() const
void set_tree_height(uint32_t value)
void set_tree_index(uint32_t value)
const secure_vector< uint8_t > & bytes() const
static void create_l_tree(secure_vector< uint8_t > &result, wots_keysig_t pk, XMSS_Address &adrs, const secure_vector< uint8_t > &seed, XMSS_Hash &hash, const XMSS_Parameters &params)
static void randomize_tree_hash(secure_vector< uint8_t > &result, const secure_vector< uint8_t > &left, const secure_vector< uint8_t > &right, XMSS_Address &adrs, const secure_vector< uint8_t > &seed, XMSS_Hash &hash, const XMSS_Parameters &params)
void prf(secure_vector< uint8_t > &result, std::span< const uint8_t > key, std::span< const uint8_t > data)
Definition xmss_hash.h:57
void h(secure_vector< uint8_t > &result, std::span< const uint8_t > key, std::span< const uint8_t > data)
Definition xmss_hash.h:97
size_t element_size() const
std::vector< secure_vector< uint8_t > > wots_keysig_t
std::vector< T, secure_allocator< T > > secure_vector
Definition secmem.h:61