forked from eden-emu/eden
		
	
						commit
						c4d7092d4b
					
				
					 5 changed files with 35 additions and 35 deletions
				
			
		|  | @ -3,10 +3,22 @@ | ||||||
| // Refer to the license.txt file included.
 | // Refer to the license.txt file included.
 | ||||||
| 
 | 
 | ||||||
| #include <mbedtls/cipher.h> | #include <mbedtls/cipher.h> | ||||||
|  | #include "common/assert.h" | ||||||
|  | #include "common/logging/log.h" | ||||||
| #include "core/crypto/aes_util.h" | #include "core/crypto/aes_util.h" | ||||||
| #include "core/crypto/key_manager.h" | #include "core/crypto/key_manager.h" | ||||||
| 
 | 
 | ||||||
| namespace Core::Crypto { | namespace Core::Crypto { | ||||||
|  | namespace { | ||||||
|  | std::vector<u8> CalculateNintendoTweak(size_t sector_id) { | ||||||
|  |     std::vector<u8> out(0x10); | ||||||
|  |     for (size_t i = 0xF; i <= 0xF; --i) { | ||||||
|  |         out[i] = sector_id & 0xFF; | ||||||
|  |         sector_id >>= 8; | ||||||
|  |     } | ||||||
|  |     return out; | ||||||
|  | } | ||||||
|  | } // Anonymous namespace
 | ||||||
| 
 | 
 | ||||||
| static_assert(static_cast<size_t>(Mode::CTR) == static_cast<size_t>(MBEDTLS_CIPHER_AES_128_CTR), | static_assert(static_cast<size_t>(Mode::CTR) == static_cast<size_t>(MBEDTLS_CIPHER_AES_128_CTR), | ||||||
|               "CTR has incorrect value."); |               "CTR has incorrect value."); | ||||||
|  | @ -56,27 +68,28 @@ void AESCipher<Key, KeySize>::SetIV(std::vector<u8> iv) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| template <typename Key, size_t KeySize> | template <typename Key, size_t KeySize> | ||||||
| void AESCipher<Key, KeySize>::Transcode(const u8* src, size_t size, u8* dest, Op op) { | void AESCipher<Key, KeySize>::Transcode(const u8* src, size_t size, u8* dest, Op op) const { | ||||||
|     size_t written = 0; |     auto* const context = op == Op::Encrypt ? &ctx->encryption_context : &ctx->decryption_context; | ||||||
| 
 |  | ||||||
|     const auto context = op == Op::Encrypt ? &ctx->encryption_context : &ctx->decryption_context; |  | ||||||
| 
 | 
 | ||||||
|     mbedtls_cipher_reset(context); |     mbedtls_cipher_reset(context); | ||||||
| 
 | 
 | ||||||
|  |     size_t written = 0; | ||||||
|     if (mbedtls_cipher_get_cipher_mode(context) == MBEDTLS_MODE_XTS) { |     if (mbedtls_cipher_get_cipher_mode(context) == MBEDTLS_MODE_XTS) { | ||||||
|         mbedtls_cipher_update(context, src, size, dest, &written); |         mbedtls_cipher_update(context, src, size, dest, &written); | ||||||
|         if (written != size) |         if (written != size) { | ||||||
|             LOG_WARNING(Crypto, "Not all data was decrypted requested={:016X}, actual={:016X}.", |             LOG_WARNING(Crypto, "Not all data was decrypted requested={:016X}, actual={:016X}.", | ||||||
|                         size, written); |                         size, written); | ||||||
|  |         } | ||||||
|     } else { |     } else { | ||||||
|         const auto block_size = mbedtls_cipher_get_block_size(context); |         const auto block_size = mbedtls_cipher_get_block_size(context); | ||||||
| 
 | 
 | ||||||
|         for (size_t offset = 0; offset < size; offset += block_size) { |         for (size_t offset = 0; offset < size; offset += block_size) { | ||||||
|             auto length = std::min<size_t>(block_size, size - offset); |             auto length = std::min<size_t>(block_size, size - offset); | ||||||
|             mbedtls_cipher_update(context, src + offset, length, dest + offset, &written); |             mbedtls_cipher_update(context, src + offset, length, dest + offset, &written); | ||||||
|             if (written != length) |             if (written != length) { | ||||||
|                 LOG_WARNING(Crypto, "Not all data was decrypted requested={:016X}, actual={:016X}.", |                 LOG_WARNING(Crypto, "Not all data was decrypted requested={:016X}, actual={:016X}.", | ||||||
|                             length, written); |                             length, written); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -97,16 +110,6 @@ void AESCipher<Key, KeySize>::XTSTranscode(const u8* src, size_t size, u8* dest, | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| template <typename Key, size_t KeySize> |  | ||||||
| std::vector<u8> AESCipher<Key, KeySize>::CalculateNintendoTweak(size_t sector_id) { |  | ||||||
|     std::vector<u8> out(0x10); |  | ||||||
|     for (size_t i = 0xF; i <= 0xF; --i) { |  | ||||||
|         out[i] = sector_id & 0xFF; |  | ||||||
|         sector_id >>= 8; |  | ||||||
|     } |  | ||||||
|     return out; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| template class AESCipher<Key128>; | template class AESCipher<Key128>; | ||||||
| template class AESCipher<Key256>; | template class AESCipher<Key256>; | ||||||
| } // namespace Core::Crypto
 | } // namespace Core::Crypto
 | ||||||
|  | @ -7,7 +7,7 @@ | ||||||
| #include <memory> | #include <memory> | ||||||
| #include <type_traits> | #include <type_traits> | ||||||
| #include <vector> | #include <vector> | ||||||
| #include "common/assert.h" | #include "common/common_types.h" | ||||||
| #include "core/file_sys/vfs.h" | #include "core/file_sys/vfs.h" | ||||||
| 
 | 
 | ||||||
| namespace Core::Crypto { | namespace Core::Crypto { | ||||||
|  | @ -38,15 +38,19 @@ public: | ||||||
|     void SetIV(std::vector<u8> iv); |     void SetIV(std::vector<u8> iv); | ||||||
| 
 | 
 | ||||||
|     template <typename Source, typename Dest> |     template <typename Source, typename Dest> | ||||||
|     void Transcode(const Source* src, size_t size, Dest* dest, Op op) { |     void Transcode(const Source* src, size_t size, Dest* dest, Op op) const { | ||||||
|  |         static_assert(std::is_trivially_copyable_v<Source> && std::is_trivially_copyable_v<Dest>, | ||||||
|  |                       "Transcode source and destination types must be trivially copyable."); | ||||||
|         Transcode(reinterpret_cast<const u8*>(src), size, reinterpret_cast<u8*>(dest), op); |         Transcode(reinterpret_cast<const u8*>(src), size, reinterpret_cast<u8*>(dest), op); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Transcode(const u8* src, size_t size, u8* dest, Op op); |     void Transcode(const u8* src, size_t size, u8* dest, Op op) const; | ||||||
| 
 | 
 | ||||||
|     template <typename Source, typename Dest> |     template <typename Source, typename Dest> | ||||||
|     void XTSTranscode(const Source* src, size_t size, Dest* dest, size_t sector_id, |     void XTSTranscode(const Source* src, size_t size, Dest* dest, size_t sector_id, | ||||||
|                       size_t sector_size, Op op) { |                       size_t sector_size, Op op) { | ||||||
|  |         static_assert(std::is_trivially_copyable_v<Source> && std::is_trivially_copyable_v<Dest>, | ||||||
|  |                       "XTSTranscode source and destination types must be trivially copyable."); | ||||||
|         XTSTranscode(reinterpret_cast<const u8*>(src), size, reinterpret_cast<u8*>(dest), sector_id, |         XTSTranscode(reinterpret_cast<const u8*>(src), size, reinterpret_cast<u8*>(dest), sector_id, | ||||||
|                      sector_size, op); |                      sector_size, op); | ||||||
|     } |     } | ||||||
|  | @ -56,7 +60,5 @@ public: | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     std::unique_ptr<CipherContext> ctx; |     std::unique_ptr<CipherContext> ctx; | ||||||
| 
 |  | ||||||
|     static std::vector<u8> CalculateNintendoTweak(size_t sector_id); |  | ||||||
| }; | }; | ||||||
| } // namespace Core::Crypto
 | } // namespace Core::Crypto
 | ||||||
|  |  | ||||||
|  | @ -4,6 +4,7 @@ | ||||||
| 
 | 
 | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
|  | #include "common/common_types.h" | ||||||
| #include "core/file_sys/vfs.h" | #include "core/file_sys/vfs.h" | ||||||
| 
 | 
 | ||||||
| namespace Core::Crypto { | namespace Core::Crypto { | ||||||
|  |  | ||||||
|  | @ -2,19 +2,16 @@ | ||||||
| // Licensed under GPLv2 or any later version
 | // Licensed under GPLv2 or any later version
 | ||||||
| // Refer to the license.txt file included.
 | // Refer to the license.txt file included.
 | ||||||
| 
 | 
 | ||||||
|  | #include <algorithm> | ||||||
| #include <array> | #include <array> | ||||||
| #include <fstream> | #include <fstream> | ||||||
| #include <locale> | #include <locale> | ||||||
| #include <sstream> | #include <sstream> | ||||||
| #include <string_view> | #include <string_view> | ||||||
| #include <mbedtls/sha256.h> |  | ||||||
| #include "common/assert.h" |  | ||||||
| #include "common/common_paths.h" | #include "common/common_paths.h" | ||||||
| #include "common/file_util.h" | #include "common/file_util.h" | ||||||
| #include "common/logging/log.h" |  | ||||||
| #include "core/crypto/key_manager.h" | #include "core/crypto/key_manager.h" | ||||||
| #include "core/settings.h" | #include "core/settings.h" | ||||||
| #include "key_manager.h" |  | ||||||
| 
 | 
 | ||||||
| namespace Core::Crypto { | namespace Core::Crypto { | ||||||
| 
 | 
 | ||||||
|  | @ -66,8 +63,7 @@ KeyManager::KeyManager() { | ||||||
|     AttemptLoadKeyFile(yuzu_keys_dir, hactool_keys_dir, "title.keys", true); |     AttemptLoadKeyFile(yuzu_keys_dir, hactool_keys_dir, "title.keys", true); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void KeyManager::LoadFromFile(std::string_view filename_, bool is_title_keys) { | void KeyManager::LoadFromFile(const std::string& filename, bool is_title_keys) { | ||||||
|     const auto filename = std::string(filename_); |  | ||||||
|     std::ifstream file(filename); |     std::ifstream file(filename); | ||||||
|     if (!file.is_open()) |     if (!file.is_open()) | ||||||
|         return; |         return; | ||||||
|  | @ -107,11 +103,8 @@ void KeyManager::LoadFromFile(std::string_view filename_, bool is_title_keys) { | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void KeyManager::AttemptLoadKeyFile(std::string_view dir1_, std::string_view dir2_, | void KeyManager::AttemptLoadKeyFile(const std::string& dir1, const std::string& dir2, | ||||||
|                                     std::string_view filename_, bool title) { |                                     const std::string& filename, bool title) { | ||||||
|     const std::string dir1(dir1_); |  | ||||||
|     const std::string dir2(dir2_); |  | ||||||
|     const std::string filename(filename_); |  | ||||||
|     if (FileUtil::Exists(dir1 + DIR_SEP + filename)) |     if (FileUtil::Exists(dir1 + DIR_SEP + filename)) | ||||||
|         LoadFromFile(dir1 + DIR_SEP + filename, title); |         LoadFromFile(dir1 + DIR_SEP + filename, title); | ||||||
|     else if (FileUtil::Exists(dir2 + DIR_SEP + filename)) |     else if (FileUtil::Exists(dir2 + DIR_SEP + filename)) | ||||||
|  |  | ||||||
|  | @ -5,6 +5,7 @@ | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #include <array> | #include <array> | ||||||
|  | #include <string> | ||||||
| #include <type_traits> | #include <type_traits> | ||||||
| #include <unordered_map> | #include <unordered_map> | ||||||
| #include <vector> | #include <vector> | ||||||
|  | @ -109,9 +110,9 @@ private: | ||||||
|     std::unordered_map<KeyIndex<S256KeyType>, Key256> s256_keys; |     std::unordered_map<KeyIndex<S256KeyType>, Key256> s256_keys; | ||||||
| 
 | 
 | ||||||
|     bool dev_mode; |     bool dev_mode; | ||||||
|     void LoadFromFile(std::string_view filename, bool is_title_keys); |     void LoadFromFile(const std::string& filename, bool is_title_keys); | ||||||
|     void AttemptLoadKeyFile(std::string_view dir1, std::string_view dir2, std::string_view filename, |     void AttemptLoadKeyFile(const std::string& dir1, const std::string& dir2, | ||||||
|                             bool title); |                             const std::string& filename, bool title); | ||||||
| 
 | 
 | ||||||
|     static const std::unordered_map<std::string, KeyIndex<S128KeyType>> s128_file_id; |     static const std::unordered_map<std::string, KeyIndex<S128KeyType>> s128_file_id; | ||||||
|     static const std::unordered_map<std::string, KeyIndex<S256KeyType>> s256_file_id; |     static const std::unordered_map<std::string, KeyIndex<S256KeyType>> s256_file_id; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei