summaryrefslogtreecommitdiff
path: root/src/core/crypto
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/crypto')
-rw-r--r--src/core/crypto/aes_util.cpp14
-rw-r--r--src/core/crypto/ctr_encryption_layer.cpp2
2 files changed, 15 insertions, 1 deletions
diff --git a/src/core/crypto/aes_util.cpp b/src/core/crypto/aes_util.cpp
index 72e4bed67..89ade5000 100644
--- a/src/core/crypto/aes_util.cpp
+++ b/src/core/crypto/aes_util.cpp
@@ -82,11 +82,25 @@ void AESCipher<Key, KeySize>::Transcode(const u8* src, size_t size, u8* dest, Op
82 } 82 }
83 } else { 83 } else {
84 const auto block_size = mbedtls_cipher_get_block_size(context); 84 const auto block_size = mbedtls_cipher_get_block_size(context);
85 if (size < block_size) {
86 std::vector<u8> block(block_size);
87 std::memcpy(block.data(), src, size);
88 Transcode(block.data(), block.size(), block.data(), op);
89 std::memcpy(dest, block.data(), size);
90 return;
91 }
85 92
86 for (size_t offset = 0; offset < size; offset += block_size) { 93 for (size_t offset = 0; offset < size; offset += block_size) {
87 auto length = std::min<size_t>(block_size, size - offset); 94 auto length = std::min<size_t>(block_size, size - offset);
88 mbedtls_cipher_update(context, src + offset, length, dest + offset, &written); 95 mbedtls_cipher_update(context, src + offset, length, dest + offset, &written);
89 if (written != length) { 96 if (written != length) {
97 if (length < block_size) {
98 std::vector<u8> block(block_size);
99 std::memcpy(block.data(), src + offset, length);
100 Transcode(block.data(), block.size(), block.data(), op);
101 std::memcpy(dest + offset, block.data(), length);
102 return;
103 }
90 LOG_WARNING(Crypto, "Not all data was decrypted requested={:016X}, actual={:016X}.", 104 LOG_WARNING(Crypto, "Not all data was decrypted requested={:016X}, actual={:016X}.",
91 length, written); 105 length, written);
92 } 106 }
diff --git a/src/core/crypto/ctr_encryption_layer.cpp b/src/core/crypto/ctr_encryption_layer.cpp
index 3ea60dbd0..296fad419 100644
--- a/src/core/crypto/ctr_encryption_layer.cpp
+++ b/src/core/crypto/ctr_encryption_layer.cpp
@@ -21,7 +21,7 @@ size_t CTREncryptionLayer::Read(u8* data, size_t length, size_t offset) const {
21 UpdateIV(base_offset + offset); 21 UpdateIV(base_offset + offset);
22 std::vector<u8> raw = base->ReadBytes(length, offset); 22 std::vector<u8> raw = base->ReadBytes(length, offset);
23 cipher.Transcode(raw.data(), raw.size(), data, Op::Decrypt); 23 cipher.Transcode(raw.data(), raw.size(), data, Op::Decrypt);
24 return raw.size(); 24 return length;
25 } 25 }
26 26
27 // offset does not fall on block boundary (0x10) 27 // offset does not fall on block boundary (0x10)