Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

std::span for Botan::Cipher_Mode #3392

Merged
merged 4 commits into from
Mar 21, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 3 additions & 3 deletions src/lib/modes/aead/ccm/ccm.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,7 @@ void CCM_Mode::start_msg(const uint8_t nonce[], size_t nonce_len)
m_msg_buf.clear();
}

size_t CCM_Mode::process(uint8_t buf[], size_t sz)
size_t CCM_Mode::process_msg(uint8_t buf[], size_t sz)
{
BOTAN_STATE_CHECK(!m_nonce.empty());
m_msg_buf.insert(m_msg_buf.end(), buf, buf + sz);
Expand Down Expand Up @@ -174,7 +174,7 @@ secure_vector<uint8_t> CCM_Mode::format_c0()
return C;
}

void CCM_Encryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void CCM_Encryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
BOTAN_ARG_CHECK(buffer.size() >= offset, "Offset is out of range");

Expand Down Expand Up @@ -227,7 +227,7 @@ void CCM_Encryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
reset();
}

void CCM_Decryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void CCM_Decryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
BOTAN_ARG_CHECK(buffer.size() >= offset, "Offset is out of range");

Expand Down
13 changes: 7 additions & 6 deletions src/lib/modes/aead/ccm/ccm.h
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,6 @@ namespace Botan {
class CCM_Mode : public AEAD_Mode
{
public:
size_t process(uint8_t buf[], size_t sz) override final;

void set_associated_data(const uint8_t ad[], size_t ad_len) override final;

bool associated_data_requires_key() const override final { return false; }
Expand Down Expand Up @@ -67,6 +65,7 @@ class CCM_Mode : public AEAD_Mode
secure_vector<uint8_t> format_c0();
private:
void start_msg(const uint8_t nonce[], size_t nonce_len) override final;
size_t process_msg(uint8_t buf[], size_t sz) override final;

void key_schedule(const uint8_t key[], size_t length) override final;

Expand All @@ -93,12 +92,13 @@ class CCM_Encryption final : public CCM_Mode
CCM_Encryption(std::unique_ptr<BlockCipher> cipher, size_t tag_size = 16, size_t L = 3) :
CCM_Mode(std::move(cipher), tag_size, L) {}

void finish(secure_vector<uint8_t>& final_block, size_t offset = 0) override;

size_t output_length(size_t input_length) const override
{ return input_length + tag_size(); }

size_t minimum_final_size() const override { return 0; }

private:
void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
};

/**
Expand All @@ -117,15 +117,16 @@ class CCM_Decryption final : public CCM_Mode
CCM_Decryption(std::unique_ptr<BlockCipher> cipher, size_t tag_size = 16, size_t L = 3) :
CCM_Mode(std::move(cipher), tag_size, L) {}

void finish(secure_vector<uint8_t>& final_block, size_t offset = 0) override;

size_t output_length(size_t input_length) const override
{
BOTAN_ARG_CHECK(input_length >= tag_size(), "Sufficient input");
return input_length - tag_size();
}

size_t minimum_final_size() const override { return tag_size(); }

private:
void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
};

}
Expand Down
8 changes: 4 additions & 4 deletions src/lib/modes/aead/chacha20poly1305/chacha20poly1305.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -105,15 +105,15 @@ void ChaCha20Poly1305_Mode::start_msg(const uint8_t nonce[], size_t nonce_len)
}
}

size_t ChaCha20Poly1305_Encryption::process(uint8_t buf[], size_t sz)
size_t ChaCha20Poly1305_Encryption::process_msg(uint8_t buf[], size_t sz)
{
m_chacha->cipher1(buf, sz);
m_poly1305->update(buf, sz); // poly1305 of ciphertext
m_ctext_len += sz;
return sz;
}

void ChaCha20Poly1305_Encryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void ChaCha20Poly1305_Encryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
update(buffer, offset);
if(cfrg_version())
Expand All @@ -133,15 +133,15 @@ void ChaCha20Poly1305_Encryption::finish(secure_vector<uint8_t>& buffer, size_t
m_nonce_len = 0;
}

size_t ChaCha20Poly1305_Decryption::process(uint8_t buf[], size_t sz)
size_t ChaCha20Poly1305_Decryption::process_msg(uint8_t buf[], size_t sz)
{
m_poly1305->update(buf, sz); // poly1305 of ciphertext
m_chacha->cipher1(buf, sz);
m_ctext_len += sz;
return sz;
}

void ChaCha20Poly1305_Decryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void ChaCha20Poly1305_Decryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
BOTAN_ARG_CHECK(buffer.size() >= offset, "Offset is out of range");
const size_t sz = buffer.size() - offset;
Expand Down
12 changes: 6 additions & 6 deletions src/lib/modes/aead/chacha20poly1305/chacha20poly1305.h
Original file line number Diff line number Diff line change
Expand Up @@ -77,9 +77,9 @@ class ChaCha20Poly1305_Encryption final : public ChaCha20Poly1305_Mode

size_t minimum_final_size() const override { return 0; }

size_t process(uint8_t buf[], size_t size) override;

void finish(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
private:
size_t process_msg(uint8_t buf[], size_t size) override;
void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
};

/**
Expand All @@ -96,9 +96,9 @@ class ChaCha20Poly1305_Decryption final : public ChaCha20Poly1305_Mode

size_t minimum_final_size() const override { return tag_size(); }

size_t process(uint8_t buf[], size_t size) override;

void finish(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
private:
size_t process_msg(uint8_t buf[], size_t size) override;
void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
};

}
Expand Down
8 changes: 4 additions & 4 deletions src/lib/modes/aead/eax/eax.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -128,15 +128,15 @@ void EAX_Mode::start_msg(const uint8_t nonce[], size_t nonce_len)
m_cmac->update(2);
}

size_t EAX_Encryption::process(uint8_t buf[], size_t sz)
size_t EAX_Encryption::process_msg(uint8_t buf[], size_t sz)
{
BOTAN_STATE_CHECK(!m_nonce_mac.empty());
m_ctr->cipher(buf, buf, sz);
m_cmac->update(buf, sz);
return sz;
}

void EAX_Encryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void EAX_Encryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
BOTAN_STATE_CHECK(!m_nonce_mac.empty());
update(buffer, offset);
Expand All @@ -156,15 +156,15 @@ void EAX_Encryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
m_nonce_mac.clear();
}

size_t EAX_Decryption::process(uint8_t buf[], size_t sz)
size_t EAX_Decryption::process_msg(uint8_t buf[], size_t sz)
{
BOTAN_STATE_CHECK(!m_nonce_mac.empty());
m_cmac->update(buf, sz);
m_ctr->cipher(buf, buf, sz);
return sz;
}

void EAX_Decryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void EAX_Decryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
BOTAN_ARG_CHECK(buffer.size() >= offset, "Offset is out of range");
const size_t sz = buffer.size() - offset;
Expand Down
12 changes: 6 additions & 6 deletions src/lib/modes/aead/eax/eax.h
Original file line number Diff line number Diff line change
Expand Up @@ -85,9 +85,9 @@ class EAX_Encryption final : public EAX_Mode

size_t minimum_final_size() const override { return 0; }

size_t process(uint8_t buf[], size_t size) override;

void finish(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
private:
size_t process_msg(uint8_t buf[], size_t size) override;
void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
};

/**
Expand All @@ -111,9 +111,9 @@ class EAX_Decryption final : public EAX_Mode

size_t minimum_final_size() const override { return tag_size(); }

size_t process(uint8_t buf[], size_t size) override;

void finish(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
private:
size_t process_msg(uint8_t buf[], size_t size) override;
void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
};

}
Expand Down
8 changes: 4 additions & 4 deletions src/lib/modes/aead/gcm/gcm.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -128,15 +128,15 @@ void GCM_Mode::start_msg(const uint8_t nonce[], size_t nonce_len)
clear_mem(m_y0.data(), m_y0.size());
}

size_t GCM_Encryption::process(uint8_t buf[], size_t sz)
size_t GCM_Encryption::process_msg(uint8_t buf[], size_t sz)
{
BOTAN_ARG_CHECK(sz % update_granularity() == 0, "Invalid buffer size");
m_ctr->cipher(buf, buf, sz);
m_ghash->update(buf, sz);
return sz;
}

void GCM_Encryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void GCM_Encryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
BOTAN_ARG_CHECK(offset <= buffer.size(), "Invalid offset");
const size_t sz = buffer.size() - offset;
Expand All @@ -150,15 +150,15 @@ void GCM_Encryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
buffer += std::make_pair(mac, tag_size());
}

size_t GCM_Decryption::process(uint8_t buf[], size_t sz)
size_t GCM_Decryption::process_msg(uint8_t buf[], size_t sz)
{
BOTAN_ARG_CHECK(sz % update_granularity() == 0, "Invalid buffer size");
m_ghash->update(buf, sz);
m_ctr->cipher(buf, buf, sz);
return sz;
}

void GCM_Decryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void GCM_Decryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
BOTAN_ARG_CHECK(offset <= buffer.size(), "Invalid offset");
const size_t sz = buffer.size() - offset;
Expand Down
12 changes: 6 additions & 6 deletions src/lib/modes/aead/gcm/gcm.h
Original file line number Diff line number Diff line change
Expand Up @@ -83,9 +83,9 @@ class GCM_Encryption final : public GCM_Mode

size_t minimum_final_size() const override { return 0; }

size_t process(uint8_t buf[], size_t size) override;

void finish(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
private:
size_t process_msg(uint8_t buf[], size_t size) override;
void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
};

/**
Expand All @@ -109,9 +109,9 @@ class GCM_Decryption final : public GCM_Mode

size_t minimum_final_size() const override { return tag_size(); }

size_t process(uint8_t buf[], size_t size) override;

void finish(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
private:
size_t process_msg(uint8_t buf[], size_t size) override;
void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
};

}
Expand Down
8 changes: 4 additions & 4 deletions src/lib/modes/aead/ocb/ocb.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -375,14 +375,14 @@ void OCB_Encryption::encrypt(uint8_t buffer[], size_t blocks)
}
}

size_t OCB_Encryption::process(uint8_t buf[], size_t sz)
size_t OCB_Encryption::process_msg(uint8_t buf[], size_t sz)
{
BOTAN_ARG_CHECK(sz % update_granularity() == 0, "Invalid OCB input size");
encrypt(buf, sz / block_size());
return sz;
}

void OCB_Encryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void OCB_Encryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
assert_key_material_set();
BOTAN_STATE_CHECK(m_L->initialized());
Expand Down Expand Up @@ -466,14 +466,14 @@ void OCB_Decryption::decrypt(uint8_t buffer[], size_t blocks)
}
}

size_t OCB_Decryption::process(uint8_t buf[], size_t sz)
size_t OCB_Decryption::process_msg(uint8_t buf[], size_t sz)
{
BOTAN_ARG_CHECK(sz % update_granularity() == 0, "Invalid OCB input size");
decrypt(buf, sz / block_size());
return sz;
}

void OCB_Decryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void OCB_Decryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
assert_key_material_set();
BOTAN_STATE_CHECK(m_L->initialized());
Expand Down
10 changes: 4 additions & 6 deletions src/lib/modes/aead/ocb/ocb.h
Original file line number Diff line number Diff line change
Expand Up @@ -102,11 +102,10 @@ class BOTAN_TEST_API OCB_Encryption final : public OCB_Mode

size_t minimum_final_size() const override { return 0; }

size_t process(uint8_t buf[], size_t size) override;

void finish(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
private:
void encrypt(uint8_t input[], size_t blocks);
size_t process_msg(uint8_t buf[], size_t size) override;
void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
};

class BOTAN_TEST_API OCB_Decryption final : public OCB_Mode
Expand All @@ -127,11 +126,10 @@ class BOTAN_TEST_API OCB_Decryption final : public OCB_Mode

size_t minimum_final_size() const override { return tag_size(); }

size_t process(uint8_t buf[], size_t size) override;

void finish(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
private:
void decrypt(uint8_t input[], size_t blocks);
size_t process_msg(uint8_t buf[], size_t size) override;
void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
};

}
Expand Down
6 changes: 3 additions & 3 deletions src/lib/modes/aead/siv/siv.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,7 @@ void SIV_Mode::start_msg(const uint8_t nonce[], size_t nonce_len)
m_msg_buf.clear();
}

size_t SIV_Mode::process(uint8_t buf[], size_t sz)
size_t SIV_Mode::process_msg(uint8_t buf[], size_t sz)
{
// all output is saved for processing in finish
m_msg_buf.insert(m_msg_buf.end(), buf, buf + sz);
Expand Down Expand Up @@ -164,7 +164,7 @@ void SIV_Mode::set_ctr_iv(secure_vector<uint8_t> V)
ctr().set_iv(V.data(), V.size());
}

void SIV_Encryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void SIV_Encryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
BOTAN_ARG_CHECK(buffer.size() >= offset, "Offset is out of range");

Expand All @@ -182,7 +182,7 @@ void SIV_Encryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
}
}

void SIV_Decryption::finish(secure_vector<uint8_t>& buffer, size_t offset)
void SIV_Decryption::finish_msg(secure_vector<uint8_t>& buffer, size_t offset)
{
BOTAN_ARG_CHECK(buffer.size() >= offset, "Offset is out of range");

Expand Down
Loading