8 #include <botan/sp800_108.h>
9 #include <botan/loadstor.h>
10 #include <botan/exceptn.h>
16 const uint8_t secret[],
size_t secret_len,
17 const uint8_t salt[],
size_t salt_len,
18 const uint8_t label[],
size_t label_len)
const
20 const std::size_t prf_len = m_prf->output_length();
21 const uint8_t delim = 0;
22 const uint32_t length =
static_cast<uint32_t
>(key_len * 8);
26 uint8_t be_len[4] = { 0 };
30 m_prf->set_key(secret, secret_len);
32 while(p < key + key_len && counter != 0)
34 const std::size_t to_copy = std::min< std::size_t >(key + key_len - p, prf_len);
35 uint8_t be_cnt[4] = { 0 };
39 m_prf->update(be_cnt,4);
40 m_prf->update(label,label_len);
42 m_prf->update(salt,salt_len);
43 m_prf->update(be_len,4);
58 const uint8_t secret[],
size_t secret_len,
59 const uint8_t salt[],
size_t salt_len,
60 const uint8_t label[],
size_t label_len)
const
62 const uint32_t length =
static_cast<uint32_t
>(key_len * 8);
63 const std::size_t prf_len = m_prf->output_length();
64 const std::size_t iv_len = (salt_len >= prf_len ? prf_len : 0);
65 const uint8_t delim = 0;
69 uint8_t be_len[4] = { 0 };
74 m_prf->set_key(secret, secret_len);
76 while(p < key + key_len && counter != 0)
78 const std::size_t to_copy = std::min< std::size_t >(key + key_len - p, prf_len);
79 uint8_t be_cnt[4] = { 0 };
84 m_prf->update(be_cnt,4);
85 m_prf->update(label,label_len);
88 m_prf->update(be_len,4);
104 const uint8_t secret[],
size_t secret_len,
105 const uint8_t salt[],
size_t salt_len,
106 const uint8_t label[],
size_t label_len)
const
108 const uint32_t length =
static_cast<uint32_t
>(key_len * 8);
109 const std::size_t prf_len = m_prf->output_length();
110 const uint8_t delim = 0;
113 uint32_t counter = 1;
114 uint8_t be_len[4] = { 0 };
118 m_prf->set_key(secret,secret_len);
121 std::copy(label,label + label_len,std::back_inserter(ai));
122 ai.emplace_back(delim);
123 std::copy(salt,salt + salt_len,std::back_inserter(ai));
124 std::copy(be_len,be_len + 4,std::back_inserter(ai));
126 while(p < key + key_len && counter != 0)
133 const std::size_t to_copy = std::min< std::size_t >(key + key_len - p, prf_len);
134 uint8_t be_cnt[4] = { 0 };
139 m_prf->update(be_cnt,4);
140 m_prf->update(label, label_len);
141 m_prf->update(delim);
142 m_prf->update(salt, salt_len);
143 m_prf->update(be_len,4);
void store_be(uint16_t in, uint8_t out[2])
size_t kdf(uint8_t key[], size_t key_len, const uint8_t secret[], size_t secret_len, const uint8_t salt[], size_t salt_len, const uint8_t label[], size_t label_len) const override
std::vector< T, secure_allocator< T >> secure_vector
size_t kdf(uint8_t key[], size_t key_len, const uint8_t secret[], size_t secret_len, const uint8_t salt[], size_t salt_len, const uint8_t label[], size_t label_len) const override
void copy_mem(T *out, const T *in, size_t n)
size_t kdf(uint8_t key[], size_t key_len, const uint8_t secret[], size_t secret_len, const uint8_t salt[], size_t salt_len, const uint8_t label[], size_t label_len) const override