summaryrefslogtreecommitdiff
path: root/src/core/crypto (follow)
Commit message (Collapse)AuthorAgeFilesLines
* vfs: Move vfs files to their own directoryGravatar FearlessTobi2024-01-254-6/+6
|
* key_manager: Remove uncaught usage of stoulGravatar lat9nq2023-09-131-4/+4
|
* core: Add support for loading NSPs with personalized tickets. (#10048)Gravatar Steveice102023-09-052-106/+179
| | | | Co-authored-by: Morph <39850852+Morph1984@users.noreply.github.com>
* android: frontend: Integrate key installation for SAF.Gravatar bunnei2023-06-032-2/+2
|
* core: crypto: key_manager: Add methods to reload & validate keys.Gravatar bunnei2023-06-032-0/+11
|
* general: fix spelling mistakesGravatar Liam2023-03-123-3/+3
|
* crypto: use user-provided keys whenever possibleGravatar Valeri2022-11-271-4/+4
| | | Solves an issue where autogenerated title keys would take precedence over those provided by user.
* common: Change semantics of UNREACHABLE to unconditionally crashGravatar Liam2022-06-131-2/+0
|
* general: Convert source file copyright comments over to SPDXGravatar Morph2022-04-2314-42/+28
| | | | | This formats all copyright comments according to SPDX formatting guidelines. Additionally, this resolves the remaining GPLv2 only licensed files by relicensing them to GPLv2.0-or-later.
* core: Fix transitive include build errorsGravatar ameerj2021-11-031-0/+1
|
* core: Remove unused includesGravatar ameerj2021-11-035-8/+0
|
* General: Resolve fmt specifiers to adhere to 8.0.0 API where applicableGravatar Lioncash2021-06-231-1/+1
| | | | Also removes some deprecated API usages.
* common: fs: Rework the Common Filesystem interface to make use of ↵Gravatar Morph2021-05-252-66/+79
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | std::filesystem (#6270) * common: fs: fs_types: Create filesystem types Contains various filesystem types used by the Common::FS library * common: fs: fs_util: Add std::string to std::u8string conversion utility * common: fs: path_util: Add utlity functions for paths Contains various utility functions for getting or manipulating filesystem paths used by the Common::FS library * common: fs: file: Rewrite the IOFile implementation * common: fs: Reimplement Common::FS library using std::filesystem * common: fs: fs_paths: Add fs_paths to replace common_paths * common: fs: path_util: Add the rest of the path functions * common: Remove the previous Common::FS implementation * general: Remove unused fs includes * string_util: Remove unused function and include * nvidia_flags: Migrate to the new Common::FS library * settings: Migrate to the new Common::FS library * logging: backend: Migrate to the new Common::FS library * core: Migrate to the new Common::FS library * perf_stats: Migrate to the new Common::FS library * reporter: Migrate to the new Common::FS library * telemetry_session: Migrate to the new Common::FS library * key_manager: Migrate to the new Common::FS library * bis_factory: Migrate to the new Common::FS library * registered_cache: Migrate to the new Common::FS library * xts_archive: Migrate to the new Common::FS library * service: acc: Migrate to the new Common::FS library * applets/profile: Migrate to the new Common::FS library * applets/web: Migrate to the new Common::FS library * service: filesystem: Migrate to the new Common::FS library * loader: Migrate to the new Common::FS library * gl_shader_disk_cache: Migrate to the new Common::FS library * nsight_aftermath_tracker: Migrate to the new Common::FS library * vulkan_library: Migrate to the new Common::FS library * configure_debug: Migrate to the new Common::FS library * game_list_worker: Migrate to the new Common::FS library * config: Migrate to the new Common::FS library * configure_filesystem: Migrate to the new Common::FS library * configure_per_game_addons: Migrate to the new Common::FS library * configure_profile_manager: Migrate to the new Common::FS library * configure_ui: Migrate to the new Common::FS library * input_profiles: Migrate to the new Common::FS library * yuzu_cmd: config: Migrate to the new Common::FS library * yuzu_cmd: Migrate to the new Common::FS library * vfs_real: Migrate to the new Common::FS library * vfs: Migrate to the new Common::FS library * vfs_libzip: Migrate to the new Common::FS library * service: bcat: Migrate to the new Common::FS library * yuzu: main: Migrate to the new Common::FS library * vfs_real: Delete the contents of an existing file in CreateFile Current usages of CreateFile expect to delete the contents of an existing file, retain this behavior for now. * input_profiles: Don't iterate the input profile dir if it does not exist Silences an error produced in the log if the directory does not exist. * game_list_worker: Skip parsing file if the returned VfsFile is nullptr Prevents crashes in GetLoader when the virtual file is nullptr * common: fs: Validate paths for path length * service: filesystem: Open the mod load directory as read only
* core: Make variable shadowing a compile-time errorGravatar Lioncash2021-05-163-4/+4
| | | | | | Now that we have most of core free of shadowing, we can enable the warning as an error to catch anything that may be remaining and also eliminate this class of logic bug entirely.
* aes_util: Make use of std::spanGravatar Lioncash2021-04-232-9/+5
| | | | | Allows us to simplify the interface quite a bit as it will handle contiguous sequences for us.
* common: Move settings to common from core.Gravatar bunnei2021-04-141-1/+1
| | | | - Removes a dependency on core and input_common from common.
* aes_util: Remove malformed mbedtls_cipher_finish function callGravatar Morph2021-03-051-2/+0
|
* key_manager: Create the keys directory if it does not existGravatar Morph2021-02-041-0/+5
|
* core: Silence warnings when compiling without assertsGravatar ReinUsesLisp2021-01-051-6/+5
|
* Revert "core: Fix clang build"Gravatar bunnei2020-10-202-6/+3
|
* core: Fix clang buildGravatar Lioncash2020-10-172-3/+6
| | | | | | | Recent changes to the build system that made more warnings be flagged as errors caused building via clang to break. Fixes #4795
* core/CMakeLists: Make some warnings errorsGravatar Lioncash2020-10-131-1/+1
| | | | | | | | | Makes our error coverage a little more consistent across the board by applying it to Linux side of things as well. This also makes it more consistent with the warning settings in other libraries in the project. This also updates httplib to 0.7.9, as there are several warning cleanups made that allow us to enable several warnings as errors.
* crypto/key_manager: Remove dependency on the global system accessorGravatar Lioncash2020-09-142-5/+8
| | | | | We can supply the content provider as an argument instead of hardcoding a global accessor in the implementation.
* Merge pull request #4564 from lioncash/file-includeGravatar bunnei2020-09-021-0/+1
|\ | | | | file_sys: Replace inclusions with forward declarations where applicable
| * file_sys: Replace inclusions with forward declarations where applicableGravatar Lioncash2020-08-231-0/+1
| | | | | | | | Same behavior, minus unnecessary inclusions where not necessary.
* | key_manager: Make data arrays constexprGravatar Lioncash2020-08-222-75/+82
|/ | | | | We can convert these maps into constexpr arrays to eliminate some runtime static constructors.
* Merge pull request #4535 from lioncash/fileutilGravatar bunnei2020-08-172-112/+178
|\ | | | | common/fileutil: Convert namespace to Common::FS
| * common/fileutil: Convert namespace to Common::FSGravatar Lioncash2020-08-162-112/+178
| | | | | | | | | | | | | | | | | | | | | | | | Migrates a remaining common file over to the Common namespace, making it consistent with the rest of common files. This also allows for high-traffic FS related code to alias the filesystem function namespace as namespace FS = Common::FS; for more concise typing.
* | Merge pull request #4494 from lioncash/transcodeGravatar bunnei2020-08-172-3/+3
|\ \ | |/ |/| aes_util: Make use of non-template variant of Transcode
| * partition_data_manager: Eliminate magic valueGravatar Lioncash2020-08-061-2/+2
| | | | | | | | | | We can use sizeof to make it obvious at the call site where the value is coming from.
| * aes_util: Make use of non-template variant of TranscodeGravatar Lioncash2020-08-061-1/+1
| | | | | | | | Same behavior, less template instantiations.
* | Merge pull request #4483 from lioncash/constexpr-hexGravatar bunnei2020-08-062-98/+118
|\ \ | |/ |/| partition_data_manager: Make data arrays constexpr
| * partition_data_manager: Update master key hashesGravatar Lioncash2020-08-061-5/+5
| | | | | | | | Fills in some hashes that were previously unhandled.
| * partition_data_manager: Make data arrays constexprGravatar Lioncash2020-08-062-98/+118
| | | | | | | | | | | | | | | | | | | | | | | | | | Previously the constructor for all of these would run at program startup, consuming time before the application can enter main(). This is also particularly dangerous, given the logging system wouldn't have been initialized properly yet, yet the program would use the logs to signify an error. To rectify this, we can replace the literals with constexpr functions that perform the conversion at compile-time, completely eliminating the runtime cost of initializing these arrays.
* | aes_util: Allow SetIV to be non-allocatingGravatar Lioncash2020-08-035-23/+30
|/ | | | | | In a few places, the data to be set as the IV is already within an array. We shouldn't require this data to be heap-allocated if it doesn't need to be. This allows certain callers to reduce heap churn.
* KeyManager: Prevent writing of invalid keysGravatar Morph2020-07-101-4/+8
| | | | If the keys are zero, don't write them to the autogenerated file.
* key_manager: Correct casing of instance()Gravatar Lioncash2020-07-011-1/+1
| | | | Our codebase uppercases member function names.
* key_manager: Delete move operationsGravatar Lioncash2020-07-011-0/+3
| | | | Prevents the singleton from being moved from.
* key_manager: Make use of canonical deleted operator=Gravatar Lioncash2020-07-011-2/+2
| | | | | | | operator= typically returns a reference, it's not void. While we're at it, we can correct the parameter formatting to adhere to the codebase.
* crypto: Make KeyManager a singleton classGravatar FearlessTobi2020-05-201-1/+9
| | | | | | Previously, we were reading the keys everytime a KeyManager object was created, causing yuzu to reread the keys file multiple hundreds of times when loading the game list. With this change, it is only loaded once. On my system, this decreased game list loading times by a factor of 20.
* Merge pull request #3697 from lioncash/declarationsGravatar bunnei2020-04-231-4/+3
|\ | | | | CMakeLists: Enable -Wmissing-declarations on Linux builds
| * General: Resolve warnings related to missing declarationsGravatar Lioncash2020-04-161-4/+3
| |
* | key_manager: Resolve missing field initializer warningGravatar Lioncash2020-04-161-1/+2
|/
* Merge pull request #3091 from lioncash/core-conversionGravatar bunnei2019-11-152-11/+12
|\ | | | | core: Make most implicit type conversion warnings errors on MSVC
| * externals: Update httplibGravatar Lioncash2019-11-121-1/+1
| | | | | | | | | | | | | | Since the introduction of this library, numerous improvements have been made. Notably, many of the warnings we would get by simply including the library header have now been fixed. This makes it much easier to make conversion warning an error.
| * crypto: Resolve sign-conversion warningsGravatar Lioncash2019-11-122-11/+12
| |
* | Merge pull request #3093 from lioncash/mbedtlsGravatar bunnei2019-11-142-3/+3
|\ \ | | | | | | core: Migrate off deprecated mbedtls functions
| * | core: Migrate off deprecated mbedtls functionsGravatar Lioncash2019-11-122-3/+3
| |/ | | | | | | | | These functions are marked for deprecation and it's recommended that the *_ret variants be used instead.
* / key_manager: Make use of IOFile in WriteKeyToFile()Gravatar Lioncash2019-11-121-11/+15
|/ | | | | | | | | This properly handles unicode-based paths on Windows, while opening a raw stream doesn't out-of-the-box. Prevents file creation from potentially failing on Windows PCs that make use of unicode characters in their save paths (e.g. writing to a user's AppData folder, where the user has a name with non-ASCII characters).
* [crypto] Use IsAllZeroArray helper functionGravatar vperus2019-10-021-1/+1
|