8#include <botan/internal/siphash.h>
10#include <botan/internal/fmt.h>
11#include <botan/internal/loadstor.h>
12#include <botan/internal/rotate.h>
13#include <botan/internal/stl_util.h>
26 for(
size_t i = 0; i != r; ++i) {
53void SipHash::add_data(std::span<const uint8_t> input) {
57 m_words +=
static_cast<uint8_t
>(input.size());
59 BufferSlicer in(input);
62 while(!in.empty() && m_mbuf_pos != 8) {
63 m_mbuf = (m_mbuf >> 8) | (
static_cast<uint64_t
>(in.take_byte()) << 56);
68 SipRounds(m_mbuf, m_V, m_C);
74 while(in.remaining() >= 8) {
79 m_mbuf = (m_mbuf >> 8) | (
static_cast<uint64_t
>(in.take_byte()) << 56);
84void SipHash::final_result(std::span<uint8_t> mac) {
88 m_mbuf = (
static_cast<uint64_t
>(m_words) << 56);
89 }
else if(m_mbuf_pos < 8) {
90 m_mbuf = (m_mbuf >> (64 - m_mbuf_pos * 8)) | (
static_cast<uint64_t
>(m_words) << 56);
93 SipRounds(m_mbuf, m_V, m_C);
96 SipRounds(0, m_V, m_D);
98 const uint64_t X = m_V[0] ^ m_V[1] ^ m_V[2] ^ m_V[3];
102 m_V[0] = m_K[0] ^ 0x736F6D6570736575;
103 m_V[1] = m_K[1] ^ 0x646F72616E646F6D;
104 m_V[2] = m_K[0] ^ 0x6C7967656E657261;
105 m_V[3] = m_K[1] ^ 0x7465646279746573;
115void SipHash::key_schedule(std::span<const uint8_t> key) {
124 m_V[0] = m_K[0] ^ 0x736F6D6570736575;
125 m_V[1] = m_K[1] ^ 0x646F72616E646F6D;
126 m_V[2] = m_K[0] ^ 0x6C7967656E657261;
127 m_V[3] = m_K[1] ^ 0x7465646279746573;
139 return fmt(
"SipHash({},{})", m_C, m_D);
143 return std::make_unique<SipHash>(m_C, m_D);
std::string name() const override
bool has_keying_material() const override
std::unique_ptr< MessageAuthenticationCode > new_object() const override
void assert_key_material_set() const
void zap(std::vector< T, Alloc > &vec)
std::string fmt(std::string_view format, const T &... args)
constexpr auto store_le(ParamTs &&... params)
BOTAN_FORCE_INLINE constexpr T rotl(T input)
constexpr auto load_le(ParamTs &&... params)
std::vector< T, secure_allocator< T > > secure_vector