Browse Source
Merge pull request #6231 from lioncash/aes
aes_util: Make use of std::span
pull/15/merge
bunnei
5 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with
5 additions and
9 deletions
-
src/core/crypto/aes_util.cpp
-
src/core/crypto/aes_util.h
|
|
|
@ -119,9 +119,9 @@ void AESCipher<Key, KeySize>::XTSTranscode(const u8* src, std::size_t size, u8* |
|
|
|
} |
|
|
|
|
|
|
|
template <typename Key, std::size_t KeySize> |
|
|
|
void AESCipher<Key, KeySize>::SetIVImpl(const u8* data, std::size_t size) { |
|
|
|
ASSERT_MSG((mbedtls_cipher_set_iv(&ctx->encryption_context, data, size) || |
|
|
|
mbedtls_cipher_set_iv(&ctx->decryption_context, data, size)) == 0, |
|
|
|
void AESCipher<Key, KeySize>::SetIV(std::span<const u8> data) { |
|
|
|
ASSERT_MSG((mbedtls_cipher_set_iv(&ctx->encryption_context, data.data(), data.size()) || |
|
|
|
mbedtls_cipher_set_iv(&ctx->decryption_context, data.data(), data.size())) == 0, |
|
|
|
"Failed to set IV on mbedtls ciphers."); |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@ -5,6 +5,7 @@ |
|
|
|
#pragma once |
|
|
|
|
|
|
|
#include <memory> |
|
|
|
#include <span> |
|
|
|
#include <type_traits> |
|
|
|
#include "common/common_types.h" |
|
|
|
#include "core/file_sys/vfs.h" |
|
|
|
@ -33,10 +34,7 @@ public: |
|
|
|
AESCipher(Key key, Mode mode); |
|
|
|
~AESCipher(); |
|
|
|
|
|
|
|
template <typename ContiguousContainer> |
|
|
|
void SetIV(const ContiguousContainer& container) { |
|
|
|
SetIVImpl(std::data(container), std::size(container)); |
|
|
|
} |
|
|
|
void SetIV(std::span<const u8> data); |
|
|
|
|
|
|
|
template <typename Source, typename Dest> |
|
|
|
void Transcode(const Source* src, std::size_t size, Dest* dest, Op op) const { |
|
|
|
@ -60,8 +58,6 @@ public: |
|
|
|
std::size_t sector_size, Op op); |
|
|
|
|
|
|
|
private: |
|
|
|
void SetIVImpl(const u8* data, std::size_t size); |
|
|
|
|
|
|
|
std::unique_ptr<CipherContext> ctx; |
|
|
|
}; |
|
|
|
} // namespace Core::Crypto |