Commit message (Collapse) | Author | Files | Lines | ||
---|---|---|---|---|---|
2021-07-08 | qt/main: Make title string more i18n-friendly | Lioncash | 1 | -2/+4 | |
Currently, whether or not the title is 32-bit or 64-bit was being appended as a suffix to the title, which is fine for left-to-right languages, but may not always fly so smoothly with some right-to-left languages. We also weren't marking that portion of the string as translatable, which prevents translators from translating part of the title string. | |||||
2021-07-08 | general: Code formatting improvements | lat9nq | 4 | -22/+25 | |
Slight improvements to readability. Dropped suggestions for string_view (settings.h:101), pass by value (settings.h:82), reverting double to a float (config.cpp:316), and other smaller ones, some out of scope. Addresses review feedback. Co-authored-by: Ameer J <52414509+ameerj@users.noreply.github.com> | |||||
2021-07-08 | Out of bound blit (#6531) | Feng Chen | 2 | -58/+35 | |
* Fix out of bound blit error * Fix code read * Fix ci error Co-authored-by: Feng Chen <chen.feng@gloritysolutions.com> | |||||
2021-07-08 | audio_core: Preserve front channel volume after 6 to 2 downmix | Kelebek1 | 5 | -75/+81 | |
Many games report 6 channel output while only providing data for 2. We only output 2-channel audio regardless, and in the downmixing, front left/right only provide 36% of their volume. This is done assuming all of the other channels also contain valid data, but in many games they don't. This PR alters the downmixing to preserve front left/right, so volume is not lost. This improves volume in Link's Awakening, New Super Mario Bros U, Disgaea 6, Super Kirby Clash. | |||||
2021-07-07 | util_shaders: Fix BindImageTexture | lat9nq | 1 | -2/+2 | |
According to https://gitlab.freedesktop.org/mesa/mesa/-/issues/3820#note_753371 we need to set these to true for use with 3D textures. Fixes BOTW teleporting on RadeonSI and iris. | |||||
2021-07-06 | Report 2 channels active. Fixes Tales of Vesperia's mono channel audio. | Kelebek1 | 1 | -1/+1 | |
2021-07-06 | Support more PCM formats. Fixes Ys IX audio. | Kelebek1 | 2 | -18/+51 | |
2021-07-06 | CMakeLists: Treat -Wsign-compare as an error on GCC/Clang | Morph | 4 | -8/+1 | |
Treats (un)signed comparison mismatches as errors to be consistent with MSVC | |||||
2021-07-06 | common: logging: backend: Close the file after exceeding the write limit | Morph | 1 | -8/+11 | |
There's no point in keeping the file open after the write limit is exceeded. This allows the file to be committed to the disk shortly after it is closed and avoids redundantly checking whether or not the write limit is exceeded. | |||||
2021-07-06 | common: fs: file: Revert Flush to its previous behavior and add Commit | Morph | 2 | -3/+34 | |
It became apparent that logging can continuously spam errors that trigger file flushing. Since committing the files to disk is an expensive operation, this causes unnecessarily high disk usage. As such, we will revert Flush() to the previous behavior and add a Commit() member function in the event that this behavior is needed. | |||||
2021-07-06 | common: fs: file: Flush the file in GetSize | Morph | 1 | -0/+3 | |
This ensures that GetSize always retrieves the correct file size after a write operation. | |||||
2021-07-05 | input_common: Add missing modifier callback to analog from button | german77 | 1 | -0/+1 | |
2021-07-05 | profiler: Fix deprecated functions | german77 | 1 | -4/+5 | |
2021-07-04 | Texture Cache: Fix collision with multiple overlaps of the same sparse texture. | Fernando Sahmkow | 1 | -1/+6 | |
2021-07-04 | Texture Cache: Fix GCC & Clang. | Fernando Sahmkow | 2 | -11/+11 | |
2021-07-04 | Texture Cache: Address feedback. | Fernando Sahmkow | 5 | -18/+37 | |
2021-07-04 | Texture Cache: Improve accuracy of sparse texture detection. | Fernando Sahmkow | 6 | -131/+342 | |
2021-07-04 | Texture Cache: Initial Implementation of Sparse Textures. | Fernando Sahmkow | 12 | -23/+310 | |
2021-07-04 | service: mii: Retrieve the correct default miis. | Morph | 1 | -2/+3 | |
We were including the first 2 default miis which are not meant to be shown in games. With this change, we properly retrieve the 6 default miis shown in games, with 3 of each gender. | |||||
2021-07-03 | TextureCacheOGL: Implement Image Copies for 1D and 1D Array. | Fernando Sahmkow | 1 | -0/+26 | |
2021-07-03 | TextureCache: Fix 1D to 2D overlapps. | Fernando Sahmkow | 1 | -3/+0 | |
2021-07-03 | CMakeLists: Enforce C4189 | Morph | 1 | -0/+1 | |
This supplements C4101 by detecting initialized but unreferenced local variables | |||||
2021-07-02 | config: Read UISettings as basic settings | lat9nq | 1 | -30/+19 | |
I must have been asleep or something. These need to be read with the new ReadBasicSetting function. | |||||
2021-07-01 | settings: Set resolution_factor default to 1 | lat9nq | 1 | -1/+1 | |
Fixes Disgaea 6 Demo issues. | |||||
2021-07-01 | Slightly refactor NVDEC and codecs for readability and safety | Kelebek1 | 10 | -356/+522 | |
2021-07-01 | Fix XC2/VOEZ crashing, add audio looping and a few misc fixes | Kelebek1 | 7 | -132/+188 | |
2021-07-01 | yuzu_cmd: config: Pass a reference in | lat9nq | 2 | -5/+11 | |
Also adds documentation for the ReadSetting function. Address review comments. Co-authored-by: Mai M. <mathew1800@gmail.com> | |||||
2021-06-29 | core, input_common: Miscellaneous fixes | lat9nq | 3 | -5/+8 | |
bcat: Fix settings access telemetry_session: Fix settings accesses So this is what I get for testing with the web service disabled. touch_from_button: Fix settings access for clang | |||||
2021-06-29 | yuzu qt: Make most UISettings a BasicSetting | lat9nq | 12 | -91/+107 | |
For simple primitive settings, moves their defaults and labels to definition time. Also fixes typo and clang-format yuzu qt: config: Fix rng_seed | |||||
2021-06-28 | general: Make most settings a BasicSetting | lat9nq | 32 | -660/+807 | |
Creates a new BasicSettings class in common/settings, and forces setting a default and label for each setting that uses it in common/settings. Moves defaults and labels from both frontends into common settings. Creates a helper function in each frontend to facillitate reading the settings now with the new default and label properties. Settings::Setting is also now a subclass of Settings::BasicSetting. Also adds documentation for both Setting and BasicSetting. | |||||
2021-06-28 | CMakeLists: Disable all warnings for external headers | Morph | 1 | -0/+5 | |
This lets us avoid needing to wrap external headers with #pragma warning directives for warnings we treat as errors and avoids generating warnings for external code. Thanks to MerryMage for pointing this out. | |||||
2021-06-28 | video_core: Remove #pragma warning directives for external headers | Morph | 2 | -15/+0 | |
2021-06-28 | input_common: Remove #pragma warning directives for external headers | Morph | 2 | -14/+0 | |
2021-06-28 | CMakeLists: Enforce C4018, C4267, C4305, C4389 | Morph | 1 | -3/+7 | |
2021-06-28 | core: Enforce C4242 | Morph | 1 | -6/+3 | |
2021-06-28 | input_common: Enforce C4242 | Morph | 1 | -12/+4 | |
2021-06-28 | video_core: Enforce C4242 | Morph | 1 | -3/+2 | |
2021-06-28 | patch_manager: Do not apply LayeredFS mods when dumping | Morph | 3 | -4/+8 | |
We should not apply any mods when dumping a game's RomFS. | |||||
2021-06-28 | filesystem: Open a read-only directory for SDMC mods | Morph | 3 | -19/+25 | |
This prevents mod files from being locked due to the read-only share flag in Windows. | |||||
2021-06-28 | core: Simplify SDMC mod loading | lat9nq | 3 | -21/+10 | |
If someone else wants to support other mod formats in the SDMC directory, that can be added later. For now, just allow RomFS modding here and force people to do other types of mods the old way. Addresses review comments. Co-authored-by: LC <mathew1800@gmail.com> | |||||
2021-06-28 | core: Support LayeredFS mod from SDMC directory | lat9nq | 5 | -2/+47 | |
Enables loading a mod directly from `[yuzu data directory]/sdmc/atmosphere/contents/[title_id]`. For use with some homebrew mod managers. | |||||
2021-06-28 | yuzu qt: Add option to dump to SDMC directory | lat9nq | 4 | -7/+23 | |
Enables dumping the RomFS to SDMC directory, specifically '[yuzu data directory]/sdmc/atmosphere/contents/[title_id]/romfs'. | |||||
2021-06-28 | video_core: Silence signed/unsigned mismatch warnings | Morph | 4 | -5/+6 | |
2021-06-28 | main: Display the instruction set of the running title in the window name | ameerj | 1 | -0/+3 | |
Displays whether the currently running title uses 64-bit instructions or only 32-bit instructions. | |||||
2021-06-27 | Decouple audio processing and run at variable rate | Kelebek1 | 3 | -79/+115 | |
Currently, processing of audio samples is called from AudioRenderer's Update method, using a fixed 4 buffers to process the given samples. Games call Update at variable rates, depending on framerate and/or sample count, which causes inconsistency in audio processing. From what I've seen, 60 FPS games update every ~0.004s, but 30 FPS/160 sample games update somewhere between 0.02 and 0.04, 5-10x slower. Not enough samples get fed to the backend, leading to a lot of audio skipping. This PR seeks to address this by de-coupling the audio consumption and the audio update. Update remains the same without calling for buffer queuing, and the consume now schedules itself to run based on the sample rate and count. | |||||
2021-06-26 | hle: service: hwopus: OpenHardwareOpusDecoderEx: Remove unused buffer size. | bunnei | 1 | -1/+30 | |
2021-06-26 | configuration: Defer to common/settings for per-game settings defaults | lat9nq | 2 | -127/+100 | |
Avoids double-setting defaults, and avoids potential accidents when inconsistently setting the default on new settings. | |||||
2021-06-26 | common: Force defaults for Settings::Setting's | lat9nq | 1 | -44/+57 | |
Requires a default value when creating each per-game setting. | |||||
2021-06-26 | buffer_cache: Only flush downloaded size | ReinUsesLisp | 1 | -2/+3 | |
Fixes a regression unintentionally introduced by the garbage collector. This makes regular memory downloads only flush the requested sizes. This negatively affected Koei Tecmo games. | |||||
2021-06-26 | video_core: Enforce C4244 | ReinUsesLisp | 1 | -0/+1 | |
Enforce implicit integer casts to a smaller type as errors. | |||||
2021-06-26 | codec,vic: Disable warnings in ffmpeg headers | ReinUsesLisp | 2 | -4/+29 | |
2021-06-26 | vk_buffer_cache: Silence implicit cast warnings | ReinUsesLisp | 1 | -2/+3 | |
2021-06-26 | buffer_cache/texture_cache: Make GC functions private | ReinUsesLisp | 2 | -5/+5 | |
2021-06-26 | buffer_cache: Silence implicit cast warning | ReinUsesLisp | 1 | -1/+1 | |
2021-06-25 | vulkan_device: Make device memory match the rest of the file | ReinUsesLisp | 2 | -19/+18 | |
Match the style in the file. | |||||
2021-06-25 | hle: hle_helpers: Skip data payload offset checks on TIPC requests. | bunnei | 1 | -2/+6 | |
- TIPC does not use this. | |||||
2021-06-25 | hle: service: hwopus: Implement GetWorkBufferSizeEx and OpenHardwareOpusDecoderEx. | bunnei | 2 | -5/+15 | |
- This is used by the latest update of Doom Eternal. | |||||
2021-06-25 | hle: service: aoc: Stub GetAddOnContentListChangedEventWithProcessId. | bunnei | 2 | -1/+10 | |
- This is used by the latest update of Doom Eternal. | |||||
2021-06-25 | audio_core: common: Bump audio revision to 9. | bunnei | 1 | -1/+1 | |
- This is used in fw 12.x.x games. | |||||
2021-06-24 | common: Replace common_sizes into user-literals | Wunkolo | 19 | -126/+152 | |
Removes common_sizes.h in favor of having `_KiB`, `_MiB`, `_GiB`, etc user-literals within literals.h. To keep the global namespace clean, users will have to use: ``` using namespace Common::Literals; ``` to access these literals. | |||||
2021-06-24 | general: Add missing #pragma once directives | Morph | 4 | -0/+8 | |
2021-06-24 | Add missing includes (#6521) | Chloe | 4 | -0/+7 | |
* Add missing includes * Add array | |||||
2021-06-23 | General: Resolve fmt specifiers to adhere to 8.0.0 API where applicable | Lioncash | 9 | -15/+23 | |
Also removes some deprecated API usages. | |||||
2021-06-23 | maxwell3d: Add missing return in default SizeInBytes() case | Lioncash | 1 | -0/+1 | |
We were returning '1' in ComponentCount()'s default case but were neglecting to do the same with SizeInBytes(). | |||||
2021-06-23 | Simple resizing of the Per-Game configuration window and removal of useless Help question mark button in the title bar | OZtistic | 2 | -1/+8 | |
2021-06-22 | Reaper: Set minimum cleaning limit on OGL. | Fernando Sahmkow | 1 | -1/+4 | |
2021-06-22 | common: fs: Add a description of a regular file in IsFile | Morph | 1 | -4/+6 | |
This provides a more concrete example of what a regular file is and isn't. | |||||
2021-06-22 | vfs_real: Fix Mode to FileAccessMode conversion | Morph | 1 | -6/+1 | |
These enforce requiring the file to exist prior to opening. | |||||
2021-06-22 | common: fs: Amend IsFile check in FileOpen / (Write/Append)StringToFile | Morph | 4 | -9/+12 | |
This check was preventing files with the Write or Append file access modes from being created, as per the documented behavior in FileAccessMode. This amends the check to test for the existence of a filesystem object prior to checking whether it is a regular file. Thanks to liushuyu for pointing out that removing the check altogether would not guard against attempting to open non-regular files such as directories, symlinks, FIFO (pipes), sockets, block devices, or character devices. The documentation has also been updated for these functions to clarify that a file refers to a regular file. | |||||
2021-06-22 | common: fs: file: Remove [[nodiscard]] attribute from Flush | Morph | 2 | -3/+3 | |
Similarly, Flush() is typically called to attempt to flush a file into the disk. In the one case where this is used, we do not care whether the flush has succeeded or not, making [[nodiscard]] unnecessary. | |||||
2021-06-22 | common: fs: Remove [[nodiscard]] attribute on Remove* functions | Morph | 6 | -26/+26 | |
There are a lot of scenarios where we don't particularly care whether or not the removal operation and just simply attempt a removal. As such, removing the [[nodiscard]] attribute is best for these functions. | |||||
2021-06-22 | core: Make is_powered_on atomic | Rodrigo Locatti | 1 | -2/+3 | |
Fixes potential data races when shutting down. | |||||
2021-06-22 | common/detached_tasks: Wait for tasks before shutting down | Rodrigo Locatti | 1 | -0/+2 | |
If this is not waited on, the synchronization primitives are destroyed whe main exits and the detached task ends up signalling garbage and not properly finishing. | |||||
2021-06-22 | npad: Fix data race when updating devices | Rodrigo Locatti | 2 | -0/+8 | |
Add a lock to avoid data races. This reduces the number of -fsanitize=thread errors significantly. | |||||
2021-06-22 | input_common/mouse_input: Fix data race | Rodrigo Locatti | 2 | -12/+10 | |
Fix data race using std::jthread and std::stop_token. | |||||
2021-06-22 | Implement audout GetAudioOutPlayedSampleCount | Kelebek1 | 3 | -3/+20 | |
Used in Ninja Gaiden games. | |||||
2021-06-22 | bootmanager: Use std::stop_source for stopping emulation | ReinUsesLisp | 8 | -18/+18 | |
Use its std::stop_token to abort shader cache loading. Using std::stop_token instead of std::atomic_bool allows the usage of other utilities like std::stop_callback. | |||||
2021-06-22 | vk_master_semaphore: Use jthread for debug thread | ReinUsesLisp | 2 | -19/+8 | |
2021-06-21 | gl_device: Expand on Mesa driver names | lat9nq | 1 | -3/+28 | |
Makes this list a bit more capable at identifying Mesa drivers. Tries to deal with two of the overloaded vendor strings in a more generic fashion. | |||||
2021-06-21 | video_core: Add GPU vendor name to window title bar | ameerj | 9 | -10/+75 | |
2021-06-20 | Update dynarmic and add new unsafe CPU option. | Fernando Sahmkow | 7 | -0/+31 | |
2021-06-20 | Reaper: Guarantee correct deletion. | Fernando Sahmkow | 5 | -2/+23 | |
2021-06-20 | Reaper: Upgrade label from unsafe to experimental as no regressions are known now. | Fernando Sahmkow | 1 | -1/+1 | |
2021-06-19 | util_shaders: Specify ASTC decoder memory barrier bits | ameerj | 1 | -1/+6 | |
2021-06-19 | astc_decoder.comp: Remove unnecessary LUT SSBOs | ameerj | 5 | -113/+34 | |
We can move them to instead be compile time constants within the shader. | |||||
2021-06-19 | astc: Various robustness enhancements for the gpu decoder | ameerj | 5 | -47/+16 | |
These changes should help in reducing crashes/drivers panics that may occur due to synchronization issues between the shader completion and later access of the decoded texture. | |||||
2021-06-19 | host_memory: Correct MEM_RESERVE_PLACEHOLDER | lat9nq | 1 | -1/+1 | |
Microsoft defines `MEM_RESERVE_PLACEHOLDER` as `0x00040000`, but our manually imported version of it drops the last zero. | |||||
2021-06-18 | externals: httplib: replace custom httplib header with upstream as submodule. | Vortex | 1 | -1/+2 | |
This also includes a minor change to web_service.cpp - to fix compatibility with upstream changes. | |||||
2021-06-18 | service: time: Use GetFileRelative to get files within subdirectories | Morph | 1 | -1/+1 | |
The timezone info file can be within subdirectories (such as Asia/Tokyo), use GetFileRelative instead of GetFile to get files within subdirectories. | |||||
2021-06-18 | kernel: Fix missing peak set in KResourceLimit::SetLimitValue | Morph | 1 | -0/+1 | |
2021-06-18 | vulkan_debug_callback: Skip logging known false-positive validation errors | ameerj | 1 | -0/+8 | |
Avoids overwhelming the log with validation errors that are not applicable | |||||
2021-06-17 | Reaper: Correct size calculation on Vulkan. | Fernando Sahmkow | 1 | -5/+3 | |
2021-06-17 | config: Add frame limiter toggle hotkey | ameerj | 3 | -3/+8 | |
2021-06-17 | nvflinger: Add toggle to disable buffer swap interval limits | ameerj | 8 | -0/+38 | |
Enabling this setting will allow some titles to present more frames to the screen as they become available in the nvflinger buffer queue. | |||||
2021-06-17 | Reaper: Change memory restrictions on TC depending on host memory on VK. | Fernando Sahmkow | 10 | -41/+90 | |
2021-06-16 | Reaper: Address Feedback. | Fernando Sahmkow | 6 | -20/+43 | |
2021-06-16 | Reaper: Setup settings and final tuning. | Fernando Sahmkow | 10 | -32/+64 | |
2021-06-16 | Reaper: Tune it up to be an smart GC. | Fernando Sahmkow | 5 | -13/+130 | |
2021-06-16 | Initial Reaper Setup | ReinUsesLisp | 6 | -56/+226 | |
WIP | |||||
2021-06-16 | vulkan_memory_allocator: Release allocations with no commits | ReinUsesLisp | 2 | -5/+22 | |
2021-06-16 | spl: Mark the other functions as unimplemented | Morph | 1 | -5/+30 | |
2021-06-16 | spl: Implement spl::GetConfig | Morph | 2 | -1/+90 | |
2021-06-16 | hle: api_version: Add HLE API version constants | Morph | 3 | -33/+54 | |
2021-06-16 | spl: Add the general SPL interface | Morph | 4 | -45/+64 | |
2021-06-16 | spl: Add SPL types | Morph | 2 | -0/+231 | |
2021-06-16 | spl: Add SPL result codes | Morph | 2 | -0/+30 | |
2021-06-16 | common: fs: file: Remove redundant call to WriteStringToFile | Morph | 2 | -6/+1 | |
The Append open mode will create a new file if said file does not exist at a given path, making this call redundant. | |||||
2021-06-16 | fsp_srv: Fix filesystem access logging | Morph | 10 | -38/+63 | |
This introduces a new setting Enable FS Access Log which saves the filesystem access log to sdmc:/FsAccessLog.txt If this setting is not enabled, this will indicate to FS to not call OutputAccessLogToSdCard. Fixes softlocks during loading in Xenoblade Chronicles 2 when certain DLC is enabled. | |||||
2021-06-16 | astc_decoder: Fix LDR CEM1 endpoint calculation | ameerj | 2 | -2/+2 | |
Per the spec, L1 is clamped to the value 0xff if it is greater than 0xff. An oversight caused us to take the maximum of L1 and 0xff, rather than the minimum. Huge thanks to wwylele for finding this. Co-Authored-By: Weiyi Wang <wwylele@gmail.com> | |||||
2021-06-16 | yuzu_cmd/config: Add Accelerate ASTC and missing NVDEC emulation settings | ameerj | 2 | -2/+12 | |
2021-06-16 | configure_graphics: Add Accelerate ASTC decoding setting | ameerj | 9 | -2/+32 | |
2021-06-16 | textures: Reintroduce CPU ASTC decoder | ameerj | 4 | -2/+1592 | |
Users may want to fall back to the CPU ASTC texture decoder due to hangs and crashes that may be caused by keeping the GPU under compute heavy loads for extended periods of time. This is especially the case in games such as Astral Chain which make extensive use of ASTC textures. | |||||
2021-06-15 | lm: Demote guest logs to LOG_DEBUG | ameerj | 1 | -27/+20 | |
Guest logs are not very useful, as they are intended for use by the game developers during development. As such, they provide little meaning to be logged by yuzu and tend to overwhelm the log output at times. | |||||
2021-06-15 | texture_cache/util: Avoid relaxed image views on different bytes per pixel | ReinUsesLisp | 1 | -1/+9 | |
Avoids API usage errors on UE4 titles leading to crashes. | |||||
2021-06-13 | general: Remove extraneous includes | Morph | 3 | -3/+0 | |
2021-06-13 | common: logging: Restructure backend code | Morph | 8 | -278/+288 | |
2021-06-13 | common: logging: backend: Wrap IOFile in a unique_ptr | Morph | 2 | -6/+27 | |
Allows us to forward declare Common::FS::IOFile. | |||||
2021-06-13 | common: fs: file: Flush the file to the disk when Flush() is called | Morph | 1 | -1/+5 | |
std::fflush does not guarantee that file buffers are flushed to the disk. Use _commit on Windows and fsync on all other OSes to ensure that the file is flushed to the disk. | |||||
2021-06-13 | cmake: Fix find_program usage for 3.15 | lat9nq | 1 | -1/+4 | |
yuzu requires CMake 3.15 yet find_program was using REQUIRED, which is only available on 3.18 and later. Instead, we check for "<VAR>-NOTFOUND". In addition, check for additional requirements before building libusb or FFmpeg with autotools. Otherwise, CMake configuration will pass yet compilation will fail. | |||||
2021-06-13 | configure_cpu_debug: Clarify settings behavior | Morph | 1 | -1/+1 | |
This makes it clear that the disabled settings only take effect when CPU Accuracy is set to Debug Mode. | |||||
2021-06-12 | common: fs: Use the normal directory iterator in *Recursively functions | Morph | 1 | -2/+16 | |
MSVC's implementation of recursive_directory_iterator throws an exception on an error despite a std::error_code being passed into its constructor. This is most likely a bug in MSVC's implementation since directory_iterator does not throw an exception on an error. We can replace the usage of recursive_directory_iterator for now until MSVC fixes their implementation of it. | |||||
2021-06-11 | hid: Stub IsFirmwareUpdateAvailableForSixAxisSensor | german77 | 2 | -1/+23 | |
2021-06-11 | yuzu: main: Ensure enough space is available for RomFS dumping | Morph | 1 | -0/+12 | |
This warns the user if there isn't enough free space to dump the entire RomFS to disk. It requires at least the size of the extracted RomFS + 1 GiB as a buffer of free space. | |||||
2021-06-11 | common/host_memory: Implement a fallback if fastmem fails. | Markus Wick | 2 | -14/+49 | |
This falls back to the old approach of using a virtual buffer. Windows is untested, but this build should fix support for Windows < 10 v1803. However without fastmem support at all. | |||||
2021-06-11 | common/host_shader: Load Windows 10 functions dynamically | ReinUsesLisp | 1 | -29/+88 | |
Workaround old headers and libraries shipped on MinGW. | |||||
2021-06-11 | GPUTHread: Remove async reads from Normal Accuracy. | Fernando Sahmkow | 1 | -18/+6 | |
2021-06-11 | rasterizer: Update pages in batches | ReinUsesLisp | 1 | -15/+41 | |
2021-06-11 | host_memory: Support staged VirtualProtect calls | ReinUsesLisp | 1 | -3/+12 | |
2021-06-11 | General: Add settings for fastmem and disabling adress space check. | FernandoS27 | 12 | -6/+83 | |
2021-06-11 | common/host_memory: Optimize for huge tables. | Markus Wick | 2 | -11/+24 | |
In theory, if we have 2 MB continously mapped, this should save one layer of TLB. Let's make it at least more likely by aligning the memory. | |||||
2021-06-11 | core: Make use of fastmem | Markus Wick | 6 | -8/+30 | |
2021-06-11 | tests: Add tests for host memory | ReinUsesLisp | 2 | -0/+184 | |
2021-06-11 | common/host_memory: Add Linux implementation | Markus Wick | 1 | -10/+120 | |
2021-06-11 | common/host_memory: Add interface and Windows implementation | ReinUsesLisp | 3 | -0/+384 | |
2021-06-11 | kernel: Unconditionally set thread state when appropriate | Morph | 2 | -23/+12 | |
2021-06-11 | kernel: KLightConditionVariable: Update implementation to 12.x | Morph | 2 | -14/+31 | |
Updates the implementation of KLightConditionVariable to FW 12.x | |||||
2021-06-10 | Fix GCC undefined behavior sanitizer. | Markus Wick | 3 | -1/+9 | |
* Wrong alignment in u64 LOG_DEBUG -> memcpy. * Huge shift exponent in stride calculation for linear buffer, unused result -> skipped. * Large shift in buffer cache if word = 0, skip checking for set bits. Non of those were critical, so this should not change any behavior. At least with the assumption, that the last one used masking behavior, which always yield continuous_bits = 0. | |||||
2021-06-10 | hle: service: sm: Remove redundant session reservation, etc. | bunnei | 2 | -18/+13 | |
- We were double-reserving, causing us to run out of sessions in Pokemon Sword & Shield. | |||||
2021-06-10 | hle: service: Increase arbitrary max sessions limit. | bunnei | 1 | -4/+1 | |
- Pokemon Sword/Shield are still hitting this for some reason, causing an svcBreak. | |||||
2021-06-10 | hle: kernel: KClientPort: Add an assert for session count. | bunnei | 1 | -0/+3 | |
- Prevents us from over decrementing num_sessions. | |||||
2021-06-10 | hle: service: sm: Fix GetService setup of session & port. | bunnei | 2 | -5/+5 | |
2021-06-10 | hle: service: Use correct size for ServerSessionCountMax. | bunnei | 1 | -4/+6 | |
2021-06-10 | hle: kernel: KServerSession: Fix client disconnected. | bunnei | 3 | -9/+8 | |
- Prevents a cloned session's handler from being overwritten by another disconnected session. - Fixes session handler nullptr asserts with Pokemon Sword & Shield. | |||||
2021-06-10 | kernel: svc: Add missing error check to CancelSynchronization. | bunnei | 1 | -2/+2 | |
- Avoids a potential crash if the handle is invalid, and also makes this code accurate to real kernel behavior. | |||||
2021-06-09 | hle: service: Increase arbitrary max sessions limit. | bunnei | 1 | -1/+1 | |
- Pokemon Sword/Shield are still hitting this for some reason, causing an svcBreak. | |||||
2021-06-09 | src/common/CMakeLists.txt: fix variable escaping | liushuyu | 1 | -8/+9 | |
2021-06-09 | common/fs/path_util: Remove [[nodiscard]] from function with void return | Lioncash | 1 | -1/+1 | |
We can't make use of the return value here, since we don't a return value to work with. | |||||
2021-06-09 | configure_ui: Add translation context for file-scope strings | Lioncash | 1 | -13/+27 | |
Allows for these strings to show up in the translation files. | |||||
2021-06-08 | hle: kernel: KServerSession: Work-around scenario where session is closed too early. | bunnei | 1 | -7/+24 | |
2021-06-08 | hle: kernel: hle_ipc: Ensure SessionRequestHandler is valid. | bunnei | 3 | -5/+26 | |
2021-06-08 | hle: kernel: Remove service thread manager and use weak_ptr. | bunnei | 3 | -18/+8 | |
- We no longer need to queue up service threads to be destroyed. - Fixes a race condition where a thread could be destroyed too early, which caused a crash in Pokemon Sword/Shield. | |||||
2021-06-08 | yuzu qt: Start games from context menu | lat9nq | 4 | -3/+23 | |
This connects the BootGame function to the context menu. In addition, there is an option to boot without using the custom configuration. | |||||
2021-06-07 | Various suggestions by v1993 and lioncash | Clément Gallet | 2 | -11/+9 | |
2021-06-07 | hle: kernel: KServerSession: Use ASSERT_MSG where appropriate. | bunnei | 1 | -1/+1 | |
2021-06-07 | hle: kernel: k_server_session: Return service thread by strong pointer. | bunnei | 2 | -4/+4 | |
2021-06-07 | hle: kernel: k_server_session: Ensure service thread is valid before dereference. | bunnei | 1 | -1/+3 | |
2021-06-07 | hle: kernel: hle_ipc: Use default destructor for SessionRequestManager. | bunnei | 1 | -1/+1 | |
2021-06-07 | hle: kernel: KAutoObjectWithListContainer: Use boost::instrusive::rbtree. | bunnei | 11 | -22/+26 | |
- Fixes some crashes introduced by our common intrusive red/black tree impl. | |||||
2021-06-06 | Add sdl2 audio description in the yuzu-cmd config file | Clément Gallet | 1 | -1/+2 | |
2021-06-06 | Add SDL2 audio backend | Clément Gallet | 4 | -0/+211 | |
2021-06-06 | limitable_input_dialog: Implement character limiter | Kewlan | 3 | -5/+48 | |
When using GetText() you can now choose what set of characters the user can't enter. | |||||
2021-06-05 | Avoid -Wshadow warning | Clément Gallet | 1 | -1/+1 | |
Co-authored-by: Mai M. <mathew1800@gmail.com> | |||||
2021-06-05 | result: Add [[nodiscard]] specifiers where applicable | Lioncash | 1 | -20/+20 | |
The result code classes are used quite extensively throughout both the kernel and service HLE code. We can mark these member functions as [[nodiscard]] to prevent a few logic bugs from slipping through. | |||||
2021-06-05 | hle: kernel: Refactor to allocate a ServiceThread per service handler. | bunnei | 13 | -67/+75 | |
- Previously, we would allocate a thread per session, which adds new threads on CloneCurrentObject. - This results in race conditions with N sessions queuing requests to the same service interface. - Fixes Pokken Tournament DX crashes/softlocks, which were regressed by #6347. | |||||
2021-06-04 | yuzu-cmd: Fix OpenGL rendering | Clément Gallet | 2 | -12/+6 | |
2021-06-04 | decoders: Break instead of continue | lat9nq | 1 | -2/+2 | |
continue causes a memory leak in A Hat in Time. | |||||
2021-06-04 | decoders: Avoid out-of-bounds access | lat9nq | 1 | -0/+8 | |
This is not a real fix, so assert here and continue before crashing. | |||||
2021-06-04 | [game_list] Correct light theme loading (#6408) | Maide | 1 | -5/+1 | |
Correct light theme loading The setLayout call in game list instantiation will call resizing signals with default values in light theme, which was then being erroneously saved. setLayout doesn't seem to call resizing for any other theme, so I'm not sure why that happens. | |||||
2021-06-04 | yuzu-cmd: Add touch_from_button in config file | Clément Gallet | 2 | -1/+50 | |
2021-06-03 | cmake: General improvements to libusb linking | lat9nq | 1 | -2/+1 | |
Delegates libusb external communication to externals/CMakeLists.txt Ensures an interface library `usb` for every pathway input_common just links to the `usb` library now externals/libusb/CMakeLists.txt sets variables to override SDL2's libusb finding Other minor cleanup | |||||
2021-06-03 | fsp-srv: Replace one last instance of RESULT_SUCCESS | Morph | 1 | -1/+1 | |
2021-06-03 | fspsrv: Implement DisableAutoSaveDataCreation (#6355) | Chloe | 6 | -2/+25 | |
- Used by Mii Edit | |||||
2021-06-03 | yuzu qt: Revert some usages of string_view | lat9nq | 7 | -18/+27 | |
Causes a heap-use-after free reported by AddressSanitizer. This makes use of std::filesystem::path, but due to that we have to use their string() function which may not work for all characters. | |||||
2021-06-02 | game_list: Minor for loop optimizations | Kewlan | 1 | -9/+6 | |
There's no need to check the first and last rows since they'll always be the Favorites and AddDir rows. Also change the name of the clear_all variable for consistency. | |||||
2021-06-02 | Stop the columns resizing on NAND install | Kelebek1 | 2 | -34/+17 | |
2021-06-02 | general: Replace RESULT_UNKNOWN with ResultUnknown | Morph | 13 | -45/+45 | |
Transition to PascalCase for result names. | |||||
2021-06-02 | general: Replace RESULT_SUCCESS with ResultSuccess | Morph | 113 | -933/+930 | |
Transition to PascalCase for result names. | |||||
2021-06-02 | common: fs: fs_util: Move PathToUTF8String to fs_util | Morph | 4 | -15/+14 | |
2021-06-02 | common: fs: fs_util: Add more string conversion functions | Morph | 2 | -0/+33 | |
2021-06-01 | yuzu qt: Use lambda and std::function for reset callback | lat9nq | 4 | -19/+17 | |
Also makes use of std::move, and performs a clang-format cleanup. This addresses review comments. Co-authored-by: LC <mathew1800@gmail.com> | |||||
2021-06-01 | yuzu: Add settings reset button to general configuration | lat9nq | 8 | -23/+111 | |
Builds on german77's work to reset all settings back to their defaults. This include UISettings and Settings values structs, but does not affect save profiles, input profiles, and game directories. This works from a button input in configure_general. When activated, it calls a callback to close the whole configure dialog, then GMainWindow deletes the old configuration, both on disk and in memory, and reinitalizes a new one. It also resets a portion of the UI and calls the telemetry window prompt. | |||||
2021-06-01 | configuration: Initial work to reset all settings | fearlessTobi | 6 | -0/+33 | |
This commit does not compile. Initial work to add and connect a Reset to Defaults button to the configure_general tab. Co-authored-by: german77 <juangerman-13@hotmail.com> | |||||
2021-06-01 | buffer_cache: Simplify uniform disabling logic | ameerj | 8 | -6/+29 | |
2021-05-31 | common_funcs: Move R_ macros to result.h | Lioncash | 2 | -25/+25 | |
These macros all interact with the result code type, so they should ideally be within this file as well, so all the common_funcs machinery doesn't need to be pulled in just to use them. | |||||
2021-05-30 | settings: Disable controller preview if controller is not active | german77 | 3 | -2/+25 | |
2021-05-30 | input_common: Analog button, use time based position instead of frequent updates | german77 | 3 | -73/+138 | |
2021-05-29 | k_class_token: Use variable templates where applicable | Lioncash | 1 | -43/+36 | |
Same behavior, less code. | |||||
2021-05-29 | video_core: gpu: WaitFence: Do not block threads during shutdown. | bunnei | 2 | -1/+13 | |
- Fixes a hang on shutdown when NVFlinger thread is waiting on a syncpoint that will never occur. - Commonly observed when stopping emulation in Super Mario Odyssey. | |||||
2021-05-29 | core/memory: Check our memory fallbacks for out-of-bound behavior. | Markus Wick | 3 | -4/+46 | |
This makes it by far harder to crash yuzu. Also implement the 48bit masking of AARCH64 while touching this code. | |||||
2021-05-29 | core/arm_interface: Improve the performance of memory fallbacks. | Markus Wick | 2 | -29/+31 | |
We just create one memory subsystem. This is a constant all the time. So there is no need to call the non-inlined parent.Memory() helper on every callback. | |||||
2021-05-29 | kernel: Add missing override specifiers | Lioncash | 15 | -53/+48 | |
Over the course of the kernel refactoring a tiny bit of missing overrides slipped through review, so we can add these. While we're at it, we can remove redundant virtual keywords where applicable as well. | |||||
2021-05-29 | Fix two GCC 11 warnings: Unneeded copies. | Markus Wick | 2 | -3/+3 | |
std::move created an unneeded copy. iterating without reference also created copies. | |||||
2021-05-29 | externals: Update dynarmic. | Markus Wick | 6 | -11/+11 | |
The new version supports fastmem on a64. | |||||
2021-05-29 | k_thread: Move dereference after null check in Initialize() | Lioncash | 1 | -5/+5 | |
Prevents a -Wnonnull warning on GCC. | |||||
2021-05-29 | hle: kernel: KSlabHeap: Allow host or guest allocations. | bunnei | 2 | -11/+191 | |
- Use host allocations for kernel memory, as this is not properly emulated yet. - Use guest allocations for TLS, as this needs to be backed by DeviceMemory. | |||||
2021-05-28 | touchscreen: Make use of common point struct | Lioncash | 2 | -10/+10 | |
2021-05-28 | common: Extract point into a common struct | Lioncash | 3 | -29/+65 | |
This is generic enough that it can be moved into the Common class for reuse. | |||||
2021-05-28 | common/fs/file: Explicitly delete copy constructors | Lioncash | 1 | -1/+4 | |
Relocates them to the same place the move equivalents are at for consistent viewing. | |||||
2021-05-28 | common/fs/file: Devirtualize destructor | Lioncash | 1 | -1/+1 | |
IOFile is a final class, so there's no need for a virtual destructor. | |||||
2021-05-28 | common/fs/file: Default initialize IOFile members | Lioncash | 1 | -2/+2 | |
Prevents a potential uninitialized read vector in the move constructor. | |||||
2021-05-28 | applets/swkbd: Make use of std::move where applicable | Morph | 2 | -22/+19 | |
Avoids redundant string copies | |||||
2021-05-28 | applets/swkbd: Only read the text check message on Failure/Confirm | Morph | 1 | -2/+7 | |
Applications may leave this region of memory uninitialized when the text check result is not either Failure or Confirm. Attempting to read uninitialized memory may cause an exception within the UTF16 to UTF8 string converter. Fix this by only reading the text check message on Failure or Confirm. | |||||
2021-05-27 | video_core: rasterizer_cache: Use u16 for cached page count. | bunnei | 2 | -9/+9 | |
- Greatly reduces the risk of overflow, at the cost of doubling the size of this array. | |||||
2021-05-27 | core/arm_interface: Call SVC after end of dynarmic block. | Markus Wick | 6 | -18/+42 | |
So we can modify all of dynarmic states within SVC without ExceptionalExit. Especially as the ExceptionalExit hack is dropped on upstream dynarmic. | |||||
2021-05-27 | vulkan_memory_allocator: Allow textures to be allocated in host memory | ReinUsesLisp | 2 | -31/+43 | |
Allow Vulkan's allocator to use host memory when there's no more device local memory. This delays OOM, but it will eventually still happen. | |||||
2021-05-26 | cmake: Download Qt binaries on Linux if needed | lat9nq | 1 | -2/+11 | |
If the local version of Qt is older than the minimum version required by yuzu, download a pre-built binary package from yuzu-emu/ext-linux-bin and build yuzu with it, instead. This also requires linking yuzu to the correct libraries after building it, and copying over the required binaries when building yuzu. This sets the Qt requirement to 5.12, which is intentionally behind the versions used by our toolchains since they are not all updated yet to 5.15. | |||||
2021-05-26 | core/arm: Drop ChangeProcessorID. | Markus Wick | 5 | -12/+0 | |
This code was used to switch the CPU ID on thread switches. However since "hle: kernel: multicore: Replace n-JITs impl. with 4 JITs.", the CPU ID is not a constant. This has been dead code since this rewrite, and dropped in dynarmic as well. So there is no need to keep it. | |||||
2021-05-26 | ldn: Add and stub lp2p:sys lp2p:app INetworkServiceMonitor INetworkService | german77 | 1 | -0/+141 | |
2021-05-26 | yuzu qt: Restore const qualifiers | lat9nq | 2 | -23/+12 | |
This addresses review comments. Co-authored-by: LC <mathew1800@gmail.com> | |||||
2021-05-26 | yuzu qt: Handle per-game configs for title id 0 | lat9nq | 8 | -22/+46 | |
Currently with programs that have a 0 title id, yuzu loads the custom configuration 0000000000000000.ini for per-game configs. This is not ideal since many homebrews share this id. Instead for these programs, we load a config that is simply the file name and `.ini` appended to it. | |||||
2021-05-26 | common: fs: Rework the Common Filesystem interface to make use of std::filesystem (#6270) | Morph | 74 | -2173/+3789 | |
* 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 | |||||
2021-05-25 | yuzu qt: Add an Apply button to configuration dialogs | lat9nq | 6 | -18/+57 | |
Most of the code already exists to do this, but the Apply button itself was never added. This adds a button and boolean that tells yuzu to save the configuration after applying settings, even if close/Cancel is pressed on the dialog. Changes after applying will not be saved when Cancel is pressed, though. | |||||
2021-05-25 | kernel: process_capability: Add MapRegion capability | Morph | 2 | -0/+12 | |
- Used by nx-hbloader | |||||
2021-05-24 | zstd_compression: Make use of std::span | Lioncash | 2 | -3/+4 | |
Allows for the incoming data stream to be non-allocating. | |||||
2021-05-24 | lz4_compression: Make use of std::span | Lioncash | 2 | -4/+4 | |
Allows making the incoming data stream non-allocating. | |||||
2021-05-24 | hid: ApplyNpadSystemCommonPolicy | Chloe Marcec | 1 | -1/+10 | |
We already do this specifically for homebrew, so we can keep it stubbed out for the time being | |||||
2021-05-24 | settings: Forbid docked mode on handheld | german77 | 3 | -4/+24 | |
2021-05-23 | input_common: Add dual joycon support | german77 | 2 | -60/+258 | |
2021-05-23 | settings: Suppress duplicate label name warning | german77 | 1 | -3/+3 | |
2021-05-22 | applets/swkbd: Make use of QueuedConnection in returnPressed signal | Morph | 1 | -15/+3 | |
Some users have reported rare crashes when pressing the Enter key on the keyboard to confirm input in the normal software keyboard, particularly in Super Smash Bros. Ultimate while entering the name of a ruleset or controller layout. It is suspected that the QLineEdit::returnPressed signal is causing a race condition as confirming input through other means does not produce the crash. Since Qt::QueuedConnection posts an event to the event queue of the callee's thread instead of executing it directly on the caller's thread, this eliminates any potential race conditions from occurring in this scenario. | |||||
2021-05-21 | hle: kernel: service_thread: Take reference to KServerSession on service request. | bunnei | 1 | -9/+5 | |
2021-05-21 | hle: kernel: k_port: Use AcceptSession to ensure SessionList state is correct. | bunnei | 1 | -1/+1 | |
- Fixes a use-after-free, work-around until we fixup session/port management. | |||||
2021-05-21 | hle: kernel: Use host memory allocations for KSlabMemory. | bunnei | 4 | -174/+20 | |
- There are some issues with the current workaround, we will just use host memory until we have a complete kernel memory implementation. | |||||
2021-05-21 | Revert "WORKAROUND: Do not use slab heap while we track down issues with resource management." | bunnei | 1 | -2/+2 | |
This reverts commit f2c26443f85a3c3fd43137509368ba5c7ab80ee7. | |||||
2021-05-21 | hle: kernel: hle_ipc: Simplify incoming/outgoing move/copy/domain objects. | bunnei | 3 | -62/+17 | |
2021-05-21 | common: tree: Avoid a crash on nullptr dereference. | bunnei | 1 | -0/+11 | |
2021-05-21 | hle: kernel: Implement CloneCurrentObject and improve session management. | bunnei | 13 | -99/+184 | |
2021-05-21 | Revert "WORKAROUND: temp. disable session resource limits while we work out issues" | bunnei | 4 | -11/+11 | |
This reverts commit fc086f93b2165b5c210cb7dcd6c18ebe17f1fd7b. | |||||
2021-05-20 | configure_cpu: Simplify UpdateGroup | lat9nq | 1 | -7/+4 | |
Co-authored-by: Ameer J <52414509+ameerj@users.noreply.github.com> | |||||
2021-05-19 | configuration_shared: Drop unused function and template another | lat9nq | 2 | -52/+7 | |
Drops an unused variant of ApplyPerGameSetting, and turns the QComboBox variants of SetPerGameSetting into a template. Co-authored-by: Ameer J <52414509+ameerj@users.noreply.github.com> | |||||
2021-05-19 | applets/swkbd: Send the correct text string on TextCheck::Confirm | Morph | 1 | -8/+8 | |
Previously the text string for the inline software keyboard was being sent instead of the normal software keyboard, leading to empty text being sent all the time. | |||||
2021-05-18 | KTransferMemory: Return size instead of size * PageSize in GetSize() | Morph | 1 | -1/+1 | |
size is already the size in bytes. We do not need to multiply it by the page size | |||||
2021-05-18 | hid/gesture: Factor out last gesture retrieval into its own function | Lioncash | 2 | -14/+23 | |
Deduplicates a commonly repeated expression. | |||||
2021-05-18 | hid/gesture: Ensure all ID arrays are initialized | Lioncash | 1 | -4/+4 | |
Makes for deterministic initial state. | |||||
2021-05-18 | hid/gesture: Make Point a template | Lioncash | 2 | -38/+46 | |
We can now use this in a generic context to reuse it with the finger position. | |||||
2021-05-18 | hid/gesture: Replace x,y members of GestureState with a Point | Lioncash | 2 | -6/+4 | |
Simplifies assignments. | |||||
2021-05-18 | hid/gesture: Add default comparators to Point | Lioncash | 2 | -10/+7 | |
Simplifies some comparisons. | |||||
2021-05-18 | hid/gesture: Rename Points to Point | Lioncash | 1 | -5/+5 | |
This only represents a single point | |||||
2021-05-17 | general: Demote custom_rtc to regular setting | lat9nq | 6 | -58/+30 | |
2021-05-17 | CMakeLists: Enforce C4715 on MSVC | Morph | 1 | -0/+1 | |
This is similar to -Werror=return-type | |||||
2021-05-17 | configure_debug: FIx duplicate labels | Morph | 1 | -5/+5 | |
Duplicate labels were unintentionally introduced due to copy-paste. This silences the compilation warning produced by the presence of these duplicates. | |||||
2021-05-17 | yuzu/main: Fix version info in logging and about dialog | Morph | 3 | -14/+17 | |
2021-05-16 | buffer_cache: Ensure null buffers cannot take the fast uniform bind path | ameerj | 1 | -1/+4 | |
Fixes a crash in New Pokemon Snap | |||||
2021-05-16 | main: Prevent installing base titles into NAND | Morph | 4 | -3/+28 | |
Many users have been installing their base titles into NAND instead of adding them into the games list. This prevents users from installing any base titles and warns the user about the action. | |||||
2021-05-16 | hle_ipc: unsigned -> u32 | Morph | 1 | -7/+7 | |
This is more concise and consistent with the rest of the codebase. | |||||
2021-05-16 | hle_ipc: Add a getter for PID | Morph | 2 | -2/+7 | |
2021-05-16 | core: Make variable shadowing a compile-time error | Lioncash | 99 | -279/+304 | |
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. | |||||
2021-05-16 | configuration: Add CPU tab to game properties | lat9nq | 13 | -88/+181 | |
Allows setting CPU accuracy to Accurate or Unsafe per-game, as well as the accuracy options for Unsafe. Debug is not allowed here as a per-game CPU accuracy. | |||||
2021-05-16 | nifm, ssl: Fix incorrect response sizes | Morph | 2 | -2/+2 | |
2021-05-16 | configuration: Simplify applying per-game settings | lat9nq | 6 | -112/+69 | |
Originally, every time we add a per-game setting, we'd have to guard for it when setting it on the global config, and use a specific function to do it for the per-game config. This moves the global check into the ApplyPerGameSetting function so that we can use it for changing both the global and per-game states. Less work for the programmer. | |||||
2021-05-16 | configuration_shared: Add some comments | lat9nq | 1 | -6/+14 | |
Monke brain can't remember what all of these does a year later. | |||||
2021-05-16 | general: Make CPU accuracy and related a Settings::Setting | lat9nq | 7 | -41/+47 | |
Required to make CPU accuracy and unsafe settings available to use as a per-game setting. | |||||
2021-05-16 | perf_stats: Rework FPS counter to be more accurate | ameerj | 10 | -14/+26 | |
The FPS counter was based on metrics in the nvdisp swapbuffers call. This metric would be accurate if the gpu thread/renderer were synchronous with the nvdisp service, but that's no longer the case. This commit moves the frame counting responsibility onto the concrete renderers after their frame draw calls. Resulting in more meaningful metrics. The displayed FPS is now made up of the average framerate between the previous and most recent update, in order to avoid distracting FPS counter updates when framerate is oscillating between close values. The status bar update frequency was also changed from 2 seconds to 500ms. | |||||
2021-05-15 | main: Add title's version to window name on EA/mainline | ameerj | 1 | -11/+6 | |
Fixes the missing title version number on EA/mainline builds which override the title bar string. | |||||
2021-05-15 | input_common: Implement SDL motion | german77 | 5 | -3/+167 | |
2021-05-15 | input_common: Fix crash when controller disconnects | german77 | 1 | -1/+3 | |
2021-05-15 | input_common: Rewrite sdl analog mapping | german77 | 1 | -25/+25 | |
2021-05-13 | input_common: Sanitize motion data | german77 | 1 | -0/+23 | |
2021-05-13 | ssl: Stub Import(Client/Server)Pki | Morph | 1 | -2/+40 | |
- Used in JUMP FORCE Deluxe Edition | |||||
2021-05-12 | common: tree: Avoid a nullptr dereference. | bunnei | 1 | -1/+1 | |
2021-05-11 | hle: kernel: hle_ipc: Fix outgoing IPC response size calculation. | bunnei | 3 | -1/+15 | |
2021-05-11 | WORKAROUND: temp. disable session resource limits while we work out issues | bunnei | 4 | -11/+11 | |
2021-05-11 | WORKAROUND: Do not use slab heap while we track down issues with resource management. | bunnei | 1 | -2/+2 | |
2021-05-11 | audren | bunnei | 2 | -25/+16 | |
2021-05-11 | core: hle: ipc_helpers: Fix cast on raw_data_size calculation. | bunnei | 1 | -1/+1 | |
2021-05-11 | hle: service: sm: Add TIPC support. | bunnei | 2 | -41/+66 | |
- Fixes our error checking of names as well. | |||||
2021-05-11 | hle: kernel: hle_ipc: Improve IPC code and add initial support for TIPC. | bunnei | 2 | -81/+57 | |
- Fixes our move handles implementation to actually move objects. - Simplifies the traditional IPC path. | |||||
2021-05-11 | hle: service: sm: GetService: Reserve session resource when we create a KSession. | bunnei | 1 | -0/+7 | |
2021-05-11 | hle: service: Add support for dispatching TIPC requests. | bunnei | 2 | -1/+52 | |
2021-05-11 | hle: service: Implement IPC::CommandType::Close. | bunnei | 3 | -11/+15 | |
- This was not actually closing sessions before. | |||||
2021-05-11 | hle: service: sm: Use RegisterNamedService to register the service. | bunnei | 1 | -1/+1 | |
2021-05-11 | hle: service: sm: Improve Initialize implementation. | bunnei | 2 | -0/+3 | |
2021-05-11 | hle: kernel: svc: Update ConnectToNamedPort to use new CreateNamedServicePort interface. | bunnei | 1 | -4/+3 | |
2021-05-11 | hle: kernel: Implement named service ports using service interface factory. | bunnei | 4 | -22/+30 | |
- This allows us to create a new interface each time ConnectToNamedPort is called, removing the assumption that these are static. | |||||
2021-05-11 | hle: kernel: KSession: Improve implementation of CloneCurrentObject. | bunnei | 1 | -2/+10 | |
2021-05-11 | hle: service: sm: Increase point buffer size. | bunnei | 1 | -1/+1 | |
2021-05-11 | hle: ipc_helpers: Reserve session resource when we create a KSession. | bunnei | 1 | -0/+5 | |
2021-05-11 | hle: kernel: KClientPort: Cleanup comment format. | bunnei | 1 | -1/+1 | |
2021-05-11 | hle: ipc: Add declarations for TIPC. | bunnei | 1 | -1/+16 | |
2021-05-11 | hle: kernel: Further cleanup and add TIPC helpers. | bunnei | 2 | -4/+12 | |
2021-05-11 | hle: ipc_helpers: Update IPC response generation for TIPC. | bunnei | 2 | -19/+39 | |
2021-05-10 | configure_ui: Call RequestGameListUpdate when toggling "Show Add-Ons Column" | Kewlan | 1 | -0/+1 | |
2021-05-10 | parent_of_member: Make sign conversion explicit in OffsetOfImpl() | Lioncash | 1 | -1/+2 | |
Previously these conversions were implicit and causing quite a few warnings on clang. | |||||
2021-05-09 | kernel: Delete unused files | german77 | 2 | -151/+0 | |
2021-05-08 | kernel: Eliminate variable shadowing | Lioncash | 40 | -140/+138 | |
Now that the large kernel refactor is merged, we can eliminate the remaining variable shadowing cases. | |||||
2021-05-08 | texture_cache: Handle out of bound texture blits | ameerj | 8 | -61/+99 | |
Some games interleave a texture blit using regions which are out-of-bounds. This addresses the interleaving to avoid oob reads from the src texture. | |||||
2021-05-07 | ldr: Simplify memory copy within LoadNro() | Lioncash | 1 | -5/+3 | |
We can use the dedicated memory function for performing copies instead of reading into a temporary buffer and then immediately writing it back out to memory. Eliminates a bit of heap memory churn. | |||||
2021-05-06 | nvflinger: Create layers when they are queried but not found | ameerj | 2 | -5/+35 | |
Fixes Shantae softlock on boot. | |||||
2021-05-06 | hle: kernel: KPageTable: CanContain should not be constexpr. | bunnei | 2 | -2/+2 | |
2021-05-06 | hle: kernel: Move slab resource counts to Kernel. | bunnei | 4 | -33/+52 | |
2021-05-06 | fixup! hle: kernel: Migrate KSharedMemory to KAutoObject. | bunnei | 1 | -2/+2 | |
2021-05-06 | fixup! hle: kernel: Migrate more of KThread to KAutoObject. | bunnei | 1 | -1/+1 | |
2021-05-06 | fixup! common: bit_util: Add BIT macro. | bunnei | 1 | -2/+0 | |
2021-05-06 | fixup! hle: kernel: Ensure all kernel objects with KAutoObject are properly created. | bunnei | 1 | -2/+0 | |
2021-05-06 | fixup! hle: kernel: Ensure all kernel objects with KAutoObject are properly created. | bunnei | 1 | -2/+0 | |
2021-05-06 | kernel: svc: Remove unused RetrieveResourceLimitValue function. | bunnei | 1 | -32/+0 | |
2021-05-06 | hle: kernel: Fix un/sign mismatch errors with NUM_CPU_CORES. | bunnei | 1 | -3/+3 | |
2021-05-06 | fixup! hle: kernel: Add initial impl. of slab setup. | bunnei | 1 | -6/+2 | |
2021-05-06 | fixup! hle: kernel: Migrate to KHandleTable. | bunnei | 1 | -0/+3 | |
2021-05-06 | fixup! hle: kernel: Migrate more of KThread to KAutoObject. | bunnei | 1 | -7/+0 | |
2021-05-06 | common: parent_of_member: Fix build for OffsetOf(). | bunnei | 1 | -4/+4 | |
2021-05-06 | fixup! common: intrusive_red_black_tree: Disable static_assert that will not evaluate as constant on MSVC. | bunnei | 1 | -5/+0 | |
2021-05-06 | fixup! hle: kernel: Migrate KReadableEvent and KWritableEvent to KAutoObject. | bunnei | 2 | -2/+2 | |
2021-05-06 | fixup! hle: kernel: Migrate to KHandleTable. | bunnei | 1 | -1/+1 | |
2021-05-06 | fixup! hle: kernel: Add initial impl. of KLinkedList. | bunnei | 1 | -12/+12 | |
2021-05-06 | fixup! hle: kernel: Migrate to KHandleTable. | bunnei | 1 | -1/+1 | |
2021-05-06 | fixup! hle: kernel: Migrate KPort, KClientPort, and KServerPort to KAutoObject. | bunnei | 1 | -1/+1 | |
2021-05-06 | fixup! hle: kernel: Migrate KSession, KClientSession, and KServerSession to KAutoObject. | bunnei | 3 | -22/+28 | |
2021-05-06 | fixup! hle: kernel: Migrate KSession, KClientSession, and KServerSession to KAutoObject. | bunnei | 1 | -1/+1 | |
2021-05-06 | fixup! hle: kernel: Migrate KPort, KClientPort, and KServerPort to KAutoObject. | bunnei | 1 | -1/+1 | |
2021-05-06 | fixup! hle: kernel: Migrate to KHandleTable. | bunnei | 1 | -60/+58 | |
2021-05-06 | fixup! hle: kernel: Add initial impl. of KAutoObjectWithListContainer. | bunnei | 1 | -11/+9 | |
2021-05-06 | fixup! hle: kernel: Add initial impl. of KAutoObjectWithListContainer. | bunnei | 1 | -9/+2 | |
2021-05-06 | fixup! hle: kernel: Add initial impl. of KAutoObject. | bunnei | 1 | -46/+46 | |
2021-05-06 | fixup! hle: kernel: Add initial impl. of KAutoObject. | bunnei | 1 | -1/+1 | |
2021-05-06 | fixup! hle: kernel: Add initial impl. of slab setup. | bunnei | 1 | -8/+8 | |
2021-05-06 | common: Rename NON_COPYABLE/NON_MOVABLE with YUZU_ prefix. | bunnei | 5 | -11/+11 | |
2021-05-06 | fixup! hle: kernel: Rename Process to KProcess. | bunnei | 1 | -1/+1 | |
2021-05-06 | fixup! hle: kernel: Migrate to KHandleTable. | bunnei | 1 | -1/+1 | |
2021-05-06 | fixup! hle: kernel: Improve MapSharedMemory and implement UnmapSharedMemory. | bunnei | 1 | -3/+3 | |
2021-05-06 | hle: kernel: svc: ConnectToNamedPort: Use KHandleTable::Reserve. | bunnei | 1 | -3/+8 | |
2021-05-06 | hle: kernel: Migrate to KHandleTable. | bunnei | 22 | -381/+503 | |
2021-05-06 | hle: kernel: KClassToken: Ensure class tokens are correct. | bunnei | 1 | -1/+127 | |
2021-05-06 | hle: kernel: Improve MapSharedMemory and implement UnmapSharedMemory. | bunnei | 10 | -95/+210 | |
2021-05-06 | hle: kernel: Rename Process to KProcess. | bunnei | 83 | -247/+249 | |
2021-05-06 | hle: kernel: Remove deprecated Object class. | bunnei | 39 | -423/+34 | |
2021-05-06 | hle: kernel: Do not shutdown twice on emulator close. | bunnei | 1 | -3/+1 | |
2021-05-06 | hle: kernel: Cleanup shutdown of persistent kernel objects. | bunnei | 1 | -14/+12 | |
2021-05-06 | hle: kernel: Migrate KPort, KClientPort, and KServerPort to KAutoObject. | bunnei | 22 | -166/+444 | |
2021-05-06 | hle: kernel: Migrate KServerPort to KAutoObject. | bunnei | 8 | -52/+67 | |
2021-05-06 | hle: kernel: Migrate KClientPort to KAutoObject. | bunnei | 18 | -63/+92 | |
2021-05-06 | hle: kernel: HandleTable: Remove deprecated APIs. | bunnei | 7 | -111/+28 | |
2021-05-06 | hle: kernel: Migrate KResourceLimit to KAutoObject. | bunnei | 13 | -122/+197 | |
2021-05-06 | hle: kernel: svc: Migrate WaitSynchronization. | bunnei | 2 | -47/+78 | |
2021-05-06 | hle: kernel: svc: Use new handle table API for Process. | bunnei | 2 | -16/+17 | |
2021-05-06 | hle: kernel: Migrate KTransferMemory to KAutoObject. | bunnei | 12 | -68/+209 | |
2021-05-06 | hle: kernel: Migrate KSession, KClientSession, and KServerSession to KAutoObject. | bunnei | 31 | -356/+412 | |
2021-05-06 | hle: kernel: svc: Migrate GetThreadContext, GetThreadCoreMask. | bunnei | 1 | -2/+59 | |
2021-05-06 | hle: kernel: svc: Migrate GetProcessId, CancelSynchronization, SetThreadActivity. | bunnei | 1 | -13/+67 | |
2021-05-06 | hle: kernel: KThread: Remove incorrect resource release. | bunnei | 1 | -2/+1 | |
2021-05-06 | hle: kernel: svc_results: Update naming.. | bunnei | 8 | -42/+43 | |
2021-05-06 | hle: kernel: KThread: Add missing resource hint release. | bunnei | 1 | -1/+1 | |
2021-05-06 | hle: kernel: Migrate KReadableEvent and KWritableEvent to KAutoObject. | bunnei | 35 | -200/+215 | |
2021-05-06 | hle: ipc_helpers: Add methods for copy/move references. | bunnei | 1 | -2/+24 | |
2021-05-06 | hle: kernel: Move slab heaps to their own container. | bunnei | 2 | -10/+16 | |
2021-05-06 | hle: kernel: Refactor several threads/events/sharedmemory to use slab heaps. | bunnei | 11 | -59/+53 | |
2021-05-06 | hle: kernel: Move slab heap management to KernelCore. | bunnei | 7 | -64/+106 | |
2021-05-06 | hle: kernel: Ensure all kernel objects with KAutoObject are properly created. | bunnei | 20 | -0/+55 | |
2021-05-06 | hle: kernel: Use unique_ptr for suspend and dummy threads. | bunnei | 1 | -8/+8 | |
2021-05-06 | hle: kernel: Migrate KEvent to KAutoObject. | bunnei | 37 | -266/+269 | |
2021-05-06 | hle: kernel: Migrate KSharedMemory to KAutoObject. | bunnei | 16 | -114/+128 | |
2021-05-06 | hle: kernel: Migrate KProcess to KAutoObject. | bunnei | 14 | -58/+80 | |
2021-05-06 | hle: kernel: Refactor IPC interfaces to not use std::shared_ptr. | bunnei | 28 | -59/+65 | |
2021-05-06 | hle: kernel: Migrate more of KThread to KAutoObject. | bunnei | 18 | -294/+451 | |
2021-05-06 | hle: kernel: svc: Migrate GetThreadPriority, StartThread, and ExitThread. | bunnei | 1 | -21/+12 | |
2021-05-06 | hle: kernel: svc: Migrate CreateThread. | bunnei | 1 | -14/+21 | |
2021-05-06 | hle: kernel: Migrate idle threads. | bunnei | 2 | -13/+9 | |
2021-05-06 | hle: kernel: Migrate KThread to KAutoObject. | bunnei | 2 | -109/+91 | |
2021-05-06 | hle: kernel: Add initial impl. of slab setup. | bunnei | 3 | -0/+227 | |
2021-05-06 | hle: kernel: Refactor out various KThread std::shared_ptr usage. | bunnei | 10 | -58/+30 | |
2021-05-06 | core: Defer CoreTiming initialization. | bunnei | 1 | -1/+1 | |
2021-05-06 | core: memory: Add a work-around to allocate and access kernel memory regions by vaddr. | bunnei | 3 | -1/+46 | |
2021-05-06 | common: common_funcs: Add Size helper function. | bunnei | 1 | -0/+15 | |
2021-05-06 | hle: kernel: Add initial impl. of KLinkedList. | bunnei | 2 | -0/+234 | |
2021-05-06 | common: bit_util: Add BIT macro. | bunnei | 1 | -0/+2 | |
2021-05-06 | hle: kernel: Add initial impl. of KSlabAllocated. | bunnei | 2 | -0/+153 | |
2021-05-06 | hle: kernel: Add initial impl. of KAutoObjectWithListContainer. | bunnei | 3 | -0/+109 | |
2021-05-06 | hle: kernel: Add initial impl. of KAutoObject. | bunnei | 3 | -0/+306 | |
2021-05-06 | common: intrusive_red_black_tree: Disable static_assert that will not evaluate as constant on MSVC. | bunnei | 1 | -0/+4 | |
2021-05-06 | common: common_funcs: Add helper macros for non-copyable and non-moveable. | bunnei | 1 | -0/+8 | |
- Useful for scenarios where we do not want to inherit from NonCopyable. | |||||
2021-05-06 | Update src/core/hle/service/nvdrv/interface.cpp | bunnei | 1 | -1/+1 | |
Co-authored-by: Ameer J <52414509+ameerj@users.noreply.github.com> | |||||
2021-05-05 | hid: Improve hardware accuracy of gestures | german77 | 2 | -76/+340 | |
2021-05-05 | service: Remove unused class variables | Lioncash | 3 | -7/+4 | |
Prevents some warnings from occurring. | |||||
2021-05-04 | service: Resolve cases of member field shadowing | Lioncash | 60 | -117/+119 | |
Now all that remains is for kernel code to be 'shadow-free' and then -Wshadow can be turned into an error. | |||||
2021-05-03 | core: Resolve misc cases of variable shadowing | Lioncash | 10 | -25/+27 | |
Resolves shadowing warnings that aren't in a particularly large subsection of core. Brings us closer to turning -Wshadow into an error. All that remains now is for cases in the kernel (left untouched for now since a big change by bunnei is pending), and a few left over in the service code (will be tackled next). | |||||
2021-05-03 | nvdrv: /dev/nvhost-prof-gpu for production | Chloe Marcec | 1 | -3/+14 | |
While we're at it, we can fix the is_initialized error code. This fixes the crashes on Shante | |||||
2021-05-03 | hid: Fix touch not initializing properly if disabled | german77 | 2 | -2/+10 | |
2021-05-03 | input_common: Release mouse buttons on out of focus | german77 | 3 | -1/+18 | |
2021-05-02 | file_sys: Resolve cases of variable shadowing | Lioncash | 21 | -114/+132 | |
Brings us closer to enabling -Wshadow as an error in the core code. | |||||
2021-05-01 | service: filesystem: Return proper error codes for CreateFile | Morph | 2 | -2/+8 | |
This improves the accuracy of CreateFile by returning the correct error codes on certain conditions (parent directory does not exist, path already exists). This fixes saving and the loading of existing saves in New Pokemon Snap | |||||
2021-05-01 | Disable touch if setting is not enabled | german77 | 2 | -2/+2 | |
2021-04-30 | game_list: Fix dir move up/down expand state | Kewlan | 1 | -2/+4 | |
2021-04-30 | game_list: Update filter results when removing directories | Kewlan | 2 | -5/+6 | |
2021-04-29 | yuzu: config: Silence narrowing conversion warning on MSVC | Morph | 1 | -2/+1 | |
2021-04-28 | applets/web: Fix a use-after-free when passing in the URL string | Morph | 6 | -25/+28 | |
The URL string was being deleted before being used, leading to a use-after-free occurring when it is used afterwards. Fix this by taking the string by const ref to extend its lifetime, ensuring it doesn't get deleted before use. | |||||
2021-04-28 | yuzu: main: Silence type conversion warning on MSVC | Morph | 1 | -1/+1 | |
2021-04-27 | loader: Resolve instances of variable shadowing | Lioncash | 19 | -169/+257 | |
Eliminates variable shadowing cases across all the loaders to bring us closer to enabling variable shadowing as an error in core. | |||||
2021-04-27 | address comments | german77 | 2 | -5/+5 | |
2021-04-27 | input_common: Reset GC sticks center by measuring multiple packets | german77 | 2 | -2/+7 | |
2021-04-26 | gl_device: Intel: Disable texture view formats workaround on mesa | A-w-x | 1 | -1/+1 | |
2021-04-26 | service: Eliminate cases of member shadowing | Lioncash | 15 | -76/+81 | |
Resolves a few localized instances of member variable shadowing. Brings us a little closer to turning shadowing warnings into errors. | |||||
2021-04-25 | config: Add new keyboard bindings | Morph | 1 | -9/+10 | |
Changes the keyboard bindings to be based on RPCS3's tried and true keyboard bindings. | |||||
2021-04-25 | vk_texture_cache: Swap R and B channels of color flipped format | ameerj | 1 | -1/+24 | |
Swaps the Red and Blue channels of the A1B5G5R5_UNORM texture format, which was being incorrectly rendered. | |||||
2021-04-25 | nvhost_vic: Fix device closure | ameerj | 4 | -15/+11 | |
Implements the OnClose method of the nvhost_vic device, and removes the remnants of an older implementation. Also cleans up some of the surrounding code. | |||||
2021-04-24 | applets/swkbd: Fix software keyboard button hint scaling | Its-Rei | 1 | -12/+6 | |
Fixes the scaling of the button hints using background images. Now they scale like the rest of the elements. | |||||
2021-04-24 | glue: Add ectx:aw placeholder | german77 | 4 | -0/+49 | |
2021-04-24 | hid: Implement SevenSixAxis and ConsoleSixAxisSensor | german77 | 10 | -17/+220 | |
2021-04-24 | ICommonStateGetter: Stub SetRequestExitToLibraryAppletAtExecuteNextProgramEnabled | Morph | 2 | -1/+10 | |
- Used by Pixel Game Maker Series Werewolf Princess Kaguya | |||||
2021-04-23 | program_metadata: Set a default resource size when a NPDM is not present | Morph | 3 | -4/+8 | |
Sets a default size of 0x1FE00000 bytes (510 MiB) for the system_resource_size when a NPDM is not present. | |||||
2021-04-23 | emu_window: Return pair from ClipToTouchScreen() instead of tuple | Lioncash | 2 | -5/+8 | |
This is only a 2-tuple, so it can be converted over to the std::pair class. | |||||
2021-04-23 | emu_window: unsigned -> u32 | Lioncash | 4 | -23/+23 | |
This is more concise and consistent with the rest of the codebase. | |||||
2021-04-23 | aes_util: Make use of std::span | Lioncash | 2 | -9/+5 | |
Allows us to simplify the interface quite a bit as it will handle contiguous sequences for us. | |||||
2021-04-23 | acc/lbl: Remove unused variables | Lioncash | 2 | -6/+0 | |
2021-04-23 | lm: Make use of insert_or_assign() in Log() | Lioncash | 1 | -1/+1 | |
Avoids unnecessary default construction of an entry in cases where no entry exists before overwriting the created entry. | |||||
2021-04-23 | lm: Prevent redundant map lookups in Log() | Lioncash | 1 | -4/+5 | |
We can perform the lookup and then do the contains check by checking the end iterator. The benefit of this is that if we *do* find an entry, then we aren't hashing into the map again to find it. We can also get rid of an unused std::vector temporary while we're at it. | |||||
2021-04-23 | lm: Resolve -Wextra-semi warning | Lioncash | 1 | -1/+1 | |
Resolves a trivial warning with clang. | |||||
2021-04-23 | program_metadata: Explicitly specify copy/move functions | Lioncash | 1 | -0/+6 | |
The generation of the copy assignment operators are deprecated on being generated when a user-provided destructor is present. We can explicitly specify that we desire this behavior to keep the class forward compatible with future standards. | |||||
2021-04-23 | yuzu_cmd: Remove unused resource.h | ameerj | 2 | -17/+0 | |
2021-04-22 | service: hid: Get transfer memory for InitializeSevenSixAxisSensor | Morph | 1 | -1/+38 | |
2021-04-20 | log/backend: Use in-class initializer for FileBackend | Lioncash | 2 | -6/+8 | |
We can also avoid redundant constructions of the same string repeatedly. | |||||
2021-04-20 | log/backend: Make use of erase_if | Lioncash | 1 | -4/+4 | |
Same behavior, but less verbose. | |||||
2021-04-19 | texture_cache/util: Fix src being used instead of dst within DeduceBlitImages | Lioncash | 1 | -1/+1 | |
This line can only ever be reached if src is null, so dereferencing it here is a logic bug that slipped through. Instead, we dereference dst instead which is guaranteed to be valid. | |||||
2021-04-19 | general: Write buffers before pushing raw arguments | Morph | 3 | -5/+12 | |
For consistency with the rest of the service implementations | |||||
2021-04-19 | arp: Use type alias for issue function | Lioncash | 1 | -4/+4 | |
Reduces some verbosity and centralizes the function details in one spot. | |||||
2021-04-19 | arp: Prevent uninitialized read of launch member variable | Lioncash | 1 | -1/+1 | |
If anything happened to call arp functions in the wrong order and called IRegistrar's Issue function before SetApplicationLaunchProperty, we'd read from an uninitialized ApplicationLaunchProperty instance. Instead, we can always initialize it so if this does happen, then the outcome of doing such a thing is at least consistently reproducible. | |||||
2021-04-19 | npad: Remove duplicated class member variable | Lioncash | 2 | -2/+1 | |
ControllerBase already has a System reference that can be accessed from this class, so we can get rid of this to make the class layout a little more straightforward. | |||||
2021-04-19 | time: Write buffer before pushing RESULT_SUCCESS in GetClockSnapshot | Morph | 1 | -1/+2 | |
2021-04-19 | time: Fix GetClockSnapshotFromSystemClockContext | Morph | 1 | -2/+3 | |
This removes an incorrect alignment usage and corrects the positions of the popped parameters. - Fixes Super Kirby Clash crashing on boot | |||||
2021-04-18 | general: Ignore implicit-fallthrough for SDL.h | lat9nq | 5 | -0/+47 | |
SDL 2.0.14 introduces an incompatibility with Clang, causing it to trigger -Wimplicit-fallthrough even though it is marked. Ignore it for now, with a comment mentioning why this is needed. | |||||
2021-04-18 | cmake: Use SDL 2.0.14 and fix CMake scope issue | lat9nq | 1 | -1/+1 | |
Forces using SDL 2.0.14. Upgrades the SDL external to that version. Adds a message when switching to the external. Fixes an error where input_common only links to SDL when SDL2_FOUND is set, but externals/CMakeLists cannot set that variable to the required scope. Switch to using ENABLE_SDL2, which we can use since we now include the SDL source. | |||||
2021-04-17 | applets: Send focus state change message on applet state change | Morph | 10 | -22/+56 | |
Fixes the softlock after the controller applet exits in Mario Kart 8 Deluxe. | |||||
2021-04-17 | applets: Make the applet mode a protected property of Applet | Morph | 14 | -22/+20 | |
2021-04-16 | Address issues | Chloe Marcec | 1 | -3/+2 | |
2021-04-15 | applets/swkbd: Implement the Qt Software Keyboard frontend | Morph | 6 | -14/+5518 | |
The Qt Software Keyboard frontend attempts to mimic the software keyboard rendered by the Nintendo Switch. This frontend implements multiple keyboard types, such as the normal software keyboard, the numeric pad software keyboard and the inline software keyboard. Keyboard and controller input is also supported in this frontend. Keyboard input is handled as native keyboard input, and so the on-screen keyboard cannot be navigated with the keyboard arrow keys as the arrow keys are used to move the text cursor. Controller input is translated into mouse hover movements on the onscreen keyboard or their respective button actions (B for backspace, A for entering the selected button, L/R for moving the text cursor, etc). The text check dialogs can also be confirmed with controller input through the use of the OverlayDialog Massive thanks to Rei for creating all the UI for the various keyboards and OverlayDialog. This would not have been possible without his excellent work. Co-authored-by: Its-Rei <kupfel@gmail.com> | |||||
2021-04-15 | error: Make the error code as the title text of the OverlayDialog | Morph | 4 | -15/+17 | |
Co-authored-by: Its-Rei <kupfel@gmail.com> | |||||
2021-04-15 | overlay_dialog: Add an overlay text dialog that accepts controller input | Morph | 5 | -1/+768 | |
An OverlayDialog is an interactive dialog that accepts controller input (while a game is running) This dialog attempts to replicate the look and feel of the Nintendo Switch's overlay dialogs and provide some extra features such as embedding HTML/Rich Text content in a QTextBrowser. The OverlayDialog provides 2 modes: one to embed regular text into a QLabel and another to embed HTML/Rich Text content into a QTextBrowser. Co-authored-by: Its-Rei <kupfel@gmail.com> | |||||
2021-04-15 | main: Move meta type registration into its own function | Morph | 2 | -9/+65 | |
Moves the existing meta type registration into its own function and adds registration of common integral, floating point and string types. This function is also now called in the constructor of the GMainWindow instead of on starting a game. | |||||
2021-04-15 | input_interpreter: Fix button hold being interpreted incorrectly on init | Morph | 2 | -1/+17 | |
We reset all the button states to 0 except the first index (which has all the buttons as pressed) to prevent a button hold being interpreted as a button that was pressed once on the first poll. | |||||
2021-04-15 | applets/swkbd: Implement the Default Software Keyboard frontend | Morph | 2 | -2/+236 | |
2021-04-15 | applets/swkbd: Implement the Normal and Inline Software Keyboard Applet | Morph | 4 | -13/+1488 | |
2021-04-15 | ILibraryAppletCreator: Implement CreateHandleStorage | Morph | 2 | -6/+64 | |
Used by Monster Hunter Generations Ultimate | |||||
2021-04-15 | hle_ipc: Add helper functions to get copy/move handles | Morph | 2 | -2/+16 | |
2021-04-15 | ILibraryAppletAccessor: Demote from ERROR to DEBUG for null storage logs | Morph | 1 | -2/+2 | |
Avoids unnecessary console spam when the inline software keyboard is used. | |||||
2021-04-15 | applets: Pass in the LibraryAppletMode each applet's constructor | Morph | 13 | -33/+58 | |
2021-04-15 | applets: Remove the previous software keyboard applet implementation | Morph | 8 | -492/+14 | |
2021-04-15 | game_list: Mark games as favorite to make them appear at the top. | Kewlan | 5 | -5/+144 | |
Icons are from Icons8. | |||||
2021-04-15 | log/backend: Correct order of const in copy constructor | Lioncash | 1 | -2/+5 | |
Follows our predominant coding style. Also explicitly specifies the move constructor/assignment operator as well. | |||||
2021-04-15 | common/log: Move Log namespace into the Common namespace | Lioncash | 11 | -43/+53 | |
Forgot to move this over when I moved the rest of the source files with lacking namespaces over. | |||||
2021-04-15 | common: Move settings to common from core. | bunnei | 116 | -146/+144 | |
- Removes a dependency on core and input_common from common. | |||||
2021-04-15 | core: settings: Add setting for debug assertions and disable by default. | bunnei | 7 | -2/+28 | |
- This is a developer-only setting and no longer needs to be enabled by default. - Also adds "use_auto_stub" setting to SDL frontend while we are here. - Supersedes #1340. | |||||
2021-04-14 | k_resource_limit: Minor cleanup of member variables/headers | ameerj | 4 | -21/+13 | |
2021-04-13 | applets/controller: Hook up the "Motion" button functionality | Morph | 2 | -0/+19 | |
I forgot to hook this up during the development of the controller applet, this PR amends that. | |||||
2021-04-13 | nvidia_flags: Add missing header guard | Lioncash | 1 | -0/+2 | |
Prevents potential inclusion compilation errors. | |||||
2021-04-12 | kernel/process: Replace process resource limit instance with the kernel's resource limit | ameerj | 2 | -38/+27 | |
This commit addresses the inaccurate behavior of kernel processes creating their own resource limit, rather than utilizing the kernel's system-wide resource limit instance. | |||||
2021-04-12 | k_thread: Remove [[nodiscard]] attribute from ClearWaitCancelled() | Lioncash | 1 | -1/+1 | |
This function has a void return value, so this attribute doesn't apply to it. | |||||
2021-04-12 | engine_interface: Add missing virtual destructor | Lioncash | 4 | -4/+5 | |
Eliminates a potential bug vector related to inheritance. Plus, we should generally be specifying the destructor as virtual within purely virtual interfaces to begin with. | |||||
2021-04-12 | vk_master_semaphore: Deduplicate atomic access within IsFree() | Lioncash | 1 | -1/+1 | |
We can just reuse the already existing KnownGpuTick() to deduplicate the access. | |||||
2021-04-12 | vk_master_semaphore: Add missing const qualifier for IsFree() | Lioncash | 1 | -1/+1 | |
This member function doesn't modify class state. | |||||
2021-04-12 | vk_texture_cache: Make use of Common::BitCast where applicable | Lioncash | 1 | -5/+6 | |
Also clarify the TODO comment a little more on the lacking implementations for std::bit_cast. | |||||
2021-04-12 | texure_cache/util: Resolve implicit sign conversions with std::reduce | Lioncash | 2 | -11/+15 | |
Amends implicit sign conversions occurring with usages of std::reduce and also relocates it to its own utility function to reduce verbosity a little bit. | |||||
2021-04-12 | query_cache: Make use of std::erase_if | Lioncash | 1 | -5/+4 | |
Same behavior, but much more straightforward to read. | |||||
2021-04-11 | vk_buffer_cache: Fix offset for NULL vertex buffers | Joshua Ashton | 1 | -1/+1 | |
The Vulkan spec states: If an element of pBuffers is VK_NULL_HANDLE, then the corresponding element of pOffsets must be zero. https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkCmdBindVertexBuffers2EXT.html#VUID-vkCmdBindVertexBuffers2EXT-pBuffers-04112 | |||||
2021-04-11 | vulkan_device: Enable EXT_robustness2 features | Joshua Ashton | 1 | -0/+9 | |
When this was being made mandatory, these enablement of these features was removed, but this is still needed. Fixes: 757fd1e91716 ("vulkan_device: Require VK_EXT_robustness2") | |||||
2021-04-11 | renderer_vulkan: Check return value of AcquireNextImage | Joshua Ashton | 3 | -5/+10 | |
We can get into a really bad state by ignoring this leading to device loss and using incorrect resources. | |||||
2021-04-09 | ns: Update to 12.x | Morph | 1 | -3/+38 | |
2021-04-09 | aoc_u: Update to 12.x | Morph | 1 | -0/+2 | |
2021-04-09 | nim: Update to 12.x | Morph | 1 | -44/+55 | |
2021-04-09 | npns: Update to 12.x | Morph | 1 | -0/+3 | |
2021-04-09 | bgtc: Update to 12.x and implement OpenTaskService | Morph | 4 | -1/+36 | |
2021-04-09 | vi: Update to 12.x | Morph | 1 | -0/+8 | |
2021-04-09 | erpt: Update to 12.x | Morph | 1 | -1/+6 | |
2021-04-09 | btm: Update to 12.x | Morph | 1 | -0/+1 | |
2021-04-09 | btdrv: Update to 12.x | Morph | 1 | -0/+19 | |
2021-04-09 | wlan: Update to 12.x | german77 | 1 | -0/+7 | |
2021-04-09 | usb: Use proper names | german77 | 1 | -21/+21 | |
2021-04-09 | ITimeZoneService: Update to 12.x | german77 | 1 | -0/+1 | |
2021-04-09 | spl: Update to 12.x | german77 | 1 | -0/+3 | |
2021-04-09 | sfdnsres: Use proper names | german77 | 1 | -2/+2 | |
2021-04-09 | nsd: Update to 12.x | german77 | 1 | -0/+1 | |
2021-04-09 | ethc: Update to 12.x | german77 | 1 | -0/+1 | |
2021-04-09 | sm: Use proper names, update to 12.x | german77 | 1 | -4/+5 | |
2021-04-09 | set_sys: Update to 12.x | german77 | 1 | -0/+6 | |
2021-04-09 | pctl_module: Update to 12.x | german77 | 1 | -0/+3 | |
2021-04-09 | pcie: Use proper names | german77 | 1 | -1/+1 | |
2021-04-09 | olsc: Update to 12.x | german77 | 1 | -0/+1 | |
2021-04-09 | pl_u: Update to 12.x | german77 | 1 | -0/+4 | |
2021-04-09 | ldr: Use proper names | german77 | 1 | -16/+16 | |
2021-04-09 | arp: Use proper names, update to 12.x | german77 | 2 | -3/+10 | |
2021-04-09 | caps_u: Update to 12.x | german77 | 1 | -0/+1 | |
2021-04-09 | caps_a: Update to 12.x | german77 | 1 | -0/+1 | |
2021-04-09 | bpc: Use proper names | german77 | 1 | -2/+2 | |
2021-04-09 | bcat_module: Update to 12.x | german77 | 1 | -0/+2 | |
2021-04-09 | codecctl: Use proper names | german77 | 1 | -13/+13 | |
2021-04-09 | audren_u: Use proper names | german77 | 2 | -4/+4 | |
2021-04-09 | audren_a: Use proper names | german77 | 1 | -6/+6 | |
2021-04-09 | audrec_u: Use proper names, update to 12.x | german77 | 1 | -3/+4 | |
2021-04-09 | audrec_a: Use proper names | german77 | 1 | -2/+2 | |
2021-04-09 | audout_u: Use proper names | german77 | 1 | -3/+3 | |
2021-04-09 | audout_a: Use proper names | german77 | 1 | -6/+6 | |
2021-04-09 | audin_u: Use proper names | german77 | 1 | -7/+7 | |
2021-04-09 | audin_a: Use proper names | german77 | 1 | -4/+4 | |
2021-04-08 | externals: Search for shared opus installation. | Markus Wick | 1 | -1/+1 | |
We had used conan for opus before, but there was a bug in the AVX detection. However we still had the Findopus.cmake file within the repository, but not used. This patch reenables the Findopus helper and prefer the system wide installation of opus. | |||||
2021-04-08 | service: time: Setup the network clock with the local clock context | Morph | 6 | -21/+38 | |
Setting the network time allows some time based events using the network clock to not reset. | |||||
2021-04-08 | service: hid: Stub SetAnalogStickUseCenterClamp | Morph | 4 | -1/+29 | |
- Used by eBASEBALLパワフルプロ野球2020 | |||||
2021-04-08 | service: time: Fix CalculateStandardUserSystemClockDifferenceByUser | Morph | 1 | -3/+8 | |
CalculateStandardUserSystemClockDifferenceByUser passes in the ClockSnapshots through 2 input buffers and not as raw arguments. Fix this by reading the 2 input buffers instead of popping raw arguments. | |||||
2021-04-07 | video_core: Use a CV for blocking commands. | Markus Wick | 2 | -23/+31 | |
There is no need for a busy loop here. Let's just use a condition variable to save some power. | |||||
2021-04-07 | video_core/gpu_thread: Keep the write lock for allocating the fence. | Markus Wick | 2 | -1/+4 | |
Else the fence might get submited out-of-order into the queue, which makes testing them pointless. Overhead should be tiny as the mutex is just moved from the queue to the writing code. | |||||
2021-04-07 | video_core/gpu_thread: Implement a ShutDown method. | Markus Wick | 5 | -15/+28 | |
This was implicitly done by `is_powered_on = false`, however the explicit method allows us to block until the GPU is actually gone. This should fix a race condition while removing the other subsystems while the GPU is still active. | |||||
2021-04-07 | common/threadsafe_queue: Provide Wait() method. | Markus Wick | 2 | -3/+10 | |
It shall block until there is something to consume in the queue. And use it for the GPU emulation instead of the spin loop. This is only in booting the emulator, however in BOTW this is the case for about 1 second. | |||||
2021-04-07 | hwopus: Update to 12.x | Morph | 1 | -0/+4 | |
2021-04-07 | IFile: Update to 12.x | Morph | 1 | -3/+7 | |
2021-04-07 | fsp-srv: Update to 12.x | Morph | 2 | -3/+8 | |
2021-04-07 | dauth_o: Update to 11.x | Morph | 1 | -6/+11 | |
2021-04-07 | acc_u1: Update to 12.x | Morph | 1 | -13/+15 | |
2021-04-07 | acc_su: Update to 12.x | Morph | 1 | -17/+19 | |
2021-04-07 | hid: Update service function tables | german77 | 2 | -0/+85 | |
2021-04-07 | ISelfController: Update to 11.x | Morph | 1 | -0/+1 | |
2021-04-07 | IApplicationFunctions: Update to 11.x | Morph | 1 | -0/+6 | |
2021-04-07 | IDebugFunctions: Update to 12.x | Morph | 1 | -0/+2 | |
2021-04-07 | ICommonStateGetter: Update to 12.x | Morph | 1 | -0/+9 | |
2021-04-07 | IGlobalStateController: Update to 12.x | Morph | 1 | -0/+1 | |
2021-04-07 | IHomeMenuFunctions: Update to 12.x | Morph | 1 | -0/+3 | |
2021-04-07 | Amend bizarre clang-format suggestions | Lioncash | 3 | -5/+5 | |
2021-04-07 | k_scoped_scheduler_lock_and_sleep: Mark class as [[nodiscard]] | Lioncash | 1 | -1/+1 | |
Prevents logic bugs from slipping through. | |||||
2021-04-07 | k_scoped_lock: delete copy and move assignment operators | Lioncash | 1 | -2/+5 | |
If we delete the copy and move constructor, we should also be deleting the copy and move assignment operators (and even if this were intended, it would be pretty odd to not document why it's done this way). | |||||
2021-04-07 | k_scoped_lock: Mark class as [[nodiscard]] | Lioncash | 1 | -1/+1 | |
Prevents logic bugs of the kind described in the previous commit from slipping through. | |||||
2021-04-07 | k_scheduler: Mark KScopedSchedulerLock as [[nodiscard]] | Lioncash | 1 | -1/+1 | |
Prevents logic bugs like: KScopedSchedulerLock{kernel}; instead of: KScopedSchedulerLock lk{kernel}; from slipping through. | |||||
2021-04-07 | kernel: Increase event and session counts | ameerj | 1 | -2/+2 | |
12.x increased the number of available sessions and event resource counts | |||||
2021-04-07 | svc: Expand SVC tables | Lioncash | 1 | -0/+132 | |
12.x expanded the range of SVC entries from 0x7F to 0xBF (with all new entries being unused), so we can expand it to also match. | |||||
2021-04-07 | process_capability: Handle extended SVC range | Lioncash | 2 | -6/+1 | |
12.x extended the range of SVC IDs, so we need to expand the range of bits that need to be tested. The upside of this is that we can eliminate a range check, given the whole range is used. | |||||
2021-04-06 | config: Default to exclusive fullscreen mode on platforms other than Windows | Morph | 1 | -0/+12 | |
Several issues have been reported with the borderless windowed fullscreen mode on *nix platforms. Default to exclusive fullscreen mode on these platforms for now. | |||||
2021-04-06 | configure_graphics: Add Borderless Windowed fullscreen mode | Morph | 5 | -9/+108 | |
The borderless windowed fullscreen mode solves several issues with the presentation of the overlay dialogs and on-screen keyboard in exclusive fullscreen mode, and also has other benefits such as smoother gameplay, lower latency and a significant reduction in screen tearing. Co-authored-by: Its-Rei <kupfel@gmail.com> | |||||
2021-04-05 | nvhost_nvdec_common: Avoid memcpy with null pointers | lat9nq | 1 | -6/+11 | |
Avoid sending null pointer to memcpy as reported by Undefined Behavious Sanitizer. Co-authored-by: LC <mathew1800@gmail.com> | |||||
2021-04-05 | nvhost_ctrl_gpu: Avoid sending null pointer to memcpy | lat9nq | 1 | -1/+7 | |
Undefined Behaviour Sanitizer reports a null pointer is being sent to memcpy, thought it's "guaranteed to never be null". Guard it with an if statement, and log when the action has been averted. | |||||
2021-04-05 | vp9: Avoid memcpy with null pointers | lat9nq | 1 | -7/+9 | |
Avoid sending null pointer to memcpy as reported by Undefined Behaviour Sanitizer. Replaces the std::memcpy calls in SpliceVectors with std::copy calls. Opting to replace all the memcpy's with copy's. Co-authored-by: LC <mathew1800@gmail.com> | |||||
2021-04-04 | common: Move assert failure handling into a cpp file. | Markus Wick | 3 | -6/+20 | |
Advantage: Altering the handler does not need a full recompilation. Disadvantage: noreturn is droped, so the caller is a bit slower. We quite often run yuzu with a YOLO assertion handler. In fact, only very few games run at all with asserts. This patch allows developers to patch the handler without recompiling everything. The overhead of the missing "noreturn" attribute shoul be negletable. | |||||
2021-04-04 | configure_graphics: Prevent stack-use-after-scope | lat9nq | 1 | -1/+1 | |
Address Sanitizer reports stack-use-after-scope on line 231 `vulkan_devices.push_back(QString::fromStdString(name));`. Instead of using a pointer, copy the string into a std::string and use that, instead. | |||||
2021-04-02 | arm_dynarmic: Increase size of code cache | MerryMage | 2 | -0/+8 | |
2021-04-02 | HID: Fix SL and SR buttons for right joycon | german77 | 1 | -2/+6 | |
2021-03-31 | Use a single connection for UDP server, make connection test longer and check all pads instead of only the first one | german77 | 4 | -102/+101 | |
2021-03-31 | InputCommon: Name properly xbox 360 and one controllers, Fix mappings for Nintendo Pro controllers | german77 | 2 | -6/+24 | |
2021-03-30 | ISelfController: Stub SetAlbumImageTakenNotificationEnabled | Morph | 2 | -1/+17 | |
This service call sets an internal flag whether a notification is shown when an image is captured. Currently we do not support capturing images via the capture button, so this can be stubbed for now. | |||||
2021-03-30 | configuration: Add auto stub toggle that resets on boot | ameerj | 5 | -4/+32 | |
Auto-stub is an experimental debugging feature that may cause unforseen bugs. This adds a toggle to only allow auto-stubbing unimplemented functions when explicitly enabled when yuzu is launched. | |||||
2021-03-30 | service: Auto stub fallback | ameerj | 1 | -0/+4 | |
For simple services we can implement an automatic stub fallback to help with compatibility until a proper implementation is done. Co-Authored-By: Chloe <25727384+ognik5377@users.noreply.github.com> | |||||
2021-03-30 | nvdrv: Cleanup CDMA Processor on device closure | Chloe Marcec | 3 | -11/+15 | |
Brings us a step closer to unifying all channels to share a common interface. | |||||
2021-03-30 | Addressed issues | Chloe Marcec | 2 | -21/+22 | |
2021-03-30 | vulkan_common: enable OpenGL interop on other Unices | Jan Beich | 2 | -5/+5 | |
2021-03-27 | yuzu/main: Add user command line argument | german77 | 1 | -0/+28 | |
2021-03-27 | hle: kernel: Initialize preemption task after schedulers. | bunnei | 1 | -1/+1 | |
- Fixes a startup crash that occurs if CoreTiming tries to preempt before kernel initialization completes. | |||||
2021-03-27 | service: friend: Change logging class from ACC to Friend | Morph | 1 | -11/+12 | |
2021-03-27 | Friend: Stub GetPlayHistoryRegistrationKey | german77 | 1 | -1/+13 | |
2021-03-26 | HID: Initialize correctly the gesture finger_id and filter invalid results | Narr the Reg | 2 | -3/+13 | |
2021-03-26 | pctl: Rework how pctl works to be more accurate | Chloe Marcec | 6 | -31/+253 | |
Introduces the usage of compatibilities to allow it the module to be closer to how it works on hardware. | |||||
2021-03-25 | astc_decoder: Refactor for style and more efficient memory use | ameerj | 9 | -2256/+502 | |
2021-03-25 | nvdrv: Pass device fd and handle device create methods for device opening and closing | Chloe Marcec | 20 | -78/+161 | |
We pass the fd to the ioctl as well as alert the device when it's opened or closed to allow for fd unique actions to take place | |||||
2021-03-24 | gl_device: unblock async shaders on other Unix systems | Jan Beich | 1 | -1/+1 | |
Mesa is the primary OpenGL provider on all FreeDesktop systems. For example, iris is used on Intel GPU + FreeBSD by default. | |||||
2021-03-24 | arm_dynarmic: Always have a 'valid' jit instance | MerryMage | 4 | -53/+26 | |
2021-03-24 | hle: kernel: Breakup InitializeMemoryLayout. | bunnei | 1 | -3/+7 | |
2021-03-24 | hle: kernel: k_memory_region_type: Minor code cleanup. | bunnei | 1 | -13/+12 | |
2021-03-24 | hle: kernel: k_memory_region: Minor code cleanup. | bunnei | 1 | -7/+5 | |
2021-03-24 | hle: kernel: k_memory_layout: Use pair instead of tuple. | bunnei | 1 | -2/+4 | |
2021-03-24 | hle: kernel: k_system_control: Remove unnecessary inline. | bunnei | 1 | -4/+4 | |
2021-03-24 | common: common_sizes: Move sizes to the Common namespace. | bunnei | 5 | -45/+50 | |
2021-03-22 | nvdrv: Change InitializeEx to AllocAsEx | Chloe Marcec | 2 | -27/+49 | |
Wee also report the correct "big page size" now in GetVARegions & fix up the struct for IoctlAllocAsEx | |||||
2021-03-21 | hle: kernel: Merge KMemoryRegionAttr and KMemoryRegionType. | bunnei | 2 | -11/+9 | |
- Fixes clang errors with mixed enum arithmetic. | |||||
2021-03-21 | hle: kernel: Remove unused variable. | bunnei | 1 | -1/+0 | |
2021-03-21 | hle: kernel: k_memory_region_type: Remove extra ". | bunnei | 1 | -1/+1 | |
2021-03-21 | core: arm_dynarmic: Ensure JIT state is saved/restored on page table changes. | bunnei | 2 | -0/+10 | |
- We re-create the JIT here without preserving any state. | |||||
2021-03-21 | hle: kernel: k_memory_layout: Move KMemoryRegionAllocator out of global. | bunnei | 3 | -35/+47 | |
2021-03-21 | hle: kernel: k_memory_layout: Derive memory regions based on board layout. | bunnei | 6 | -56/+1033 | |
2021-03-21 | common: common_sizes: Move Invalid to Size_* prefix and add missing values. | bunnei | 2 | -15/+21 | |
2021-03-21 | hle: kernel: k_memory_region: Refactor to simplify code. | bunnei | 2 | -83/+89 | |
2021-03-21 | hle: kernel: board: k_system_control: Extend to include memory region sizes. | bunnei | 3 | -1/+135 | |
2021-03-21 | hle: kernel: board: Add secure_monitor module. | bunnei | 2 | -0/+27 | |
2021-03-21 | common: Move common sizes to their own header for code reuse. | bunnei | 3 | -13/+25 | |
2021-03-21 | hle: kernel: k_address_space_info: Cleanup. | bunnei | 1 | -9/+9 | |
2021-03-21 | hle: kernel: Add k_trace module. | bunnei | 2 | -0/+13 | |
2021-03-21 | hle: kernel: KSystemControl: Update to reflect board-specific behavior. | bunnei | 4 | -10/+41 | |
2021-03-21 | hle: kernel: KMemoryManager: Add CalculateManagementOverheadSize. | bunnei | 2 | -0/+26 | |
2021-03-21 | hle: kernel: KMemoryManager: Add aliases. | bunnei | 1 | -0/+4 | |
2021-03-21 | hle: kernel: Add architecture and board specific memory regions. | bunnei | 2 | -0/+72 | |
2021-03-21 | hle: kernel: KMemoryRegion: Derive region values. | bunnei | 1 | -0/+327 | |
2021-03-21 | hle: kernel: Migrate some code from Common::SpinLock to KSpinLock. | bunnei | 5 | -25/+25 | |
2021-03-21 | hle: kernel: Add initial KMemoryRegionType module. | bunnei | 3 | -18/+41 | |
2021-03-21 | hle: kernel: Move KMemoryRegion to its own module and update. | bunnei | 4 | -31/+322 | |
2021-03-21 | gl_device: Block async shaders on AMD and Intel | lat9nq | 1 | -1/+13 | |
Currently, the Windows versions of the Intel OpenGL driver and the AMD proprietary OpenGL driver do not properly support (or in fact degrade) when asynchronous shader compilation is enabled. This blocks specifically those drivers from using this feature. This affects AMDGPU-PRO on Linux, and AMD's and Intel's OpenGL drivers on Windows. | |||||
2021-03-20 | Fix cancelation of choose directory dialog | ivan-boikov | 1 | -1/+4 | |
2021-03-17 | IApplicationDisplayService: Stub GetIndirectLayerImageMap | Morph | 1 | -1/+27 | |
Used by games invoking the inline software keyboard such as GNOSIA | |||||
2021-03-16 | bsd: Avoid writing empty buffers | Morph | 1 | -2/+6 | |
Silences log spam on empty buffer writes | |||||
2021-03-14 | system_version: Update to 11.0.1 | Morph | 1 | -5/+5 | |
2021-03-14 | system_archive: Update NgWord archive version | Morph | 1 | -2/+2 | |
2021-03-13 | astc_decoder: Reimplement Layers | Rodrigo Locatti | 5 | -142/+161 | |
Reimplements the approach to decoding layers in the compute shader. Fixes multilayer astc decoding when using Vulkan. | |||||
2021-03-13 | astc_decoder: Fix out of bounds memory access | ameerj | 1 | -2/+10 | |
resolves a crash with some anamolous textures found in Astral Chain. | |||||
2021-03-13 | renderer_vulkan: Accelerate ASTC decoding | ameerj | 11 | -57/+426 | |
Co-Authored-By: Rodrigo Locatti <reinuseslisp@airmail.cc> | |||||
2021-03-13 | host_shaders: Modify shader cmake integration to allow for larger shaders | ameerj | 4 | -8/+27 | |
using a raw string to encapsulate the entire shader code limits us to shaders of size less than 2KB. This change overcomes this limitation. | |||||
2021-03-13 | renderer_opengl: Accelerate ASTC texture decoding with a compute shader | ameerj | 6 | -2/+1598 | |
ASTC texture decoding is currently handled by a CPU decoder for GPU's without native ASTC decoding support (most desktop GPUs). This is the cause for noticeable performance degradation in titles which use the format extensively. This commit adds support to accelerate ASTC decoding using a compute shader on OpenGL for GPUs without native support. | |||||
2021-03-13 | video_core: rasterizer_accelerated: Fix un/signed mismatch. | bunnei | 1 | -1/+2 | |
2021-03-11 | Fix casing on DeallocateAesKeySlot | zkitx | 1 | -3/+3 | |
2021-03-11 | Update SPL to fit N's service refactor (4.0.0+) which split into new services. | zkitx | 3 | -9/+178 | |
2021-03-10 | fiber: Double default stack size | MerryMage | 1 | -1/+1 | |
Stack overflow occurs with some guest applications | |||||
2021-03-10 | time: Fix CalculateSpanBetween implementation | Morph | 1 | -3/+9 | |
CalculateSpanBetween passes in the ClockSnapshots through 2 input buffers and not as raw arguments. Fix this by reading the 2 input buffers instead of popping raw arguments. Partially fixes Super Smash Bros. Ultimate's Spirit Board | |||||
2021-03-10 | time: Assign the current time point to the ClockSnapshot | Morph | 1 | -0/+2 | |
Fixes the timer in Super Smash Bros Ultimate's Spirit Board. | |||||
2021-03-07 | common: Fiber: use a reference for YieldTo. | bunnei | 5 | -34/+27 | |
- Fixes another small leak. | |||||
2021-03-07 | qt: Set DISPLAY env var when not present | Ani | 1 | -0/+9 | |
Fixes web browser opening (Help > Open Mods Page, Help > Open Quickstart Guide) | |||||
2021-03-06 | Enable mouse toggle buttons | german77 | 5 | -11/+65 | |
2021-03-06 | Add toggle button option for normal buttons | german | 1 | -0/+5 | |
2021-03-06 | common: fiber: Use weak_ptr when yielding. | bunnei | 2 | -8/+13 | |
- Avoids a memory leak, as taking a strong reference of the fiber here causes a circular reference. - Supersedes #6006 with a more narrow fix. | |||||
2021-03-06 | Enable button toggle for keyboard in the modifier button | german | 3 | -6/+44 | |
2021-03-06 | hle: kernel: KThread: Rework dummy threads & fix memory leak. | bunnei | 6 | -36/+65 | |
- Dummy threads are created on thread local storage for all host threads. - Fixes a leak by removing creation of fibers, which are not applicable here. | |||||
2021-03-06 | Revert "core: Switch to unique_ptr for usage of Common::Fiber." | bunnei | 10 | -58/+59 | |
2021-03-05 | aes_util: Remove malformed mbedtls_cipher_finish function call | Morph | 1 | -2/+0 | |
2021-03-05 | CMakeLists: Add /utf-8 compile option for MSVC | Morph | 1 | -0/+2 | |
Ensures that the source and execution character sets are in UTF-8 | |||||
2021-03-04 | texture_cache: Blacklist BGRA8 copies and views on OpenGL | ameerj | 9 | -28/+80 | |
In order to force the BGRA8 conversion on Nvidia using OpenGL, we need to forbid texture copies and views with other formats. This commit also adds a boolean relating to this, as this needs to be done only for the OpenGL api, Vulkan must remain unchanged. | |||||
2021-03-04 | renderer_opengl: Swizzle BGR textures on copy | ameerj | 5 | -2/+132 | |
OpenGL does not natively support BGR internal formats, which causes many BGR textures to render incorrectly, with Red and Blue channels swapped. This commit aims to address this by swizzling the blue and red channels on texture copies when a BGR format is encountered. | |||||
2021-03-03 | video_core: rasterizer_accelerated: Fix delta check ordering. | bunnei | 1 | -3/+3 | |
2021-03-03 | video_core: rasterizer_accelerated: Improve error handling & fix implicit conversion. | bunnei | 1 | -4/+8 | |
2021-03-03 | video_core: rasterizer_accelerated: Use a flat array instead of interval_map for cached pages. | bunnei | 2 | -44/+32 | |
- Uses a fixed 64MB for the cache instead of an ever growing map. - Slightly faster by using atomics instead of a single mutex for access. - Thanks for Rodrigo for the idea. | |||||
2021-03-02 | buffer_cache: Heuristically decide to skip cache on uniform buffers | ReinUsesLisp | 2 | -11/+37 | |
Some games benefit from skipping caches (Pokémon Sword), and others don't (Animal Crossing: New Horizons). Add an heuristic to decide this at runtime. The cache hit ratio has to be ~98% or better to not skip the cache. There are 16 frames of buffer. | |||||
2021-03-02 | core: Shutdown: Move kernel cleanup to later in shutdown. | bunnei | 1 | -12/+1 | |
- Fixes a shutdown crash due to a race condition with GPU still accessing memory. | |||||
2021-03-02 | Fix default bcat_backend init | Kelebek1 | 2 | -3/+3 | |
2021-03-01 | inputCommon: Use an unique client id for each socket instance | german | 4 | -19/+23 | |
2021-03-01 | gpu_thread: Remove Async NVDEC placeholders | ameerj | 3 | -26/+8 | |
This commit removes early placeholders for an implementation of async nvdec. With recent changes to the source code, the placeholders are no longer accurate, and can cause a nullptr dereference due to the nature of the cdma_pusher lifetime. | |||||
2021-02-28 | [network] Error handling reform | comex | 6 | -111/+147 | |
`network.cpp` has several error paths which either: - report "Unhandled host socket error=n" and return `SUCCESS`, or - switch on a few possible errors, log them, and translate them to Errno; the same switch statement is copied and pasted in multiple places in the code Convert these paths to use a helper function `GetAndLogLastError`, which is roughly the equivalent of one of the switch statements, but: - handling more cases (both ones that were already in `Errno`, and a few more I added), and - using OS functions to convert the error to a string when logging, so it'll describe the error even if it's not one of the ones in the switch statement. - To handle this, refactor the logic in `GetLastErrorMsg` to expose a new function `NativeErrorToString` which takes the error number explicitly as an argument. And improve the Windows version a bit. Also, add a test which exercises two random error paths. | |||||
2021-02-28 | Implements touch, pan, pinch and rotation gestures | german | 2 | -11/+240 | |
2021-02-28 | inputCommon: Mouse fixes | german77 | 9 | -25/+89 | |
2021-02-27 | core: hle: ldn: Error out on call to Initialization. | bunnei | 1 | -1/+1 | |
- Since we do not emulate LDN, returning an error here makes more sense. | |||||
2021-02-27 | core: Switch to unique_ptr for usage of Common::Fiber. | bunnei | 10 | -59/+58 | |
- With using unique_ptr instead of shared_ptr, we have more explicit ownership of the context. - Fixes a memory leak due to circular reference of the shared pointer. | |||||
2021-02-24 | Implement glDepthRangeIndexeddNV | Kelebek1 | 3 | -1/+12 | |
2021-02-23 | vk_command_pool: Reduce the command pool size from 4096 to 4 | ReinUsesLisp | 1 | -1/+1 | |
This allows drivers to reuse memory more easily and preallocate less. The optimal number has been measured booting Pokémon Sword. | |||||
2021-02-23 | video_core: add missing header after 468bd9c1b0f9 | Jan Beich | 1 | -0/+1 | |
src/video_core/shader_notify.cpp: In member function 'void VideoCore::ShaderNotify::MarkShaderComplete()': src/video_core/shader_notify.cpp:33:10: error: 'unique_lock' is not a member of 'std' 33 | std::unique_lock lock{mutex}; | ^~~~~~~~~~~ src/video_core/shader_notify.cpp:6:1: note: 'std::unique_lock' is defined in header '<mutex>'; did you forget to '#include <mutex>'? 5 | #include "video_core/shader_notify.h" +++ |+#include <mutex> 6 | src/video_core/shader_notify.cpp: In member function 'void VideoCore::ShaderNotify::MarkSharderBuilding()': src/video_core/shader_notify.cpp:38:10: error: 'unique_lock' is not a member of 'std' 38 | std::unique_lock lock{mutex}; | ^~~~~~~~~~~ src/video_core/shader_notify.cpp:38:10: note: 'std::unique_lock' is defined in header '<mutex>'; did you forget to '#include <mutex>'? | |||||
2021-02-23 | common: add missing header after f3805376f726 | Jan Beich | 1 | -0/+1 | |
In file included from src/video_core/dma_pusher.cpp:5: src/./common/cityhash.h:69:47: error: 'size_t' has not been declared 69 | [[nodiscard]] u64 CityHash64(const char* buf, size_t len); | ^~~~~~ src/./common/cityhash.h:73:55: error: 'size_t' has not been declared 73 | [[nodiscard]] u64 CityHash64WithSeed(const char* buf, size_t len, u64 seed); | ^~~~~~ src/./common/cityhash.h:77:56: error: 'size_t' has not been declared 77 | [[nodiscard]] u64 CityHash64WithSeeds(const char* buf, size_t len, u64 seed0, u64 seed1); | ^~~~~~ src/./common/cityhash.h:80:47: error: 'size_t' has not been declared 80 | [[nodiscard]] u128 CityHash128(const char* s, size_t len); | ^~~~~~ src/./common/cityhash.h:84:55: error: 'size_t' has not been declared 84 | [[nodiscard]] u128 CityHash128WithSeed(const char* s, size_t len, u128 seed); | ^~~~~~ | |||||
2021-02-21 | hid: Implement GameCube Controller Vibrations | Morph | 2 | -3/+130 | |
Implements both SendVibrationGcErmCommand and GetActualVibrationGcErmCommand, and modifies GetVibrationDeviceInfo to account for additional controllers. | |||||
2021-02-21 | acc: Stub GetNintendoAccountUserResourceCacheForApplication | Morph | 1 | -1/+17 | |
This command returns a Nintendo Account ID and writes 2 output buffers. The first output buffer is a NasUserBaseForApplication and the second output buffer is currently empty. Used by: - Pokken Tournament DX - Super Smash Bros. Ultimate - Super Nintendo Entertainment System - Nintendo Switch Online - Mario Kart 8 Deluxe | |||||
2021-02-21 | kernel: Fix resource release exception on exit | ameerj | 4 | -2/+16 | |
After rewriting the resource limit, objects releasing reserved resources require a live kernel instance. This commit fixes exceptions that occur due to the kernel being destroyed before some objects released their resources, allowing for a graceful exit. | |||||
2021-02-20 | gl_disk_shader_cache: Log total shader entries count on game load | Morph | 1 | -0/+4 | |
2021-02-20 | common: wall_clock: Fix integer overflow with StandardWallClock. | bunnei | 2 | -7/+28 | |
- Previous optimized impl. resulted in an integer overflow, so revert. - This is our slow/fallback path that should never be really be used, so the optimization in unimportant. | |||||
2021-02-19 | hle: kernel: Migrate PageHeap/PageTable to KPageHeap/KPageTable. | bunnei | 24 | -147/+131 | |
2021-02-19 | hle: kernel: Migrate MemoryManager to KMemoryManager. | bunnei | 8 | -47/+48 | |
2021-02-19 | hle: kernel: Migrate PageLinkedList to KPageLinkedList. | bunnei | 8 | -38/+41 | |
2021-02-19 | hle: kernel: Migrate to KMemoryBlock, KMemoryBlockManager, and others. | bunnei | 18 | -476/+479 | |
2021-02-19 | hle: kernel: Migrate SlabHeap to KSlabHeap. | bunnei | 4 | -22/+21 | |
2021-02-19 | hle: kernel: Migrate MemoryLayout to KMemoryLayout. | bunnei | 5 | -31/+30 | |
2021-02-19 | hle: kernel: Migrate AddressSpaceInfo to KAddressSpaceInfo. | bunnei | 4 | -59/+54 | |
2021-02-19 | hle: kernel: memory_manager: Rename AllocateContinuous to AllocateContinuous. | bunnei | 2 | -4/+28 | |
2021-02-19 | hle: kernel: KSystemControl does not belong in Memory namespace. | bunnei | 7 | -31/+38 | |
2021-02-19 | hle: kernel: memory: PageHeap: Migrate to KPageBitmap class. | bunnei | 4 | -197/+23 | |
2021-02-19 | hle: kernel: Add KPageBitmap class. | bunnei | 2 | -0/+280 | |
2021-02-19 | hle: kernel: system_control: Add function GenerateRandomU64. | bunnei | 2 | -3/+5 | |
2021-02-19 | common: Add implementation of TinyMT (Mersenne Twister RNG). | bunnei | 2 | -0/+251 | |
2021-02-19 | hle: kernel: Add KSpinLock implementation. | bunnei | 3 | -0/+89 | |
2021-02-19 | core: memory: Add templated GetPointer methods. | bunnei | 1 | -0/+10 | |
2021-02-19 | common: alignment: Add DivideUp utility method. | bunnei | 1 | -0/+5 | |
2021-02-19 | hle: kernel: Rename SharedMemory to KSharedMemory. | bunnei | 13 | -54/+54 | |
2021-02-18 | Revert "Port citra-emu/citra#5123: "SDL: Disable hidapi drivers due to compatibility problems with certain controllers"" | Morph | 1 | -7/+0 | |
2021-02-18 | common/cityhash: Use common types | ReinUsesLisp | 3 | -116/+100 | |
Allow sharing return types with the rest of the code base. For example, we use 'u128 = std::array<u64, 2>', meanwhile Google's code uses 'uint128 = std::pair<u64, u64>'. While we are at it, use size_t instead of std::size_t. | |||||
2021-02-18 | tests: Add tests for CityHash | ReinUsesLisp | 2 | -0/+23 | |
2021-02-16 | vk_rasterizer: Fix loading shader addresses twice | ReinUsesLisp | 1 | -1/+0 | |
This was recently introduced on a wrongly rebased commit. | |||||
2021-02-15 | core: core_timing_util: Optimize core timing math. | bunnei | 3 | -98/+48 | |
- Avoids a lot of unnecessary 128-bit math for imperceptible accuracy. | |||||
2021-02-15 | common: wall_clock: Optimize GetClockCycles/GetCPUCycles to use a single MUL instruction. | bunnei | 1 | -8/+9 | |
2021-02-15 | common: Merge uint128 to a single header file with inlines. | bunnei | 4 | -135/+84 | |
2021-02-15 | core/CMakeLists: Add web_types.h | Morph | 1 | -0/+1 | |
2021-02-15 | Review 1 | Kelebek1 | 2 | -3/+3 | |
2021-02-15 | Implement texture offset support for TexelFetch and TextureGather and add offsets for Tlds | Kelebek1 | 3 | -9/+34 | |
Formatting | |||||
2021-02-14 | debugger: controller: Add access key | lat9nq | 1 | -1/+1 | |
Adds the access key to the Controller P1 selection at View -> Debugger -> Controller P1. Avoids using the windowTitle as that would add a literal & to the beginning of the window title. | |||||
2021-02-14 | yuzu: Various frontend improvements to avoid crashes and improve experience on Linux. | bunnei | 10 | -10/+52 | |
2021-02-14 | hle: service: ldn: IUserLocalCommunicationService: Improve the stub. | bunnei | 1 | -5/+29 | |
2021-02-14 | Improve mouse panning | german | 1 | -5/+21 | |
2021-02-14 | hle: service: ldn: IUserLocalCommunicationService: Indicate that LDN is disabled. | bunnei | 3 | -3/+19 | |
- Fixes crash on Pokemon Sword/Shield when pressing 'Y'. | |||||
2021-02-14 | hle: service: am: IStorageAccessor: Fix out of bounds error handling. | bunnei | 1 | -6/+7 | |
2021-02-13 | vk_resource_pool: Load GPU tick once and compare with it | ReinUsesLisp | 2 | -8/+8 | |
Other minor style improvements. Rename free_iterator to hint_iterator, to describe better what it does. | |||||
2021-02-13 | vk_update_descriptor: Inline and improve code for binding buffers | ReinUsesLisp | 4 | -24/+24 | |
Allow compilers with our settings inline hot code. | |||||
2021-02-13 | fixed_pipeline_cache: Use dirty flags to lazily update key | ReinUsesLisp | 7 | -56/+103 | |
Use dirty flags to avoid building pipeline key from scratch on each draw call. This saves a bit of unnecesary work on each draw call. | |||||
2021-02-13 | gl_texture_cache: Lazily create non-sRGB texture views for sRGB formats | ameerj | 3 | -7/+41 | |
This creates non-sRGB texture views for sRGB texture formats to allow for interfacing with these views in compute shaders using imageLoad and imageStore. Co-Authored-By: Rodrigo Locatti <reinuseslisp@airmail.cc> | |||||
2021-02-13 | rebase, fix name shadowing, more const | ameerj | 4 | -11/+10 | |
2021-02-13 | Address PR feedback | ameerj | 4 | -12/+7 | |
Co-Authored-By: LC <712067+lioncash@users.noreply.github.com> | |||||
2021-02-13 | streamline cdma_pusher/command_classes | ameerj | 1 | -13/+5 | |
2021-02-13 | streamline cdma_pusher/command_classes | ameerj | 5 | -85/+34 | |
2021-02-13 | nvdec cleanup | ameerj | 8 | -43/+38 | |
2021-02-13 | vk_master_semaphore: Mark gpu_tick atomic operations with relaxed order | ReinUsesLisp | 1 | -4/+4 | |
2021-02-13 | vk_staging_buffer_pool: Inline tick tests | ReinUsesLisp | 2 | -1/+7 | |
Load the current tick to a local variable, moving it out of an atomic and allowing us to compare the value without going through a pointer each time. This should make the loop more optimizable. | |||||
2021-02-13 | gl_stream_buffer/vk_staging_buffer_pool: Fix size check | ReinUsesLisp | 2 | -2/+2 | |
Fix a tragic off-by-one condition that causes Vulkan's stream buffer to think it's always full, using fallback memory. The OpenGL was also affected by this bug to a lesser extent. | |||||
2021-02-13 | vulkan_device: Require VK_EXT_robustness2 | ReinUsesLisp | 2 | -37/+14 | |
We are already using robustness2 features without requiring it explicitly, causing potential crashes on drivers without the extension. Requiring this at boot allows better diagnostics for it and formalizes our usage on the extension. | |||||
2021-02-13 | config: Make high GPU accuracy the default | ReinUsesLisp | 2 | -3/+3 | |
This is a better default for most games, yielding better performance and less graphical issues. | |||||
2021-02-13 | video_core: Fix clang build issues | ReinUsesLisp | 2 | -8/+5 | |
2021-02-13 | vk_staging_buffer_pool: Fix softlock when stream buffer overflows | ReinUsesLisp | 2 | -19/+20 | |
There was still a code path that could wait on a timeline semaphore tick that would never be signalled. While we are at it, make use of more STL algorithms. | |||||
2021-02-13 | vk_buffer_cache: Add support for null index buffers | ReinUsesLisp | 2 | -4/+40 | |
Games can bind a null index buffer (size=0) where all indices are evaluated as zero. VK_EXT_robustness2 doesn't support this and all drivers segfault when a null index buffer is passed to vkCmdBindIndexBuffer. Workaround this by creating a 4 byte buffer and filling it with zeroes. If it's read out of bounds, robustness takes care of returning zeroes as indices. | |||||
2021-02-13 | buffer_cache: Add extra bytes to guest SSBOs | ReinUsesLisp | 1 | -1/+7 | |
Bind extra bytes beyond the guest API's bound range. This is due to some games like Astral Chain operating out of bounds. Binding the whole map range would be technically correct, but games have large maps that make this approach unaffordable for now. | |||||
2021-02-13 | Merge branch 'bytes-to-map-end' into new-bufcache-wip | ReinUsesLisp | 1 | -0/+2 | |
2021-02-13 | vk_staging_buffer_pool: Get a staging buffer instead of waiting | ReinUsesLisp | 2 | -9/+18 | |
Avoids waiting idle while the GPU finishes to do work, and fixes an issue where we'd wait forever if a single command buffer (logic tick) all the data. | |||||
2021-02-13 | yuzu/config: Disable assembly shaders by default | ReinUsesLisp | 1 | -2/+2 | |
Due to BindBufferRangeNV limitations and poor quality code emission from our side, assembly shaders are currently slower than GLSL. Their build time and feature advantages are still relevant, but they are outweighted by their runtime performance. | |||||
2021-02-13 | renderer_opengl: Remove interop | ReinUsesLisp | 8 | -122/+10 | |
Remove unused interop code from the OpenGL backend. | |||||
2021-02-13 | gl_buffer_cache: Drop interop based parameter buffer workarounds | ReinUsesLisp | 3 | -65/+45 | |
Sacrify runtime performance to avoid generating kernel exceptions on Windows due to our abusive aliasing of interop buffer objects. | |||||
2021-02-13 | buffer_cache: Heuristically detect stream buffers | ReinUsesLisp | 2 | -6/+33 | |
Detect when a memory region has been joined several times and increase the size of the created buffer on those instances. The buffer is assumed to be a "stream buffer", increasing its size should stop us from constantly recreating it and fragmenting memory. | |||||
2021-02-13 | buffer_cache: Split CreateBuffer in separate functions | ReinUsesLisp | 1 | -29/+52 | |
Allow adding functionality to each function without making CreateBuffer more complex. | |||||
2021-02-13 | buffer_cache: Skip cache on small uploads on Vulkan | ReinUsesLisp | 3 | -9/+18 | |
Ports from OpenGL the optimization to skip small 3D uniform buffer uploads. This will take advantage of the previously introduced stream buffer. Fixes instances where the staging buffer offset was being ignored. | |||||
2021-02-13 | vk_staging_buffer_pool: Add stream buffer for small uploads | ReinUsesLisp | 15 | -127/+298 | |
This uses a ring buffer similar to OpenGL's stream buffer for small uploads. This stops us from allocating several small buffers, reducing memory fragmentation and cache locality. It uses dedicated allocations when possible. | |||||
2021-02-13 | vulkan_device: Enable robustBufferAccess | ReinUsesLisp | 1 | -1/+2 | |
Fix regression on Pascal on Animal Crossing: New Horizons, fixing a validation error. | |||||
2021-02-13 | video_core: Reimplement the buffer cache | ReinUsesLisp | 67 | -2607/+2514 | |
Reimplement the buffer cache using cached bindings and page level granularity for modification tracking. This also drops the usage of shared pointers and virtual functions from the cache. - Bindings are cached, allowing to skip work when the game changes few bits between draws. - OpenGL Assembly shaders no longer copy when a region has been modified from the GPU to emulate constant buffers, instead GL_EXT_memory_object is used to alias sub-buffers within the same allocation. - OpenGL Assembly shaders stream constant buffer data using glProgramBufferParametersIuivNV, from NV_parameter_buffer_object. In theory this should save one hash table resolve inside the driver compared to glBufferSubData. - A new OpenGL stream buffer is implemented based on fences for drivers that are not Nvidia's proprietary, due to their low performance on partial glBufferSubData calls synchronized with 3D rendering (that some games use a lot). - Most optimizations are shared between APIs now, allowing Vulkan to cache more bindings than before, skipping unnecesarry work. This commit adds the necessary infrastructure to use Vulkan object from OpenGL. Overall, it improves performance and fixes some bugs present on the old cache. There are still some edge cases hit by some games that harm performance on some vendors, this are planned to be fixed in later commits. | |||||
2021-02-13 | vulkan_common: Expose interop and headless devices | ReinUsesLisp | 4 | -21/+100 | |
2021-02-13 | vulkan_common: Make interop extensions mandatory | ReinUsesLisp | 1 | -0/+6 | |
2021-02-13 | vulkan_device: Enable robust buffers | ReinUsesLisp | 1 | -2/+4 | |
2021-02-13 | vulkan_device: Use designated initializers for features | ReinUsesLisp | 1 | -60/+59 | |
2021-02-13 | vulkan_wrapper: Add memory barrier pipeline barrier helper | ReinUsesLisp | 1 | -0/+6 | |
2021-02-13 | vulkan_device: Fix formatting of constants | ReinUsesLisp | 1 | -10/+6 | |
2021-02-13 | vulkan_wrapper: Add interop functions | ReinUsesLisp | 2 | -1/+41 | |
2021-02-13 | vulkan_instance: Initialize Vulkan instance in a separate thread | ReinUsesLisp | 1 | -1/+5 | |
Workaround an issue on Nvidia where creating a Vulkan instance from an active OpenGL thread disables threaded optimization on the driver. This optimization is important to have good performance on Nvidia OpenGL. | |||||
2021-02-13 | vulkan_wrapper: Pull Windows symbols | ReinUsesLisp | 2 | -0/+14 | |
2021-02-13 | gpu: Report renderer errors with exceptions | ReinUsesLisp | 27 | -232/+176 | |
Instead of using a two step initialization to report errors, initialize the GPU renderer and rasterizer on the constructor and report errors through std::runtime_error. | |||||
2021-02-13 | tests/buffer_base: Add cached CPU writes tests | ReinUsesLisp | 1 | -0/+76 | |
Ensure the behavior of the previous commit in tests. | |||||
2021-02-13 | buffer_base: Add support for cached CPU writes | ReinUsesLisp | 1 | -61/+145 | |
Some games usually write memory pages currently used by the GPU, causing rendering issues (e.g. flashing geometry and shadows on Link's Awakening). To workaround this issue, Guest CPU writes are delayed until the command buffer finishes processing, but the pages are updated immediately. The overall behavior is: - CPU writes are cached until they are flushed, they update the page state, but don't change the modification state. Cached writes stop pages from being flushed, in case games have meaningful data in it. - Command processing writes (e.g. push constants) update the page state and are marked to the command processor as dirty. They don't remove the state of cached writes. | |||||
2021-02-13 | maxwell_to_gl: Remove unused code | ameerj | 2 | -36/+3 | |
Removes unused declarations in maxwell_to_gl.h | |||||
2021-02-13 | revert to std::sin and std::cos | Chloe Marcec | 3 | -6/+6 | |
2021-02-13 | address issues | Chloe Marcec | 3 | -22/+25 | |
2021-02-13 | audren: Implement I3dl2Reverb | Chloe Marcec | 8 | -18/+569 | |
Most notable fix is the voices in Fire Emblem Three Houses | |||||
2021-02-13 | kernel: More accurately reserve and release resources | ameerj | 6 | -14/+42 | |
2021-02-13 | kernel: KScopedReservation implementation | ameerj | 6 | -26/+152 | |
This implements KScopedReservation, allowing resource limit reservations to be more HW accurate, and release upon failure without requiring too many conditionals. | |||||
2021-02-13 | kernel: Unify result codes (#5890) | Chloe | 21 | -256/+223 | |
* kernel: Unify result codes Drop the usage of ERR_NAME convention in kernel for ResultName. Removed seperation between svc_results.h & errors.h as we mainly include both most of the time anyways. * oops * rename errors to svc_results | |||||
2021-02-12 | yuzu: Create screenshot path before capture | lat9nq | 1 | -0/+5 | |
Allows screenshots in cases where the screenshots path doesn't already exist. | |||||
2021-02-11 | software_keyboard: Implement Finalize request command | Morph | 1 | -0/+4 | |
2021-02-10 | configure_input_player_widget: Silence unused variable warnings | lat9nq | 1 | -7/+0 | |
Prevents clang 11 from throwing an error since these variables are unused. | |||||
2021-02-10 | common: Add -fsized-deallocation as a Clang flag | lat9nq | 1 | -0/+2 | |
Prevents an operator delete error when compiling with Clang 11. | |||||
2021-02-10 | core: Add -fsized-dealloction as a Clang flag | lat9nq | 1 | -0/+2 | |
Prevents a operator delete error when compiling with Clang 11. | |||||
2021-02-09 | bsd: Remove usage of optional emplace() with no arguments | Lioncash | 1 | -2/+4 | |
Clang 12 currently falls over in the face of this. | |||||
2021-02-09 | am/controller: Remove [[fallthrough]] from unreachable path | Lioncash | 1 | -1/+2 | |
Prevents warnings on clang 12. This path is reachable on other variations of the build that disable the unreachable macro. | |||||
2021-02-09 | nfp: Correct uninitialized size being used within GetTagInfo() | Lioncash | 1 | -1/+1 | |
We were previously the name of the object being initialized within its own initializer, which results in uninitialized data being read. | |||||
2021-02-09 | udp: Silence unused member variable warnings | Lioncash | 1 | -2/+2 | |
Simply mark them as unused for now. | |||||
2021-02-09 | udp/client: Define ClientData constructor/destructor in cpp file | Lioncash | 2 | -0/+7 | |
Prevents compilation errors on clang 12 due to incomplete types within a unique_ptr member. | |||||
2021-02-09 | gl_rasterizer: Remove unused variables | Lioncash | 1 | -3/+0 | |
Resolves warnings on clang 12 | |||||
2021-02-09 | texture_cache/util: Remove unused functions | Lioncash | 1 | -34/+0 | |
Silences a few warnings on clang 12. | |||||
2021-02-09 | configure_input_player_widget: Reduce duplication of array accessors where applicable | Lioncash | 1 | -108/+125 | |
Reduces the amount of code to read in expressions a little bit by separating constituents out a little. | |||||
2021-02-09 | configure_input_player_widget: Avoid nontrivial copies where applicable | Lioncash | 2 | -5/+6 | |
Previously a function was copying an array of 20 std::string instances by value. | |||||
2021-02-09 | Use GC image | german | 1 | -0/+3 | |
2021-02-09 | Settings: Add depth to Joysticks on Pro Controller preview (#5894) | Jatoxo | 2 | -6/+30 | |
* Add some depth to ProJoysticks * address comments * clang * address nits * fix wrong inner_offset when offset.x was 0 | |||||
2021-02-08 | string_util: Remove MSVC workaround for converting between UTF8/UTF16 | Morph | 1 | -14/+0 | |
This has been fixed as of Visual Studio 2019 Version 16.2 | |||||
2021-02-08 | hid: Implement GC controller | german | 7 | -6/+206 | |
2021-02-08 | olsc: Stub GetSaveDataBackupSetting | german | 1 | -1/+12 | |
2021-02-08 | Add mouse panning | german | 11 | -38/+149 | |
2021-02-08 | video_core: Delete morton | Chloe Marcec | 3 | -2/+0 | |
moron.h & morton.cpp are not used anywhere and are just empty files | |||||
2021-02-07 | renderer_opengl: Update OpenGL backend version requirement to 4.6 | Morph | 3 | -42/+17 | |
2021-02-07 | lm: Fix ReadLeb128 | Chloe Marcec | 1 | -7/+9 | |
Fixes assertion on Bloodstained Ritual of the Night. We would over read sometimes, this is fixed by checking if the top bit is set in the first iteration. We also lock the loop off to be only the max size of the type we can fit. Finally we changed an incorrect print of "DEBUG" to "TRACE" to reflect the proper log severity | |||||
2021-02-07 | Add GC controller animation | german | 2 | -52/+429 | |
2021-02-06 | ring_buffer: Remove granularity template argument | MerryMage | 2 | -16/+15 | |
Non-obvious bug in RingBuffer::Push(std::vector<T>&) when granularity != 1 Just remove it altogether because we do not have a use for granularity != 1 | |||||
2021-02-06 | pl_u: Fix read out of bounds | Alessandro Astone | 1 | -2/+7 | |
2021-02-06 | Refresh debug controller settings | german | 4 | -10/+18 | |
2021-02-06 | Refresh controller only when necessary | german | 2 | -15/+37 | |
2021-02-06 | Add SL SR vectors, change dual joycon view, add missing raw data from keyboard/mouse | german | 4 | -178/+247 | |
2021-02-06 | Add controller window and single joycon top view | german | 7 | -29/+391 | |
2021-02-06 | Replace text with vectors | german | 2 | -77/+306 | |
2021-02-06 | Make settings controller image change with controller input | german | 9 | -75/+2076 | |
2021-02-06 | k_address_arbiter: Unfold R_UNLESS macros | Lioncash | 1 | -5/+8 | |
Allows for more descriptive error messages and also doesn't hide control-path exit returns from the reader. | |||||
2021-02-06 | k_address_arbiter: Remove unnecessary usages of std::addressof | Lioncash | 1 | -10/+10 | |
This is a useful function in a generic context or with types that overload unary operator&. However, primitives and pointers will never do this, so we can opt for a more straightforward syntax. | |||||
2021-02-06 | k_address_arbiter: Remove dead code | Lioncash | 1 | -40/+13 | |
This code is never used, so we can remove it. It's in version control, so it can always be brought back when needed. | |||||
2021-02-06 | svc: Provide more detailed error logs for svc functions | Lioncash | 1 | -59/+188 | |
Allows SVC calls to have much more informative information during error cases. This also doesn't hide control flow returns from the reader. | |||||
2021-02-05 | hle: kernel: Drop R_UNLESS_NOLOG in favor of expanded if-statement. | bunnei | 3 | -11/+11 | |
2021-02-05 | hle: kernel: KAddressArbiter: Remove noisy error log. | bunnei | 1 | -1/+1 | |
2021-02-05 | hle: kernel: svc: Cleanup KEvent/KReadableEvent/KWritableEvent SVCs. | bunnei | 5 | -69/+89 | |
2021-02-05 | common: scope_exit: Add a cancellable ScopeExit macro. | bunnei | 1 | -0/+6 | |
2021-02-05 | hle: kernel: Reimplement KReadableEvent and KWritableEvent. | bunnei | 38 | -298/+341 | |
2021-02-05 | hle: kernel: Implement KEvent. | bunnei | 3 | -0/+91 | |
2021-02-05 | hle: kernel: KAddressArbiter: Use R_UNLESS_NOLOG where applicable. | bunnei | 1 | -1/+1 | |
2021-02-05 | common: common_funcs: Add R_UNLESS_NOLOG for scenarios that should not log. | bunnei | 1 | -0/+8 | |
2021-02-05 | hle: kernel: Rename WritableEvent to KWritableEvent. | bunnei | 44 | -101/+101 | |
2021-02-05 | hle: kernel: Rename ReadableEvent to KReadableEvent. | bunnei | 42 | -81/+82 | |
2021-02-05 | Address reviewer comments | lat9nq | 1 | -1/+1 | |
2021-02-05 | CMake: Port citra-emu/citra FindFFmpeg.cmake | lat9nq | 1 | -2/+2 | |
Also renames related CMake variables to match both the Find*FFmpeg* and variables defined within the file. Fixes odd errors produced by the old FindFFmpeg. Citra's FindFFmpeg is slightly modified here: adds Citra's copyright at the beginning, renames FFmpeg_INCLUDES to FFmpeg_INCLUDE_DIR, disables a few components in _FFmpeg_ALL_COMPONENTS, and adds the missing avutil component to the comment above. | |||||
2021-02-05 | CMake: Implement YUZU_USE_BUNDLED_FFMPEG | lat9nq | 2 | -7/+6 | |
For Linux, instructs CMake to use the FFmpeg submodule in externals. This is HEAVILY based on our usage of the late Unicorn. Minimal change to MSVC as it uses the yuzu-emu/ext-windows-bin. MinGW now targets the same ext-windows-bin libraries as MSVC for FFmpeg. Adds FFMPEG_LIBRARIES to WIN32 and simplifies video_core/CMakeLists.txt a bit. | |||||
2021-02-04 | k_affinity_mask: Avoid implicit truncation to bool | Lioncash | 1 | -1/+1 | |
This can cause compiler warnings. Instead, we can explicitly add a boolean expression around it to naturally turn the result into a bool. | |||||
2021-02-04 | k_priority_queue: Unfold several declval usages | Lioncash | 1 | -5/+5 | |
Given these are only used as function existence checks, we can simplify some usages of declval, given they aren't particularly useful here. Reduces a few template instantiations, which at most reduces compile times a tiny bit. | |||||
2021-02-04 | k_priority_queue: Simplify affinity mask type alias | Lioncash | 1 | -2/+2 | |
We can make use of the _t variants of the templates to cut down on a little bit of verbosity. | |||||
2021-02-04 | k_priority_queue: Resolved reserved identifier | Lioncash | 1 | -2/+2 | |
An identifier containing a starting underscore followed by a capital letter is reserved by the standard. It's trivial to avoid this by moving the underscore to the end of the identifier. While the likelihood of clashing here being minimal, we can turn a "should not break" scenario into a definitive "will not break" one, so why not?. | |||||
2021-02-04 | key_manager: Create the keys directory if it does not exist | Morph | 1 | -0/+5 | |
2021-02-04 | Add footer types and address comments | german | 7 | -58/+106 | |
2021-02-04 | Fix npad struct to match switchbrew | german | 4 | -106/+135 | |
2021-02-04 | Adds missing controller types and properties | german | 9 | -30/+191 | |
2021-02-04 | Always update handheld config | german | 1 | -4/+2 | |
2021-02-03 | Simplify limitableresource names | Chloe Marcec | 6 | -36/+29 | |
2021-02-02 | Prevent over scheduling audio events and terminate properly the motion update event | german | 2 | -1/+9 | |
2021-02-02 | IApplicationFunctions: Implement GetHealthWarningDisappearedSystemEvent | Morph | 2 | -1/+14 | |
2021-02-02 | settings: Log the cache, config, and mod load directories | Morph | 1 | -0/+3 | |
2021-02-02 | video_core: host_shaders: Don't pass --quiet to glslangValidator if unavailable | lat9nq | 1 | -1/+19 | |
Prevents CMake from calling `glslangValidator` with `--quiet` when it is not available, i.e. on older downstream versions from Ubuntu. | |||||
2021-02-02 | Compile error | Chloe Marcec | 1 | -1/+1 | |
2021-02-02 | Address issues | Chloe Marcec | 3 | -19/+15 | |
2021-02-01 | arm_dynarmic_32: Print out CPSR.T on exception | MerryMage | 2 | -2/+7 | |
2021-02-01 | audren: Disable reverb for the time being | Chloe Marcec | 1 | -1/+4 | |
As this is causing issues in a few games, it's best to have it disabled until it's completely implemented | |||||
2021-02-01 | Only update motion for npad and prevent over scheduling events | german | 1 | -2/+11 | |
2021-01-31 | nifm: Stub GetCurrentIpConfigInfo | Morph | 1 | -1/+29 | |
- Used by Lets Sing 12 | |||||
2021-01-31 | prepo: Stub GetTransmissionStatus | Morph | 1 | -1/+11 | |
2021-01-31 | prepo: Stub RequestImmediateTransmission | Morph | 1 | -1/+8 | |
- Used by Animal Crossing: New Horizons | |||||
2021-01-31 | nifm: Stub GetCurrentNetworkProfile | Morph | 1 | -1/+41 | |
- Used by Minecraft Bedrock Edition - Used by Bloons TD 5 | |||||
2021-01-31 | nifm: Add several structs | Morph | 1 | -0/+87 | |
2021-01-31 | am/IApplicationFunctions: Stub IsGamePlayRecordingSupported | Morph | 2 | -1/+12 | |
Used by RetroArch | |||||
2021-01-31 | bsd: Fix EventFd stub | Morph | 1 | -3/+3 | |
2021-01-31 | nifm: Fix GetAppletInfo stub | Morph | 1 | -1/+5 | |
2021-01-31 | bsd: Fix GetSockOpt stub | Morph | 1 | -1/+5 | |
2021-01-31 | bsd: Stub EventFd | ameerj | 2 | -1/+12 | |
Used by Family Feud | |||||
2021-01-31 | am: Stub TryPopFromFriendInvitationStorageChannel | ameerj | 2 | -1/+10 | |
Used by Family Feud | |||||
2021-01-30 | fix compile error | Chloe Marcec | 1 | -1/+1 | |
2021-01-30 | cleanup commenting | Chloe Marcec | 1 | -2/+2 | |
2021-01-30 | Drop m_ from lock | Chloe Marcec | 2 | -9/+9 | |
2021-01-30 | Move to GetGlobalTimeNs, fix GetTotalPhysicalMemoryAvailable | Chloe Marcec | 3 | -9/+7 | |
2021-01-30 | kernel: Rewrite resource limit to be more accurate | Chloe Marcec | 13 | -231/+357 | |
Matches closer to hardware | |||||
2021-01-30 | Stub GetSystemSessionId | german | 1 | -1/+10 | |
2021-01-30 | analog_from_button: Fix update_thread.join exception | ameerj | 1 | -5/+9 | |
This commit aims to address an exception that occurs when trying to join the Analog object's update_thread. By using an atomic bool for the status of the update thread, we ensure its value is consistent across the threads accessing it. | |||||
2021-01-29 | hle: kernel: KLightLock: Fix several bugs. | bunnei | 1 | -3/+3 | |
2021-01-29 | common: common_funcs: Change R_UNLESS to LOG_ERROR. | bunnei | 1 | -1/+1 | |
2021-01-29 | arm: dynarmic: Reintroduce JIT checks on SaveContext/LoadContext. | bunnei | 2 | -0/+12 | |
2021-01-29 | hle: kernel: KThread: Release thread resource on thread exit. | bunnei | 1 | -0/+1 | |
2021-01-29 | yuzu: debugger: Ignore HLE threads. | bunnei | 3 | -9/+21 | |
2021-01-29 | hle: kernel: process: Add state lock. | bunnei | 3 | -6/+15 | |
2021-01-29 | hle: kernel: threading: Fix bug with host thread naming. | bunnei | 1 | -3/+2 | |
2021-01-29 | hle: kernel: k_scheduler_lock: Cleanup. | bunnei | 1 | -3/+3 | |
2021-01-29 | core: arm: Remove unnecessary JIT checks. | bunnei | 2 | -24/+0 | |
2021-01-29 | common: common_funcs: Log error on R_UNLESS. | bunnei | 1 | -0/+3 | |
2021-01-29 | hle: kernel: Allocate a dummy KThread for each host thread, and use it for scheduling. | bunnei | 8 | -43/+45 | |
2021-01-29 | hle: kernel: k_scheduler: Use atomics for current_thread, etc. | bunnei | 2 | -26/+28 | |
2021-01-29 | hle: kernel: k_scheduler: Fix for single core mode. | bunnei | 1 | -1/+2 | |
2021-01-29 | kernel: Fix build errors. | bunnei | 2 | -4/+9 | |
2021-01-29 | core: cpu_manager: Remove unused variable. | bunnei | 1 | -1/+0 | |
2021-01-29 | hle: kernel: KScheduler: Introduce thread context_guard. | bunnei | 2 | -3/+16 | |
2021-01-29 | hle: kernel: Recode implementation of KThread to be more accurate. | bunnei | 14 | -785/+1562 | |
2021-01-29 | kernel: svc_types: Add ThreadActivity. | bunnei | 1 | -0/+5 | |
2021-01-29 | kernel: KSchedulerPriorityQueue: Lowest priority should be LowestThreadPriority. | bunnei | 1 | -1/+1 | |
2021-01-29 | kernel: k_light_lock: Simplify EmuThreadHandle implementation. | bunnei | 5 | -51/+33 | |
2021-01-29 | hle: kernel: TimeManager: Simplify to not rely on previous EmuThreadHandle implementation. | bunnei | 6 | -69/+25 | |
2021-01-29 | common: common_funcs: Add useful kernel macro R_SUCCEED_IF. | bunnei | 1 | -0/+3 | |
2021-01-29 | core: hle: kernel: object: Implement Finalize() virtual method. | bunnei | 15 | -6/+29 | |
2021-01-29 | core: hle: kernel: svc_results: Populate with several missing error codes. | bunnei | 1 | -0/+3 | |
2021-01-29 | core: hle: kernel: Implement KLightLock. | bunnei | 3 | -0/+173 | |
2021-01-29 | core: hle: kernel: Implement KThreadQueue. | bunnei | 2 | -0/+82 | |
2021-01-29 | common: common_funcs: Add a few more useful macros for kernel code. | bunnei | 1 | -0/+11 | |
2021-01-29 | hle: kernel: KThread: Clean up thread priorities. | bunnei | 10 | -83/+44 | |
2021-01-29 | hle: kernel: KThread: Reorganize thread priority defaults. | bunnei | 9 | -31/+31 | |
2021-01-29 | hle: kernel: KThread: Fix ThreadType definition. | bunnei | 5 | -11/+12 | |
2021-01-29 | hle: kernel: Move single core "phantom mode" out of KThread. | bunnei | 4 | -16/+31 | |
- This is a workaround that does not belong in a kernel primitive. | |||||
2021-01-29 | hle: kernel: KThread: Remove thread types that do not exist. | bunnei | 6 | -53/+30 | |
2021-01-29 | arm: arm_dynarmic: Skip calls when JIT is invalid. | bunnei | 2 | -0/+24 | |
- This can happen if called from an idle or suspension thread. | |||||
2021-01-29 | core: hle: kernel: Rename Thread to KThread. | bunnei | 45 | -272/+271 | |
2021-01-29 | Fix user changing to 0 if valid | german | 1 | -2/+8 | |
2021-01-28 | Avoid overwritting username | german | 1 | -1/+1 | |
2021-01-28 | hid: Add static_assert for Parameter size | Morph | 1 | -15/+19 | |
2021-01-28 | prepo: Fix BufferDescriptorX invalid buffer errors and add "New" variants of SaveReport | Morph | 1 | -24/+42 | |
The second input buffer could be optional when prepo/srepo is called, test for the availability of the second buffer prior to reading from it. | |||||
2021-01-28 | hle_ipc: Add Can(Read, Write)Buffer | Morph | 2 | -0/+28 | |
Allows us to test whether a buffer can be read from or written to memory | |||||
2021-01-28 | Stub GetSockOpt | german | 2 | -1/+17 | |
2021-01-28 | vk_scheduler: Fix unaligned placement new expressions | ReinUsesLisp | 1 | -6/+6 | |
We were accidentaly creating an object in an unaligned memory address. Fix this by manually aligning the offset. | |||||
2021-01-27 | vulkan_device: Blacklist Intel from float16 math (#5798) | Rodrigo Locatti | 1 | -0/+5 | |
Astral Chain crashes Intel's SPIR-V compiler when using fp16. Disable this while the vendor works on a fix. | |||||
2021-01-27 | npad: Remove unused device handle parameter | Morph | 3 | -11/+9 | |
2021-01-25 | Omit system reference | Chloe Marcec | 1 | -2/+1 | |
2021-01-25 | psm: IPsmSession | Chloe Marcec | 1 | -2/+114 | |
Used by homebrew menu | |||||
2021-01-25 | Revert "Start of Integer flags implementation" | ReinUsesLisp | 3 | -59/+3 | |
This reverts #4713. The implementation in that PR is not accurate. It does not reflect the behavior seen in hardware. | |||||
2021-01-25 | vk_graphics_pipeline: Fix narrowing conversion on MSVC | ReinUsesLisp | 1 | -2/+2 | |
2021-01-24 | vk_texture_cache: Support image store on sRGB images with VkImageViewUsageCreateInfo | ReinUsesLisp | 3 | -38/+72 | |
Vulkan 1.0 didn't support creating sRGB image views on an ABGR8 VkImage with storage usage bits. VK_KHR_maintenance2 addressed this allowing to reduce the usage bits on a VkImageView. To allow image store on non-sRGB image views when the VkImage is created with sRGB, always create VkImages without sRGB and add the sRGB format on the view. | |||||
2021-01-25 | vulkan_device: Lift VK_EXT_extended_dynamic_state blacklist on RDNA | ReinUsesLisp | 1 | -23/+0 | |
It seems to be safe to use this on new drivers. | |||||
2021-01-24 | cmake: Enforce -Warray-bounds and -Wmissing-field-initializers globally | ReinUsesLisp | 2 | -2/+2 | |
2021-01-24 | Stub Set/Get/Reset SixaxisSensorFusionParameters | german | 4 | -3/+104 | |
2021-01-24 | Print Process ID and Thread ID as hex | Chloe Marcec | 1 | -2/+2 | |
2021-01-24 | hle: Implement remaining services for Stereo Vision | Chloe Marcec | 3 | -7/+60 | |
Used by Zelda Breath of the Wild, Super Mario Odyssey and Nintendo Labo | |||||
2021-01-24 | audout: FlushAudioOutBuffers | Chloe Marcec | 3 | -1/+20 | |
Fixes Devil May Cry | |||||
2021-01-24 | host_shaders/cmake: Pass --quiet to glslang to keep it quiet | ReinUsesLisp | 1 | -1/+1 | |
Silences noisy builds on toolchains. | |||||
2021-01-24 | video_core/cmake: Enforce -Warray-bounds and -Wmissing-field-initializers | ReinUsesLisp | 1 | -0/+2 | |
2021-01-24 | video_core: Silence -Wmissing-field-initializers warnings | ReinUsesLisp | 5 | -25/+56 | |
2021-01-24 | maxwell_3d: Silence array bounds warnings | ReinUsesLisp | 2 | -35/+35 | |
2021-01-24 | maxwell_to_vk: Silence -Wextra warnings about using different enum types | ReinUsesLisp | 2 | -2/+2 | |
2021-01-24 | Fix connect and disconnect controller events | german | 2 | -15/+37 | |
2021-01-23 | vfs_real: When moving files or directories, don't assume file opening will succeed | comex | 1 | -4/+10 | |
Found this via a warning, but it's a substantive fix. Since this is only for a cache, it should be safe to silently drop the entry if opening fails. I think. | |||||
2021-01-23 | shader_ir: Fix comment typo | Levi Behunin | 1 | -1/+1 | |
2021-01-23 | sdl_impl: Set the maximum vibration duration to 1 second | Morph | 1 | -2/+6 | |
2021-01-23 | Simplify condition | Chloe Marcec | 1 | -2/+1 | |
2021-01-23 | nvdrv: Unregister already registered events | Chloe Marcec | 1 | -1/+8 | |
2021-01-23 | Clamp string reads to buffer size | Chloe Marcec | 1 | -3/+5 | |
2021-01-23 | video_core/cmake: Properly generate fatal errors on Aftermath | ReinUsesLisp | 1 | -2/+2 | |
Fix "message(ERROR ..." to "message(FATAL_ERROR ..." to properly stop cmake when Nsight Aftermath can't be configured. | |||||
2021-01-23 | nsight_aftermath_tracker: Fix build issues when enabled | ReinUsesLisp | 2 | -16/+5 | |
Fixes a bunch of build errors when Nsight Aftermath is properly enabled. | |||||
2021-01-23 | vk_pipeline_cache: Properly bypass VertexA shaders | ReinUsesLisp | 1 | -9/+3 | |
The VertexA stage is not yet implemented, but Vulkan is adding its descriptors, causing a discrepancy in the pushed descriptors and the template. This generally ends up in a driver side crash. Bypass the VertexA stage for now. | |||||
2021-01-22 | video_core/memory_manager: Add BytesToMapEnd | ReinUsesLisp | 2 | -2/+27 | |
Track map address sizes in a flat ordered map and add a method to query the number of bytes until the end of a map in a given address. | |||||
2021-01-22 | common: Add missing include to bit_util.h | bunnei | 1 | -0/+1 | |
2021-01-21 | gl_shader_decompiler: Fix constant buffer size calculation | ReinUsesLisp | 1 | -1/+2 | |
The divide logic was wrong and can cause an uniform buffer size overflow. | |||||
2021-01-21 | video_core/memory_manager: Remove unused CopyBlockUnsafe | ReinUsesLisp | 2 | -8/+0 | |
This function was not being used. | |||||
2021-01-21 | video_core/memory_manager: Flush destination buffer on CopyBlock | ReinUsesLisp | 1 | -0/+4 | |
When we copy into a buffer, it might contain data modified from the GPU on the same pages. Because of this, we have to flush the contents before writing new data. An alternative approach would be to write the data in place, but games can also write data in other ways, invalidating our contents. Fixes geometry in Zombie Panic in Wonderland DX. | |||||
2021-01-21 | video_core/memory_manager: Add GPU address based flush method | ReinUsesLisp | 2 | -0/+17 | |
Allow flushing rasterizer contents based on a GPU address. | |||||
2021-01-21 | bit_util: Unify implementations of MostSignificantBit32/MostSignificantBit64 | Lioncash | 1 | -35/+13 | |
We can use the standardized CLZ facilities to perform this. This also allows us to make utilizing functions constexpr and eliminate the inclusion of an intrinsics header. | |||||
2021-01-21 | hle: service: am: Stub ILibraryAppletAccessor::PresetLibraryAppletGpuTimeSliceZero. | bunnei | 1 | -1/+8 | |
- Used by Monster Hunter Rise demo. | |||||
2021-01-21 | renderer_opengl: Avoid precompiled cache and force NV GL cache directory | ReinUsesLisp | 8 | -5/+59 | |
Setting __GL_SHADER_DISK_CACHE_PATH we can force the cache directory to be in yuzu's user directory to stop commonly distributed malware from deleting our driver shader cache. And by setting __GL_SHADER_DISK_CACHE_SKIP_CLEANUP we can have an unbounded shader cache size. This has only been implemented on Windows, mostly because previous tests didn't seem to work on Linux. Disable the precompiled cache on Nvidia's driver. There's no need to hide information the driver already has in its own cache. | |||||
2021-01-20 | lbl: Implement most of lbl | Chloe Marcec | 1 | -22/+261 | |
Pretty basic service, only thing left to do is handle setting applying once set:sys is implemented | |||||
2021-01-20 | mii: Fix BuildRandomStoreData & Cleanup raw_data | Chloe Marcec | 4 | -2274/+1657 | |
Cleaned up mii raw data to reflect the underlying values instead of just a chunk of bytes. Fixed BuildRandomStoreData not actually generating random miis properly. "values" should be a u32, not a u8. | |||||
2021-01-20 | Mark DestinationToString as static | Chloe Marcec | 1 | -1/+1 | |
2021-01-20 | Mark LogPacketHeaderEntry hash as noexcept | Chloe Marcec | 1 | -1/+1 | |
2021-01-20 | lm: Recode LM service | Chloe Marcec | 8 | -345/+286 | |
Rework the service to spit out to logs instead of a seperate file as well as fix any crashes caused by lm. | |||||
2021-01-19 | acc: Stub StoreSaveDataThumbnail | Chloe Marcec | 5 | -6/+66 | |
Fixes ACA NEOGEO METAL SLUG hanging on boot. | |||||
2021-01-18 | npad: Add check for HANDHELD_INDEX in UpdateControllerAt() | Morph | 1 | -1/+1 | |
2021-01-18 | Always update configuration for handheld | german | 1 | -0/+10 | |
2021-01-18 | game_list: Fix folder reordering | FearlessTobi | 2 | -28/+32 | |
The bug(s) happened because we swapped the contents on values.game_dirs, but the pointer each item had to their respective game_dir wasn't updated. This made it so that the item had the wrong game_dir associated with it after a "move up" or "move down" operation. It can be observed by choosing "open directory location" after such operation. Changed from raw pointer to an index because it's equivalent but a bit clearer, but the change is not essential. Co-Authored-By: Vitor K <29167336+vitor-k@users.noreply.github.com> | |||||
2021-01-17 | configure_service: Only compile FormatEventStatusString when YUZU_ENABLE_BOXCAT is enabled | lat9nq | 1 | -0/+2 | |
The function is unused if YUZU_ENABLE_BOXCAT is disabled, causing a -Wunused-funciton error when compiled. Wrapping it with `#ifdef YUZU_ENABLE_BOXCAT` to prevent compiling the function when the variable is disabled. Opting to not use [[maybe unused]] in case the function is totally unused in the future. | |||||
2021-01-17 | Fix player 1 default connected value | german | 1 | -1/+2 | |
2021-01-17 | texture_cache/util: Resolve -Wsign-compare warning | Lioncash | 1 | -1/+1 | |
Resolves a -Wsign-compare warning on Clang. | |||||
2021-01-17 | video_core: Resolve -Wdocumentation warnings | Lioncash | 2 | -4/+3 | |
Silences some -Wdocumentation warnings on Clang. | |||||
2021-01-17 | vulkan_debug_callback: Add missing header guard | Lioncash | 1 | -0/+2 | |
Prevents inclusion issues from occurring. | |||||
2021-01-16 | input_interpreter: Mark two member functions as const | Lioncash | 1 | -4/+4 | |
These aren't stateful functions, so we can make use of const. While we're at, we can resolve some -Wdocumentation warnings. | |||||
2021-01-16 | input_interpreter: Add method to check for a button press state | Morph | 2 | -0/+25 | |
This allows to check for continuous input for the duration of a button press/hold | |||||
2021-01-16 | vk_shader_decompiler: Show comments as OpUndef with a type | ReinUsesLisp | 1 | -1/+4 | |
Silence the new validation layer error about SPIR-V not allowing OpUndef on a OpTypeVoid, even when the SPIR-V spec doesn't say anything against it. They will be inserted as an undefined int to avoid SPIRV-Cross and validation errors, but only when a debugging tool is attached. | |||||
2021-01-15 | core/cmake: Enforce Wclass-memaccess | ReinUsesLisp | 1 | -0/+1 | |
Treat -Wclass-memaccess as an error. | |||||
2021-01-15 | core: Silence Wclass-memaccess warnings | ReinUsesLisp | 17 | -205/+215 | |
This requires making several types trivial and properly initialize them whenever they are called. | |||||
2021-01-15 | common/common_funcs: Rename INSERT_UNION_PADDING_{BYTES,WORDS} to _NOINIT | ReinUsesLisp | 11 | -149/+149 | |
INSERT_PADDING_BYTES_NOINIT is more descriptive of the underlying behavior. | |||||
2021-01-15 | vulkan_memory_allocator: Remove unnecesary 'device' memory from commits | ReinUsesLisp | 2 | -15/+15 | |
2021-01-15 | vk_texture_cache: Use Download memory types for texture flushes | ReinUsesLisp | 2 | -5/+10 | |
Use the Download memory type where it matters. | |||||
2021-01-15 | vulkan_memory_allocator: Add allocation support for download types | ReinUsesLisp | 2 | -55/+91 | |
Implements the allocator logic to handle download memory types. This will try to use HOST_CACHED_BIT when available. | |||||
2021-01-15 | vulkan_memory_allocator: Add "download" memory usage hint | ReinUsesLisp | 9 | -45/+86 | |
Allow users of the allocator to hint memory usage for downloads. This removes the non-descriptive boolean passed for "host visible" or not host visible memory commits, and uses an enum to hint device local, upload and download usages. | |||||
2021-01-15 | vulkan_common: Move allocator to the common directory | ReinUsesLisp | 11 | -11/+11 | |
Allow using the abstraction from the OpenGL backend. | |||||
2021-01-15 | renderer_vulkan: Rename Vulkan memory manager to memory allocator | ReinUsesLisp | 15 | -54/+52 | |
"Memory manager" collides with the guest GPU memory manager, and a memory allocator sounds closer to what the abstraction aims to be. | |||||
2021-01-15 | vk_memory_manager: Improve memory manager and its API | ReinUsesLisp | 13 | -343/+318 | |
Fix a bug where the memory allocator could leave gaps between commits. To fix this the allocation algorithm was reworked, although it's still short in number of lines of code. Rework the allocation API to self-contained movable objects instead of naively using an unique_ptr to do the job for us. Remove the VK prefix. | |||||
2021-01-15 | Always initialize keyboard input | german | 5 | -25/+20 | |
2021-01-15 | Add mutitouch support for touch screens | german | 10 | -85/+137 | |
2021-01-15 | Allow to return up to 16 touch inputs per engine | german | 10 | -154/+202 | |
2021-01-15 | Allow all touch inputs at the same time and remove config options that are not longer necesary | german | 8 | -99/+36 | |
2021-01-15 | Add multitouch support | german | 2 | -23/+93 | |
2021-01-15 | common/bit_util: Replace CLZ/CTZ operations with standardized ones | Lioncash | 10 | -113/+17 | |
Makes for less code that we need to maintain. | |||||
2021-01-15 | common/alignment: Upgrade to use constraints instead of static asserts | ReinUsesLisp | 1 | -13/+9 | |
2021-01-15 | common/alignment: Rename AlignBits to AlignUpLog2 | ReinUsesLisp | 4 | -16/+15 | |
AlignUpLog2 describes what the function does better than AlignBits. | |||||
2021-01-15 | common/timer: Remove | Lioncash | 3 | -202/+0 | |
This is a leftover from citra and dolphin that isn't used at all, particularly given the <chrono> header exists. | |||||
2021-01-15 | common/color: Remove | ReinUsesLisp | 2 | -272/+0 | |
This is a leftover from Citra we no longer use. | |||||
2021-01-15 | core/cmake: Remove Werror flags already defined code-base wide | ReinUsesLisp | 1 | -2/+0 | |
2021-01-15 | video_core/cmake: Remove Werror flags already defined code-base wide | ReinUsesLisp | 1 | -2/+0 | |
These flags are already defined in src/cmake. | |||||
2021-01-15 | cmake: Remove yuzu_tester | ReinUsesLisp | 12 | -1057/+0 | |
We never ended up using yuzu_tester. Removing it saves code duplication with yuzu_cmd, and distribution size on prebuilt packages. For unit testing, we can use catch2 from guest code and dump the results to a file. Then execute yuzu from a script on ci if we want this to be automated. | |||||
2021-01-15 | cmake: Enforce -Wunused-function code-base wide | ReinUsesLisp | 2 | -1/+1 | |
2021-01-15 | video_core: Enforce -Wunused-function | ReinUsesLisp | 1 | -0/+1 | |
Stops us from merging code with unused functions in the future. If something is invoked behind conditionally evaluated code in a way that the language can't see it (e.g. preprocessor macros), the potentially unused function should use [[maybe_unused]]. | |||||
2021-01-15 | vk_buffer_cache: Remove unused function | ReinUsesLisp | 1 | -4/+0 | |
2021-01-15 | vulkan_common: Silence missing initializer warnings | ReinUsesLisp | 2 | -145/+146 | |
Silence warnings explicitly initializing all members on construction. | |||||
2021-01-15 | vulkan_device: Enable shaderStorageImageMultisample conditionally | ReinUsesLisp | 2 | -18/+20 | |
Fix Vulkan initialization on ANV. | |||||
2021-01-15 | astc: Increase integer encoded vector size | ReinUsesLisp | 1 | -1/+1 | |
Invalid ASTC textures seem to write more bytes here, increase the size to something that can't make us push out of bounds. | |||||
2021-01-15 | astc: Return zero on out of bound bits | ReinUsesLisp | 1 | -17/+22 | |
Avoid out of bound reads on invalid ASTC textures. Games can bind invalid textures that make us read or write out of bounds. | |||||
2021-01-14 | yuzu: Remove unused variables in Qt code | Lioncash | 2 | -21/+2 | |
Removes two unused variables in out Qt code. In this case the removal of these two results in less allocations, given std::map allocates on the heap. | |||||
2021-01-14 | configure_motion_touch: Prevent use after move in ApplyConfiguration() | Lioncash | 1 | -2/+1 | |
touch_engine was being compared against after being moved into the setter for the engine, so this comparison wouldn't behave properly. | |||||
2021-01-14 | configure_motion_touch: Migrate off QRegExp to QRegularExpression | Lioncash | 1 | -6/+9 | |
QRegularExpression was introduced in Qt 5 as a better replacement for QRegExp. In Qt 6.0 QRegExp is removed entirely. To remain forward compatible with Qt 6.0, we can transition over to using QRegularExpression. | |||||
2021-01-13 | Fix IP validator error where the last octet produced an error if the value was higher than 199 | german | 1 | -2/+3 | |
2021-01-13 | yuzu: Migrate off of setMargin() to setContentsMargins() | Lioncash | 2 | -3/+3 | |
setMargin() has been deprecated since Qt 5, and replaced with setContentsMargins(). We can move over to setContentsMargins() to stay forward-compatible with Qt 6.0. | |||||
2021-01-13 | vulkan_device: Remove requirement on shaderStorageImageMultisample | ReinUsesLisp | 1 | -1/+0 | |
yuzu doesn't currently emulate MS image stores. Requiring this makes no sense for now. Fixes ANV not booting any games on Vulkan. | |||||
2021-01-13 | tests: Add unit tests for the GPU range tracking buffer container | ReinUsesLisp | 2 | -0/+474 | |
Due to how error prone the container design is, this commit adds unit tests for it. Some tests taken from here are based on bugs from using this buffer container in games, so if we ever break it in the future in a way that might harm games, the tests should fail. | |||||
2021-01-13 | buffer_cache/buffer_base: Add a range tracking buffer container | ReinUsesLisp | 2 | -0/+496 | |
It keeps track of the modified CPU and GPU ranges on a CPU page granularity, notifying the given rasterizer about state changes in the tracking behavior of the buffer. Use a small vector optimization to store buffers smaller than 256 KiB locally instead of using free store memory allocations. | |||||
2021-01-13 | cmake: Enforce -Werror=switch and -Werror=unused-variable | Morph | 1 | -0/+2 | |
2021-01-12 | common/tree: Convert defines over to templates | Lioncash | 2 | -592/+666 | |
Reworks the tree header to operate off of templates as opposed to a series of defines. This allows all tree facilities to obey namespacing rules, and also allows this code to be used within modules once compiler support is in place. This also gets rid to use a macro to define functions and structs for necessary data types. With templates, these will be generated when they're actually used, eliminating the need for the separate declaration. | |||||
2021-01-12 | common/tree: Remove unused splay tree defines | Lioncash | 1 | -249/+2 | |
Makes for less code to take care of. | |||||
2021-01-12 | common/parent_of_member: Replace TYPED_STORAGE define with template alias | Lioncash | 2 | -8/+10 | |
Provides the same construct, but makes it obey namespacing. | |||||
2021-01-11 | hle: kernel: thread: Preserve thread wait reason for debugging only. | bunnei | 8 | -4/+74 | |
- This is decoupled from core functionality and used for debugging only. | |||||
2021-01-11 | yuzu: debugger: wait_tree: Handle unknown ThreadState. | bunnei | 1 | -0/+3 | |
2021-01-11 | hle: kernel: k_scheduler_lock: Fix shadowing errors. | bunnei | 1 | -1/+1 | |
2021-01-11 | core: arm: arm_interface: Fix shadowing errors. | bunnei | 1 | -3/+4 | |
2021-01-11 | core: hle: Add missing calls to MicroProfileOnThreadExit. | bunnei | 2 | -0/+5 | |
2021-01-11 | core: hle: Integrate new KConditionVariable and KAddressArbiter implementations. | bunnei | 15 | -1182/+508 | |
2021-01-11 | core: hle: kernel: Update KAddressArbiter. | bunnei | 3 | -0/+437 | |
2021-01-11 | core: hle: kernel: Update KConditionVariable. | bunnei | 4 | -0/+413 | |
2021-01-11 | core: hle: kernel: Begin moving common SVC defintions to its own header. | bunnei | 2 | -0/+14 | |
2021-01-11 | hle: kernel: Remove unnecessary AddressArbiter definition. | bunnei | 1 | -1/+0 | |
2021-01-11 | common: common_funcs: Add R_UNLESS macro. | bunnei | 1 | -0/+8 | |
2021-01-11 | hle: kernel: k_scheduler: Cleanup OnThreadPriorityChanged. | bunnei | 2 | -6/+3 | |
2021-01-11 | hle: kernel: Rename thread "status" to "state". | bunnei | 1 | -2/+2 | |
2021-01-11 | hle: kernel: thread: Replace ThreadStatus/ThreadSchedStatus with a single ThreadState. | bunnei | 12 | -172/+111 | |
- This is how the real kernel works, and is more accurate and simpler. | |||||
2021-01-11 | core: hle: kernel: Add some useful functions for checking kernel addresses. | bunnei | 1 | -0/+19 | |
2021-01-11 | core: hle: kernel: svc_types: Add type definitions for KAddressArbiter. | bunnei | 1 | -0/+12 | |
2021-01-11 | common: Introduce useful tree structures. | bunnei | 4 | -0/+1641 | |
2021-01-11 | core: hle: kernel: Update KSynchronizationObject. | bunnei | 33 | -621/+397 | |
2021-01-11 | core: hle: kernel: Begin moving common SVC results to its own header. | bunnei | 2 | -0/+21 | |
2021-01-11 | hle: service: nfp: Remove incorrect signaling behavior in GetDeviceState. | bunnei | 1 | -6/+0 | |
2021-01-10 | config: Enable docked mode by default | Morph | 5 | -6/+6 | |
2021-01-10 | cmake: Enforce C4101 | Morph | 1 | -0/+1 | |
This matches GCC's -Wunused-variable | |||||
2021-01-10 | yuzu_cmd: Silence unreferenced local variable warning | Morph | 1 | -2/+0 | |
2021-01-09 | general: Resolve C4062 warnings on MSVC | Morph | 2 | -0/+4 | |
2021-01-09 | common/div_ceil: Return numerator type | ReinUsesLisp | 1 | -5/+5 | |
Fixes instances where DivCeil(u32, u64) would surprisingly return u64, instead of the more natural u32. | |||||
2021-01-09 | cmake: Enforce C4062, C4265, C4388, and C5038 | ReinUsesLisp | 1 | -0/+4 | |
This should match some warnings we treat as errors on gcc and clang, caching bugs early and reducing the number of instances where we have to edit commits to make CI happy when developing from Windows. | |||||
2021-01-09 | file_sys/registered_cache: Silence virtual functions without override warnings | ReinUsesLisp | 1 | -4/+4 | |
2021-01-09 | core: Silence unhandled enum in switch warnings | ReinUsesLisp | 2 | -10/+5 | |
2021-01-09 | tests/ring_buffer: Silence signed/unsigned mismatch warnings | ReinUsesLisp | 1 | -15/+15 | |
2021-01-08 | Stub IsCpuOverclockEnabled | german | 2 | -1/+10 | |
2021-01-08 | vk_fence_manager: Use timeline semaphores instead of spin waits | ReinUsesLisp | 3 | -54/+18 | |
With timeline semaphores we can avoid creating objects. Instead of creating an event, grab the current tick from the scheduler and flush the current command buffer. When the fence has to be queried/waited, we can do so against the master semaphore instead of spinning on an event. If Vulkan supported NVN like events or fences, we could signal from the command buffer and wait for that without splitting things in two separate command buffers. | |||||
2021-01-07 | remove inaccurate reference | Ameer J | 1 | -1/+1 | |
Co-authored-by: LC <mathew1800@gmail.com> | |||||
2021-01-07 | fix for nvdec disabled, cleanup host1x | ameerj | 3 | -72/+23 | |
2021-01-07 | nvdec syncpt incorporation | ameerj | 11 | -37/+59 | |
laying the groundwork for async gpu, although this does not fully implement async nvdec operations | |||||
2021-01-07 | vulkan_library: Common::DynamicLibrary::Open is [[nodiscard]] | MerryMage | 1 | -1/+1 | |
Ignore the return value on __APPLE__ systems as well | |||||
2021-01-07 | texture_cache: Replace PAGE_SHIFT with PAGE_BITS | MerryMage | 1 | -6/+6 | |
PAGE_SHIFT is a #define in system headers that leaks into user code on some systems | |||||
2021-01-05 | core: Enforce C4715 (not all control paths return a value) | ReinUsesLisp | 1 | -0/+2 | |
2021-01-05 | core: Silence warnings when compiling without asserts | ReinUsesLisp | 5 | -8/+11 | |
2021-01-04 | vk_rasterizer: Skip binding empty descriptor sets on compute | ReinUsesLisp | 1 | -2/+4 | |
Fixes unit tests where compute shaders had no descriptors in the set, making Vulkan drivers crash when binding an empty set. | |||||
2021-01-04 | buffer_queue: Protect queue_sequence list access with a mutex | ameerj | 2 | -13/+21 | |
fixes a data race as this is an unprotected variable manipulated by multiple threads | |||||
2021-01-04 | yuzu/configure_filesystem: Remove "Select Cache Directory" option | FearlessTobi | 5 | -57/+1 | |
This tab of the settings is already extremely bloated and the setting itself is quite useless. With a gamelist of almost 30 games, the cache directory is smaller than 1MB for me and therefore I don't see why it needs to be configurable. | |||||
2021-01-04 | vulkan_device: Allow creating a device without surface | ReinUsesLisp | 1 | -3/+3 | |
2021-01-04 | renderer_vulkan/nsight_aftermath_tracker: Move to vulkan_common | ReinUsesLisp | 5 | -30/+21 | |
2021-01-04 | renderer_vulkan: Move device abstraction to vulkan_common | ReinUsesLisp | 29 | -29/+31 | |
2021-01-04 | gl_texture_cache: Avoid format views on Intel and AMD | ReinUsesLisp | 11 | -21/+48 | |
Intel and AMD proprietary drivers are incapable of rendering to texture views of different formats than the original texture. Avoid creating these at a cache level. This will consume more memory, emulating them with copies. | |||||
2021-01-04 | gl_texture_cache: Create base images with sRGB | ReinUsesLisp | 2 | -99/+100 | |
This breaks accelerated decoders trying to imageStore into images with sRGB. The decoders are currently disabled so this won't cause issues at runtime. | |||||
2021-01-04 | Address review comments | FearlessTobi | 1 | -5/+5 | |
2021-01-04 | Delete the old log file before rotating (#5675) | xperia64 | 1 | -0/+3 | |
2021-01-03 | renderer_vulkan: Rename VKDevice to Device | ReinUsesLisp | 52 | -169/+166 | |
The "VK" prefix predates the "Vulkan" namespace. It was carried around the codebase for consistency. "VKDevice" currently is a bad alias with "VkDevice" (only an upcase character of difference) that can cause confusion. Rename all instances of it. | |||||
2021-01-03 | main: Resolve error string not displaying | Lioncash | 3 | -2/+8 | |
During the transition to make the error dialog translatable, I accidentally got rid of the conversion to ResultStatus, which prevented operator<< from being invoked during formatting. This adds a function to directly retrieve the result status string instead so that it displays again. | |||||
2021-01-03 | Fix the old log file to work with the log parser. | bunnei | 1 | -1/+1 | |
2021-01-03 | Rotate previous log file to '.old' if it exists | xperia64 | 1 | -4/+9 | |
2021-01-03 | hle: service: nvflinger: buffer_queue: Do not reset id/layer_id on Connect. | bunnei | 1 | -2/+0 | |
- This behavior is a mistake, fixes Katana Zero. | |||||
2021-01-02 | dynarmic: Add Unsafe_InaccurateNaN optimization | MerryMage | 6 | -0/+26 | |
2021-01-02 | general: Fix various spelling errors | Morph | 20 | -43/+43 | |
2021-01-02 | X86/NativeClock: Reimplement RTDSC access to be lock free. | Fernando Sahmkow | 5 | -103/+107 | |
2021-01-02 | X86/NativeClock: Improve performance of clock calculations on hot path. | Fernando Sahmkow | 2 | -5/+71 | |
2021-01-01 | typo fix | Timotej Leginus | 1 | -1/+1 | |
typo fix | |||||
2021-01-01 | configure_input: Modify controller connection delay | Morph | 4 | -12/+47 | |
Increases the controller connection delay to 60ms and refactors it to attempt to disconnect all controllers prior to connecting all controllers in HID. | |||||
2021-01-01 | memory: Remove MemoryHook | MerryMage | 9 | -382/+0 | |
2020-12-31 | yuzu/main: fix mouse not showing on move and port citra-emu/citra#5476 | gal20 | 4 | -19/+24 | |
2020-12-31 | main: Make the loader error dialog fully translatable | Lioncash | 1 | -8/+12 | |
Makes the dialog fully localizable and also adds disambiguation comments to help translators understand what the formatting specifiers indicate. | |||||
2020-12-31 | main: Tidy up enum comparison | Lioncash | 1 | -2/+1 | |
enum classes are comparable with one another, so these casts aren't necessary. | |||||
2020-12-31 | vulkan_instance: Allow different Vulkan versions and enforce 1.1 | ReinUsesLisp | 7 | -41/+39 | |
For listing the available physical devices we can use Vulkan 1.0. Now that MoltenVK supports 1.1 we can require it for running games. Add missing documentation. | |||||
2020-12-31 | vk_device: Use an array to report lacking device limits | ReinUsesLisp | 1 | -13/+17 | |
This makes easier to add and tune the required device limits. | |||||
2020-12-31 | vk_device: Stop initialization when device is not suitable | ReinUsesLisp | 2 | -61/+39 | |
VKDevice::IsSuitable was not being called. To address this issue, check suitability before initialization and throw an exception if it fails. By doing this, we can deduplicate some code on queue searches. Previosuly we would first search if a present and graphics queue existed, then on initialization we would search again to find the index. | |||||
2020-12-31 | renderer_vulkan: Remove two step initialization on VKDevice | ReinUsesLisp | 6 | -31/+10 | |
The Vulkan device abstraction either initializes successfully on the constructor or throws a Vulkan exception. | |||||
2020-12-31 | renderer_vulkan: Throw when enumerating devices fails | ReinUsesLisp | 5 | -33/+21 | |
Report device enumeration errors with exceptions to be consistent with other initialization related function calls. Reduces the amount of code to maintain. | |||||
2020-12-31 | renderer_vulkan: Initialize surface in separate file | ReinUsesLisp | 6 | -73/+109 | |
Move surface initialization code to a separate file. It's unlikely to use this code outside of Vulkan, but keeping platform-specific code (Win32, Xlib, Wayland) in its own translation unit keeps things cleaner. | |||||
2020-12-31 | renderer_vulkan: Catch and report exceptions | ReinUsesLisp | 1 | -2/+5 | |
Move more Vulkan code to report errors with exceptions and report them through a log before notifying it with an error boolean for backwards compatibility. In the future we can replace the rasterizer two-step initialization to always use exceptions. | |||||
2020-12-31 | renderer_vulkan: Create debug callback on separate file and throw | ReinUsesLisp | 8 | -79/+88 | |
Initialize debug callbacks (messenger) from a separate file. This allows sharing code with different backends. Change our Vulkan error handling to use exceptions instead of error codes, simplifying the initialization process. | |||||
2020-12-31 | renderer_vulkan: Move instance initialization to a separate file | ReinUsesLisp | 4 | -111/+176 | |
Simplify Vulkan's backend initialization code by moving it to a separate file, allowing us to initialize a Vulkan instance from different backends. | |||||
2020-12-31 | vulkan_common: Rename renderer_vulkan/wrapper.h to vulkan_common/vulkan_wrapper.h | ReinUsesLisp | 51 | -51/+51 | |
Allows sharing Vulkan wrapper code between different rendering backends. | |||||
2020-12-31 | vulkan_common: Move dynamic library load to a separate file | ReinUsesLisp | 4 | -31/+59 | |
Allows us to initialize a Vulkan dynamic library from different backends without duplicating code. | |||||
2020-12-31 | Port citra-emu/citra#5509 | german | 1 | -2/+45 | |
2020-12-31 | Make the coding conventions more consistant | 16-Bit-Dog | 1 | -1/+1 | |
lut_index had 0 added when nothing was supposed to be added despite this, index was not added to 0 when nothing was supposed to be added... | |||||
2020-12-30 | half_set: Resolve -Wmaybe-uninitialized warnings | Lioncash | 1 | -7/+7 | |
2020-12-30 | maxwell_to_vk: Initialize usage variable in SurfaceFormat() | Lioncash | 1 | -1/+1 | |
Silences a -Wmaybe-uninitialized warning | |||||
2020-12-30 | video_core: Rewrite the texture cache | ReinUsesLisp | 152 | -8101/+10359 | |
The current texture cache has several points that hurt maintainability and performance. It's easy to break unrelated parts of the cache when doing minor changes. The cache can easily forget valuable information about the cached textures by CPU writes or simply by its normal usage.The current texture cache has several points that hurt maintainability and performance. It's easy to break unrelated parts of the cache when doing minor changes. The cache can easily forget valuable information about the cached textures by CPU writes or simply by its normal usage. This commit aims to address those issues. | |||||
2020-12-30 | cmake: Enforce -Wuninitialized | ReinUsesLisp | 1 | -0/+1 | |
2020-12-30 | service/pcie: Fix invalid initialization argument | ReinUsesLisp | 1 | -1/+1 | |
2020-12-30 | video_core: Add a delayed destruction ring abstraction | ReinUsesLisp | 2 | -0/+33 | |
2020-12-30 | host_shaders: Add Vulkan assembler compute shaders | ReinUsesLisp | 4 | -0/+96 | |
2020-12-30 | host_shaders: Add helper to blit depth stencil fragment shader | ReinUsesLisp | 2 | -0/+17 | |
2020-12-30 | host_shaders: Add texture color blit fragment shader | ReinUsesLisp | 2 | -0/+15 | |
2020-12-30 | host_shaders: Add shaders to present to the swapchain | ReinUsesLisp | 3 | -0/+36 | |
2020-12-30 | host_shaders: Add shaders to convert between depth and color images | ReinUsesLisp | 3 | -0/+28 | |
2020-12-30 | host_shaders: Add compute shader to copy BC4 as RG32UI to RGBA8 | ReinUsesLisp | 2 | -0/+71 | |
2020-12-30 | host_shaders: Add shader to render a full screen triangle | ReinUsesLisp | 2 | -0/+30 | |
2020-12-30 | host_shaders: Add pitch linear upload compute shader | ReinUsesLisp | 2 | -0/+87 | |
2020-12-30 | host_shaders: Add block linear upload compute shaders | ReinUsesLisp | 3 | -0/+249 | |
2020-12-30 | host_shaders: Add copyright headers to OpenGL present shaders | ReinUsesLisp | 2 | -0/+8 | |
2020-12-30 | video_core/host_shaders: Add support for prebuilt SPIR-V shaders | ReinUsesLisp | 1 | -16/+37 | |
Add support for building SPIR-V shaders from GLSL and generating headers to include the text of those same GLSL shaders to consume from OpenGL. | |||||
2020-12-30 | core/memory: Read and write page table atomically | ReinUsesLisp | 7 | -147/+132 | |
Squash attributes into the pointer's integer, making them an uintptr_t pair containing 2 bits at the bottom and then the pointer. These bits are currently unused thanks to alignment requirements. Configure Dynarmic to mask out these bits on pointer reads. While we are at it, remove some unused attributes carried over from Citra. Read/Write and other hot functions use a two step unpacking process that is less readable to stop MSVC from emitting an extra AND instruction in the hot path: mov rdi,rcx shr rdx,0Ch mov r8,qword ptr [rax+8] mov rax,qword ptr [r8+rdx*8] mov rdx,rax -and al,3 and rdx,0FFFFFFFFFFFFFFFCh je Core::Memory::Memory::Impl::Read<unsigned char> mov rax,qword ptr [vaddr] movzx eax,byte ptr [rdx+rax] | |||||
2020-12-30 | hle: kernel: service_thread: Make thread naming more consistent. | bunnei | 1 | -1/+1 | |
2020-12-30 | hle: kernel: Manage service threads on another thread. | bunnei | 1 | -9/+20 | |
- This is to allow service threads to defer destruction of themselves. | |||||
2020-12-30 | common: ThreadWorker: Add class to help do asynchronous work. | bunnei | 3 | -0/+90 | |
2020-12-30 | hle: kernel: Manage host thread IDs using TLS. | bunnei | 1 | -46/+31 | |
- Avoids the need to have a large map of host to guest thread IDs. | |||||
2020-12-29 | k_priority_queue: Fix concepts use | comex | 2 | -3/+9 | |
- For `std::same_as`, add missing include of `<concepts>`. - For `std::convertible_to`, create a replacement in `common/concepts.h` and use that instead. This would also be found in `<concepts>`, but unlike `std::same_as`, `std::convertible_to` is not yet implemented in libc++, LLVM's STL implementation - not even in master. (In fact, `std::same_as` is the *only* concept currently implemented. For some reason.) | |||||
2020-12-29 | Add missing include of "core/hle/kernel/kernel.h" | comex | 1 | -0/+1 | |
This is needed as the header invokes methods on KernelCore. | |||||
2020-12-29 | svc: demote SleepThread log to LOG_TRACE | ameerj | 1 | -1/+1 | |
This log is called often, and introduces a lot of noise when debug logging is enabled, making it difficult to see other debug logs. | |||||
2020-12-29 | hle: kernel: Move ServiceThread ownership to KernelCore. | bunnei | 4 | -5/+48 | |
- Fixes a circular dependency which prevented threads from being released on shutdown. | |||||
2020-12-29 | hle: kernel: service_thread: Add thread name and take weak_ptr of ServerSession. | bunnei | 3 | -11/+22 | |
2020-12-29 | hle: service: Acquire and release a lock on requests. | bunnei | 7 | -40/+41 | |
- This makes it such that we can safely access service members from CoreTiming thread. | |||||
2020-12-29 | audio_core: stream: Ensure buffer is valid before release. | bunnei | 1 | -2/+10 | |
2020-12-29 | core: Do not reset device_memory on shutdown. | bunnei | 1 | -1/+0 | |
- This will be reset on initialization. | |||||
2020-12-29 | core: hle: kernel: Clear process list on boot. | bunnei | 1 | -2/+2 | |
2020-12-29 | gpu: gpu_thread: Ensure MicroProfile is shutdown on exit. | bunnei | 1 | -0/+3 | |
2020-12-29 | hle: service: vi: Refactor to grab buffer only once. | bunnei | 1 | -15/+4 | |
2020-12-29 | service: nvflinger: Improve synchronization for BufferQueue. | bunnei | 5 | -19/+72 | |
- Use proper mechanisms for blocking on DequeueBuffer. - Ensure service thread terminates on emulation Shutdown. | |||||
2020-12-29 | hle: service: Ensure system is powered on before writing IPC result. | bunnei | 1 | -1/+5 | |
2020-12-29 | core: kernel: Clear process list earlier. | bunnei | 1 | -2/+2 | |
2020-12-29 | video_core: gpu_thread: Do not wait when system is powered down. | bunnei | 1 | -1/+2 | |
2020-12-29 | core: settings: Untangle multicore from asynchronous GPU. | bunnei | 5 | -21/+4 | |
- Now that GPU is always threaded, we can support multicore with synchronous GPU. | |||||
2020-12-29 | video_core: gpu: Implement synchronous mode using threaded GPU. | bunnei | 4 | -12/+34 | |
2020-12-29 | video_core: gpu: Refactor out synchronous/asynchronous GPU implementations. | bunnei | 10 | -289/+130 | |
- We must always use a GPU thread now, even with synchronous GPU. | |||||
2020-12-29 | hle: kernel: hle_ipc: Remove SleepClientThread. | bunnei | 2 | -54/+0 | |
- This was kind of hacky, and no longer is necessary with service threads. | |||||
2020-12-29 | hle: service: bsd: Update to work with service threads, removing SleepClientThread. | bunnei | 4 | -250/+45 | |
2020-12-29 | hle: service: nvdrv: Revert #4981 to remove usage of SleepClientThread. | bunnei | 23 | -211/+83 | |
- Note, this always processes the ioctl right away, which fixes BotW 1.0.0 issues. | |||||
2020-12-29 | hle: kernel: service_thread: Add parameter for thread pool size. | bunnei | 3 | -7/+7 | |
2020-12-29 | hle: service: nvflinger: Refactor locking and interfaces. | bunnei | 3 | -45/+31 | |
2020-12-29 | hle: service: vi: Remove usage of SleepClientThread. | bunnei | 1 | -34/+43 | |
2020-12-29 | core: hle: server_session: Use separate threads for each service connection. | bunnei | 6 | -23/+140 | |
2020-12-27 | udp client: process packets only for the correct pad | gal20 | 1 | -0/+5 | |
2020-12-27 | Allow to invert analog axis with right click | german | 4 | -65/+99 | |
2020-12-26 | renderer_vulkan/fixed_pipeline_state: Move enabled bindings to static state | ReinUsesLisp | 3 | -26/+12 | |
Without using VK_EXT_robustness2, we can't consider the 'enabled' (not null) vertex buffers as dynamic state, as this leads to invalid Vulkan state. Move this to static state that is always hashed and compared in the pipeline key. The bits for enabled vertex buffers are moved into the attribute state bitfield. This is not 'correct' as it's not an attribute state, but that struct has bits to spare, and it's used in an array of 32 elements (the exact same number of vertex buffer bindings). | |||||
2020-12-25 | yuzu/main: Add basic command line arguments | Morph | 1 | -3/+39 | |
The following command line arguments are supported: yuzu.exe "path_to_game" - Launches a game at "path_to_game" yuzu.exe -f - Launches the next game in fullscreen yuzu.exe -g "path_to_game" - Launches a game at "path_to_game" yuzu.exe -f -g "path_to_game" - Launches a game at "path_to_game" in fullscreen | |||||
2020-12-25 | core: memory: Ensure thread safe access when pages are rasterizer cached (#5206) | bunnei | 1 | -12/+40 | |
* core: memory: Ensure thread safe access when pages are rasterizer cached. | |||||
2020-12-25 | cmake: Always enable Vulkan | ReinUsesLisp | 8 | -133/+75 | |
Removes the unnecesary burden of maintaining separate #ifdef paths and allows us sharing generic Vulkan code across APIs. | |||||
2020-12-25 | video_core: Enforce C4715 (not all control paths return a value) | ReinUsesLisp | 1 | -0/+1 | |
Most of the time people write code that always returns a value, terminates execution, throws an exception, or uses an unconventional jump primitive. This is not always true when we build without asserts on mainline builds. To avoid introducing undefined behavior on our most used builds, enforce this warning signalling an error and stopping the build from shipping. | |||||
2020-12-25 | vk_shader_decompiler: Silence warning when compiling without asserts | ReinUsesLisp | 1 | -0/+1 | |
2020-12-23 | yuzu/main: Improve menubar access keys | lat9nq | 4 | -38/+38 | |
Adds a unique access key to each action within each menu. A few actions already had their own access key, so those were untouched. | |||||
2020-12-23 | Add option to reset window size to 1080p | german | 3 | -6/+30 | |
2020-12-22 | yuzu/main: Save settings when starting guest | lat9nq | 2 | -16/+25 | |
Saves UISettings and Settings when booting a guest. Moves updating UISettings::values from GMainWindow::closeEvent into its own function, then reuses it in GMainWindow::BootGame. | |||||
2020-12-19 | yuzu: Remove gdbstub configuration | FearlessTobi | 9 | -110/+7 | |
The gdbstub itself was removed with https://github.com/yuzu-emu/yuzu/pull/5028. This PR just removes the remaining gdb configuration code from the emulator and the UI. | |||||
2020-12-18 | applets/web: Implement the online web browser applet | Morph | 8 | -64/+167 | |
2020-12-18 | applets/web: Fix keyboard to emulated controller input | Morph | 3 | -4/+30 | |
2020-12-18 | main: Add the ability to disable the web applet | Morph | 2 | -0/+27 | |
This should only be used for Super Mario 3D All-Stars. This is a temporary solution until it can be implemented properly. | |||||
2020-12-18 | main, applets/web: Re-add progress dialog for RomFS extraction | Morph | 8 | -68/+125 | |
2020-12-18 | applets/web: Implement the Qt web browser applet frontend | Morph | 4 | -5/+600 | |
2020-12-18 | web_browser_scripts: Add injection scripts for the web browser | Morph | 1 | -0/+193 | |
2020-12-18 | pl_u, applets/web: Decrypt shared fonts to TTF files | Morph | 3 | -18/+117 | |
2020-12-18 | ns_vm: Stub NeedsUpdateVulnerability | Morph | 1 | -1/+10 | |
This is used to force system updates on launching the web browser. We do not care about system updates so this can be set to false. | |||||
2020-12-18 | frontend/input_interpreter: Add InputInterpreter API | Morph | 3 | -0/+167 | |
The InputInterpreter class interfaces with HID to retrieve button press states. Input is intended to be polled every 50ms so that a button is considered to be held down after 400ms has elapsed since the initial button press and subsequent repeated presses occur every 50ms. Co-authored-by: Chloe <25727384+ogniK5377@users.noreply.github.com> | |||||
2020-12-18 | controllers/npad: Make press_state atomic | Morph | 2 | -2/+3 | |
2020-12-18 | util: Add URL Request Interceptor for QWebEngine | Morph | 3 | -0/+64 | |
2020-12-18 | bootmanager: Add a check whether loading is complete | Morph | 2 | -0/+6 | |
2020-12-18 | applets/web: Implement the default web browser applet frontend | Morph | 3 | -1/+24 | |
2020-12-18 | applets/web: Implement the offline browser applet backend | Morph | 2 | -13/+143 | |
2020-12-18 | applets/web: Initial implementation of the web browser applet | Morph | 3 | -2/+428 | |
2020-12-18 | applets: Remove the previous web browser applet implementation | Morph | 12 | -1039/+40 | |
2020-12-18 | system_archive: Add + and - buttons to the Nintendo Extended OSS font | Morph | 2 | -315/+343 | |
2020-12-18 | buffer_queue: better use of std::array | ameerj | 1 | -59/+46 | |
2020-12-17 | Overwrite slots instead of queuing them, add disconnect signal | ameerj | 3 | -27/+33 | |
Fix for Katana Zero and Yoshi's Crafted World | |||||
2020-12-17 | system_archive: Update Nintendo Extended OSS font | Morph | 2 | -182/+347 | |
Co-authored-by: Its-Rei <kupfel@gmail.com> | |||||
2020-12-13 | cmake: Fix generating CMake configs and linking with Boost | lat9nq | 1 | -1/+1 | |
Fixes regression by 761206cf81b271f7f4dd6a167a120325b760dbf3, causing yuzu to not build on Linux with any version of Boost except a cached 1.73 Conan version from before about a day ago. Moves the Boost requirement out of the `REQUIRED_LIBS` psuedo-2D-array for Conan to instead be manually configured, using Conan as a fallback solution if the system does not meet our requirements. Requires any update from the linux-fresh container in order to build. **DO NOT MERGE** until someone with the MSVC toolchain can verify this works there, too. | |||||
2020-12-12 | common: Update CMakeList to fix build issue with Boost. | bunnei | 1 | -2/+1 | |
2020-12-12 | controllers/npad: Validate device handles before use | Morph | 2 | -0/+45 | |
Some games such as NEKOPARA Vol. 3 send invalid device handles when calling InitializeVibrationDevice. Introduce a check to validate the device handle before use. | |||||
2020-12-12 | Revert "Merge pull request #5173 from lioncash/common-fs" | Morph | 2 | -112/+396 | |
This reverts commit ce5fcb6bb2c358b0251a2ce87945bda52789a76d, reversing changes made to 6f41763061082d5fa2ab039c554427152243cb46. | |||||
2020-12-12 | Revert "Merge pull request #5174 from ReinUsesLisp/fs-fix" | Morph | 2 | -36/+4 | |
This reverts commit 5fe55b16a11d9ec607fb8a3fdddc77a4393cd96a, reversing changes made to e94dd7e2c4fc3f7ca2c15c01bdc301be2b8a4c1b. | |||||
2020-12-12 | Revert "Merge pull request #5176 from Morph1984/fix-createfile" | Morph | 1 | -6/+2 | |
This reverts commit 6d6115475b4edccdf1bb4e96ecc3d3b1be319e76, reversing changes made to 5fe55b16a11d9ec607fb8a3fdddc77a4393cd96a. | |||||
2020-12-12 | Revert "Merge pull request #5179 from ReinUsesLisp/fs-path" | Morph | 1 | -1/+1 | |
This reverts commit 4e94d0d53af2cdb7b03ef9de23cc29f3565df97a, reversing changes made to 6d6115475b4edccdf1bb4e96ecc3d3b1be319e76. | |||||
2020-12-12 | Revert "Merge pull request #5181 from Morph1984/5174-review" | Morph | 1 | -3/+9 | |
This reverts commit cdb36aef9ec9d30bdef1953f9ed46776ae2f12af, reversing changes made to 5e9b77129f2cf8c039a8d98033cae4ac0f93f515. | |||||
2020-12-10 | vfs: Use existing type aliases consistently | Lioncash | 28 | -136/+142 | |
Makes use of the VirtualDir and VirtualFile aliases across the board instead of having a few isolated places that don't use it. | |||||
2020-12-10 | common/file_util: Simplify the behavior of CreateFullPath | Morph | 1 | -9/+3 | |
2020-12-09 | common/file_util: Let std::filesystem cast from UTF16 to std::string | ReinUsesLisp | 1 | -1/+1 | |
Fix invalid encoding paths when iterating over a directory on Windows. | |||||
2020-12-09 | vfs_real: Fix CreateFile for files without a file extension | Morph | 1 | -2/+6 | |
2020-12-09 | common/file_util: Fix and deprecate CreateFullPath, add CreateDirs | ReinUsesLisp | 2 | -4/+31 | |
Fix CreateFullPath to have its intended previous behavior (whatever that was), and deprecate it in favor of the new CreateDirs function. Unlike CreateDir, CreateDirs is marked as [[nodiscard]] to avoid new code ignoring its result value. | |||||
2020-12-09 | common/file_util: Succeed on CreateDir when the directory exists | ReinUsesLisp | 1 | -0/+5 | |
2020-12-09 | file_util: Migrate remaining file handling functions over to std::filesystem | Lioncash | 2 | -340/+100 | |
Converts creation and deletion functions over to std::filesystem, simplifying our file-handling code. Notably with this, CopyDir will now function on Windows. | |||||
2020-12-09 | file_util: Migrate Exists() and IsDirectory() over to std::filesystem | Lioncash | 2 | -57/+13 | |
Greatly simplifies our file-handling code for these functions. | |||||
2020-12-08 | svc: Remove unnecessary casts | Lioncash | 1 | -35/+25 | |
Simplifies and removes some casts. In all cases, these were generally widening from a 32-bit unsigned type to a 64-bit unsigned type, so no information would be lost from the conversion. | |||||
2020-12-08 | IPurchaseEventManager: Implement GetPurchasedEventReadableHandle | Morph | 1 | -1/+14 | |
- Used by Pokémon Café Mix - Used by DOOM: Eternal | |||||
2020-12-08 | IPurchaseEventManager: Stub Set(Default)DeliveryTarget | Morph | 1 | -2/+27 | |
- Used by Pokémon Café Mix - Used by DOOM: Eternal | |||||
2020-12-08 | aoc_u: Stub Create(Permanent)EcPurchasedEventManager | Morph | 2 | -2/+38 | |
- Used by Pokémon Café Mix - Used by DOOM: Eternal | |||||
2020-12-08 | memory: Resolve -Wdocumentation warning for Write() | Lioncash | 1 | -2/+0 | |
Write() doesn't return anything, so the @returns tag shouldn't be present. | |||||
2020-12-08 | fsp_srv: Implement OpenDataStorageWithProgramIndex | Morph | 6 | -1/+83 | |
- Used by RollerCoaster Tycoon 3: Complete Edition | |||||
2020-12-08 | file_sys: Consolidate common Title ID operations | Morph | 5 | -13/+67 | |
2020-12-08 | core: Remove unnecessary enum casts in log calls | Lioncash | 25 | -96/+90 | |
Follows the video core PR. fmt doesn't require casts for enum classes anymore, so we can remove quite a few casts. | |||||
2020-12-08 | controller: Use std::move within ConvertToFrontendParameters() | Lioncash | 1 | -3/+3 | |
Avoids unnecessary copies. | |||||
2020-12-08 | controller: Avoid unnecessary copies in ConfigurationComplete() | Lioncash | 1 | -9/+8 | |
Avoids unnecessary 1072 byte copies when querying info about controllers. | |||||
2020-12-08 | Disable analog joystick from buttons by default | german | 5 | -10/+52 | |
2020-12-07 | video_core: Make use of ordered container contains() where applicable | Lioncash | 8 | -16/+13 | |
With C++20, we can use the more concise contains() member function instead of comparing the result of the find() call with the end iterator. | |||||
2020-12-07 | ast: Improve string concat readability in operator() | Lioncash | 1 | -5/+4 | |
Provides an in-place format string to make it more pleasant to read. | |||||
2020-12-07 | gl_shader_decompiler: Elide unnecessary copies within DeclareConstantBuffers() | Lioncash | 1 | -1/+1 | |
Resolves a -Wrange-loop-analysis warning. | |||||
2020-12-07 | buffer_block: Mark interface as nodiscard where applicable | Lioncash | 1 | -7/+7 | |
Prevents logic errors from occurring from unused values. | |||||
2020-12-07 | buffer_block: Remove unnecessary includes | Lioncash | 1 | -5/+0 | |
Reduces the amount of dependencies the header pulls in. | |||||
2020-12-07 | shader_ir: std::move node within DeclareAmend() | Lioncash | 1 | -2/+2 | |
Same behavior, but elides an unnecessary atomic reference count increment and decrement. | |||||
2020-12-07 | video_core: Remove unnecessary enum class casting in logging messages | Lioncash | 33 | -148/+125 | |
fmt now automatically prints the numeric value of an enum class member by default, so we don't need to use casts any more. Reduces the line noise a bit. | |||||
2020-12-07 | maxwell_3d: Move member variables to end of class | Lioncash | 1 | -31/+32 | |
Follows our established coding style. | |||||
2020-12-07 | maxwell_3d: Resolve -Wdocumentation warning | Lioncash | 1 | -1/+1 | |
Removes a documentation comment for a non-existent member. | |||||
2020-12-07 | maxwell_3d: Remove unused dirty_pointer array | Lioncash | 1 | -2/+0 | |
This is unused and removing it shrinks the structure by 3584 bytes. | |||||
2020-12-07 | configure_motion_touch: Fix unescaped backslash in regex | comex | 1 | -2/+2 | |
Since this is inside a string literal, backslashes that are part of regex syntax have to be escaped. But that's ugly, so convert to a raw string instead. | |||||
2020-12-07 | network, sockets: Replace `POLL_IN`, `POLL_OUT`, etc. constants with an `enum class PollEvents` | comex | 6 | -71/+82 | |
Actually, two enum classes, since for some reason there are two separate yet identical `PollFD` types used in the codebase. I get that one is ABI-compatible with the Switch while the other is an abstract type used for the host, but why not use `WSAPOLLFD` directly for the latter? Anyway, why make this change? Because on Apple platforms, `POLL_IN`, `POLL_OUT`, etc. (with an underscore) are defined as macros in <sys/signal.h>. (This is inherited from FreeBSD.) So defining a variable with the same name causes a compile error. I could just rename the variables, but while I was at it I thought I might as well switch to an enum for stronger typing. Also, change the type used for values copied directly to/from the `events` and `revents` fields of the host *native* `pollfd`/`WSASPOLLFD`, from `u32` to `short`, as `short` is the correct canonical type on both Unix and Windows. | |||||
2020-12-07 | Fix "explicitly defaulted but implicitly deleted" warning | comex | 1 | -1/+1 | |
`PhysicalCore`'s move assignment operator was declared as `= default`, but was implicitly deleted because `PhysicalCore` has fields of reference type. Switch to explicitly deleting it to avoid a Clang warning. The move *constructor* is still defaulted, and is required to exist due to the use of `std::vector<PhysicalCore>`. | |||||
2020-12-07 | hle: Type check ResponseBuilder::Push arguments, and fix use in vi.cpp | comex | 2 | -34/+37 | |
- Add a type check so that calling Push with an invalid type produces a compile error rather than a linker error. - vi.cpp was calling Push with a variable of type `std::size_t`. There's no explicit overload for `size_t`, but there is one for `u64`, which on most platforms is the same type as `size_t`. On macOS, however, it isn't: both types are 64 bits, but `size_t` is `unsigned long` and `u64` is `unsigned long long`. Regardless, it makes more sense to explicitly use `u64` here instead of `size_t`. | |||||
2020-12-07 | CMakeLists,network: Create YUZU_UNIX macro to replace __unix__ | comex | 2 | -5/+5 | |
__unix__ is not predefined on Apple platforms even though they are Unix. | |||||
2020-12-07 | renderer_vulkan: Add missing `override` specifier | comex | 1 | -1/+1 | |
2020-12-07 | map_interval: Change field order to address uninitialized field warning | comex | 1 | -1/+2 | |
Clang complains about `new_chunk`'s constructor using the then-uninitialized `first_chunk` (even though it's just to get a pointer into it). | |||||
2020-12-07 | core: Mark unused fields as [[maybe_unused]] | comex | 2 | -3/+3 | |
2020-12-07 | boxcat: Avoid unnecessary object copy | comex | 1 | -1/+1 | |
2020-12-07 | nvdrv: Remove useless re-declaration of pure virtual methods that were already declared in the superclass | comex | 1 | -33/+0 | |
2020-12-07 | video_core: Adjust `NUM` macro to avoid Clang warning | comex | 3 | -3/+3 | |
The previous definition was: #define NUM(field_name) (sizeof(Maxwell3D::Regs::field_name) / sizeof(u32)) In cases where `field_name` happens to refer to an array, Clang thinks `sizeof(an array value) / sizeof(a type)` is an instance of the idiom where `sizeof` is used to compute an array length. So it thinks the type in the denominator ought to be the array element type, and warns if it isn't, assuming this is a mistake. In reality, `NUM` is not used to get array lengths at all, so there is no mistake. Silence the warning by applying Clang's suggested workaround of parenthesizing the denominator. | |||||
2020-12-06 | hle: kernel: Process: Various style fixes based on code review feedback. | bunnei | 1 | -2/+2 | |
2020-12-06 | core: cpu_manager: Fix a typo in PreemptSingleCore, which broke many games. | bunnei | 1 | -21/+26 | |
- We were reload'ing the old current scheduler, which may have changed. | |||||
2020-12-06 | hle: kernel: Thread: Various style fixes based on code review feedback. | bunnei | 1 | -22/+25 | |
2020-12-06 | hle: kernel: KScopedSchedulerLockAndSleep: Various style fixes based on code review feedback. | bunnei | 1 | -6/+6 | |
2020-12-06 | hle: kernel: KScopedLock: Various style fixes based on code review feedback. | bunnei | 1 | -6/+8 | |
2020-12-06 | hle: kernel: KAbstractSchedulerLock: Various style fixes based on code review feedback. | bunnei | 1 | -9/+7 | |
2020-12-06 | hle: kernel: KScheduler: Various style fixes based on code review feedback. | bunnei | 2 | -50/+41 | |
2020-12-06 | hle: kernel: KPriorityQueue: Various style fixes based on code review feedback. | bunnei | 1 | -29/+36 | |
2020-12-06 | hle: kernel: KAffinityMask: Various style fixes based on code review feedback. | bunnei | 1 | -17/+13 | |
2020-12-06 | hle: kernel: GlobalSchedulerContext: Various style fixes based on code review feedback. | bunnei | 2 | -5/+10 | |
2020-12-06 | common: BitSet: Various style fixes based on code review feedback. | bunnei | 1 | -23/+22 | |
2020-12-06 | hle: kernel: Use C++ style comments in KScheduler, etc. | bunnei | 4 | -152/+136 | |
2020-12-06 | kernel: KScopedSchedulerLockAndSleep: Remove unused ctor. | bunnei | 1 | -13/+7 | |
2020-12-06 | kernel: time_manager: Add missing lock guards. | bunnei | 1 | -3/+10 | |
2020-12-06 | hle: kernel: Migrate to KScopedSchedulerLock. | bunnei | 15 | -48/+92 | |
2020-12-06 | hle: kernel: Separate KScopedSchedulerLockAndSleep from k_scheduler. | bunnei | 11 | -69/+72 | |
2020-12-06 | hle: kernel: Separate KScheduler from GlobalSchedulerContext class. | bunnei | 9 | -520/+140 | |
2020-12-06 | hle: kernel: Rewrite scheduler implementation based on Mesopshere. | bunnei | 26 | -1223/+1215 | |
2020-12-06 | hle: kernel: physical_core: Clear exclusive state after each run. | bunnei | 3 | -0/+7 | |
- This is closer to pre-multicore behavior, and works a bit better. | |||||
2020-12-06 | hle: kernel: Port KAbstractSchedulerLock from Mesosphere. | bunnei | 2 | -0/+77 | |
2020-12-06 | hle: kernel: svc: Remove reschedule on svcBreak. | bunnei | 1 | -5/+0 | |
- This breaks things, and is unnecessary, since emulation will be done at this point. | |||||
2020-12-06 | hle: kernel: process: Add schedule count tracking, to be used for yield impl. | bunnei | 1 | -0/+13 | |
2020-12-06 | hle: kernel: svc: Remove unnecessary hack in svcSleep. | bunnei | 1 | -7/+0 | |
2020-12-06 | common: Port KPriorityQueue from Mesosphere. | bunnei | 2 | -0/+444 | |
2020-12-06 | common: Port BitSet from Mesosphere. | bunnei | 2 | -0/+101 | |
2020-12-06 | hle: kernel: Port KAffinityMask from Mesosphere. | bunnei | 7 | -16/+80 | |
2020-12-05 | maxwell_dma: Rename RenderEnable::Mode::FALSE and TRUE to avoid name conflict | comex | 1 | -5/+7 | |
On Apple platforms, FALSE and TRUE are defined as macros by <mach/boolean.h>, which is included by various system headers. Note that there appear to be no actual users of the names to fix up. | |||||
2020-12-05 | yuzu_cmd: Remove 'users_size' | comex | 1 | -1/+0 | |
Specifically: const auto size = sdl2_config->GetInteger("System", "users_size", 0); The variable is never used, producing a warning. I wondered if this ought to be assigning something to in `Settings`, but nothing else in the codebase ever mentions a setting called "users_size", so I guess it's safe to remove... | |||||
2020-12-05 | Update cubeb and request a persistent stream session | Vitor Kiguchi | 1 | -0/+1 | |
2020-12-05 | video_core: Resolve more variable shadowing scenarios pt.3 | Lioncash | 49 | -292/+305 | |
Cleans out the rest of the occurrences of variable shadowing and makes any further occurrences of shadowing compiler errors. | |||||
2020-12-05 | game_list_p: Resolve deprecated usage of QVariant operator< | Lioncash | 1 | -1/+2 | |
This is designated as obsolete in Qt's docs (see: https://doc.qt.io/qt-5/qvariant-obsolete.html#operator-lt) | |||||
2020-12-05 | applets: Resolve variable shadowing | Morph | 10 | -19/+19 | |
2020-12-05 | video_core: Resolve more variable shadowing scenarios pt.2 | Lioncash | 39 | -296/+305 | |
Migrates the video core code closer to enabling variable shadowing warnings as errors. This primarily sorts out shadowing occurrences within the Vulkan code. | |||||
2020-12-05 | xbyak_abi: Shorten std::size_t to size_t | Lioncash | 1 | -8/+8 | |
Makes for less reading. | |||||
2020-12-05 | xbyak_abi: Avoid implicit sign conversions | Lioncash | 1 | -2/+2 | |
2020-12-05 | system_version: Update to 11.0.0 | Chloe Marcec | 1 | -6/+6 | |
2020-12-05 | Fix telemetry-related exit crash from use-after-free | FearlessTobi | 1 | -3/+3 | |
Co-Authored-By: xperia64 <xperia64@users.noreply.github.com> | |||||
2020-12-04 | codec: Remove deprecated usage of AVCodecContext::refcounted_frames | Lioncash | 1 | -1/+0 | |
This was only necessary for use with the avcodec_decode_video2/avcoded_decode_audio4 APIs which are also deprecated. Given we use avcodec_send_packet/avcodec_receive_frame, this isn't necessary, this is even indicated directly within the FFmpeg API changes document here on 2017-09-26: https://github.com/FFmpeg/FFmpeg/blob/master/doc/APIchanges#L410 This prevents our code from breaking whenever we update to a newer version of FFmpeg in the future if they ever decide to fully remove this API member. | |||||
2020-12-04 | video_core: Resolve more variable shadowing scenarios | Lioncash | 42 | -206/+219 | |
Resolves variable shadowing scenarios up to the end of the OpenGL code to make it nicer to review. The rest will be resolved in a following commit. | |||||
2020-12-04 | nim: Stub IsLargeResourceAvailable | Morph | 1 | -1/+13 | |
- Used by Immortals Fenyx Rising | |||||
2020-12-03 | node: Mark member functions as [[nodiscard]] where applicable | Lioncash | 1 | -29/+29 | |
Prevents logic bugs from accidentally ignoring the return value. | |||||
2020-12-03 | node: Eliminate variable shadowing | Lioncash | 1 | -47/+49 | |
2020-12-03 | vp9/vic: Resolve pessimizing moves | Lioncash | 2 | -11/+11 | |
Removes the usage of moves that don't result in behavior different from a copy, or otherwise would prevent copy elision from occurring. | |||||
2020-12-03 | mouse_poller: Remove unused includes | Lioncash | 1 | -3/+1 | |
2020-12-03 | mouse_input: Invert conditional in UpdateYuzuSettings() | Lioncash | 1 | -4/+6 | |
Allows the struct to be constructed in place. | |||||
2020-12-03 | mouse_input: Remove two casts and amend some formatting | Lioncash | 1 | -11/+14 | |
Removes the use of two static casts and improves the readability of some vectors slightly. | |||||
2020-12-03 | mouse_input: Resolve a -Wdocumentation warning | Lioncash | 1 | -1/+1 | |
2020-12-03 | mouse_input: Remove unused includes | Lioncash | 2 | -7/+3 | |
2020-12-03 | audio_core: Make shadowing and unused parameters errors | Lioncash | 29 | -154/+163 | |
Moves the audio code closer to enabling warnings as errors in general. | |||||
2020-12-01 | Fix implicit conversion in mouse input | german | 1 | -6/+8 | |
2020-11-30 | Disable web applet and warning when compiling for Linux on CI | lat9nq | 1 | -0/+2 | |
yuzu's web applet does not or barely reacts to user input while open in Linux. It can be closed via 'Exit Web Applet' on the menubar, however if yuzu is in fullscreen, this is effectively a softlock as the menubar cannot be accessed. This disables building yuzu with the web applet on the Linux CI target. In addition, this disables the QMessageBox warning about not having compiled yuzu with the web applet. | |||||
2020-11-29 | kernel: scheduler: Minor cleanup to remove duplicated code. | bunnei | 2 | -46/+14 | |
2020-11-29 | kernel: time_manager: Protect access with a mutex. | bunnei | 2 | -1/+5 | |
2020-11-29 | common: fiber: Use VirtualBuffer for stack memory. | bunnei | 1 | -2/+5 | |
- This will be aligned by default, and helps memory usage. | |||||
2020-11-29 | hle: kernel: thread: Remove unused "Running" state. | bunnei | 3 | -21/+9 | |
2020-11-29 | core: arm: Implement InvalidateCacheRange for CPU cache invalidation. | bunnei | 12 | -16/+56 | |
2020-11-29 | hle: kernel: time_manager: Avoid a crash on process exit. | bunnei | 1 | -1/+4 | |
2020-11-29 | hle: kernel: AddressArbiter: Remove unused code. | bunnei | 2 | -9/+0 | |
2020-11-29 | hle: kernel: SynchronizationObject: Use atomic_bool for is_signaled. | bunnei | 1 | -1/+2 | |
2020-11-29 | common: fiber: Use boost::context instead of native fibers on Windows. | bunnei | 3 | -116/+9 | |
2020-11-29 | hle: kernel: multicore: Replace n-JITs impl. with 4 JITs. | bunnei | 15 | -72/+124 | |
2020-11-29 | Add missing types to NpadCommunicationMode | german | 1 | -0/+2 | |
2020-11-28 | audio_core: Remove temp_mix_buffer | Chloe Marcec | 2 | -3/+1 | |
It's unused and doesn't need to be initialized | |||||
2020-11-27 | CMakeLists: disable -Winvalid-offsetof | comex | 1 | -0/+1 | |
This Clang warning complains when offsetof is used on a non-standard-layout type (i.e. any class using various C++ features), even though it works fine (and is not undefined behavior as of C++17). | |||||
2020-11-27 | tests: Fix warning about comparison between signed and unsigned | comex | 1 | -2/+2 | |
2020-11-27 | core: Eliminate remaining usages of the global system instance | Lioncash | 21 | -1593/+58 | |
Removes all remaining usages of the global system instance. After this, migration can begin to migrate to being constructed and managed entirely by the various frontends. | |||||
2020-11-27 | savedata_factory: Eliminate usage of the global system instance | Lioncash | 4 | -14/+22 | |
Now there's only two meaningful instances left in core. | |||||
2020-11-27 | Stub set and get NpadCommunicationMode | german | 4 | -2/+50 | |
2020-11-27 | service: Eliminate usages of the global system instance | Lioncash | 222 | -907/+1221 | |
Completely removes all usages of the global system instance within the services code by passing in the using system instance to the services. | |||||
2020-11-26 | codec: Fix `pragma GCC diagnostic pop` missing corresponding push | comex | 1 | -0/+1 | |
2020-11-26 | vk_shader_decompiler: Implement force early fragment tests | ReinUsesLisp | 6 | -11/+19 | |
Force early fragment tests when the 3D method is enabled. The established pipeline cache takes care of recompiling if needed. This is implemented only on Vulkan to avoid invalidating the shader cache on OpenGL. | |||||
2020-11-26 | core: Reduce string copies in GetGameFileFromPath() | Lioncash | 1 | -12/+22 | |
Eliminates some minor string churn where applicable. Also eliminates an unnecessary vector copy. | |||||
2020-11-26 | Limit queue size to 10 frames | ameerj | 1 | -0/+4 | |
Workaround for ZLA, which seems to decode and queue twice as many frames as it displays. | |||||
2020-11-26 | Implement full mouse support | german | 14 | -277/+793 | |
2020-11-26 | Add multiple udp server support | german | 10 | -267/+420 | |
2020-11-26 | Address PR feedback | ameerj | 4 | -32/+33 | |
remove some redundant moves, make deleter match naming guidelines. Co-Authored-By: LC <712067+lioncash@users.noreply.github.com> | |||||
2020-11-26 | common: Add Common::DivCeil and Common::DivCeilLog2 | ReinUsesLisp | 2 | -0/+27 | |
Add an equivalent to 'Common::AlignUp(n, d) / d' and a log2 alternative. | |||||
2020-11-26 | input_common: ignore some Clang warnings after 5c4774e8ce1d | Jan Beich | 1 | -2/+2 | |
error: unknown warning option '-Werror=unused-but-set-parameter'; did you mean '-Werror=unused-parameter'? [-Werror,-Wunknown-warning-option] error: unknown warning option '-Werror=unused-but-set-variable'; did you mean '-Werror=unused-const-variable'? [-Werror,-Wunknown-warning-option] | |||||
2020-11-25 | Queue decoded frames, cleanup decoders | ameerj | 10 | -338/+227 | |
2020-11-25 | cleanup unneeded comments and newlines | ameerj | 1 | -6/+0 | |
2020-11-25 | hid: Check if applet_resource exists in InitializeVibrationDevice | Morph | 1 | -2/+4 | |
2020-11-25 | Refactor MaxwellToSpirvComparison. Use Common::BitCast | ameerj | 3 | -31/+34 | |
Co-Authored-By: Rodrigo Locatti <reinuseslisp@airmail.cc> | |||||
2020-11-25 | Address PR feedback from Rein | ameerj | 5 | -40/+31 | |
2020-11-25 | vulkan_renderer: Alpha Test Culling Implementation | ameerj | 5 | -2/+76 | |
Used by various textures in many titles, e.g. SSBU menu. | |||||
2020-11-25 | core: cpu_manager: Fix shutdown crash when closing before emulation starts. | bunnei | 1 | -7/+17 | |
2020-11-25 | frontend: yuzu (qt): Register a callback for ExecuteProgram. | bunnei | 4 | -7/+38 | |
2020-11-25 | service: am: Implement ExecuteProgram and required stubs. | bunnei | 2 | -3/+34 | |
- This is used by Super Mario 3D All-Stars. | |||||
2020-11-25 | core: loader: Implement support for loading indexed programs. | bunnei | 12 | -26/+74 | |
2020-11-24 | hle: services: Fix a crash with improper NVFlinger lifetime management. (#4977) | bunnei | 17 | -100/+104 | |
* hle: services: Fix a crash with improper NVFlinger lifetime management. - This crash would happen when attempting to shutdown yuzu early on in boot. | |||||
2020-11-24 | nvdrv, video_core: Don't index out of bounds when given invalid syncpoint ID | comex | 2 | -13/+20 | |
- Use .at() instead of raw indexing when dealing with untrusted indices. - For the special case of WaitFence with syncpoint id UINT32_MAX, instead of crashing, log an error and ignore. This is what I get when running Super Mario Maker 2. | |||||
2020-11-24 | input_common: Fix typo in gc_poller.cpp with [[maybe_unused]]. | bunnei | 1 | -2/+2 | |
2020-11-24 | nvservices: Reintroducee IoctlCtrl | Chloe Marcec | 24 | -91/+214 | |
Fixes regression caused by #4907 which caused games like Breath of the Wild 1.0.0 not to boot. | |||||
2020-11-24 | input_common: Add more missing [[maybe_unused]] from #4927. | bunnei | 3 | -4/+6 | |
2020-11-24 | Fix warnings in core/frontend/input.h with [[maybe_unused]] | bunnei | 1 | -1/+3 | |
Fixes build break due to #4927 | |||||
2020-11-23 | Overhaul EmuWindow::PollEvents to fix yuzu-cmd calling SDL_PollEvents off main thread | comex | 10 | -73/+68 | |
EmuWindow::PollEvents was called from the GPU thread (or the CPU thread in sync-GPU mode) when swapping buffers. It had three implementations: - In GRenderWindow, it didn't actually poll events, just set a flag and emit a signal to indicate that a frame was displayed. - In EmuWindow_SDL2_Hide, it did nothing. - In EmuWindow_SDL2, it did call SDL_PollEvents, but this is wrong because SDL_PollEvents is supposed to be called on the thread that set up video - in this case, the main thread, which was sleeping in a busyloop (regardless of whether sync-GPU was enabled). On macOS this causes a crash. To fix this: - Rename EmuWindow::PollEvents to OnFrameDisplayed, and give it a default implementation that does nothing. - In EmuWindow_SDL2, do not override OnFrameDisplayed, but instead have the main thread call SDL_WaitEvent in a loop. | |||||
2020-11-23 | svc: Remove unnecessary [[maybe_unused]] tag | Lioncash | 1 | -1/+1 | |
The parameter is used in this function, so this suppression isn't necessary. | |||||
2020-11-22 | input_common: Treat warnings as errors | Lioncash | 8 | -10/+23 | |
Migrates over warnings as errors for input common to match how the common library treats warnings as errors. | |||||
2020-11-21 | applets/controller: Use a pair of emulated controller index to controller type | Morph | 2 | -44/+96 | |
2020-11-21 | configure_input_player: Use the npad style set to show the available controllers | Morph | 2 | -55/+96 | |
This will reduce the likelihood of an invalid controller type to be set within a game | |||||
2020-11-21 | gl_rasterizer: Remove warning of untested alpha test | ReinUsesLisp | 1 | -4/+0 | |
Alpha test has been proven to only affect the first render target. | |||||
2020-11-20 | olsc: Move member initialization to after member functions. | bunnei | 1 | -2/+2 | |
2020-11-20 | async_shaders: emplace threads into the worker thread vector | Lioncash | 1 | -2/+2 | |
Same behavior, but constructs the threads in place instead of moving them. | |||||
2020-11-20 | async_shaders: Simplify implementation of GetCompletedWork() | Lioncash | 1 | -2/+1 | |
This is equivalent to moving all the contents and then clearing the vector. This avoids a redundant allocation. | |||||
2020-11-20 | async_shaders: Simplify moving data into the pending queue | Lioncash | 1 | -13/+8 | |
2020-11-20 | async_shaders: std::move data within QueueVulkanShader() | Lioncash | 1 | -2/+2 | |
Same behavior, but avoids redundant copies. While we're at it, we can simplify the pushing of the parameters into the pending queue. | |||||
2020-11-20 | gl_rasterizer: Make floating-point literal a float | Lioncash | 1 | -1/+1 | |
Gets rid of an unnecessary expansion from float to double. | |||||
2020-11-20 | shader_bytecode: Make use of [[nodiscard]] where applicable | Lioncash | 1 | -73/+79 | |
Ensures that all queried values are made use of. | |||||
2020-11-20 | shader_bytecode: Eliminate variable shadowing | Lioncash | 1 | -15/+17 | |
2020-11-20 | common/bit_cast: Add function matching std::bit_cast without constexpr | ReinUsesLisp | 2 | -0/+23 | |
Add a std::bit_cast-like function archiving the same runtime results as the standard function, without compile time support. This allows us to use bit_cast while we wait for compiler support, it can be trivially replaced in the future. | |||||
2020-11-19 | hle: service: Stub OLSC Initialize and SetSaveDataBackupSettingEnabled functions. | bunnei | 6 | -0/+91 | |
- Used by Animal Cross: New Horizons v1.6.0 update, minimal stub gets this update working. | |||||
2020-11-19 | Modify rumble amplification | german77 | 2 | -4/+3 | |
2020-11-19 | virtual_buffer: Do nothing on resize() calls with same sizes | Lioncash | 1 | -1/+6 | |
Prevents us from churning memory by freeing and reallocating a memory block that would have already been adequate as is. | |||||
2020-11-18 | patch_manager: Remove usages of the global system instance | Lioncash | 26 | -157/+259 | |
With this, only 19 usages of the global system instance remain within the core library. We're almost there. | |||||
2020-11-18 | core: Remove unused private Init function for the System class | Lioncash | 2 | -16/+4 | |
This isn't used, so it can be removed. | |||||
2020-11-18 | core: Make use of [[nodiscard]] with the System class | Lioncash | 4 | -85/+82 | |
Given this is a central class, we should flag cases where the return value of some functions not being used is likely a bug. | |||||
2020-11-18 | configure_input_player: Use static qualifier for IsProfileNameValid() | Lioncash | 1 | -1/+1 | |
This is a static member function, so we don't need use an existing instance to call this function. | |||||
2020-11-18 | virtual_buffer: Add compile-time type-safety guarantees with VirtualBuffer | Lioncash | 1 | -0/+6 | |
VirtualBuffer makes use of VirtualAlloc (on Windows) and mmap() (on other platforms). Neither of these ensure that non-trivial objects are properly constructed in the allocated memory. To prevent potential undefined behavior occurring due to that, we can add a static assert to loudly complain about cases where that is done. | |||||
2020-11-18 | page_table: Allow page tables to be moved | Lioncash | 4 | -9/+30 | |
Makes page tables and virtual buffers able to be moved, but not copied, making the interface more flexible. Previously, with the destructor specified, but no move assignment or constructor specified, they wouldn't be implicitly generated. | |||||
2020-11-18 | page_table: Add missing doxygen parameters to Resize() | Lioncash | 1 | -0/+2 | |
Resolves two -Wdocumentation warnings. | |||||
2020-11-18 | page_table: Remove unnecessary header inclusions | Lioncash | 1 | -4/+0 | |
Prevents indirect inclusions for these headers. | |||||
2020-11-17 | rasterizer_interface: Make use of [[nodiscard]] where applicable | Lioncash | 1 | -8/+9 | |
2020-11-17 | render_base: Make use of [[nodiscard]] where applicable | Lioncash | 1 | -11/+11 | |
2020-11-17 | gpu: Make use of [[nodiscard]] where applicable | Lioncash | 1 | -31/+35 | |
2020-11-17 | Addressed changes | Chloe Marcec | 4 | -10/+13 | |
2020-11-17 | audren: Make use of nodiscard, rework downmixing, release all buffers | Chloe Marcec | 13 | -102/+194 | |
Preliminary work for upmixing & general cleanup. Fixes basic issues in games such as Shovel Knight and slightly improves the LEGO games. Upmixing stitll needs to be implemented. Audio levels in a few games will be fixed as we now use the downmix coefficients when possible instead of supplying our own | |||||
2020-11-16 | sdl_impl: Pump SDL Events at 1000 Hz | Morph | 1 | -1/+1 | |
2020-11-16 | configure_input: Accommodate for the mouse input device engine | Morph | 2 | -2/+18 | |
2020-11-16 | hid: Reimplement Begin/EndPermitVibrationSession | Morph | 3 | -5/+17 | |
Upon further investigation, these commands allow temporary vibrations even when the "Controller Vibration" system setting is disabled. As a result, vibrations are allowed when either the system setting or this flag is set to true. Therefore, we can only block vibrations when both flags are set to false. | |||||
2020-11-16 | controllers/npad: Load input devices on init | Morph | 1 | -0/+2 | |
2020-11-16 | configure_input: Update the input profiles for other player tabs | Morph | 4 | -11/+38 | |
2020-11-16 | general: Fix compiler warnings on linux and miscellaneous changes | Morph | 12 | -22/+31 | |
2020-11-16 | sdl_impl: Revert to the "old" method of mapping sticks | Morph | 3 | -33/+29 | |
Not all controllers have a SDL_GameController binding. This caused controllers not present in the SDL GameController database to have buttons mapped instead of axes. Furthermore, it was not possible to invert the axes when it could be useful such as emulating a horizontal single joycon or other potential cases. This allows us to invert the axes by reversing the order of mapping (vertical, then horizontal). | |||||
2020-11-16 | applets/controller: Change the input button to create input profiles | Morph | 10 | -100/+117 | |
Co-authored-by: Its-Rei <kupfel@gmail.com> | |||||
2020-11-16 | controllers/npad: Remove the old vibration filter | Morph | 4 | -65/+64 | |
Previously we used a vibration filter that filters out amplitudes close to each other. It turns out there are cases where this results into vibrations that are too inaccurate. Remove this and move the 100Hz vibration filter (Only allowing a maximum of 100 vibrations per second) from sdl_impl to npad when enable_accurate_vibrations is set to false. | |||||
2020-11-16 | input: Disconnect a controller prior to connecting a new one | Morph | 2 | -50/+73 | |
Some games do not respond to a change in controller type if 1) The controller is not disconnected prior to being reconnected and/or 2) The controller is reconnected instantly after being disconnected. Since it is not possible to change controllers instantly on hardware and requiring a disconnect prior to connecting a new one, we should emulate this as well with a small delay, fixing the aforementioned issue. | |||||
2020-11-16 | hid: Implement InitializeVibrationDevice and IsVibrationDeviceMounted | Morph | 3 | -12/+66 | |
2020-11-16 | input_common: Add VibrationDevice and VibrationDeviceFactory | Morph | 19 | -101/+327 | |
A vibration device is an input device that returns an unsigned byte as status. It represents whether the vibration device supports vibration or not. If the status returns 1, it supports vibration. Otherwise, it does not support vibration. | |||||
2020-11-16 | configure_input: Add per-player vibration | Morph | 16 | -28/+730 | |
Allows for enabling and modifying vibration and vibration strength per player. Also adds a toggle for enabling/disabling accurate vibrations. Co-authored-by: Its-Rei <kupfel@gmail.com> | |||||
2020-11-16 | settings: Remove global vibration strength modifier | Morph | 9 | -19/+1 | |
This will be replaced in favor of per-player vibration strength modifiers. | |||||
2020-11-16 | hid: Mark Begin/EndPermitVibrationSession as stubs | Morph | 3 | -18/+4 | |
The implementation of these commands seem incomplete and causes rumble in Super Mario Party to stop working since only EndPermitVibrationSession is called. Thus, these are better off being marked as a stub until this can be investigated more thoroughly. | |||||
2020-11-16 | controllers/npad: Send an empty vibration on destruction/deactivation | Morph | 3 | -22/+38 | |
This stops all controllers from continuously vibrating when emulation is stopped. | |||||
2020-11-16 | hid: Stub IsVibrationDeviceMounted | Morph | 2 | -1/+23 | |
- Used in Super Mario Odyssey | |||||
2020-11-16 | controllers/npad: Add heuristics to reduce rumble state changes | Morph | 3 | -35/+72 | |
Sending too many state changes in a short period of time can cause massive performance issues. As a result, we have to use several heuristics to reduce the number of state changes to minimize/eliminate this performance impact while maintaining the quality of these vibrations as much as possible. | |||||
2020-11-16 | configure_input: Hook up the vibration percentage spinbox | Morph | 11 | -3/+26 | |
This allows setting the vibration strength percentage anywhere from 1% to 100%. Also hooks up the remaining motion button and checkbox in the Controller Applet. | |||||
2020-11-16 | controllers/npad: Stop games from vibrating incorrect controllers | Morph | 1 | -0/+10 | |
Fixes vibration in 1-2 Switch and potentially other games where they would vibrate both players' joycons at the same time. | |||||
2020-11-16 | hid: Fix controller rumble based on new research | Morph | 3 | -43/+69 | |
This fixes the issue where rumble is only sent to the first controller. Now, individual controllers can receive their own rumble commands. | |||||
2020-11-16 | hid: Pop a struct of parameters instead of popping individual parameters | Morph | 1 | -103/+237 | |
Some parameters need to be doubleword aligned due to the presence of the applet_resource_user_id. Previously, this value was invalid in many commands where it was not doubleword aligned when popped. | |||||
2020-11-16 | hid: Reorder all HID commands | Morph | 5 | -217/+232 | |
Reorders all HID commands in command id order. | |||||
2020-11-16 | hid: Implement GetVibrationDeviceInfo | Morph | 2 | -3/+39 | |
The first u32 describes the vibration device type which is a Linear Resonant Actuator used in Nintendo Switch controller hardware. The second u32 describes the vibration device position, in this case distinguishing between left and right vibration actuators. Pro Controllers have 2 LRAs each that can vibrate independently of each other, which means they have 2 distinct vibration device handles to distinguish between the two actuators. Similarly for joycons, the left joycon can be distinguished from the right joycon through the vibration device handle since each joycon has 1 LRA. | |||||
2020-11-16 | hid: Stub InitializeVibrationDevice | Morph | 1 | -3/+11 | |
2020-11-16 | controllers/npad: Rename NPadType to NpadStyleSet | Morph | 3 | -9/+9 | |
This more accurately represents the underlying type and avoids confusion with NpadType | |||||
2020-11-16 | controllers/npad: Add DeviceHandle struct | Morph | 1 | -27/+50 | |
A DeviceHandle describes a vibration device or six-axis sensor based on the npad type, npad id, and device index/position | |||||
2020-11-16 | configure_input_player: Change "Defaults" button behavior | Morph | 2 | -35/+30 | |
RestoreDefaults() now restores the selected devices' mappings using UpdateMappingWithDefaults(). This allows us to move the keyboard mapping from RestoreDefaults() to UpdateMappingWithDefaults(). | |||||
2020-11-16 | settings: Preparation for per-game input settings | Morph | 19 | -115/+167 | |
2020-11-16 | udp/client: Reduce testing period to 5 seconds | Morph | 1 | -1/+1 | |
2020-11-16 | config: Migrate config files into config/custom | Morph | 4 | -21/+61 | |
Co-authored-by: lat9nq <lat9nq@virginia.edu> | |||||
2020-11-16 | controllers/npad: Connect a controller on init if none are connected | Morph | 2 | -1/+15 | |
2020-11-16 | applets/controller: Auto accept a valid single player configuration | Morph | 3 | -14/+24 | |
2020-11-16 | bootmanager: Allow mouse clicks only if touch is disabled | Morph | 1 | -3/+13 | |
Previously mouse clicks will not register when touch is disabled. This rectifies that and allows mouse clicks to be mapped to other buttons if the touchscreen is disabled. | |||||
2020-11-16 | input_profiles: Implement input profiles | Morph | 13 | -130/+509 | |
2020-11-16 | configure_input_player: Implement input exclusivity and persistence | Morph | 4 | -138/+205 | |
With this, the "Input Devices" combobox should accurately reflect the input device being used and disallows inputs from other input devices unless the input device is set to "Any". | |||||
2020-11-16 | ui/themes: Cleanup UI | Morph | 13 | -397/+263 | |
2020-11-15 | motion_input: Mark constructor as explicit | Lioncash | 1 | -1/+1 | |
2020-11-15 | motion_input: Mark member functions as [[nodiscard]] where applicable | Lioncash | 1 | -10/+11 | |
2020-11-11 | maxwell_3d: Use insert instead of loop push_back | ReinUsesLisp | 1 | -3/+1 | |
This reduces the overhead of bounds checking on each element. It won't reduce the cost of allocation because usually this vector's capacity is usually large enough to hold whatever we push to it. | |||||
2020-11-11 | maxwell_3d: Move code to separate functions | ReinUsesLisp | 2 | -151/+124 | |
Deduplicate some code and put it in separate functions so it's easier to understand and profile. | |||||
2020-11-10 | fix minor clang error | german | 1 | -1/+1 | |
2020-11-10 | Addressed issues | Chloe Marcec | 10 | -17/+86 | |
2020-11-10 | core: Make nvservices more standardized | Chloe Marcec | 26 | -903/+1156 | |
2020-11-10 | bootmanager: Address review comments | lat9nq | 1 | -12/+16 | |
Changes QMessageBox usages to warnings, as the problems they bring to light are being safely handled by the application and do not warrant something of the "critical" level. Changes LOG_CRITICAL to LOG_ERROR for the same reason. Preferring ERROR to WARNING as yuzu is denying loading of any guest applications after checking for these conditions. Moved logging the GL_RENDERER string into GetUnsupportedGLExtensions() to make more clear that unsupported extensions were already being logged. Makes placement of the logs easier to understand later, as well. | |||||
2020-11-10 | bootmanager: Log and show GL_RENDERER string when GPU is insufficient | lat9nq | 1 | -3/+19 | |
Changes the first message to not include the OpenGL version, as the error is caused by OpenGL failing to load. Adds a new check for OpenGL version 4.3. This will display a message with a similar error as well as the GL_RENDERER string. Adds a CRITICAL log message when triggered. This prevents a crash with yuzu trying to use older OpenGL versions. Modifies the unsupported extension message to output the GL_RENDERER string in the message, as well as logging the string. | |||||
2020-11-08 | ipc_helpers: Remove usage of the global system instance | Lioncash | 16 | -7/+23 | |
Resolves numerous deprecation warnings throughout the codebase due to inclusion of this header. Now building core should be significantly less noisy (and also relying on less global state). This also uncovered quite a few modules that were relying on indirect includes, which have also been fixed. | |||||
2020-11-08 | cpu_interrupt_handler: Mark move contructor/assignment as deleted | Lioncash | 1 | -2/+2 | |
The interrupt handler contains a std::atomic_bool, which isn't copyable or movable, so the special move member functions will always be deleted, despite being defaulted. This can resolve warnings on clang and GCC. | |||||
2020-11-08 | Allow to dial any angle with digital joystick | german | 1 | -19/+103 | |
2020-11-08 | applets: Rename LibraryAppletVersion to ControllerAppletVersion | Morph | 2 | -15/+15 | |
2020-11-08 | applets/controller: Pop normal data for StrapGuide and FirmwareUpdate | Morph | 2 | -6/+19 | |
2020-11-08 | applets/controller: Introduce additional checks for mode and caller | Morph | 2 | -5/+39 | |
Some games like Cave Story+ set invalid values in the ControllerPrivateArg's mode and caller fields. Use other fields to determine the appropriate mode and caller should either or both fields be invalid. | |||||
2020-11-08 | applets/controller: Add ControllerUpdateFirmwareArg struct | Morph | 1 | -0/+7 | |
2020-11-07 | settings: log value of CPU_Accuracy | lat9nq | 1 | -0/+1 | |
2020-11-07 | video_core: dma_pusher: Remove integrity check on command lists. | bunnei | 3 | -29/+1 | |
- This seems to cause softlocks in Breath of the Wild. | |||||
2020-11-07 | hle: service: caps_u: Stub GetAlbumFileList3AaeAruid. | bunnei | 2 | -9/+17 | |
- This works similiar to GetAlbumContentsFileListForApplication. - Since we do not implement the album, this should be safe to stub for now. - Used by Super Smash Bros. Ultimate (newer updates) in World of Light. | |||||
2020-11-07 | common/fiber: Move all member variables into impl class | Lioncash | 2 | -89/+86 | |
Hides all of the implementation details for users of the class. This has the benefit of reducing includes and also making the fiber classes movable again. | |||||
2020-11-06 | settings: Simplify initializer of resolution factor | Lioncash | 1 | -1/+1 | |
This can use a braced initializer to accomplish the same thing with less code. | |||||
2020-11-05 | General: Fix clang build | Lioncash | 4 | -7/+14 | |
Allows building on clang to work again | |||||
2020-11-04 | core/settings: Move configuring_global behind an API | Lioncash | 9 | -39/+50 | |
Rather than have directly modified global state here, we can make it an implementation detail and have an interface that changes are queried through. | |||||
2020-11-04 | core: Remove usage of unicorn | Lioncash | 11 | -418/+15 | |
Unicorn long-since lost most of its use, due to dynarmic gaining support for handling most instructions. At this point any further issues encountered should be used to make dynarmic better. This also allows us to remove our dependency on Python. | |||||
2020-11-02 | common: Enable warnings as errors | Lioncash | 9 | -31/+49 | |
Cleans up common so that we can enable warnings as errors. | |||||
2020-11-02 | nvdec: Make use of [[nodiscard]] where applicable | Lioncash | 7 | -16/+16 | |
Prevents bugs from occurring where the results of a function are accidentally discarded | |||||
2020-11-01 | fixup! hle service: nvdrv: nvhost_gpu: Update to use SyncpointManager and other improvements. | bunnei | 2 | -3/+11 | |
2020-11-01 | core: Initialize GPU before services. | bunnei | 1 | -4/+6 | |
2020-11-01 | hle service: nvdrv: nvhost_gpu: Update to use SyncpointManager and other improvements. | bunnei | 3 | -46/+106 | |
- Refactor so that SubmitGPFIFO and KickoffPB use shared functionality. - Implement add_wait and add_increment flags. | |||||
2020-11-01 | video_core: dma_pusher: Add support for integrity checks. | bunnei | 2 | -0/+27 | |
- Log corrupted command lists, rather than crash. | |||||
2020-11-01 | video_core: dma_pusher: Add support for prefetched command lists. | bunnei | 2 | -25/+52 | |
2020-11-01 | service: hle: nvflinger: Fix potential shutdown crash when GPU is destroyed. | bunnei | 1 | -0/+4 | |
2020-11-01 | video_core: gpu: Implement WaitFence and IncrementSyncPoint. | bunnei | 3 | -28/+70 | |
2020-11-01 | hle service: nvdrv: nvhost_ctrl: Update to use SyncpointManager. | bunnei | 3 | -9/+31 | |
2020-11-01 | hle service: nvdrv: Update to instantiate SyncpointManager. | bunnei | 2 | -5/+18 | |
2020-11-01 | hle: service: nvdrv: Implement SyncpointManager, to manage syncpoints. | bunnei | 4 | -1/+127 | |
2020-11-01 | Rename to align with switchbrew and remove gpu function (#4714) | Levi Behunin | 2 | -16/+10 | |
* Rename to align with switchbrew * Rename to align with switchbrew and remove gpu function that checks if clearing should be done. | |||||
2020-10-31 | hle: service: ldr: Implement UnloadNrr. | bunnei | 1 | -1/+15 | |
- Used by Final Fantasy X/X-2 HD Remaster. | |||||
2020-10-30 | CMakeLists: Resolve MSVC build failures | Lioncash | 1 | -1/+0 | |
Prevents the compiler tripping up about Windows headers. | |||||
2020-10-30 | video_core: unbreak -Werror in NVDEC with Clang | Jan Beich | 1 | -1/+1 | |
src/core/hle/service/nvdrv/devices/nvhost_nvdec_common.cpp:41:15: error: unused variable 'OutOfMemory' [-Werror,-Wunused-const-variable] constexpr u32 OutOfMemory{static_cast<u32>(-12)}; ^ | |||||
2020-10-30 | General: Catch more expressions with no effect on MSVC | Lioncash | 1 | -0/+4 | |
MSVC lets us fine-tune catching expressions with no side-effects a little more. | |||||
2020-10-30 | General: Make ignoring a discarded return value an error | Lioncash | 3 | -6/+17 | |
Allows our CI to catch more potential bugs. This also removes the [[nodiscard]] attribute of IOFile's Open member function. There are cases where a file may want to be opened, but have the status of it checked at a later time. | |||||
2020-10-30 | common/stream: Be explicit with copy and move operators | Lioncash | 1 | -3/+9 | |
2020-10-30 | vp9: Be explicit with copy and move operators | Lioncash | 1 | -0/+18 | |
It's deprecated in the language to autogenerate these if the destructor for a type is specified, so we can explicitly specify how we want these to be generated. | |||||
2020-10-30 | vp9: Mark functions with [[nodiscard]] where applicable | Lioncash | 2 | -13/+13 | |
Prevents values from mistakenly being discarded in cases where it's a bug to do so. | |||||
2020-10-30 | vp9: Provide a default initializer for "hidden" member | Lioncash | 1 | -1/+1 | |
The API of VP9 exposes a WasFrameHidden() function which accesses this member. Given the constructor previously didn't initialize this member, it's a potential vector for an uninitialized read. Instead, we can initialize this to a deterministic value to prevent that from occurring. | |||||
2020-10-30 | vp9: Make some member functions internally linked | Lioncash | 2 | -58/+54 | |
These helper functions don't directly modify any member state and can be hidden from view. | |||||
2020-10-30 | General: Resolve a few missing initializer warnings | Lioncash | 5 | -4/+24 | |
Resolves a few -Wmissing-initializer warnings. | |||||
2020-10-29 | async_shaders: Increase Async worker thread count for 8+ thread cpus | ameerj | 1 | -8/+9 | |
Adds 1 async worker thread for every 2 available threads above 8 | |||||
2020-10-29 | kernel/process: Add missing <ctime> include | Morph | 1 | -0/+1 | |
Fixes compilation on MSVC | |||||
2020-10-29 | web_service: follow-up fix to #4842 ... | liushuyu | 1 | -5/+0 | |
* The web_service http request is now fixed on Windows (R) platform. * The issue is due to a complicated race-condition in `httplib`, a detailed explanation is available at https://github.com/yhirose/cpp-httplib/pull/701 * A pending Pull Request on `httplib` has been applied to remedy the said race-condition. * The socket availability check is removed due to a behavioral chice of `httplib` that a socket will not be created before any actual request is sent. | |||||
2020-10-29 | Add hotplug, rumble and fix 3rd party adapters for the GC adapter | german | 3 | -303/+433 | |
2020-10-29 | web_service: web_backend: Handle socket errors with GenericRequest. | bunnei | 1 | -0/+11 | |
- Fixes a shutdown crash when we try to submit telemetry if there is a service issue. | |||||
2020-10-29 | video_core: cdma_pusher: Add missing LOG_DEBUG field in ExecuteCommand. | bunnei | 1 | -1/+1 | |
2020-10-28 | shader: Partially implement texture cube array shadow | ReinUsesLisp | 3 | -25/+37 | |
This implements texture cube arrays with shadow comparisons but doesn't fix the asserts related to it. Fixes out of bounds reads on swizzle constructors and makes them use bounds checked ::at instead of the unsafe operator[]. | |||||
2020-10-28 | shader/arithmetic: Implement FCMP immediate + register variant | ReinUsesLisp | 2 | -1/+4 | |
Trivially add the encoding for this. | |||||
2020-10-28 | video_core: Enforce -Wredundant-move and -Wpessimizing-move | ReinUsesLisp | 4 | -4/+5 | |
Silence three warnings and make them errors to avoid introducing more in the future. | |||||
2020-10-28 | video_core: Enforce -Werror=type-limits | ReinUsesLisp | 2 | -1/+2 | |
Silences one warning and avoids introducing more in the future. | |||||
2020-10-28 | common/fiber: Take shared_ptr<Fiber> by copy in YieldTo | ReinUsesLisp | 2 | -3/+3 | |
YieldTo does not intend to modify the passed shared_ptrs. Pass it by copy to keep a reference count while this function executes. | |||||
2020-10-28 | tests: Fix data race in fibers test | ReinUsesLisp | 1 | -31/+40 | |
Previous to this commit, the tests were using operator[] from unordered_map to query elements but this silently inserts empty elements when they don't exist. If all threads were executed without concurrency, this wouldn't be an issue, but the same unordered_map could be written from two threads at the same time. This is a data race and makes some previously inserted elements invisible for a short period of time, causing them to insert and return an empty element. This default constructed element (a zero) was used to index an array of fibers that asserted when one of them was nullptr, shutting the test session off. To address this issue, lock on thread id reads and writes. This could be a shared mutex to allow concurrent reads, but the definition of std::this_thread::get_id is fuzzy when using non-standard techniques like fibers. I opted to use a standard mutex. While we are at it, fix the included headers. | |||||
2020-10-28 | service: Update function tables | Lioncash | 5 | -1/+7 | |
Updates function tables according to info on SwitchBrew. | |||||
2020-10-27 | web_backend: fix a regression introduced in 39c8d18 | liushuyu | 2 | -20/+2 | |
* A regression was in 39c8d18 and token verification function was broken. * The reason being `httplib` now requires OpenSSL 1.1+ API while LibreSSL 2.x provided OpenSSL 1.0 compatible API. * The bundled LibreSSL has been updated to 3.2.2 so it now provides OpenSSL 1.1 compatible API now. * Also the path hint has been added so that it will find the correct path to the CA certs on *nix systems. * An option is provided so that *nix system distributions/providers can use their own SSL implementations when compiling Yuzu/Citra to (hopefully) complies with their maintenance guidelines. * LURLParse is also removed since `httplib` can handle `scheme:host:port` string itself now. | |||||
2020-10-27 | sync_manager: Amend parameter order of calls to SyncptIncr constructor | Lioncash | 2 | -9/+9 | |
Corrects some cases where the arguments would be incorrectly swapped. | |||||
2020-10-27 | h264: Make WriteUe take a u32 | Lioncash | 2 | -7/+8 | |
Enforces the type of the desired value in calling code. | |||||
2020-10-27 | vp9: std::move buffer within ComposeFrameHeader() | Lioncash | 1 | -1/+1 | |
We can move the buffer here to avoid a heap reallocation | |||||
2020-10-27 | vp9: Remove dead code | Lioncash | 1 | -6/+0 | |
2020-10-27 | vp9: Join declarations with assignments | Lioncash | 1 | -7/+8 | |
2020-10-27 | vp9: Remove pessimizing moves | Lioncash | 1 | -2/+2 | |
The move will already occur without std::move. | |||||
2020-10-27 | vp9: Resolve variable shadowing | Lioncash | 1 | -4/+4 | |
2020-10-27 | nvdec: Tidy up header includes | Lioncash | 13 | -62/+59 | |
Prevents a few unnecessary inclusions. | |||||
2020-10-27 | yuzu: settings: Enable multicore, asynch GPU, and assembly shaders by default. | bunnei | 3 | -11/+11 | |
- In general, this is now the preferred settings for most games. # Conflicts: # src/yuzu/configuration/config.cpp | |||||
2020-10-27 | hle/kernel: Remove unused registered_core_threads to fix data races | ReinUsesLisp | 1 | -5/+0 | |
This member was only used on asserts and it triggered data races. Remove it to fix them. | |||||
2020-10-27 | video_core: NVDEC Implementation | ameerj | 50 | -310/+3909 | |
This commit aims to implement the NVDEC (Nvidia Decoder) functionality, with video frame decoding being handled by the FFmpeg library. The process begins with Ioctl commands being sent to the NVDEC and VIC (Video Image Composer) emulated devices. These allocate the necessary GPU buffers for the frame data, along with providing information on the incoming video data. A Submit command then signals the GPU to process and decode the frame data. To decode the frame, the respective codec's header must be manually composed from the information provided by NVDEC, then sent with the raw frame data to the ffmpeg library. Currently, H264 and VP9 are supported, with VP9 having some minor artifacting issues related mainly to the reference frame composition in its uncompressed header. Async GPU is not properly implemented at the moment. Co-Authored-By: David <25727384+ogniK5377@users.noreply.github.com> | |||||
2020-10-27 | kernel: Use the current time as the default RNG seed | lat9nq | 1 | -1/+1 | |
Use the current time, not zero, as the default RNG seed. | |||||
2020-10-27 | controller: Pass ControllerParameters by reference in ReconfigureControllers() | Lioncash | 4 | -7/+9 | |
Prevents unnecessary copies and heap reallocations from occurring. | |||||
2020-10-27 | hle: services: TimeZoneContentManager: This can be made explicit. | bunnei | 1 | -1/+1 | |
2020-10-27 | core: cpu_manager: Add missing call to MicroProfileOnThreadExit(). | bunnei | 1 | -0/+2 | |
- Fixes an occasional crash when trying to launch subsequent games. | |||||
2020-10-25 | general: Use template deduction guides for lock_guard | Lioncash | 2 | -2/+2 | |
Same behavior, less code. | |||||
2020-10-25 | controller: Convert led_patterns integer literals to bool literals | Lioncash | 1 | -9/+9 | |
'bool' isn't always guaranteed to be the same size as an int, so this can technically cause truncation warnings if we support other platforms. | |||||
2020-10-25 | applets/profile_select: Resolve a warning in exec() | Morph | 1 | -1/+1 | |
Resolves a warning where not all control paths return a value. | |||||
2020-10-22 | Don't ask for profile when there's only one. | Kewlan | 3 | -16/+20 | |
2020-10-22 | core: Fix clang build pt.3 | Lioncash | 4 | -16/+6 | |
Should finally resolve building with clang. | |||||
2020-10-21 | sdl_impl: Fix controller reconnection issues | Morph | 1 | -85/+84 | |
It turns out that after a controller is disconnected, there is a chance that events from the previous controller are sent/processed after it has been disconnected. This causes the previously disconnected controller to reappear as connected due to GetSDLJoystickBySDLID() emplacing this controller back to the map. Fix this by only returning an SDLJoystick if and only if it exists in the map. | |||||
2020-10-21 | core: Fix clang build pt.2 | Lioncash | 2 | -4/+10 | |
Resolves the clang build issue in a more unintrusive way. | |||||
2020-10-21 | Revert "core: Fix clang build" | bunnei | 104 | -904/+665 | |
2020-10-21 | video_core: Conditially activate relevant compiler warnings | Lioncash | 1 | -2/+4 | |
These compiler flags aren't shared with clang, so specifying these flags unconditionally can lead to a bit of warning spam. While we're in the area, we can also enable -Wunused-but-set-parameter given this is almost always a bug. | |||||
2020-10-21 | kernel: Fix build with recent compiler flag changes | Lioncash | 1 | -4/+8 | |
This slipped through the cracks due to another change being merged before the compiler flag changes. | |||||
2020-10-20 | configure_input_player: Fix modifier buttons | Morph | 3 | -25/+23 | |
Fix them for real this time, now they finally work. | |||||
2020-10-20 | gl_arb_decompiler: Implement robust buffer operations | ReinUsesLisp | 3 | -33/+54 | |
This emulates the behavior we get on GLSL with regular SSBOs with a pointer + length pair. It aims to be consistent with the crashes we might get. Out of bounds stores are ignored. Atomics are ignored and return zero. Reads return zero. | |||||
2020-10-20 | Added remaining params | David Marcec | 1 | -1/+4 | |
2020-10-20 | nifm: GetAppletInfo stub | David Marcec | 1 | -1/+8 | |
Fixes crash for Catherine Full Body | |||||
2020-10-18 | core: Add boxcat sources with target_sources | Lioncash | 1 | -7/+7 | |
Same behavior, minus a script variable. | |||||
2020-10-18 | core: Fix clang build | Lioncash | 104 | -665/+904 | |
Recent changes to the build system that made more warnings be flagged as errors caused building via clang to break. Fixes #4795 | |||||
2020-10-17 | mii/manager: Make use of unused lower bound in GetRandomValue() | Lioncash | 1 | -1/+1 | |
Previously, the lower bound wasn't being used and zero was being used as the lower bound every time this function was called. This affects the outcome of some of the randomized entries a little bit, for example, the lower-bound for beard and mustache flags was supposed to be 1, not 0. Aside from these cases, the bug didn't affect anything else. | |||||
2020-10-17 | service: bcat: Check client connection before interacting with socket. | bunnei | 1 | -0/+10 | |
- Fixes a crash when BCAT service is offline. | |||||
2020-10-16 | udp/client: Make use of designated initializers in TestCommunication() | Lioncash | 1 | -2/+5 | |
Same behavior, but makes the callback list nicer to look at. | |||||
2020-10-16 | udp/client: Take std::function by const reference with TestCommunication() | Lioncash | 2 | -5/+5 | |
Avoids redundant copies. | |||||
2020-10-16 | sdl_impl: Erase the SDLJoystick entry after removing a controller | Morph | 1 | -15/+13 | |
Previously, disconnecting a controller still leaves a null SDLJoystick entry within the vector of SDLJoysticks mapped by GUID. When a DirectInput device of the same GUID is reconnected, it adds that device to a new port causing non-detectable input. Furthermore, opening the "Configure" menu would cause yuzu to crash since it first tries to resolve the name of a null SDLJoystick entry that was not removed. Resolve this by properly erasing the SDLJoystick entry from the vector. | |||||
2020-10-16 | input_common/CMakeLists: Make some warnings errors | Lioncash | 19 | -203/+306 | |
Makes the input_common code warnings consistent with the rest of the codebase. | |||||
2020-10-15 | service: acc: Stub IManagerForApplication::StoreOpenContext. | bunnei | 1 | -1/+7 | |
- Used by Super Mario 3D All-Stars. | |||||
2020-10-14 | hle: service: vi: Implement BufferQueue::CancelBuffer. | bunnei | 3 | -14/+53 | |
- This is used by Super Mario 3D All-Stars. | |||||
2020-10-13 | kernel: Implement host thread register methods without locking | ReinUsesLisp | 1 | -28/+38 | |
Locks on GetCurrentHostThreadID were causing performance issues according to Visual Studio's profiler. It was consuming twice the time as arm_interface.Run(). The cost was not in the function itself but in the lockinig it required. Reimplement these functions using atomics and static storage instead of an unordered_map. This is a side effect to avoid locking and using linked lists for reads. Replace unordered_map with a linear search. | |||||
2020-10-13 | audio_core/CMakeLists: Make warnings consistent with core | Lioncash | 6 | -8/+17 | |
Normalizes the warnings shared between audio_core and core. | |||||
2020-10-13 | core/CMakeLists: Make some warnings errors | Lioncash | 30 | -146/+144 | |
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. | |||||
2020-10-13 | vk_graphics_pipeline: Manage primitive topology as fixed state | ReinUsesLisp | 6 | -26/+7 | |
Vulkan has requirements for primitive topologies that don't play nicely with yuzu's. Since it's only 4 bits, we can move it to fixed state without changing the size of the pipeline key. - Fixes a regression on recent Nvidia drivers on Fire Emblem: Three Houses. | |||||
2020-10-13 | filesystem: Fix CreateDirectory and DeleteFile | Morph | 1 | -2/+3 | |
Add a check if dir is nullptr (does not exist) Fixes save game creation in Hades | |||||
2020-10-13 | service: time: Update current time with changes to RTC setting. | bunnei | 9 | -198/+341 | |
- This can be used to advance time, e.g. for Pokemon Sword/Shield pokejobs. | |||||
2020-10-13 | hle: service: nvdrv: Implement nvhost_as_gpu::FreeSpace. | bunnei | 2 | -0/+25 | |
- This is used by Super Mario 3D All-Stars. | |||||
2020-10-09 | video_core: Enforce -Wclass-memaccess | ReinUsesLisp | 2 | -7/+7 | |
2020-10-09 | vk_device: Block VK_EXT_extended_dynamic_state for RDNA devices | goldenx86 | 1 | -0/+24 | |
RDNA devices seem to crash when using VK_EXT_extended_dynamic_state in the latest 20.9.2 proprietary Windows drivers. As a workaround, for now we block device names corresponding to current RDNA released products. | |||||
2020-10-08 | shader/texture: Implement CUBE texture type for TMML and fix arrays | ReinUsesLisp | 1 | -19/+22 | |
TMML takes an array argument that has no known meaning, this one appears as the first component in gpr8 followed by s, t and r. Skip this component when arrays are being used. Also implement CUBE texture types. - Used by Pikmin 3: Deluxe Demo. | |||||
2020-10-07 | renderer_vulkan/wrapper: Fix physical device sorting | ReinUsesLisp | 1 | -13/+35 | |
The old code had a sort function that was invalid and it didn't work as expected when the base vector had a different order (e.g. renderdoc was attached). This sorts devices as expected and fixes a debug assert on MSVC. | |||||
2020-10-05 | Address comments | german | 2 | -40/+40 | |
2020-10-04 | Add compatibility with only accelerometer and auto calibrate for drift | german | 2 | -12/+106 | |
2020-10-03 | video_core: Enforce -Wunused-variable and -Wunused-but-set-variable | ReinUsesLisp | 3 | -4/+7 | |
2020-10-02 | Only use inputs corresponding to controller type | german | 1 | -49/+58 | |
2020-09-30 | Stubbed EnableSixAxisSensorFusion | german | 2 | -1/+15 | |
2020-09-30 | caps_c: Stub SetShimLibraryVersion | Morph | 2 | -1/+18 | |
- Used by caps_su SetShimLibraryVersion | |||||
2020-09-30 | caps_u: Stub SetShimLibraryVersion | Morph | 2 | -2/+14 | |
- Used in Super Smash Bros. Ultimate | |||||
2020-09-30 | caps_su: Properly stub SetShimLibraryVersion | Morph | 1 | -1/+6 | |
2020-09-30 | hid: Stub HomeButtonInputProtection service commands | Morph | 4 | -2/+50 | |
- Used in 1-2 Switch. Given that we do not emulate the functionality of the home button yet, we can stub this for now. | |||||
2020-09-30 | Reduce the "shake" requirements when configuring UDP. | Lukas Senionis | 1 | -2/+6 | |
2020-09-30 | Remove ext_extended_dynamic_state blacklist | Matías Locatti | 1 | -8/+0 | |
Latest AMD 20.9.2 driver fixed this, there's no reason to keep it blocked, as the previous stable signed driver release doesn't include the extension. | |||||
2020-09-30 | common/wall_clock: Add virtual destructors | ReinUsesLisp | 3 | -2/+4 | |
From -fsanitize=address, this code wasn't calling the proper destructor. Adding virtual destructors for each inherited class and the base class fixes this bug. While we are at it, mark the functions as final. | |||||
2020-09-29 | qt/game_list: Give GameListSearchField::KeyReleaseEater a parent | ReinUsesLisp | 2 | -3/+4 | |
This fixes a memory leak as KeyReleaseEater's destructor was never called. | |||||
2020-09-29 | First implementation of controller rumble | german | 5 | -14/+63 | |
2020-09-29 | CMakeLists: use system zstd on Linux | lat9nq | 1 | -1/+6 | |
From what I understand, this tells CMake to use the system, not conan, version of zstd. Required to build on the coming MinGW Docker container. | |||||
2020-09-29 | CMakeLists: fix for finding zstd on linux-mingw | lat9nq | 1 | -1/+1 | |
2020-09-26 | main: Allow applets to display on top while fullscreen | Morph | 1 | -6/+8 | |
Using the Qt::WindowStaysOnTopHint flag allows these dialogs to show up on top while running in fullscreen. However, if yuzu goes out of focus (by alt-tabbing or otherwise), this flag does not seem to have an effect. | |||||
2020-09-26 | core: Mark GetInstance() as deprecated | Lioncash | 1 | -1/+1 | |
This way it's obvious that this function shouldn't be used in any future code. | |||||
2020-09-26 | frontend/controller: Eliminate dependency on the global system instance | Lioncash | 3 | -5/+14 | |
2020-09-26 | Add random motion input to keyboard | german | 4 | -0/+65 | |
2020-09-26 | Add random motion input to SDL | german | 5 | -5/+230 | |
2020-09-26 | command_generator: Make lookup table static constexpr | Lioncash | 1 | -2/+3 | |
Allows compilers to elide needing to push these values on the stack every time the function is called. | |||||
2020-09-25 | vk_stream_buffer: Fix initializing Vulkan with NVIDIA on Linux | lat9nq | 1 | -1/+2 | |
The previous fix only partially solved the issue, as only certain GPUs that needed 9 or less MiB subtracted would work (i.e. GTX 980 Ti, GT 730). This takes from DXVK's example to divide `heap_size` by 2 to determine `allocable_size`. Additionally tested on my Quadro K4200, which previously required setting it to 12 to boot. | |||||
2020-09-25 | behavior_info: Fix typo Renerer -> Renderer | Lioncash | 2 | -6/+6 | |
2020-09-25 | cubeb_sink: Use static_cast instead of reinterpret_cast in DataCallback() | Lioncash | 1 | -2/+2 | |
Conversions from void* to the proper data type are well-defined and supported by static_cast. We don't need to use reinterpret_cast here. | |||||
2020-09-25 | codec: Make lookup table static constexpr | Lioncash | 2 | -3/+4 | |
Allows compilers to elide needing to push these values on the stack every time the function is called. | |||||
2020-09-25 | audio_core: Remove unnecessary inclusions | Lioncash | 5 | -7/+2 | |
Same behavior, but removes header dependencies where they don't need to be. | |||||
2020-09-25 | audio_core: Resolve sign conversion warnings | Lioncash | 8 | -25/+34 | |
While were at it, we can also enable sign conversion warnings and other common warnings as errors to prevent these from creeping back into the codebase. | |||||
2020-09-25 | effect_context: Make use of explicit where applicable | Lioncash | 1 | -13/+12 | |
While we're at it we can make the destructor of the base class virtual to ensure that any polymorphism issues never occur. | |||||
2020-09-25 | vk_command_pool: Move definition of Pool into the cpp file | Lioncash | 2 | -4/+6 | |
Allows the implementation details to be changed without recompiling any files that include this header. | |||||
2020-09-25 | vk_command_pool: Make use of override on destructor | Lioncash | 1 | -1/+1 | |
2020-09-25 | vk_command_pool: Add missing header guard | Lioncash | 1 | -0/+2 | |
2020-09-25 | More forgetting... duh | Levi Behunin | 1 | -2/+2 | |
2020-09-25 | service: Restore "unused" function | Lioncash | 1 | -0/+17 | |
Turns out this function is actually used, but within a trace log. | |||||
2020-09-25 | Forgot to apply suggestion here as well | Levi Behunin | 1 | -1/+1 | |
2020-09-25 | Address Comments | Levi Behunin | 3 | -25/+34 | |
2020-09-25 | Start of Integer flags implementation | Levi Behunin | 3 | -3/+50 | |
2020-09-24 | submission_package: Fix updates integrated into cartridge images. | Morph | 1 | -3/+22 | |
2020-09-24 | arithmetic_integer_immediate: Make use of std::move where applicable | Lioncash | 1 | -16/+19 | |
Same behavior, minus any redundant atomic reference count increments and decrements. | |||||
2020-09-24 | video_core: Fix instances where msbuild always regenerated host shaders | ReinUsesLisp | 2 | -12/+7 | |
When HEADER_GENERATOR was included in the DEPENDS section of custom commands, msbuild assumed this was always modified. Changing this file is not common so we can remove it from there. | |||||
2020-09-24 | Use different timing for motion | german | 5 | -76/+157 | |
2020-09-23 | shader/registry: Silence a -Wshadow warning | Lioncash | 2 | -5/+5 | |
2020-09-23 | shader/registry: Remove unnecessary namespace qualifiers | Lioncash | 1 | -5/+3 | |
Using statements already make these unnecessary. | |||||
2020-09-23 | shader/registry: Make use of designated initializers where applicable | Lioncash | 1 | -17/+19 | |
Same behavior, less repetition. | |||||
2020-09-23 | memory: Resolve a -Wdocumentation warning | Lioncash | 1 | -1/+1 | |
memory doesn't exist as a parameter any more. | |||||
2020-09-23 | install_dialog: Make use of [[nodiscard]] where applicable | Lioncash | 1 | -2/+2 | |
Allows the compiler to warn against cases where the return value isn't used (which would be a bug). | |||||
2020-09-23 | install_dialog: Remove unused function prototype | Lioncash | 1 | -1/+0 | |
This function doesn't have an implementation, so it can be removed to prevent others from unintentionally using it. | |||||
2020-09-23 | game_list: Make game list function naming consistent | Lioncash | 3 | -36/+45 | |
Makes the naming consistent with the rest of the functions that are present. | |||||
2020-09-23 | game_list: Eliminate redundant argument copies | Lioncash | 2 | -16/+22 | |
Several functions can be taken by const reference to avoid copies | |||||
2020-09-23 | control_flow: emplace elements in place within TryQuery() | Lioncash | 1 | -6/+6 | |
Places data structures where they'll eventually be moved to to avoid needing to even move them in the first place. | |||||
2020-09-23 | control_flow: Make use of std::move in InsertBranch() | Lioncash | 1 | -7/+8 | |
Avoids unnecessary atomic increments and decrements. | |||||
2020-09-22 | General: Make use of std::nullopt where applicable | Lioncash | 17 | -59/+60 | |
Allows some implementations to avoid completely zeroing out the internal buffer of the optional, and instead only set the validity byte within the structure. This also makes it consistent how we return empty optionals. | |||||
2020-09-22 | ips_layer: Eliminate a redundant copy in Parse() | Lioncash | 1 | -2/+4 | |
Prevents unnecessary copying of the line being parsed. | |||||
2020-09-21 | acc: Stub LoadOpenContext | Morph | 3 | -1/+13 | |
This is used in multiple games such as: - Clubhouse Games: 51 Worldwide Classics - Grandia HD Collection - XCOM 2 Collection - Baldur's Gate 1/2 - Dr Kawashima's Brain Training - Super Mario 3D All-Stars | |||||
2020-09-20 | renderer_opengl: Remove emulated mailbox presentation | ReinUsesLisp | 13 | -360/+35 | |
Emulated mailbox presentation was causing performance issues on Nvidia's OpenGL driver. Remove it. | |||||
2020-09-19 | vk_query_cache: Hack counter destructor to avoid reserving queries | ReinUsesLisp | 1 | -1/+10 | |
This is a hack to destroy all HostCounter instances before the base class destructor is called. The query cache should be redesigned to have a proper ownership model instead of using shared pointers. For now, destroy the host counter hierarchy from the derived class destructor. | |||||
2020-09-19 | renderer_vulkan: Make unconditional use of VK_KHR_timeline_semaphore | ReinUsesLisp | 42 | -814/+638 | |
This reworks how host<->device synchronization works on the Vulkan backend. Instead of "protecting" resources with a fence and signalling these as free when the fence is known to be signalled by the host GPU, use timeline semaphores. Vulkan timeline semaphores allow use to work on a subset of D3D12 fences. As far as we are concerned, timeline semaphores are a value set by the host or the device that can be waited by either of them. Taking advantange of this, we can have a monolithically increasing atomic value for each submission to the graphics queue. Instead of protecting resources with a fence, we simply store the current logical tick (the atomic value stored in CPU memory). When we want to know if a resource is free, it can be compared to the current GPU tick. This greatly simplifies resource management code and the free status of resources should have less false negatives. To workaround bugs in validation layers, when these are attached there's a thread waiting for timeline semaphores. | |||||
2020-09-18 | Add automap feature for GC adapter | german | 3 | -1/+103 | |
2020-09-18 | fermi_2d: Make use of designated initializers | Lioncash | 2 | -8/+8 | |
Same behavior, less repetition. We can also ensure all members of Config are initialized. | |||||
2020-09-18 | hid: Implement Get/SetNpadHandheldActivationMode | Morph | 3 | -5/+28 | |
- Used in Clubhouse Games: 51 Worldwide Classics | |||||
2020-09-18 | configure_input_player: Fixes motion mapping using ConfigureButtonClick | Morph | 1 | -5/+8 | |
2020-09-18 | am: Stub GetPreviousProgramIndex | Morph | 2 | -1/+11 | |
- Used in Super Mario 3D All-Stars | |||||
2020-09-18 | configure_input_player: Re-add "Clear" context menu option | Morph | 2 | -31/+66 | |
The context menu was removed in Mjölnir Part 1 as part of the input rewrite as we were unaware of it's usage statistics. However, as this was the only way to clear the inputs of individual buttons, this PR will re-add it back in. | |||||
2020-09-18 | submission_package: Account for multi-content NSPs | Morph | 1 | -5/+5 | |
Previously we assumed a submission package can only contain one Program NCA with a single TitleID. However, Super Mario 3D All-Stars contains four Program NCAs, each with their unique TitleIDs. This accounts for the existence of multi-content games such as this one. - Fixes booting Super Mario 3D All-Stars from the games list. | |||||
2020-09-17 | decode/image: Eliminate switch fallthrough in DecodeImage() | Lioncash | 1 | -0/+1 | |
Fortunately this didn't result in any issues, given the block that code was falling through to would immediately break. | |||||
2020-09-17 | decoder/texture: Eliminate narrowing conversion in GetTldCode() | Lioncash | 1 | -1/+1 | |
The assignment was previously truncating a u64 value to a bool. | |||||
2020-09-17 | audio_core/command_generator: Use const references where applicable | Lioncash | 1 | -10/+11 | |
In a lot of cases, we can make use of const references rather than non-const references. While we're in the area we can silence some truncation and sign conversion warnings. | |||||
2020-09-17 | audio_core/command_generator: Avoid an unnecessary copy in GenerateFinalMixCommand() | Lioncash | 1 | -1/+1 | |
2020-09-17 | nfp: Eliminate two unnecessary copies | Lioncash | 1 | -10/+13 | |
GetAmiiboBuffer() returns by const reference, so we can use a reference instead of taking the returned buffer by value. | |||||
2020-09-17 | arm_dynarmic_cp15: Initialize member variables | Lioncash | 1 | -2/+2 | |
Ensures that the member variables are always initialized to a deterministic value on creation. | |||||
2020-09-17 | control_metadata: Resolve typo in Portuguese language name | Lioncash | 1 | -1/+1 | |
This isn't used anywhere, so this is a trivial fix. | |||||
2020-09-17 | service: Remove unused funcation | Lioncash | 1 | -22/+0 | |
This is now completely unused, so it can be removed. | |||||
2020-09-17 | service/sm: Slightly more efficient string name validation | Lioncash | 1 | -2/+2 | |
We can check the end of the string first for null-termination, rather than the beginning of the string. | |||||
2020-09-17 | service/sm: Eliminate dependency on the global system instance | Lioncash | 3 | -7/+9 | |
2020-09-17 | file_sys/romfs_factory: Eliminate usage of the global system accessor | Lioncash | 5 | -34/+49 | |
2020-09-17 | file_sys/bis_factory: Eliminate usage of the global system accessor | Lioncash | 5 | -11/+11 | |
2020-09-17 | loader/nso: Remove unnecessary [[maybe_unused]] | Lioncash | 1 | -2/+1 | |
2020-09-16 | video_core: Enforce -Werror=switch | ReinUsesLisp | 7 | -10/+59 | |
This forces us to fix all -Wswitch warnings in video_core. | |||||
2020-09-16 | core/loader: Remove dependencies on the global system instance | Lioncash | 20 | -45/+85 | |
Now all that remains is: 18 instances in file_sys code 14 instances in GDB stub code (this can be tossed wholesale) 4 instances in HLE code 2 instances in settings code. | |||||
2020-09-15 | nca_patch: Significantly reduce the stack usage size within SearchBucketEntry() | Lioncash | 1 | -4/+4 | |
Previously this function was using ~16KB of stack (16528 bytes), which was caused by the function arguments being taken by value rather than by reference. We can make this significantly lighter on the stack by taking them by reference. | |||||
2020-09-15 | nca_patch: Make SearchBucketEntry() internally linked | Lioncash | 2 | -44/+43 | |
This is only used internally and doesn't depend on any class state, so we can make it fully internal. | |||||
2020-09-15 | cheat_engine: Convert ExtractName into a non-template function | Lioncash | 1 | -19/+17 | |
We don't need to create two separate instantiations of the same code, we can simply make the character template argument a regular function parameter. | |||||
2020-09-15 | cheat_engine: Remove unnecessary system argument to CheatParser's Parse function | Lioncash | 3 | -15/+9 | |
This isn't used within the function at all in any implementations, so we can remove it entirely. | |||||
2020-09-15 | patch_manager: Resolve implicit truncations in FormatTitleVersion() | Lioncash | 1 | -3/+4 | |
We make it explicit that we're truncating arithmetic here to resolve compiler warnings (even if the sizes weren't u32/u64 arithmetic generally promotes to int :<) | |||||
2020-09-15 | patch_manager: Make use of type aliases | Lioncash | 2 | -69/+79 | |
We can use these to avoid typing the same type redundantly. This way, if these ever change, only a single location needs to be modified. | |||||
2020-09-15 | patch_manager: Make a few functions internally linked | Lioncash | 2 | -15/+12 | |
These functions are only used within this translation unit, so we can make them internally linked. | |||||
2020-09-15 | gc_adapter: Disable MSVC nonstandard extension warning on libusb.h | ReinUsesLisp | 1 | -0/+9 | |
Pragma disable zero-sized array nonstandard extension warning on MSVC. | |||||
2020-09-14 | crypto/key_manager: Remove dependency on the global system accessor | Lioncash | 3 | -7/+12 | |
We can supply the content provider as an argument instead of hardcoding a global accessor in the implementation. | |||||
2020-09-14 | kernel: Remove all dependencies on the global system instance | Lioncash | 5 | -11/+20 | |
With this, the kernel finally doesn't depend directly on the global system instance anymore. | |||||
2020-09-10 | Test: Decrease pad_update_ns | FearlessTobi | 1 | -1/+1 | |
There have been reports of quite heavy input lag in the past. Compared to Citra for example, our pad_update_ns value is very high. So let's decrease it and see if it helps with this problem. | |||||
2020-09-07 | service: Remove two usages of the global system accessor | Lioncash | 3 | -7/+5 | |
Removes more instances of reliance on global state. | |||||
2020-09-07 | gc_adapter: Make DeviceConnected() a const member function | Lioncash | 3 | -9/+9 | |
This doesn't modify instance state, so it can be made const. | |||||
2020-09-07 | bsd: Resolve unused value within SendToImpl | Lioncash | 1 | -0/+1 | |
Previously the address provided to SendToImpl would never be propagated to SendTo(). This fixes that. | |||||
2020-09-07 | bsd: Resolve sign comparison warnings | Lioncash | 1 | -3/+3 | |
2020-09-07 | sockets_translate: Make use of designated initializers | Lioncash | 1 | -12/+12 | |
Same behavior, less typing. | |||||
2020-09-07 | blocking_worker: Make use of templated lambda | Lioncash | 1 | -3/+2 | |
We can simplify this a little by explicitly specifying the typename for the lambda function. | |||||
2020-09-07 | blocking_worker: Resolve -Wdocumentation warning | Lioncash | 1 | -1/+1 | |
2020-09-06 | video_core: Remove all Core::System references in renderer | ReinUsesLisp | 53 | -633/+573 | |
Now that the GPU is initialized when video backends are initialized, it's no longer needed to query components once the game is running: it can be done when yuzu is booting. This allows us to pass components between constructors and in the process remove all Core::System references in the video backend. | |||||
2020-09-05 | configure_input: Hook up the motion button and checkbox | Morph | 7 | -7/+19 | |
This allows toggling motion on or off, and allows access to the motion configuration. Also changes the [waiting] text for motion buttons to Shake! as this is how motion is connected to a player. | |||||
2020-09-05 | Minor cleanup | german | 1 | -19/+16 | |
2020-09-05 | Add cemu hook changes related to PR #4609 | german | 8 | -139/+449 | |
2020-09-05 | Remove RealMotionDevice | german | 7 | -35/+41 | |
2020-09-05 | configure_input_player: Show/hide motion buttons based on the controller | Morph | 3 | -103/+141 | |
2020-09-05 | controllers/npad: Simplify motion entry assignment | Morph | 1 | -29/+18 | |
Simplifies the motion assignment in the Dual Joycon entry and assigns index 1 of the motion entry (Motion 2) for the right joycon. | |||||
2020-09-05 | Include HID and configuration changes related to motion | german | 13 | -16/+448 | |
2020-09-04 | hid: Implement MergeSingleJoyasDualJoy | Morph | 3 | -5/+24 | |
- Used in multiple games such as Super Mario Odyssey. | |||||
2020-09-04 | applets/controller: Resolve several compiler warnings | Morph | 2 | -7/+8 | |
Resolves -Wsign-compare and -Wunused-variable | |||||
2020-09-04 | Address feedback | Morph | 4 | -2/+12 | |
2020-09-04 | clang-format | Morph | 2 | -2/+4 | |
2020-09-04 | applets/controller: Set min_players to have a minimum value of 1. | Morph | 1 | -1/+1 | |
- Some games like Shipped have a minimum requirement of 0 connected players and is undesired behavior. We must require a minimum of 1 player connected regardless of what games may ask. | |||||
2020-09-04 | applets/controller: Modify heuristic to account for certain games | Morph | 1 | -7/+12 | |
Now left and right joycons have the same priority (meaning both needs to be supported by the game). Explanation of the new heuristic: Assign left joycons to even player indices and right joycons to odd player indices. We do this since Captain Toad Treasure Tracker expects a left joycon for Player 1 and a right Joycon for Player 2 in 2 Player Assist mode. | |||||
2020-09-04 | main: Apply settings after applet configuration is complete. | Morph | 1 | -0/+4 | |
2020-09-04 | applets/controller: Implement fallback applet for the SDL frontend | Morph | 3 | -90/+34 | |
Implement the fallback applet for the SDL frontend, connecting only the minimum amount of players required. | |||||
2020-09-04 | applets/controller: Load configuration prior to setting up connections | Morph | 2 | -23/+29 | |
This avoids unintentionally changing the states of elements while loading them in. | |||||
2020-09-04 | applets/controller: Make 8 a static constexpr value of NUM_PLAYERS | Morph | 2 | -15/+22 | |
Avoids repetitive usages of the int literal '8' or calls to player_widgets.size() | |||||
2020-09-04 | applets/controller: Implement "Explain Text" | Morph | 6 | -25/+304 | |
"Explain Text" is additional text that is shown for each player in the controller applet. | |||||
2020-09-04 | Project Mjölnir: Part 2 - Controller Applet | Morph | 20 | -59/+3803 | |
Co-authored-by: Its-Rei <kupfel@gmail.com> | |||||
2020-09-03 | file_sys/patch_manager: Add missing include | ReinUsesLisp | 1 | -0/+1 | |
Fixes build issues | |||||
2020-09-02 | main: Use three dots to complete the ellipsis | lat9nq | 1 | -1/+1 | |
Fixes a typo in the UI file. An ellipsis has 3 dots. | |||||
2020-09-02 | input_common/motion_input: Make use of Common::PI constant | Morph | 3 | -5/+10 | |
Also amend the copyright notice to yuzu's instead of Dolphin's, which was mistakenly copy-pasted from another file. | |||||
2020-08-31 | vk_device: Fix driver id check on AMD for VK_EXT_extended_dynamic_state | ReinUsesLisp | 1 | -6/+9 | |
'driver_id' can only be known on Vulkan 1.1 after creating a logical device. Move the driver id check to disable VK_EXT_extended_dynamic_state after the logical device is successfully initialized. The Vulkan device will have the extension enabled but it will not be used. | |||||
2020-08-30 | externals: Update Xbyak to 5.96 | Lioncash | 2 | -21/+21 | |
I made a request on the Xbyak issue tracker to allow some constructors to be constexpr in order to avoid static constructors from needing to execute for some of our register constants. This request was implemented, so this updates Xbyak so that we can make use of it. | |||||
2020-08-30 | sdl_joystick: disable the use of the hidapi drivers due to many problems caused by them. | Vitor Kiguchi | 1 | -0/+7 | |
The main problem is the loss of compatibility with some controllers, but there are also unwanted changes to the behaviour of PS4 controllers (hardcoded lightbar color). | |||||
2020-08-30 | Address second batch of reviews | FearlessTobi | 9 | -30/+27 | |
2020-08-29 | configure_input_player: Resolve sign conversion warnings in UpdateMappingWithDefaults() | Lioncash | 1 | -2/+2 | |
Prevents sign mismatch warnings in the loop conditionals. | |||||
2020-08-29 | Reolve reorder warning | FearlessTobi | 2 | -3/+3 | |
2020-08-29 | Address review comments and fix code compilation | FearlessTobi | 13 | -155/+218 | |
2020-08-29 | bootmanager: Prevent unnecessary copies in TouchUpdateEvent() | Lioncash | 1 | -1/+1 | |
The list of points is returned by const reference, so we don't need to make a copy of every element in the list. | |||||
2020-08-29 | game_list_p: Avoid string churn in GameListItemPath data() | Lioncash | 1 | -4/+8 | |
2020-08-29 | game_list_p: Mark some constants as constexpr | Lioncash | 1 | -10/+10 | |
Consistency change with how we mark constants in the rest of the codebase. | |||||
2020-08-29 | yuzu: Add motion and touch configuration | FearlessTobi | 18 | -3/+1889 | |
2020-08-29 | yuzu/main: Amend lifetime issues with InputSubsystem | Lioncash | 4 | -7/+8 | |
Due to the way Qt performs destruction of parent/child widgets, we need to make the lifetime of the input subsystem shared across the main window and the render window. | |||||
2020-08-29 | yuzu/configuration: Fix index out of bounds for default_analogs | Morph | 3 | -12/+13 | |
2020-08-29 | sdl_impl: Reduce allocations in GetButtonMappingForDevice() | Lioncash | 1 | -31/+37 | |
These maps can be constexpr arrays of std::pair. | |||||
2020-08-29 | sdl_impl: Make use of std::move on std::string where applicable | Lioncash | 1 | -3/+3 | |
Avoids redundant copies. | |||||
2020-08-29 | sdl_impl: Make use of insert_or_assign() where applicable | Lioncash | 1 | -14/+18 | |
Avoids churning ParamPackage instances. | |||||
2020-08-29 | sdl_impl: Prevent type truncation in BuildAnalogParamPackageForButton() default arguments | Lioncash | 1 | -1/+1 | |
We need to add the 'f' suffix to make the right hand side a float and not a double. | |||||
2020-08-29 | sdl_impl: Simplify make_tuple call | Lioncash | 1 | -1/+1 | |
The purpose of make_tuple is that you don't need to explicitly type out the types of the things that comprise said tuple. Given this just returns default values, we can simplify this a bit. | |||||
2020-08-29 | sdl_impl: Mark FromEvent() as a const member function | Lioncash | 1 | -2/+2 | |
This doesn't modify internal member state, so it can be marked as const. | |||||
2020-08-29 | input_common/main: Remove unnecessary headers | Lioncash | 3 | -5/+11 | |
2020-08-29 | input_common/main: Remove unimplemented prototype | Lioncash | 1 | -3/+0 | |
I forgot to remove this in the rebase when removing most of the global variables within the input common codebase. | |||||
2020-08-29 | vk_device: Blacklist AMD proprietary from VK_EXT_extended_dynamic_state | ReinUsesLisp | 1 | -1/+6 | |
Vertex binding's <stride> is bugged on AMD's proprietary drivers when using VK_EXT_extended_dynamic_state. Blacklist it for now while we investigate how to report this issue to AMD. | |||||
2020-08-28 | Fix orientation errors and improve drift correction | german | 2 | -14/+31 | |
2020-08-28 | Address comments | german | 2 | -85/+65 | |
2020-08-28 | Implement a basic class for motion devices | german | 4 | -0/+279 | |
2020-08-27 | input_common: Eliminate most global state | Lioncash | 25 | -242/+396 | |
Abstracts most of the input mechanisms under an InputSubsystem class that is managed by the frontends, eliminating any static constructors and destructors. This gets rid of global accessor functions and also allows the frontends to have a more fine-grained control over the lifecycle of the input subsystem. This also makes it explicit which interfaces rely on the input subsystem instead of making it opaque in the interface functions. All that remains to migrate over is the factories, which can be done in a separate change. | |||||
2020-08-27 | input_common/main: Add "/Mouse" to the display name | Morph | 1 | -1/+1 | |
2020-08-27 | memory_manager: Make use of [[nodiscard]] in the interface | Lioncash | 1 | -17/+17 | |
2020-08-27 | memory_manager: Make operator+ const qualified | Lioncash | 1 | -1/+1 | |
This doesn't modify member state, so it can be marked as const. | |||||
2020-08-26 | configure_input_player: Fix modifier scale button mapping | Morph | 2 | -20/+19 | |
2020-08-26 | configuration/input: Add support for mouse button clicks | Morph | 5 | -11/+82 | |
Supports the Left, Right, Middle, Backward and Forward mouse buttons. | |||||
2020-08-26 | controllers/npad: Fix inconsistencies with controller connection statuses | Morph | 1 | -1/+7 | |
2020-08-26 | controllers/npad: Fix LibNX controller connection statuses | Morph | 1 | -1/+9 | |
This allows homebrew applications to be able to properly detect connected controllers. | |||||
2020-08-26 | controllers/npad: Fix LedPattern for P1-4 | Morph | 1 | -3/+3 | |
2020-08-26 | input_common: Fix directional deadzone values | Morph | 2 | -2/+2 | |
The hardware tested value is 0.5 which translates to SHRT_MAX / 2 | |||||
2020-08-26 | Address feedback | Morph | 13 | -96/+77 | |
2020-08-26 | Project Mjölnir: Part 1 | Morph | 43 | -3177/+8306 | |
Co-authored-by: James Rowe <jroweboy@gmail.com> Co-authored-by: Its-Rei <kupfel@gmail.com> | |||||
2020-08-26 | gc_poller: Resolve compilation warnings on MSVC | Lioncash | 1 | -3/+5 | |
We just need to make our intentional implicit truncations explicit. | |||||
2020-08-26 | hle/scheduler: Fix data race in is_context_switch_pending | ReinUsesLisp | 1 | -2/+6 | |
As reported by tsan, SelectThreads could write to is_context_switch_pending holding a mutex while SwitchToCurrent reads it without holding any. It is assumed that the author didn't want an atomic here, so the code is reordered so that whenever is_context_switch_pending is read inside SwitchToContext, the mutex is locked. | |||||
2020-08-26 | hle/kernel: Fix data race in GetCurrentHostThreadID | ReinUsesLisp | 1 | -1/+2 | |
As reported by tsan, host_thread_ids could be read while any of the RegisterHostThread variants were called. To fix this, lock the register mutex when yuzu is running in multicore mode and GetCurrentHostThreadID is called. | |||||
2020-08-26 | common/thread: Fix data race in is_set | ReinUsesLisp | 1 | -4/+5 | |
As report by tsan, Event::Set can write is_set while WaitFor and friends are reading from it. To address this issue, make is_set an atomic. | |||||
2020-08-26 | cpu_interrupt_handler: Misc style changes | ReinUsesLisp | 2 | -5/+3 | |
2020-08-26 | cpu_interrupt_handler: Make is_interrupted an atomic | ReinUsesLisp | 2 | -2/+3 | |
Fixes a race condition detected from tsan | |||||
2020-08-25 | logging/settings: Increase maximum log size to 100 MB and add extended logging option | M&M | 5 | -11/+54 | |
The extended logging option is automatically disabled on boot but can be enabled afterwards, allowing the log file to go up to 1 GB during that session. This commit also fixes a few errors that are present in the general debug menu. | |||||
2020-08-24 | common_funcs: Add missing XOR operators to DECLARE_ENUM_FLAG_OPERATORS | Lioncash | 1 | -4/+10 | |
Ensures that the full set of bitwise operators are available for types that make use of this macro. | |||||
2020-08-24 | common/assert: Make use of C++ attribute syntax | Lioncash | 1 | -3/+4 | |
Normalizes the syntax used for attributes | |||||
2020-08-24 | async_shaders: Mark getters as const member functions | Lioncash | 2 | -17/+15 | |
While we're at it, we can also mark them as nodiscard. | |||||
2020-08-24 | memory_manager: Mark IsGranularRange() as a const member function | Lioncash | 2 | -3/+3 | |
This doesn't modify internal member state, so it can be marked as const. | |||||
2020-08-24 | gl_texture_cache: Take std::string by reference in DecorateViewName() | Lioncash | 2 | -2/+2 | |
LabelGLObject takes a string_view, so we don't need to make copies of the std::string. | |||||
2020-08-24 | video_core/fence_manager: Remove unnecessary includes | Lioncash | 3 | -9/+4 | |
Avoids pulling in unnecessary things that can cause rebuilds when they aren't required. | |||||
2020-08-24 | video_core/host_shaders: Add CMake integration for string shaders | ReinUsesLisp | 7 | -42/+106 | |
Add the necessary CMake code to copy the contents in a string source shader (GLSL or GLASM) to a header file then consumed by video_core files. This allows editting GLSL in its own files without having to maintain them in source files. For now, only OpenGL presentation shaders are moved, but we can add GLASM presentation shaders and static SPIR-V generation through glslangValidator in the future. | |||||
2020-08-24 | gl_shader_util: Use std::string_view instead of star pointer | ReinUsesLisp | 5 | -9/+21 | |
This allows us passing any type of string and hinting the length of the string to the OpenGL driver. | |||||
2020-08-23 | fsp_srv: Resolve -Wunused-but-set-variable warning | Lioncash | 1 | -1/+8 | |
We can just log out the parameters in the meantime. | |||||
2020-08-23 | file_sys: Replace inclusions with forward declarations where applicable | Lioncash | 27 | -37/+66 | |
Same behavior, minus unnecessary inclusions where not necessary. | |||||
2020-08-23 | fsp_srv: Resolve -Wmaybe_uninitialized warning in OpenSaveDataFileSystem() | Lioncash | 1 | -2/+5 | |
Initialize id to a deterministic value and also mark the unreachable cases in the switch with UNREACHABLE(). | |||||
2020-08-23 | registered_cache: Make use of ends_with for string suffix checking | Lioncash | 1 | -2/+1 | |
Simplifies code. | |||||
2020-08-23 | registered_cache: Make use of designated initializers | Lioncash | 1 | -15/+15 | |
Removes the need for comments to indicate the fields being assigned. | |||||
2020-08-23 | key_manager: Make data arrays constexpr | Lioncash | 2 | -75/+82 | |
We can convert these maps into constexpr arrays to eliminate some runtime static constructors. | |||||
2020-08-23 | cpu_manager: Make use of ranged for where applicable | Lioncash | 1 | -16/+13 | |
We can simplify a few loops by making use of ranged for. | |||||
2020-08-23 | core_timing: Remove unused header | Lioncash | 3 | -2/+2 | |
2020-08-23 | core_timing: Move clock initializer into constructor initializer list | Lioncash | 1 | -4/+2 | |
Same behavior, minus unnecessary zeroing out of the pointer. | |||||
2020-08-23 | core_timing: Resolve sign conversion warning | Lioncash | 1 | -2/+2 | |
This constant is only ever assigned to downcount, which is a s64, not a u64. | |||||
2020-08-23 | web_service: Move web_result.h into web_service | Lioncash | 7 | -47/+41 | |
This is the only place it's actively used. It's also more appropriate for web-related structures to be within the web service target. Especially given this one doesn't rely on anything in the common library. | |||||
2020-08-22 | video_core: Initialize renderer with a GPU | ReinUsesLisp | 22 | -119/+172 | |
Add an extra step in GPU initialization to be able to initialize render backends with a valid GPU instance. | |||||
2020-08-21 | vk_state_tracker: Fix primitive topology | ReinUsesLisp | 3 | -13/+14 | |
State track the current primitive topology with a regular comparison instead of using dirty flags. This fixes a bug in dirty flags for this particular state and it also avoids unnecessary state changes as this property is stored in a frequently changed bit field. | |||||
2020-08-20 | vk_device: Use Vulkan 1.0 properly | ReinUsesLisp | 5 | -52/+66 | |
Enable the required capabilities to use Vulkan 1.0 without validation errors and disable those that are not compatible with it. | |||||
2020-08-20 | renderer_vulkan: Create a Vulkan 1.0 instance when 1.1 is not available | ReinUsesLisp | 3 | -6/+26 | |
This commit doesn't make yuzu compatible with Vulkan 1.0 yet, it only creates an 1.0 instance. | |||||
2020-08-20 | Revert "common/time_zone: Simplify GetOsTimeZoneOffset()" | bunnei | 1 | -5/+9 | |
2020-08-18 | common/telemetry: Migrate namespace into the Common namespace | Lioncash | 13 | -35/+43 | |
Migrates the Telemetry namespace into the Common namespace to make the code consistent with the rest of our common code. | |||||
2020-08-18 | vfs_real: Resolve sign conversion warnings | Lioncash | 1 | -2/+2 | |
2020-08-18 | vfs_real: Avoid redundant map lookups | Lioncash | 1 | -30/+46 | |
Avoids some trivially avoidable map lookups by keeping the result of find operations around and querying them. | |||||
2020-08-18 | common/color: Migrate code over to the Common namespace | Lioncash | 1 | -2/+2 | |
No external code makes use of this header, so we can freely change the namespace. | |||||
2020-08-18 | common/concepts: Move <type_traits> include out of the Common namespace | Lioncash | 1 | -2/+2 | |
This is a compiler/linker error waiting to happen. | |||||
2020-08-16 | Remove unneeded newlines, optional Registry in shader params | ameerj | 5 | -14/+9 | |
Addressing feedback from Rodrigo | |||||
2020-08-16 | Morph: Update worker allocation comment | Ameer J | 1 | -1/+1 | |
Co-authored-by: Morph <39850852+Morph1984@users.noreply.github.com> | |||||
2020-08-16 | move thread 1/4 count computation into allocate workers method | ameerj | 4 | -23/+14 | |
2020-08-16 | Address feedback, add shader compile notifier, update setting text | ameerj | 9 | -162/+117 | |
2020-08-16 | Vk Async Worker directly emplace in cache | ameerj | 3 | -58/+41 | |
2020-08-16 | Address feedback. Bruteforce delete duplicates | ameerj | 7 | -80/+116 | |
2020-08-16 | Vk Async pipeline compilation | ameerj | 13 | -20/+182 | |
2020-08-16 | Preliminary effects | David Marcec | 10 | -35/+731 | |
2020-08-16 | dynarmic: Add unsafe optimizations | MerryMage | 7 | -4/+108 | |
2020-08-16 | configure_hotkeys: Don't translate empty strings | Lioncash | 1 | -2/+2 | |
There's no need to translate an empty string. This just gives translators unnecessary work. | |||||
2020-08-16 | common/fileutil: Convert namespace to Common::FS | Lioncash | 40 | -547/+639 | |
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. | |||||
2020-08-16 | common: Silence two discarded result warnings | Lioncash | 2 | -3/+3 | |
These are intentionally discarded internally, since the rest of the public API allows querying success. We want all non-internal uses of these functions to be explicitly checked, so we can signify that we intentionally want to discard the return values here. | |||||
2020-08-16 | common/time_zone: Simplify GetOsTimeZoneOffset() | Lioncash | 1 | -9/+5 | |
We can simplify this function down into a single line with the use of fmt. A benefit with the fmt approach is that the fmt variant of localtime is thread-safe as well, making GetOsTimeZoneOffset() thread-safe as well. | |||||
2020-08-16 | yuzu: Resolve -Wextra-semi warnings | Lioncash | 3 | -6/+6 | |
While we're in the same area, we can ensure GameDir member variables are always initialized to consistent values. | |||||
2020-08-16 | main: Add an option to modify the currrent game's configuration | lat9nq | 3 | -20/+46 | |
Creates a new entry in the Emulation menu called "Configure Current Game..." that is only available if a game is currently being executed in yuzu. When selected, it opens the game properties dialog for the current game. Thanks to @BSoDGamingYT for reminding me to do this. | |||||
2020-08-15 | common/compression: Roll back std::span changes | Lioncash | 5 | -38/+45 | |
Seems like all compilers don't support std::span yet. | |||||
2020-08-15 | common: Make use of [[nodiscard]] where applicable | Lioncash | 34 | -358/+343 | |
Now that clang-format makes [[nodiscard]] attributes format sensibly, we can apply them to several functions within the common library to allow the compiler to complain about any misuses of the functions. | |||||
2020-08-14 | configuration_shared: Simplify name lookup in highlighting functions | Lioncash | 7 | -90/+74 | |
We can query the given object name directly from the widget itself. This removes any potential for forgetting to change the name if the widget gets renamed and makes the API much simpler (just pass in the widget, and not worry about its name). | |||||
2020-08-14 | yuzu: Make use of qOverload where applicable | Lioncash | 1 | -2/+1 | |
Eliminates a verbose function cast. | |||||
2020-08-14 | time_zone_content_manager: Collapse auto and default case | Lioncash | 1 | -3/+1 | |
Prevents a useless self-assignment from occurring. | |||||
2020-08-14 | Disable biquad filter | David Marcec | 1 | -8/+9 | |
2020-08-14 | software_keyboard: Resolve a pessimizing move warning | Lioncash | 1 | -2/+1 | |
A std::vector created in place like this is already an rvalue and doesn't need to be moved. | |||||
2020-08-14 | core: Resolve several -Wextra-semi warnings | Lioncash | 3 | -7/+12 | |
We can amend one of the cascade macros to require semicolons in order to compile. In other cases, we can just remove the superfluous semicolons. | |||||
2020-08-14 | shader/memory: Amend UNIMPLEMENTED_IF_MSG without a message | Lioncash | 1 | -1/+2 | |
We need to provide a message for this variant of the macro, so we can simply log out the type being used. | |||||
2020-08-14 | macro-interpreter: Resolve -Wself-assign-field warning | Lioncash | 1 | -1/+0 | |
This was assigning the field to itself, which is a no-op. The size doesn't change between its initial assignment and this one, so this is a safe change to make. | |||||
2020-08-14 | vulkan/wrapper: Avoid unnecessary copy in EnumerateInstanceExtensionProperties() | Lioncash | 1 | -1/+1 | |
Given this is implicitly creating a std::optional, we can move the vector into it. | |||||
2020-08-14 | gl_shader_disk_cache: Make use of std::nullopt where applicable | Lioncash | 1 | -11/+12 | |
Allows the compiler to avoid unnecessarily zeroing out the internal buffer of std::optional on some implementations. | |||||
2020-08-14 | async_shaders: Resolve -Wpessimizing-move warning | Lioncash | 1 | -2/+2 | |
Prevents pessimization of the move constructor (which thankfully didn't actually happen in practice here, given std::thread isn't copyable). | |||||
2020-08-14 | maxwell_3d: Resolve -Wextra-semi warning | Lioncash | 1 | -1/+1 | |
Semicolons after a function definition aren't necessary. | |||||
2020-08-14 | Reworked ADPCM decoder to allow better streaming | David Marcec | 2 | -33/+95 | |
2020-08-14 | emu_window: Mark Scoped constructor and Acquire() as nodiscard | Lioncash | 1 | -2/+2 | |
Ensures that callers make use of the constructor, preventing bugs from silently occurring. | |||||
2020-08-14 | kernel/scheduler: Mark SchedulerLock constructor as nodiscard | Lioncash | 1 | -1/+1 | |
Allows the compiler to warn about cases where the constructor is used but then immediately discarded, which is a potential cause of locking/unlocking bugs. | |||||
2020-08-13 | General: Tidy up clang-format warnings part 2 | Lioncash | 17 | -117/+129 | |
2020-08-12 | gl_shader_cache: Use std::max() for determining num_workers | Morph | 1 | -1/+1 | |
Does not allocate more threads than available in the host system for boot-time shader compilation and always allocates at least 1 thread if hardware_concurrency() returns 0. | |||||
2020-08-11 | textures/decoders: Fix block linear to pitch copies | ReinUsesLisp | 3 | -34/+34 | |
There were two issues with block linear copies. First the swizzling was wrong and this commit reimplements them. The other issue was that these copies are generally used to download render targets from the GPU and yuzu was not downloading them from host GPU memory unless the extreme GPU accuracy setting was selected. This commit enables cached memory reads for all accuracy levels. - Fixes level thumbnails in Super Mario Maker 2. | |||||
2020-08-10 | Remove UI changes | ameerj | 5 | -86/+5 | |
This PR is now only the Analog devices handling the range value defaulting at 100% | |||||
2020-08-10 | Add range slider functionality for gc adapter | ameerj | 1 | -7/+7 | |
2020-08-10 | undo unnecessary newlines, slider range 50-150 | Ameer | 3 | -6/+5 | |
2020-08-10 | Address c++20 warning, fix inaccurate range text display when slide == 0 | Ameer | 1 | -2/+2 | |
2020-08-10 | Add range slider for analog sticks | Ameer | 4 | -14/+99 | |
2020-08-09 | General: Tidy up clang-format warnings | Lioncash | 1 | -1/+1 | |
2020-08-07 | common/concepts: Rename IsBaseOf to DerivedFrom | Lioncash | 3 | -6/+8 | |
This makes it more inline with its currently unavailable standardized analogue std::derived_from. While we're at it, we can also make the template match the requirements of the standardized variant as well. | |||||
2020-08-06 | freezer: Move entry finding to its own function | Lioncash | 2 | -12/+21 | |
Cleans up the callsites in other functions. | |||||
2020-08-06 | freezer: Take address values by value | Lioncash | 1 | -3/+3 | |
VAddr will always be 64-bit, so there's no need to take a trivial primitive alias by reference. | |||||
2020-08-06 | freezer: Make use of std::erase_if | Lioncash | 1 | -4/+1 | |
With C++20 we can simplify the erasing idiom. | |||||
2020-08-06 | cheat_engine: Resolve implicit bool->u64 conversion | Lioncash | 1 | -1/+1 | |
We can just return zero here. | |||||
2020-08-06 | cheat_engine: Make use of designated initializers | Lioncash | 1 | -6/+18 | |
Same behavior, but makes the member being assigned obvious. | |||||
2020-08-06 | partition_data_manager: Update master key hashes | Lioncash | 1 | -5/+5 | |
Fills in some hashes that were previously unhandled. | |||||
2020-08-06 | partition_data_manager: Make data arrays constexpr | Lioncash | 4 | -138/+141 | |
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. | |||||
2020-08-06 | partition_data_manager: Eliminate magic value | Lioncash | 1 | -2/+2 | |
We can use sizeof to make it obvious at the call site where the value is coming from. | |||||
2020-08-06 | aes_util: Make use of non-template variant of Transcode | Lioncash | 1 | -1/+1 | |
Same behavior, less template instantiations. | |||||
2020-08-06 | Fix thread naming on Linux, which limits names to 15 bytes. | comex | 2 | -1/+13 | |
- In `SetCurrentThreadName`, when on Linux, truncate to 15 bytes, as (at least on glibc) `pthread_set_name_np` will otherwise return `ERANGE` and do nothing. - Also, add logging in case `pthread_set_name_np` returns an error anyway. This is Linux-specific, as the Apple and BSD versions of `pthread_set_name_np return `void`. - Change the name for CPU threads in multi-core mode from "yuzu:CoreCPUThread_N" (19 bytes) to "yuzu:CPUCore_N" (14 bytes) so it fits into the Linux limit. Some other thread names are also cut off, but I didn't bother addressing them as you can guess them from the truncated versions. For a CPU thread, truncation means you can't see which core it is! | |||||
2020-08-05 | common/virtual_buffer: drop unused includes | Jan Beich | 1 | -9/+0 | |
On DragonFly and NetBSD build fails with src/common/virtual_buffer.cpp src/common/virtual_buffer.cpp:16:10: fatal error: sys/sysinfo.h: No such file or directory #include <sys/sysinfo.h> ^~~~~~~~~~~~~~~ | |||||
2020-08-05 | system_control: Make functions internally linked where applicable | Lioncash | 2 | -15/+11 | |
These functions are only ever used internally as implementation details for GenerateRandomRange(), so these can be given internal linkage. | |||||
2020-08-05 | kernel: Remove unused variables | Lioncash | 2 | -18/+11 | |
Resolves a few compiler warnings. | |||||
2020-08-05 | scheduler: Resolve sign conversion warning | Lioncash | 1 | -1/+2 | |
2020-08-05 | address_arbiter: Resolve sign conversion warning | Lioncash | 1 | -1/+1 | |
Makes our type conversion explicit. | |||||
2020-08-05 | ipc_helpers: Only allow trivially copyable objects with PushRaw() and PopRaw() | Lioncash | 1 | -0/+4 | |
It's undefined behavior to use non-trivially copyable objects with std::memcpy, so we can add asserts to catch usages of these at compile-time. | |||||
2020-08-05 | vfs_vector: Make creation of array vfs files less verbose | Lioncash | 4 | -41/+41 | |
We can add a helper function to make creation of these files nicer. While we're at it, we can eliminate an unnecessary std::array copy in the constructor. This makes the overhead on some of these functions way less intensive, given some arrays were quite large. e.g. The timezone location names are 9633 bytes in size. | |||||
2020-08-05 | main: Fallback to loader if no control nca is found with patch manager | Morph | 1 | -6/+17 | |
In some rare instances, the patch manager is not able to find a control nca, fallback to the previous method of parsing a control nca through the loader if this occurs. | |||||
2020-08-05 | main: Fix Open Save/Mod Locations for installed titles | Morph | 4 | -12/+12 | |
Previously NAND/SDMC installed titles would open device saves when they are supposed to be user saves. This is due to the control nca not being read and thus returns 0 for both GetDefaultNormalSaveSize() and GetDeviceSaveDataSize(). Fix this by utilizing the patch manager to read the control nca. | |||||
2020-08-05 | game_list_worker: Do not clear entries when > 1 gamedir is present | Morph | 1 | -1/+1 | |
Previously the map of entries was being cleared while looping through each game directory, this resulted into all game directories except the last game dir to lose content metadata information. Fix this by clearing the entries only once. | |||||
2020-08-03 | aes_util: Allow SetIV to be non-allocating | Lioncash | 7 | -27/+36 | |
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. | |||||
2020-08-03 | perf_stats: Make use of designated initializers | Lioncash | 1 | -6/+7 | |
Same behavior, but allows us to avoid a now-unnecessary zero initialization. | |||||
2020-08-03 | perf_stats: Mark GetMeanFrametime() as const | Lioncash | 2 | -9/+9 | |
The general pattern is to mark mutexes as mutable when it comes to matters of constness, given the mutex acts as a transient member of a data structure. | |||||
2020-08-03 | vulkan: Silence more -Wmissing-field-initializer warnings | Lioncash | 6 | -3/+18 | |
2020-08-03 | yuzu: Resolve C++20 deprecation warnings related to lambda captures | Lioncash | 9 | -81/+88 | |
C++20 deprecates capturing the this pointer via the '=' capture. Instead, we replace it or extend the capture specification. | |||||
2020-08-03 | service/ldr: Resolve sign mismatch warnings | Lioncash | 1 | -3/+2 | |
We were performing an int < size_t comparison. We can just correct the type of the induction variable. | |||||
2020-08-03 | CMakeLists: Resolve #4478 | Lioncash | 1 | -1/+6 | |
This switch is enabled by default in all recent versions of GCC and Clang. | |||||
2020-08-03 | tests/core_timing: Remove pragma optimize(off) | Lioncash | 1 | -9/+5 | |
I made a review comment about this in the PR that this was introduced in (#3955, commit 71c4779211dc081a3b2dd4af52edad5748e7a7f5), but it seems to have been missed. We shouldn't be using this pragma here because it's MSVC specific. This causes warnings on other compilers. The test it's surrounding is *extremely* dubious, but for the sake of silencing warnings on other compilers, we can mark "placebo" as volatile and be on with it. | |||||
2020-08-03 | time_zone_binary: Make use of designated initializers | Lioncash | 1 | -17/+25 | |
2020-08-03 | logging/backend: Make use of designated initializers | Lioncash | 2 | -21/+15 | |
Same behavior, less code. | |||||
2020-08-03 | buffer_queue: Make use of std::nullopt | Lioncash | 1 | -5/+6 | |
Allows compilers to eliminate unnecessary zeroing out of the optional's buffer. | |||||
2020-08-03 | buffer_queue: Make use of designated initializers | Lioncash | 1 | -5/+5 | |
2020-08-03 | profile_manager: Make use of std::nullopt | Lioncash | 1 | -4/+4 | |
Allows some implementations to completely avoid unnecessarily zeroing out the internal buffer. | |||||
2020-08-03 | profile_manager: Make use of designated initializers | Lioncash | 1 | -13/+22 | |
More compact code. | |||||
2020-08-03 | dmnt_cheat_vm: Make use of designated initializers | Lioncash | 1 | -105/+121 | |
Allows for more compact code. | |||||
2020-08-03 | file_sys/mode: Make use of DECLARE_ENUM_FLAG_OPERATORS with Mode | Lioncash | 2 | -18/+21 | |
Same behavior, minus a hand-rolled operator. | |||||
2020-08-03 | sm: Make use of IsBaseOf for GetService | David Marcec | 1 | -3/+2 | |
2020-08-03 | patch_manager: Resolve -Wignored-qualifier warnings | Lioncash | 1 | -2/+2 | |
Top level const will always be ignored in this case, so it can be removed. | |||||
2020-08-03 | registered_cache: Resolve -Wmaybe_uninitialized warnings | Lioncash | 1 | -10/+15 | |
While we're at it, we can avoid a redundant map lookup. | |||||
2020-08-03 | Place in anonymous namespace | David Marcec | 1 | -0/+4 | |
2020-08-03 | loader: Make IdentifyFile typesafe | David Marcec | 1 | -20/+32 | |
Relies on #4465 for concept.h Common::IsBaseOf | |||||
2020-08-03 | ipc: Allow all trivially copyable objects to be passed directly into WriteBuffer (#4465) | David | 12 | -30/+64 | |
* ipc: Allow all trivially copyable objects to be passed directly into WriteBuffer With the support of C++20, we can use concepts to deduce if a type is an STL container or not. * More agressive concept for stl containers * Add -fconcepts * Move to common namespace * Add Common::IsBaseOf | |||||
2020-08-01 | mix buffer depopping | David Marcec | 2 | -30/+101 | |
2020-07-31 | minor nits | Morph | 1 | -1/+3 | |
2020-07-31 | am: Unstub SetScreenShotPermission | David Marcec | 2 | -1/+12 | |
2020-07-30 | fsp-srv: Stub Read/WriteSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute | Morph | 2 | -23/+56 | |
Stub these 2 service commands required for Animal Crossing: New Horizons Update 1.4.0 | |||||
2020-07-30 | fs: Rename SaveDataDescriptor to SaveDataAttribute | Morph | 5 | -41/+63 | |
2020-07-30 | adpcm streaming | David Marcec | 4 | -27/+32 | |
2020-07-29 | game_list_worker: Fix game list subdirectory scanning | Morph | 1 | -2/+2 | |
Oddly enough the scan that feeds the manual content provider is hardcoded to scan 2 nested directories deep. This effectively rendered the scan subdirectories setting useless as the manual content provider cannot find any games located more than 2 nested directories deep. Furthermore, this behavior causes game files to be picked up by the manual content provider even if scan subdirectories is disabled. FIx this by utilizing the behavior described when populating the game list for populating the content provider. | |||||
2020-07-29 | main: Add support for removing SDMC installed titles | Morph | 1 | -14/+13 | |
2020-07-29 | xts_archive: Check if the file is nullptr prior to parsing | Morph | 1 | -5/+9 | |
Fixes an access violation where the file no longer exists at the specified path while being parsed. | |||||
2020-07-29 | registered_cache: Add support for removing folder ncas | Morph | 2 | -53/+54 | |
2020-07-29 | game_list: Limit context menu options for homebrew | Morph | 1 | -1/+7 | |
Hides the following options when the title id is 0: - Open Save Location - Open Mod Data Location - Open Transferable Shader Cache - All removal options except Remove Custom Configuration | |||||
2020-07-29 | main: Remove assert for opening savedata when program_id = 0 | Morph | 1 | -1/+0 | |
2020-07-29 | main: Silence [[fallthrough]] warning | Morph | 1 | -3/+2 | |
2020-07-29 | main: Split removal cases into their individual functions and address feedback | Morph | 2 | -113/+131 | |
2020-07-29 | main: Connect game list remove signals to removal functions | Morph | 2 | -5/+167 | |
2020-07-29 | game_list: Add "Remove" context menu | Morph | 2 | -4/+37 | |
Adds the following actions: - Remove Installed Update - Remove All Installed DLC - Remove Shader Cache - Remove Custom Configuration - Remove All Installed Contents | |||||
2020-07-28 | configure_graphics: Remove Force 30 FPS mode | Morph | 6 | -25/+0 | |
The introduction of multicore rendered this setting non-functional as timing code was changed. This removes the setting entirely. | |||||
2020-07-28 | renderer_opengl: Use 1/4 of all threads for async shader compilation | Morph | 1 | -9/+4 | |
2020-07-28 | common/atomic_ops: Don't cast away volatile from pointers | Lioncash | 3 | -27/+30 | |
Preserves the volatility of the pointers being casted. | |||||
2020-07-28 | service/bsd: Handle Poll with no entries accurately | ReinUsesLisp | 1 | -0/+5 | |
Testing shows that Poll called with zero entries returns -1 and signals an errno of zero. | |||||
2020-07-28 | services/bsd: Implement most of bsd:s | ReinUsesLisp | 5 | -55/+911 | |
This implements: Socket, Poll, Accept, Bind, Connect, GetPeerName, GetSockName, Listen, Fcntl, SetSockOpt, Shutdown, Recv, RecvFrom, Send, SendTo, Write, and Close The implementation was done referencing: SwIPC, switchbrew, testing with libnx and inspecting its code, general information about bsd sockets online, and analysing official software. Not everything from these service calls is implemented, but everything that is not implemented will be logged in some way. | |||||
2020-07-28 | service/sockets: Add worker pool abstraction | ReinUsesLisp | 1 | -0/+30 | |
Manage worker threads with an easy to use abstraction. We can expand this to support thread deletion in the future. | |||||
2020-07-28 | service/sockets: Add worker abstraction to execute blocking calls asynchronously | ReinUsesLisp | 2 | -0/+133 | |
This abstraction allows executing blocking functions (like recvfrom on a socket configured for blocking) without blocking the service thread. It is intended to be used with SleepClientThread. | |||||
2020-07-28 | service/sockets: Add translate functions | ReinUsesLisp | 3 | -0/+215 | |
These functions translate from Network enumerations/structures to guest enumerations/structures and viceversa. | |||||
2020-07-28 | service/sockets: Add enumerations and structures | ReinUsesLisp | 2 | -0/+81 | |
Add guest enumerations and structures used in socket services | |||||
2020-07-28 | services/nifm: Implement GetCurrentIpAddress | ReinUsesLisp | 1 | -1/+12 | |
This is trivially implemented using the Network abstraction - Used by ftpd | |||||
2020-07-28 | device_memory: Remove unused system member | Lioncash | 3 | -11/+4 | |
This isn't used by anything in particular, so it can be removed. | |||||
2020-07-28 | cpu_manager: Remove redundant std::function declarations | Lioncash | 1 | -3/+3 | |
We can just return the function directly. Making for less reading. | |||||
2020-07-28 | Update src/core/hle/service/nvdrv/devices/nvmap.cpp | bunnei | 1 | -1/+1 | |
Co-authored-by: LC <mathew1800@gmail.com> | |||||
2020-07-28 | core_timing: Make use of uintptr_t to represent user_data | Lioncash | 15 | -43/+52 | |
Makes the interface future-proofed for supporting other platforms in the event we ever support platforms with differing pointer sizes. This way, we have a type in place that is always guaranteed to be able to represent a pointer exactly. | |||||
2020-07-28 | yuzu/main: Remove redundant usages of QStringLiteral("") | Lioncash | 1 | -6/+5 | |
An empty QStringLiteral can more efficiently be replaced with an empty QString. | |||||
2020-07-27 | remove unused variable; | CrazyMax | 1 | -1/+0 | |
2020-07-26 | GCAdapter: only join worker thread if running & joinable | Brian J. Tarricone | 1 | -1/+3 | |
2020-07-26 | video_core/gpu: Correct the size of the puller registers | Billy Laws | 1 | -2/+2 | |
The puller register array is made up of u32s however the `NUM_REGS` value is the size in bytes, so switch it to avoid making the struct unnecessary large. Also fix a small typo in a comment. | |||||
2020-07-26 | config: Make the save-as identifier more consistent | lat9nq | 1 | -2/+2 | |
Solves an issue with restoring the value upon reloading program. | |||||
2020-07-26 | hle: nvdrv: Rewrite of GPU memory management. | bunnei | 6 | -593/+431 | |
2020-07-26 | yuzu/configure_debug: Remove duplicated checkboxes | FearlessTobi | 1 | -22/+0 | |
Those are already found in the Filesystem tab. They were added back to the Debug tab by mistake in the Vulkan PR. | |||||
2020-07-26 | nvflinger: Mark interface functions with return values as [[nodiscard]] | Lioncash | 1 | -16/+14 | |
Not using the return value of these functions are undeniably the source of a bug. This way we allow compilers to loudly make any future misuses evident. | |||||
2020-07-26 | nvflinger: Use return value of Lock() | Lioncash | 3 | -4/+4 | |
comex reported in #4424 that we were incorrectly discarding the return value of Lock() which is correct. | |||||
2020-07-25 | common/string_util: Remove unimplemented function prototype (#4414) | LC | 1 | -12/+0 | |
This function was relocated to log.h as a constexpr function, so this can be removed. | |||||
2020-07-25 | Fix perf regression | David Marcec | 1 | -1/+2 | |
2020-07-25 | vulkan: Resolve -Wmissing-field-initializer warnings | Lioncash | 2 | -0/+4 | |
2020-07-25 | udp/client: Remove unused boost include | Lioncash | 1 | -1/+0 | |
Also silences a deprecation warning from boost on Clang/GCC. | |||||
2020-07-25 | gc_adapter: Resolve C++20 deprecation warning | Lioncash | 1 | -1/+1 | |
2020-07-25 | gc_poller: Resolve -Wsign-compare warning | Lioncash | 1 | -1/+2 | |
2020-07-25 | gc_poller: Resolve -Wredundant-move warning | Lioncash | 1 | -2/+1 | |
2020-07-25 | lz4_compression: Make use of std::span in interfaces | Lioncash | 2 | -17/+14 | |
Allows compressing the data and size parameters into one. | |||||
2020-07-25 | zstd_compression: Make use of std::span in interfaces | Lioncash | 3 | -13/+10 | |
Allows condensing the data and size parameters into a single argument. | |||||
2020-07-25 | virtual_buffer: Mark size parameter of FreeMemoryPages() as [[maybe_unused]] | Lioncash | 1 | -1/+1 | |
This isn't used on Windows, but is used on non-Windows operating systems. | |||||
2020-07-25 | Fix stream channel count when outputting to stereo | David Marcec | 1 | -1/+1 | |
2020-07-25 | Address issues | David Marcec | 8 | -101/+104 | |
2020-07-25 | Queue extra mix buffer | David Marcec | 1 | -0/+1 | |
2020-07-25 | Disable time stretcher for time being | David Marcec | 2 | -6/+4 | |
2020-07-25 | audio_core: Apollo Part 1, AudioRenderer refactor | David Marcec | 26 | -713/+4204 | |
2020-07-23 | network: add missing include for BSDs | Jan Beich | 1 | -0/+2 | |
src/core/network/network.cpp:112:28: error: use of undeclared identifier 'SHUT_RD' constexpr int SD_RECEIVE = SHUT_RD; ^ src/core/network/network.cpp:113:25: error: use of undeclared identifier 'SHUT_WR' constexpr int SD_SEND = SHUT_WR; ^ src/core/network/network.cpp:114:25: error: use of undeclared identifier 'SHUT_RDWR' constexpr int SD_BOTH = SHUT_RDWR; ^ src/core/network/network.cpp:120:37: error: unknown type name 'in_addr'; did you mean 'in_addr_t'? constexpr IPv4Address TranslateIPv4(in_addr addr) { ^~~~~~~ in_addr_t /usr/include/netdb.h:66:20: note: 'in_addr_t' declared here typedef __uint32_t in_addr_t; ^ src/core/network/network.cpp:121:27: error: member reference base type 'in_addr_t' (aka 'unsigned int') is not a structure or union const u32 bytes = addr.s_addr; ~~~~^~~~~~~ src/core/network/network.cpp:121:15: error: variables defined in a constexpr function must be initialized const u32 bytes = addr.s_addr; ^ src/core/network/network.cpp:126:10: error: incomplete result type 'sockaddr' in function definition sockaddr TranslateFromSockAddrIn(SockAddrIn input) { ^ /usr/include/netdb.h:142:9: note: forward declaration of 'sockaddr' struct sockaddr *ai_addr; /* binary address */ ^ src/core/network/network.cpp:127:5: error: unknown type name 'sockaddr_in'; did you mean 'sockaddr'? sockaddr_in result; ^~~~~~~~~~~ sockaddr /usr/include/netdb.h:142:9: note: 'sockaddr' declared here struct sockaddr *ai_addr; /* binary address */ ^ src/core/network/network.cpp:127:17: error: variable has incomplete type 'sockaddr' sockaddr_in result; ^ /usr/include/netdb.h:142:9: note: forward declaration of 'sockaddr' struct sockaddr *ai_addr; /* binary address */ ^ src/core/network/network.cpp:131:29: error: use of undeclared identifier 'AF_INET' result.sin_family = AF_INET; ^ src/core/network/network.cpp:135:29: error: use of undeclared identifier 'AF_INET' result.sin_family = AF_INET; ^ src/core/network/network.cpp:139:23: error: use of undeclared identifier 'htons' result.sin_port = htons(input.portno); ^ src/core/network/network.cpp:143:14: error: variable has incomplete type 'sockaddr' sockaddr addr; ^ /usr/include/netdb.h:142:9: note: forward declaration of 'sockaddr' struct sockaddr *ai_addr; /* binary address */ ^ src/core/network/network.cpp:156:1: error: unknown type name 'linger' linger MakeLinger(bool enable, u32 linger_value) { ^ src/core/network/network.cpp:157:5: error: unknown type name 'linger' linger value; ^ src/core/network/network.cpp:185:16: error: use of undeclared identifier 'AF_INET' return AF_INET; ^ src/core/network/network.cpp:195:16: error: use of undeclared identifier 'SOCK_STREAM' return SOCK_STREAM; ^ src/core/network/network.cpp:197:16: error: use of undeclared identifier 'SOCK_DGRAM' return SOCK_DGRAM; ^ src/core/network/network.cpp:207:16: error: use of undeclared identifier 'IPPROTO_TCP' return IPPROTO_TCP; ^ fatal error: too many errors emitted, stopping now [-ferror-limit=] | |||||
2020-07-21 | vi: IApplicationDisplayService:GetIndirectLayerImageRequiredMemoryInfo | David Marcec | 1 | -1/+19 | |
Needed for dark souls and monster hunter | |||||
2020-07-21 | surface_params: Make use of designated initializers where applicable | Lioncash | 1 | -38/+46 | |
Provides a convenient way to avoid unnecessary zero initializing. | |||||
2020-07-21 | surface_params: Remove redundant assignment | Lioncash | 1 | -1/+0 | |
This is a redundant assignment that can be removed. | |||||
2020-07-21 | surface_params: Replace questionable usages of the comma operator with semicolons | Lioncash | 1 | -9/+9 | |
These are bugs waiting to happen. | |||||
2020-07-21 | video_core: Remove unused variables | Lioncash | 8 | -33/+5 | |
Silences several compiler warnings about unused variables. | |||||
2020-07-21 | vk_rasterizer: Remove unused variable in Clear() | Lioncash | 1 | -4/+0 | |
The relevant values are already assigned further down in the lambda, so this can be removed entirely. | |||||
2020-07-21 | compatible_formats: Add missing header guard | Lioncash | 1 | -0/+2 | |
Prevents potential inclusion issues from occurring. | |||||
2020-07-21 | video_core: Allow copy elision to take place where applicable | Lioncash | 7 | -26/+26 | |
Removes const from some variables that are returned from functions, as this allows the move assignment/constructors to execute for them. | |||||
2020-07-21 | configure_ui: Ensure a separator follows the returned path | lat9nq | 1 | -3/+5 | |
2020-07-21 | configure_ui: don't use an empty string | lat9nq | 1 | -1/+3 | |
If the user had cancelled, it would clear the text box. That behavior was sanitized underneath, but may anyways cause inconveniences. | |||||
2020-07-21 | main: Don't use as many string copies | lat9nq | 1 | -6/+8 | |
Co-Authored-By: LC <lioncash@users.noreply.github.com> | |||||
2020-07-21 | main: rewrite (save as) screenshot saving | lat9nq | 1 | -9/+18 | |
This picks a default directory and file name. If on Windows and save-as screenshot saving is enabled, it asks the user, first defaulting to the default screenshot path, and with a default filename in the format `[title_id]_[year-mt-dy_hr-mn-sc-msc].png`. Otherwise, or on Linux for now, it simply saves a file in that directory with that file name. | |||||
2020-07-21 | configuration: Setup UI to config screenshot path and saving | lat9nq | 5 | -5/+93 | |
This adds two options to the General -> UI tab. The first disables picking a place to save the file. The second chooses a default directory for saving screenshots. | |||||
2020-07-21 | common: Add a screenshots directory | lat9nq | 3 | -0/+3 | |
Adds a screenshots directory as a path managed by FileUtil. | |||||
2020-07-21 | video_core: Remove redundant pixel format type | David Marcec | 1 | -1/+0 | |
We already get the format type before converting shadow formats and during shadow formats. | |||||
2020-07-20 | buffer_cache: Eliminate redundant map lookup in MarkRegionAsWritten() | Lioncash | 1 | -6/+3 | |
We can make use of emplace()'s return value to determine whether or not we need to perform an increment. emplace() performs no insertion if an element already exist, so this can eliminate a find() call. | |||||
2020-07-20 | wait_tree: Include Midnight Blue dark themes | Morph | 1 | -1/+4 | |
2020-07-20 | qt-themes: Add Midnight Blue qdarkstyle theme (2.8.1) | James Rowe | 2 | -1/+3 | |
Co-authored-by: Morph <39850852+Morph1984@users.noreply.github.com> | |||||
2020-07-20 | Address issues | David Marcec | 1 | -2/+2 | |
2020-07-19 | configure_graphics_advnaced: clang-format mk ii | lat9nq | 1 | -3/+3 | |
2020-07-19 | configure_graphics_advanced: Fix oversight from rebase | lat9nq | 1 | -1/+1 | |
2020-07-19 | configuration_shared: Remove unused functions | lat9nq | 2 | -18/+0 | |
These were only kept for compatibility with old code during testing. | |||||
2020-07-19 | configuration: Use forward declares and remove extraneous structs | lat9nq | 10 | -63/+59 | |
2020-07-19 | configuration_shared: Make CheckState strongly typed | lat9nq | 2 | -24/+23 | |
Also gets rid of unnecessary explicit namespace usage. | |||||
2020-07-19 | clang-format | lat9nq | 5 | -38/+32 | |
2020-07-19 | configuration_shared: Break up tracker structs to respective classes | lat9nq | 12 | -49/+58 | |
One less global variable. | |||||
2020-07-19 | configure_system: break instead of semicolon | lat9nq | 1 | -2/+4 | |
Makes the code more readable Co-Authored-By: LC <lioncash@users.noreply.github.com> | |||||
2020-07-19 | clang-format | lat9nq | 3 | -8/+11 | |
2020-07-19 | configure_system: Highlight labels on startup | lat9nq | 1 | -0/+5 | |
whoops | |||||
2020-07-19 | configure_graphics: Fix layout in global config | lat9nq | 1 | -1/+1 | |
Fixes a regression where the global config takes up a lot of extra space. | |||||
2020-07-19 | configure_per_game: Improve style consistency | lat9nq | 3 | -54/+43 | |
The way the configurations are set up, it is not trivial to do this. I'll leave it as is, but the API selection, and the background color and volume slider selectors are kind of not following the style. | |||||
2020-07-19 | configure_system: Implement highlighted overrides | lat9nq | 3 | -539/+544 | |
2020-07-19 | configuration_shared: Add default combobox setup function | lat9nq | 3 | -21/+52 | |
Not a catch-all, but helps clean up the code for when I do this a lot. Also fixes some bugs caught in configure_graphics. | |||||
2020-07-19 | configuration_shared: Use an int instead of a QString | lat9nq | 4 | -22/+28 | |
I noticed some of the code could be reduced to just passing the function an int, since I was doing the same thing over and over. Also clang-formats configure_graphics | |||||
2020-07-19 | configure_graphics_advanced: Implement highlighted overrides | lat9nq | 3 | -96/+146 | |
2020-07-19 | configuration_shared: Switch back to background colors | lat9nq | 1 | -2/+2 | |
Let's see if I make up my mind. | |||||
2020-07-19 | configuration_shared: Better use global text | lat9nq | 2 | -0/+15 | |
Also adds trackers for graphics and advanced graphics | |||||
2020-07-19 | configure_audio: fix UI margins | lat9nq | 1 | -1/+10 | |
2020-07-19 | configure_graphics: Implement highlighted overrides | lat9nq | 2 | -134/+200 | |
2020-07-19 | configure_audio: Implement highlighted overrides | lat9nq | 2 | -80/+87 | |
2020-07-19 | configuration_shared: Require name of the widget for highlighting | lat9nq | 3 | -16/+27 | |
Prevents mass-coloring of elements later on | |||||
2020-07-19 | configuration_shared: Use a highlight instead of background color | lat9nq | 2 | -6/+6 | |
Fixes visibility in the built-in dark theme | |||||
2020-07-19 | configure_general: Implement manual tristate buttons | lat9nq | 2 | -17/+27 | |
2020-07-19 | configuration_shared: Initial functions and data for manual tristate | lat9nq | 2 | -0/+58 | |
Sets up initial support for implementing colored tristate functions. These functions color a QWidget blue when it's overriding a global setting, and discolor it when not. The lack of color indicates it uses the global state, replacing the Qt::CheckState::PartiallyChecked state with the global state. | |||||
2020-07-19 | Fix axis thresholding while polling | ameerj | 1 | -5/+2 | |
axes were very sensitive when mapping controls. | |||||
2020-07-19 | swkbd: Return result for Calc request for inlined swkbd | David Marcec | 2 | -13/+49 | |
Fixes random swkbd popups in monster hunter | |||||
2020-07-19 | core/network: Add network abstraction | ReinUsesLisp | 5 | -0/+840 | |
This commit adds a network abstraction designed to implement bsd:s but at the same time work as a generic abstraction to implement any networking code we have to use from core. This is implemented on top of BSD sockets on Unix systems and winsock on Windows. The code is designed around winsocks having compatibility definitions to support both BSD and Windows sockets. | |||||
2020-07-19 | alignment: explicitly include <new> after 723edb4c0659 | Jan Beich | 1 | -0/+1 | |
In file included from src/core/hle/kernel/memory/page_table.cpp:5: src/./common/alignment.h:67:68: error: no member named 'align_val_t' in namespace 'std' return static_cast<T*>(::operator new (n * sizeof(T), std::align_val_t{Align})); ~~~~~^ src/./common/alignment.h:71:51: error: no member named 'align_val_t' in namespace 'std' ::operator delete (p, n * sizeof(T), std::align_val_t{Align}); ~~~~~^ | |||||
2020-07-18 | Address issues | David Marcec | 1 | -6/+3 | |
2020-07-18 | Address trivial review comments. | FearlessTobi | 1 | -1/+1 | |
2020-07-18 | configure_ui: Address some review comments from the previous PR | FearlessTobi | 2 | -16/+21 | |
2020-07-18 | yuzu: Port translation support from Citra | FearlessTobi | 10 | -84/+235 | |
Co-Authored-By: Weiyi Wang <wwylele@gmail.com> | |||||
2020-07-18 | frontend: Improve wait tree readability for dark themes | David Marcec | 1 | -11/+44 | |
2020-07-18 | gl_arb_decompiler: Use NV_shader_buffer_{load,store} on assembly shaders | ReinUsesLisp | 7 | -110/+173 | |
NV_shader_buffer_{load,store} is a 2010 extension that allows GL applications to use what in Vulkan is known as physical pointers, this is basically C pointers. On GLASM these is exposed through the LOAD/STORE/ATOM instructions. Up until now, assembly shaders were using NV_shader_storage_buffer_object. These work fine, but have a (probably unintended) limitation that forces us to have the limit of a single stage for all shader stages. In contrast, with NV_shader_buffer_{load,store} we can pass GPU addresses to the shader through local parameters (GLASM equivalent uniform constants, or push constants on Vulkan). Local parameters have the advantage of being per stage, allowing us to generate code without worrying about binding overlaps. | |||||
2020-07-18 | Fix style issues | David Marcec | 2 | -7/+13 | |
2020-07-18 | file_sys/nsp: Make SetTicketKeys actually do something | FearlessTobi | 2 | -32/+30 | |
Previously, the method wasn't modifying any class state and therefore not having any effects when called. Since this has been the case for a very long time now, I'm not sure if we couldn't just remove this method altogether. | |||||
2020-07-18 | vk_device: Fix build error on old MSVC versions | ReinUsesLisp | 1 | -3/+3 | |
Designated initializers on old MSVC versions fail to build when they take the address of a constant. | |||||
2020-07-17 | std::size_t where appropriate, make error message more clear if can't read | ameerj | 1 | -3/+4 | |
2020-07-17 | alignment: Simplify AlignmentAllocator implementation | Lioncash | 1 | -43/+4 | |
With C++20, much of the allocator interface has been simplified, so we can make the same adjustments. | |||||
2020-07-17 | Drop settings namespace | David Marcec | 1 | -2/+1 | |
2020-07-17 | Remove duplicate config | David Marcec | 2 | -2/+1 | |
2020-07-17 | Use conditional var | David Marcec | 2 | -9/+15 | |
2020-07-17 | Drop max workers from 8->2 for testing | David Marcec | 1 | -1/+1 | |
2020-07-17 | Rebase for per game settings | David Marcec | 9 | -1/+53 | |
2020-07-17 | async shaders | David Marcec | 16 | -64/+598 | |
2020-07-17 | macro_hle: Remove unnecessary static keywords | Lioncash | 1 | -7/+4 | |
These functions are already in an anonymous namespace which makes the functions internally linked. | |||||
2020-07-17 | core/CMakeLists: Add missing physical_memory.h header file | Lioncash | 1 | -0/+1 | |
Allows this header file to show up in IDE CMake generators. | |||||
2020-07-17 | macro_hle: Simplify shift expression in HLE_771BB18C62444DA0() | Lioncash | 1 | -2/+1 | |
Given the expression involves a 32-bit value, this simplifies down to just: 0x3ffffff. This is likely a remnant from testing that was never cleaned up. Resolves a -Wshift-overflow warning. | |||||
2020-07-17 | macro_hle: Remove unnecessary std::make_pair calls | Lioncash | 1 | -3/+3 | |
The purpose of make_pair is generally to deduce the types within the pair without explicitly specifying the types, so these usages were generally unnecessary, particularly when the type is enforced by the array declaration. | |||||
2020-07-17 | macro: Resolve missing parameter in doxygen comment | Lioncash | 1 | -1/+2 | |
Resolves a -Wdocumentation warning. | |||||
2020-07-17 | constants: Add missing <array> include | Lioncash | 1 | -0/+1 | |
Eliminates reliance on an indirect include. | |||||
2020-07-17 | mii/manager: Resolve sign mismatch warnings | Lioncash | 1 | -3/+3 | |
Previously the loop termination condition was testing variables of different signedness. | |||||
2020-07-17 | mii/manager: Make use of designated initializers | Lioncash | 1 | -53/+54 | |
Allows returning the structure in a more concise manner. | |||||
2020-07-17 | wrapper: Make use of designated initializers where applicable | Lioncash | 1 | -56/+64 | |
2020-07-17 | vk_texture_cache: Make use of designated initializers where applicable | Lioncash | 1 | -96/+135 | |
2020-07-17 | vk_texture_cache: Amend mismatched access masks and indices in UploadBuffer | Lioncash | 1 | -6/+4 | |
Discovered while converting relevant parts of the codebase over to designated initializers. | |||||
2020-07-17 | vk_swapchain: Make use of designated initializers where applicable | Lioncash | 1 | -43/+51 | |
2020-07-17 | vk_stream_buffer: Make use of designated initializers where applicable | Lioncash | 1 | -19/+16 | |
2020-07-17 | vk_staging_buffer_pool: Make use of designated initializers where applicable | Lioncash | 1 | -13/+12 | |
2020-07-17 | vk_shader_util: Make use of designated initializers where applicable | Lioncash | 1 | -7/+7 | |
2020-07-17 | vk_scheduler: Make use of designated initializers where applicable | Lioncash | 1 | -27/+30 | |
2020-07-17 | vk_sampler_cache: Make use of designated initializers where applicable | Lioncash | 1 | -24/+27 | |
2020-07-17 | vk_resource_manager: Make use of designated initializers where applicable | Lioncash | 1 | -15/+14 | |
2020-07-17 | vk_renderpass_cache: Make use of designated initializers where applicable | Lioncash | 1 | -59/+70 | |
2020-07-17 | vk_rasterizer: Make use of designated initializers where applicable | Lioncash | 1 | -41/+47 | |
2020-07-17 | vk_query_cache: Make use of designated initializers where applicable | Lioncash | 1 | -8/+8 | |
2020-07-17 | vk_pipeline_cache: Make use of designated initializers where applicable | Lioncash | 1 | -31/+35 | |
2020-07-17 | vk_memory_manager: Make use of designated initializers where applicable | Lioncash | 1 | -7/+6 | |
2020-07-17 | vk_image: Make use of designated initializers where applicable | Lioncash | 1 | -15/+23 | |
2020-07-17 | vk_descriptor_pool: Make use of designated initializers where applicable | Lioncash | 1 | -15/+18 | |
2020-07-17 | vk_graphics_pipeline: Resolve narrowing warnings | Lioncash | 1 | -2/+4 | |
For whatever reason, VK_TRUE and VK_FALSE aren't defined as having a VkBool32 type, so we need to cast to it explicitly. | |||||
2020-07-16 | vk_compute_pipeline: Make use of designated initializers where applicable | Lioncash | 1 | -63/+68 | |
2020-07-16 | vk_compute_pass: Make use of designated initializers where applicable | Lioncash | 1 | -95/+99 | |
Note: Some barriers can't be converted over yet, as they ICE MSVC. | |||||
2020-07-16 | vk_buffer_cache: Make use of designated initializers where applicable | Lioncash | 1 | -30/+33 | |
Note: An array within CopyFrom() cannot be converted over yet, as it ICEs MSVC when converted over. | |||||
2020-07-16 | decode/other: Implement S2R.LaneId | ReinUsesLisp | 1 | -2/+1 | |
This maps to host's thread id. - Fixes graphical issues on Paper Mario. | |||||
2020-07-16 | gl_arb_decompiler: Execute BAR even when inside control flow | ReinUsesLisp | 1 | -4/+0 | |
Unlike GLSL, GLASM allows us to call BAR inside control flow. - Fixes graphical artifacts in Paper Mario. | |||||
2020-07-16 | renderer_{opengl,vulkan}: Clamp shared memory to host's limit | ReinUsesLisp | 6 | -9/+42 | |
This stops shaders from failing to build when the exceed host's shared memory size limit. An error is logged. | |||||
2020-07-16 | kernel/thread: Remove unimplemented function prototype | Lioncash | 1 | -2/+0 | |
This isn't used, so it can be removed. | |||||
2020-07-16 | kernel: Remove unused variables | Lioncash | 3 | -7/+2 | |
Resolves some compiler warnings in the Linux build. | |||||
2020-07-16 | kernel: Add missing include | Lioncash | 1 | -0/+1 | |
2020-07-16 | cpu_manager: Mark function getters as static | Lioncash | 4 | -10/+11 | |
All these do are return std::function instances of static functions, so these can be used without an instance of the CPU manager. | |||||
2020-07-16 | cpu_manager: Remove unused preemption_count variable | Lioncash | 1 | -1/+0 | |
Shrinks the data structure by 8 bytes. | |||||
2020-07-16 | cpu_manager: Add missing includes | Lioncash | 1 | -0/+3 | |
Previously this header was relying on indirect inclusions that are no longer satisfied. | |||||
2020-07-16 | Refactor adapter code | Ameer | 2 | -179/+44 | |
2020-07-16 | hid: Only update keyboard & debug pad inputs if enabled | David Marcec | 2 | -33/+37 | |
Previously we would ignore this setting and would update the states regardless of the user setting | |||||
2020-07-16 | Check for empty section0 and CNMT prior to install | Morph | 1 | -3/+19 | |
2020-07-16 | Add comment to clarify the nullptr check | Morph | 1 | -0/+1 | |
2020-07-16 | filesystem: Create subdirectories prior to creating a file | Morph | 1 | -0/+3 | |
If subdirectories exist in the given path parameter and don't exist in the real filesystem create them prior to creating the files within. This fixes the softlocks upon save creation in The Legend of Zelda: Breath of the Wild | |||||
2020-07-16 | core_timing: Remove unused data member | Lioncash | 1 | -2/+0 | |
Shrinks the size of the CoreTiming class by 8 bytes. | |||||
2020-07-16 | core_timing: Make TimedCallback take std::chrono::nanoseconds | Lioncash | 16 | -58/+62 | |
Enforces our desired time units directly with a concrete type. | |||||
2020-07-16 | core_timing: Make use of std::chrono with ScheduleEvent | Lioncash | 13 | -49/+58 | |
2020-07-15 | settings: Resolve a sign conversion warning within GetTimeZoneString() | Lioncash | 1 | -5/+5 | |
A sign conversion warning was occurring due to an int < size_t comparison. | |||||
2020-07-15 | kernel/process: Move name and system context to the bottom of the member list | Lioncash | 1 | -6/+6 | |
These aren't directly important or commonly used within the process, so we can move these to the bottom to allow everything else to be more likely to be within a cache line. | |||||
2020-07-15 | kernel/handle_table: Remove usages of the global system instance | Lioncash | 4 | -8/+15 | |
Removes even more usages of the global system instance, trimming away more dependencies on global variables and making them explicit in the interface. | |||||
2020-07-15 | settings: Make use of std::string_view over std::string for logging | Lioncash | 1 | -33/+34 | |
In all usages of LogSetting(), string literals are provided. std::string_view is better suited here, as we won't churn a bunch of string allocations every time the settings are logged out. While we're at it, we can fold LogSetting() into LogSettings(), given it's only ever used there. | |||||
2020-07-15 | kernel/thread: Remove global GetCurrentThread() | Lioncash | 3 | -23/+7 | |
This is only used in one place, so we can fold it into the calling code, eliminating a place for the global system instance to be used. | |||||
2020-07-15 | clang format | Morph | 1 | -3/+3 | |
2020-07-15 | Use proper install result when overwriting files | Morph | 2 | -3/+3 | |
2020-07-15 | Remove global system instance and address feedback | Morph | 2 | -14/+10 | |
2020-07-15 | registered_cache: Remove previous update/dlc if it exists on install | Morph | 2 | -13/+83 | |
- This checks for and removes old updates or dlc based on title id. If a content meta nca exists within the registered cache, it will attempt to remove all the ncas associated with the content meta before installing a new update/dlc | |||||
2020-07-15 | clang-format | VolcaEM | 1 | -1/+2 | |
2020-07-15 | dmnt_cheat_vm: Implement opcode 0xC3 (ReadWriteStaticRegister) | VolcaEM | 2 | -1/+41 | |
This was based on Atmosphére's DMNT Cheat VM: - https://github.com/Atmosphere-NX/Atmosphere/blob/master/stratosphere/dmnt/source/cheat/impl/dmnt_cheat_vm.hpp - https://github.com/Atmosphere-NX/Atmosphere/blob/master/stratosphere/dmnt/source/cheat/impl/dmnt_cheat_vm.cpp From Atmosphére's documentation: "Code type 0xC3 reads or writes a static register with a given register" There are now only two remaining opcodes to implement (PauseProcess and BreakProcess) This is untested because I don't have any experience in testing cheats on yuzu | |||||
2020-07-14 | common/swap: Make use of std::endian | Lioncash | 1 | -42/+4 | |
Allows removing a bunch of defines in favor of a two liner. | |||||
2020-07-14 | shader_cache: Make use of std::erase_if | Lioncash | 1 | -2/+2 | |
Now that we use C++20, we can also make use of std::erase_if instead of needing to do the erase-remove idiom. | |||||
2020-07-14 | clang-format | lat9nq | 1 | -2/+1 | |
2020-07-14 | settings: Move settings sanitization to its own function | lat9nq | 4 | -4/+11 | |
Creates a new function that can be expanded later to fix other settings that are known to cause emulation errors across executables. | |||||
2020-07-14 | Fix crash if gc configured but adapter not connected | Ameer | 2 | -15/+25 | |
2020-07-14 | main: Set async gpu properly after loading per-game setting | lat9nq | 1 | -0/+4 | |
Another error that got pass me and only noticed when I was doing the per-game settings UI rework. This prevents asynchronous GPU emulation from being disabled while multi core is enabled as a result of a poorly put together per-game config. | |||||
2020-07-14 | configure_general: Explicitly guard use_multi_core when applying settings | lat9nq | 1 | -0/+2 | |
This is likely an oversight during a rebase. Guards use_multi_core to be only set when the global value is in use. It should not make a difference given the current code base, but makes the code sensible. | |||||
2020-07-14 | vk_device: Make use of designated initializers where applicable | Lioncash | 1 | -124/+152 | |
Avoids redundant repetitions of variable names, and allows assignment all in one statement. | |||||
2020-07-14 | input_common: drop unused libusb.h include | Ameer | 1 | -1/+0 | |
Remnant of an early implementation. | |||||
2020-07-14 | vk_graphics_pipeline: Make use of designated initializers where applicable | Lioncash | 1 | -198/+223 | |
Avoids redundant variable name repetitions. | |||||
2020-07-13 | input_common: make libusb private to gc_adapter | Jan Beich | 3 | -3/+7 | |
2020-07-13 | memory_layout: Remove unused data member | Lioncash | 1 | -2/+0 | |
This isn't used, so it can be removed entirely, shrinking the structure size by 8 bytes. | |||||
2020-07-13 | address_space_info: Use type alias to simplify code | Lioncash | 1 | -14/+13 | |
We can define an alias for the index arrays and then just reuse it to make the code nicer to read. | |||||
2020-07-13 | address_space_info: Make use of designated initializers | Lioncash | 2 | -46/+27 | |
We can alter the structure so that we can use designated initializers in the array, eliminating the comments that indicate their field names. | |||||
2020-07-13 | video_core: Rearrange pixel format names | ReinUsesLisp | 19 | -1179/+1077 | |
Normalizes pixel format names to match Vulkan names. Previous to this commit pixel formats had no convention, leading to confusion and potential bugs. | |||||
2020-07-13 | video_core: Fix DXT4 and RGB565 | ReinUsesLisp | 7 | -37/+31 | |
2020-07-13 | video_core/format_lookup_table: Add formats with existing PixelFormat | ReinUsesLisp | 1 | -1/+9 | |
2020-07-13 | video_core: Fix B5G6R5_UNORM render target format | ReinUsesLisp | 5 | -1/+10 | |
2020-07-13 | video_core: Fix B5G6R5U | ReinUsesLisp | 2 | -2/+2 | |
2020-07-13 | video_core: Implement RGBA32_SINT render target | ReinUsesLisp | 7 | -58/+71 | |
2020-07-13 | video_core: Implement RGBA32_SINT render target | ReinUsesLisp | 7 | -0/+13 | |
2020-07-13 | video_core: Implement RGBA16_SINT render target | ReinUsesLisp | 7 | -0/+13 | |
2020-07-13 | video_core: Implement RGBA8_SINT render target | ReinUsesLisp | 7 | -0/+13 | |
2020-07-13 | video_core: Implement RG32_SINT render target | ReinUsesLisp | 7 | -0/+13 | |
2020-07-13 | video_core: Implement RG8_SINT render target and fix RG8_UINT | ReinUsesLisp | 7 | -1/+14 | |
2020-07-13 | video_core: Implement R8_SINT render target | ReinUsesLisp | 7 | -0/+13 | |
2020-07-13 | video_core: Implement R8_SNORM render target | ReinUsesLisp | 7 | -0/+13 | |
2020-07-13 | video_core/surface: Remove explicit values on PixelFormat's definition | ReinUsesLisp | 1 | -80/+80 | |
2020-07-13 | video_core/surface: Reorder render target to pixel format switch | ReinUsesLisp | 1 | -53/+51 | |
2020-07-13 | kernel/scheduler: Use std::mutex instead of spin lock | ReinUsesLisp | 1 | -1/+1 | |
Profiling shows that this is a highly contested mutex, causing dimishing results compared to a OS lock. std::mutex implementations can spin for a while before falling back to an OS lock. This avoids wasting precious CPU cycles in a no-op. | |||||
2020-07-13 | vk_blit_screen: Make use of designated initializers where applicable | Lioncash | 1 | -334/+384 | |
Now that we make use of C++20, we can use designated initializers to make things a little nicer to read. | |||||
2020-07-13 | vk_state_tracker: Fix dirty flags for stencil_enable on VK_EXT_extended_dynamic_state | ReinUsesLisp | 1 | -0/+1 | |
Fixes a regression on any game using stencil on devices with VK_EXT_extended_dynamic_state. | |||||
2020-07-12 | udp: Silence a C++20 deprecation warning | Lioncash | 1 | -1/+1 | |
C++20 deprecates using the = lambda capture to implicitly capture the this pointer. Instead, we must specify it explicitly. | |||||
2020-07-12 | gc_poller: Mark GCButtonFactory::GetNextInput() as const | Lioncash | 2 | -2/+2 | |
This doesn't modify class instance state. | |||||
2020-07-12 | gc_poller: Get rid of undefined behavior in Create() | Lioncash | 1 | -0/+4 | |
Ensures that the function always has returns in all control paths. | |||||
2020-07-12 | gc_poller: Silence sign conversion warnings | Lioncash | 1 | -1/+1 | |
2020-07-12 | gc_adapter: Remove deprecated usage of = in lambda captures | Lioncash | 1 | -1/+1 | |
It's deprecated in C++20 to use = to capture the this pointer. Instead, we can simply pass this as an argument to the thread constructor. | |||||
2020-07-12 | gc_adapter: Silence sign conversion warnings | Lioncash | 2 | -7/+7 | |
2020-07-12 | configure_cpu: Split optimization settings off into Debug tab | MerryMage | 9 | -163/+302 | |
2020-07-12 | common/alignment: Fix compilation errors (#4303) | Tobias | 1 | -1/+3 | |
2020-07-12 | fs: Fix RomFS building when zero byte files are present | Morph | 4 | -10/+10 | |
When zero byte files are present, the key (offset) for that file is identical to the file right after. A std::map isn't able to fit key-value pairs with identical keys (offsets), therefore, the solution is to use std::multimap which permits multiple entries with the same key. This most prominently fixes Pokemon Sword and Shield weather with any RomFS mod applied. | |||||
2020-07-12 | hle: service: mii: Rewrite service to properly support creation of random and default miis. | bunnei | 9 | -914/+3270 | |
2020-07-12 | Revert "Port citra-emu/citra#5441: "Common: remove a mod from AlignUp"" | bunnei | 1 | -3/+1 | |
2020-07-11 | Common: remove a mod from AlignUp (#5441) | Marshall Mohror | 1 | -1/+3 | |
In cases where the size is not a known constant when inlining, AlignUp<std::size_t> currently generates two 64-bit div instructions. This generates one div and a cmov which is significantly cheaper. | |||||
2020-07-11 | configure_cpu: Add tooltips | MerryMage | 1 | -1/+54 | |
2020-07-11 | configure_cpu: Show/Hide debugging options | MerryMage | 7 | -46/+135 | |
2020-07-11 | main/profile_select: Don't prompt for profile selection when only one is available | FearlessTobi | 1 | -9/+13 | |
2020-07-11 | configuration: Add settings to enable/disable specific CPU optimizations | MerryMage | 16 | -29/+404 | |
2020-07-11 | CMakeLists: Make use of /std:c++latest on MSVC | Lioncash | 1 | -2/+2 | |
Provides the buildbot with one builder that is always tracking the latest version of the C++ standard, allowing us to progressively rectify our code and amend any differences between standards over time instead of waiting for a complete standard change, potentially breaking a lot of code all at once. | |||||
2020-07-10 | vk_rasterizer: Pass <pSizes> to CmdBindVertexBuffers2EXT | ReinUsesLisp | 1 | -6/+6 | |
This has been fixed in Nvidia's public beta driver 451.74. The previous beta driver will be broken, people using these will have to update. | |||||
2020-07-10 | Break out of scan loop if can't find adapter on first run | Ameer | 1 | -0/+3 | |
2020-07-10 | video_core/textures: Add and use SwizzleSliceToVoxel, and minor style changes | ReinUsesLisp | 5 | -84/+125 | |
Change GOB sizes from free-functions to constexpr constants. Add SwizzleSliceToVoxel, a function that swizzles a 2D array of pixels into a 3D texture and use it for 3D copies. | |||||
2020-07-10 | vfs_real: Fix MoveFile | Morph | 1 | -10/+17 | |
The file wasn't closed prior to being renamed / moved, throwing an error that states "The process cannot access the file because it is being used by another process." Fix this by closing the file prior to a rename / move operation. Fixes saving in Luigi's Mansion 3 and KATANA KAMI: A Way of the Samurai Story. | |||||
2020-07-10 | KeyManager: Prevent writing of invalid keys | Morph | 1 | -4/+8 | |
If the keys are zero, don't write them to the autogenerated file. | |||||
2020-07-10 | Add additional empty check for the QStringList returned by the InstallDialog | Morph | 1 | -0/+4 | |
2020-07-10 | Update the install and progress dialogs | Morph | 4 | -80/+65 | |
- Remove the overwrite files checkbox, it will always overwrite - The progressbar now reflects the progress in terms of data transferred. | |||||
2020-07-10 | Refactor batch installing files | Morph | 4 | -196/+238 | |
Key issues fixed: - Progress dialog showing up as white/hanging/getting stuck/unresponsive. Key changes: - Progress dialog now shows progress as a function of all files instead of per nca within a file. - Overwrite existing files will overwrite all files in the selection. | |||||
2020-07-10 | Add support for batch install to NAND | Morph | 6 | -124/+290 | |
This adds support to batch install files to NAND | |||||
2020-07-10 | bis_factory: Set User NAND free space to be 1 MiB less than total. | Morph | 1 | -1/+3 | |
2020-07-10 | sdmc_factory: Set the SDMC total size to 1 TiB | Morph | 1 | -1/+3 | |
We should not be limited by the SDMC's partition size, set this to 1 TiB. Hardware is limited to the max allowed by the MBR partition table which is 2 TiB. | |||||
2020-07-10 | bis_factory: Use hardware default NAND partition sizes | Morph | 1 | -10/+11 | |
Sets the total space of user and system partitions to their hardware defaults. Furthermore, return the total space as free space for the user partition to prevent it from reaching zero. Some games like Bioshock 2 check for the available free space prior to save creation, and we should not be limited by arbitrary limits. | |||||
2020-07-10 | settings: Remove storage size options | Morph | 5 | -214/+1 | |
2020-07-10 | cmake: Fix libfmt linking errors | David Marcec | 1 | -5/+1 | |
2020-07-10 | configuration: implement per-game configurations (#4098) | lat9nq | 57 | -835/+1942 | |
* Switch game settings to use a pointer In order to add full per-game settings, we need to be able to tell yuzu to switch to using either the global or game configuration. Using a pointer makes it easier to switch. * configuration: add new UI without changing existing funcitonality The new UI also adds General, System, Graphics, Advanced Graphics, and Audio tabs, but as yet they do nothing. This commit keeps yuzu to the same functionality as originally branched. * configuration: Rename files These weren't included in the last commit. Now they are. * configuration: setup global configuration checkbox Global config checkbox now enables/disables the appropriate tabs in the game properties dialog. The use global configuration setting is now saved to the config, defaulting to true. This also addresses some changes requested in the PR. * configuration: swap to per-game config memory for properties dialog Does not set memory going in-game. Swaps to game values when opening the properties dialog, then swaps back when closing it. Uses a `memcpy` to swap. Also implements saving config files, limited to certain groups of configurations so as to not risk setting unsafe configurations. * configuration: change config interfaces to use config-specific pointers When a game is booted, we need to be able to open the configuration dialogs without changing the settings pointer in the game's emualtion. A new pointer specific to just the configuration dialogs can be used to separate changes to just those config dialogs without affecting the emulation. * configuration: boot a game using per-game settings Swaps values where needed to boot a game. * configuration: user correct config during emulation Creates a new pointer specifically for modifying the configuration while emulation is in progress. Both the regular configuration dialog and the game properties dialog now use the pointer Settings::config_values to focus edits to the correct struct. * settings: split Settings::values into two different structs By splitting the settings into two mutually exclusive structs, it becomes easier, as a developer, to determine how to use the Settings structs after per-game configurations is merged. Other benefits include only duplicating the required settings in memory. * settings: move use_docked_mode to Controls group `use_docked_mode` is set in the input settings and cannot be accessed from the system settings. Grouping it with system settings causes it to be saved with per-game settings, which may make transferring configs more difficult later on, especially since docked mode cannot be set from within the game properties dialog. * configuration: Fix the other yuzu executables and a regression In main.cpp, we have to get the title ID before the ROM is loaded, else the renderer will reflect only the global settings and now the user's game specific settings. * settings: use a template to duplicate memory for each setting Replaces the type of each variable in the Settings::Values struct with a new class that allows basic data reading and writing. The new struct Settings::Setting duplicates the data in memory and can manage global overrides per each setting. * configuration: correct add-ons config and swap settings when apropriate Any add-ons interaction happens directly through the global values struct. Swapping bewteen structs now also includes copying the necessary global configs that cannot be changed nor saved in per-game settings. General and System config menus now update based on whether it is viewing the global or per-game settings. * settings: restore old values struct No longer needed with the Settings::Setting class template. * configuration: implement hierarchical game properties dialog This sets the apropriate global or local data in each setting. * clang format * clang format take 2 can the docker container save this? * address comments and style issues * config: read and write settings with global awareness Adds new functions to read and write settings while keeping the global state in focus. Files now generated per-game are much smaller since often they only need address the global state. * settings: restore global state when necessary Upon closing a game or the game properties dialog, we need to restore all global settings to the original global state so that we can properly open the configuration dialog or boot a different game. * configuration: guard setting values incorrectly This disables setting values while a game is running if the setting is overwritten by a per game setting. * config: don't write local settings in the global config Simple guards to prevent writing the wrong settings in the wrong files. * configuration: add comments, assume less, and clang format No longer assumes that a disabled UI element means the global state is turned off, instead opting to directly answer that question. Still however assumes a game is running if it is in that state. * configuration: fix a logic error Should not be negated * restore settings' global state regardless of accept/cancel Fixes loading a properties dialog and causing the global config dialog to show local settings. * fix more logic errors Fixed the frame limit would set the global setting from the game properties dialog. Also strengthened the Settings::Setting member variables and simplified the logic in config reading (ReadSettingGlobal). * fix another logic error In my efforts to guard RestoreGlobalState, I accidentally negated the IsPowered condition. * configure_audio: set toggle_stretched_audio to tristate * fixed custom rtc and rng seed overwriting the global value * clang format * rebased * clang format take 4 * address my own review Basically revert unintended changes * settings: literal instead of casting "No need to cast, use 1U instead" Thanks, Morph! Co-authored-by: Morph <39850852+Morph1984@users.noreply.github.com> * Revert "settings: literal instead of casting " This reverts commit 95e992a87c898f3e882ffdb415bb0ef9f80f613f. * main: fix status buttons reporting wrong settings after stop emulation * settings: Log UseDockedMode in the Controls group This should have happened when use_docked_mode was moved over to the controls group internally. This just reflects this in the log. * main: load settings if the file has a title id In other words, don't exit if the loader has trouble getting a title id. * use a zero * settings: initalize resolution factor with constructor instead of casting * Revert "settings: initalize resolution factor with constructor instead of casting" This reverts commit 54c35ecb46a29953842614620f9b7de1aa9d5dc8. * configure_graphics: guard device selector when Vulkan is global Prevents the user from editing the device selector if Vulkan is the global renderer backend. Also resets the vulkan_device variable when the users switches back-and-forth between global and Vulkan. * address reviewer concerns Changes function variables to const wherever they don't need to be changed. Sets Settings::Setting to final as it should not be inherited from. Sets ConfigurationShared::use_global_text to static. Co-Authored-By: VolcaEM <volcaem@users.noreply.github.com> * main: load per-game settings after LoadROM This prevents `Restart Emulation` from restoring the global settings *after* the per-game settings were applied. Thanks to BSoDGamingYT for finding this bug. * Revert "main: load per-game settings after LoadROM" This reverts commit 9d0d48c52d2dcf3bfb1806cc8fa7d5a271a8a804. * main: only restore global settings when necessary Loading the per-game settings cannot happen after the ROM is loaded, so we have to specify when to restore the global state. Again thanks to BSoD for finding the bug. * configuration_shared: address reviewer concerns except operator overrides Dropping operator override usage in next commit. Co-Authored-By: LC <lioncash@users.noreply.github.com> * settings: Drop operator overrides from Setting template Requires using GetValue and SetValue explicitly. Also reverts a change that broke title ID formatting in the game properties dialog. * complete rebase * configuration_shared: translate "Use global configuration" Uses ConfigurePerGame to do so, since its usage, at least as of now, corresponds with ConfigurationShared. * configure_per_game: address reviewer concern As far as I understand, it prevents the program from unnecessarily copying strings. Co-Authored-By: LC <lioncash@users.noreply.github.com> Co-authored-by: Morph <39850852+Morph1984@users.noreply.github.com> Co-authored-by: VolcaEM <volcaem@users.noreply.github.com> Co-authored-by: LC <lioncash@users.noreply.github.com> | |||||
2020-07-10 | vk_stream_buffer: set allocable_size to 9 MiB | lat9nq | 1 | -1/+1 | |
This solves the crash on Linux systems running the current Linux Long Lived branch nVidia driver. | |||||
2020-07-09 | cmake: fix fmt linking when found | John Galt | 1 | -1/+5 | |
This is a new attempt at #4206 that shouldn't break windows builds. If someone else could test on windows, it would be much appreciated. Previously, the build bot passed but the actual builds failed. | |||||
2020-07-09 | cmake: pass libusb include directory as well | Jan Beich | 1 | -0/+1 | |
In file included from src/input_common/gcadapter/gc_adapter.cpp:8: src/./input_common/gcadapter/gc_adapter.h:11:10: fatal error: 'libusb.h' file not found #include <libusb.h> ^~~~~~~~~~ | |||||
2020-07-08 | Address comments for better clarity/signed dev count | Ameer | 1 | -11/+15 | |
2020-07-08 | Add more libusb error checks | Ameer | 1 | -3/+18 | |
2020-07-08 | AM: fix GetDesiredLanguage: | CrazyMax | 1 | -1/+13 | |
try to get a control metadata from application update when is failed to get from the basic version. Tested on Kirby Star Allies | |||||
2020-07-08 | maxwell_dma: Rename registers to match official docs and reorder | ReinUsesLisp | 2 | -287/+355 | |
Rename registers in the MaxwellDMA class to match Nvidia's official documentation. This one can be found here: https://github.com/NVIDIA/open-gpu-doc/blob/master/classes/dma-copy/clb0b5.h While we are at it, reorganize the code in MaxwellDMA to be separated in different functions. | |||||
2020-07-07 | cpu_interrupt_handler: Remove #pragma once from .cpp file | MerryMage | 1 | -2/+0 | |
2020-07-07 | Address PR feedback, fix axis button thresholding | Ameer | 3 | -58/+22 | |
2020-07-07 | input_common/gcadapter: add missing C++11 header required by libc++ | Jan Beich | 1 | -0/+1 | |
In file included from src/input_common/gcadapter/gc_adapter.cpp:8: src/./input_common/gcadapter/gc_adapter.h:77:10: error: no template named 'unordered_map' in namespace 'std' std::unordered_map<int, bool> buttons; ~~~~~^ src/./input_common/gcadapter/gc_adapter.h:78:10: error: no template named 'unordered_map' in namespace 'std' std::unordered_map<int, u16> axes; ~~~~~^ | |||||
2020-07-07 | Brace the code! Fix compile error due to class member construction order | Ameer | 2 | -15/+31 | |
2020-07-07 | Recalibrate reconnected controllers | Ameer | 1 | -0/+5 | |
2020-07-07 | Save origin state of GC controller analog features, compare against origin for input detection | Ameer | 3 | -28/+72 | |
2020-07-07 | change shortcut context for other hotkeys with file open dialog | Ameer | 1 | -4/+4 | |
2020-07-07 | GetDisplayVersion should return a null-terminated version string. | CrazyMax | 1 | -4/+16 | |
also, in case of failed to get of the basic version, we will try get it from application update. | |||||
2020-07-06 | Fix ss crash on game menu, fix ss on windowed mode | Ameer | 2 | -4/+6 | |
2020-07-06 | configure_graphics: Make use of qOverload in signals/slots | Lioncash | 1 | -2/+2 | |
While we're in the same area, we can make use of qOverload to tidy up some function pointer casts. | |||||
2020-07-06 | configure_graphics: Prevent unnecessary string copies in UpdateDeviceComboBox() | Lioncash | 1 | -1/+1 | |
Unlikely to impact performance at all, but this is essentially a "free" transformation, so why not? | |||||
2020-07-05 | memory: Set page-table pointers before setting attribute = Memory | MerryMage | 1 | -2/+5 | |
2020-07-05 | AM/ISelfController: Stub CreateManagedDisplaySeparableLayer | Morph | 2 | -1/+20 | |
Stub this by sending 1 layer id instead of 2 as yuzu does not support multiple layers per display. No adverse side effects have been observed. - Used by Animal Crossing: New Horizons Update 1.3.0 | |||||
2020-07-04 | Fix for always firing triggers on some controllers, trigger threshold more universal | Ameer | 2 | -5/+5 | |
2020-07-03 | Address lioncash feedback: Log formatting, extern const PadButtonArray, little touch ups | Ameer | 3 | -24/+32 | |
2020-07-03 | Revert "cmake: fix fmt linking" | bunnei | 1 | -1/+1 | |
2020-07-02 | Fix unnecessary diffs | Ameer | 4 | -29/+27 | |
2020-07-02 | Add LR triggers as axes, half press to initiate a press, add GC axis id in config, clarify some code blocks for better readability | Ameer | 3 | -35/+80 | |
2020-07-02 | Rename two functions in NS | VolcaEM | 1 | -2/+2 | |
- Rename "GetShellEvent" to "GetShellEventHandle" - Rename "LaunchApplicationFromHost" to "LaunchApplication" | |||||
2020-07-02 | Rename GetApplicationArea2 to GetApplicationAreaSize | VolcaEM | 1 | -2/+2 | |
2020-07-02 | cmake: stop linking against QGL after c6a0ab979239 | Jan Beich | 1 | -1/+1 | |
2020-07-01 | shader_cache: Fix use-after-free and orphan invalidation cache entries | ReinUsesLisp | 1 | -29/+41 | |
This fixes some cases where entries could have been removed multiple times reading freed memory. To address this issue this commit removes duplicates from entries marked for removal and sorts out the removal process to fix another use-after-free situation. Another issue fixed in this commit is orphan invalidation cache entries. Previously only the entries that were invalidated in the current operations had its entries removed. This led to more use-after-free situations when these entries were actually invalidated but referenced an object that didn't exist. | |||||
2020-07-01 | Reset adapter state on init, fixes errors relating driver hang from unexpected unplug | Ameer | 2 | -0/+9 | |
2020-07-01 | Don't handle cycles late if stretcher is active | David Marcec | 1 | -1/+3 | |
Timestretcher seems to be broken | |||||
2020-07-01 | audio: Improving audio timing for multicore/single core | David Marcec | 2 | -20/+7 | |
Fixes the issue with needing the timestretcher for multicore. | |||||
2020-07-01 | externals: Track opus as submodule instead of using conan | David Marcec | 1 | -1/+1 | |
Supersedes #4068 see for details. | |||||
2020-07-01 | key_manager: Correct casing of instance() | Lioncash | 10 | -10/+10 | |
Our codebase uppercases member function names. | |||||
2020-07-01 | key_manager: Delete move operations | Lioncash | 1 | -0/+3 | |
Prevents the singleton from being moved from. | |||||
2020-07-01 | key_manager: Make use of canonical deleted operator= | Lioncash | 1 | -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. | |||||
2020-07-01 | common: switch to nullptr for sysctl's empty new value | Jan Beich | 1 | -4/+4 | |
2020-06-30 | Address feedback regarding increments, const vars, and general cleanup | Ameer | 2 | -24/+21 | |
2020-06-30 | fix implicit conversion of size_t type to int | Ameer | 1 | -1/+1 | |
2020-06-30 | maxwell_to_gl: Implement MirrorOnceClampOGL using GL_MIRROR_CLAMP_EXT | Morph | 1 | -0/+6 | |
Like MirrorOnceBorder, this requires the GL_EXT_texture_mirror_clamp extension. This extension is unfortunately not available on Intel's drivers (both Windows proprietary and Linux Mesa). Use GL_MIRROR_CLAMP_TO_EDGE as a fallback if the extension is unavailable. | |||||
2020-06-30 | macro: Add support for "middle methods" on the code cache (#4112) | David | 1 | -8/+27 | |
Macro code is just uploaded sequentially from a starting address, however that does not mean the entry point for the macro is at that address. This PR adds preliminary support for executing macros in the middle of our cached code. | |||||
2020-06-30 | common: add sysconf() fallback | Jan Beich | 1 | -3/+16 | |
src/common/memory_detect.cpp:15:10: fatal error: 'sys/sysinfo.h' file not found #include <sys/sysinfo.h> ^~~~~~~~~~~~~~~ | |||||
2020-06-29 | maxwell_to_gl: Rename VertexType() to VertexFormat() | Morph | 2 | -4/+5 | |
2020-06-29 | cmake: fix fmt linking | John Galt | 1 | -1/+1 | |
On gcc/ld, and clang/lld, fmt::v6 symbols are excluded, so linking fails. This fixes the issue. Note: This was included in the FindBoost changes I shared with BlinkHawk, however only they were merged. I'm not sure if it was missed, or if there was an issue with this part of the change. | |||||
2020-06-29 | Remove duplicate functions | VolcaEM | 1 | -2/+0 | |
2020-06-29 | Use decimal instead of hexadecimal | VolcaEM | 1 | -3/+5 | |
Co-authored-by: David <25727384+ogniK5377@users.noreply.github.com> | |||||
2020-06-29 | Fix typo | VolcaEM | 1 | -1/+1 | |
2020-06-29 | Clang-format | VolcaEM | 1 | -1/+1 | |
2020-06-29 | service: Update function tables | VolcaEM | 27 | -157/+285 | |
2020-06-29 | core_timing,scheduler: Use std::scoped_lock when possible | ReinUsesLisp | 2 | -15/+12 | |
Simplifies the cognitive load of procedures using locks and makes locks safe against exceptions. | |||||
2020-06-28 | ldr: Cleanup NRO & NRR structs | David Marcec | 1 | -8/+8 | |
2020-06-28 | maxwell_to_vk: Reorder vertex formats and add A2B10G10R10 for all types except float | Morph | 1 | -75/+69 | |
2020-06-28 | am: Stub GetIndirectLayerConsumerHandle | David Marcec | 1 | -1/+13 | |
Needed by Monster Hunter Generations Ultimate | |||||
2020-06-28 | maxwell_to_gl: Add 32 bit component sizes to (un)signed scaled formats | Morph | 1 | -30/+4 | |
Add 32 bit component sizes to (un)signed scaled formats and group (un)signed normalized, scaled, and integer formats together. | |||||
2020-06-28 | acc: ListOpenContextStoredUsers partial stub | David Marcec | 5 | -4/+14 | |
Needed by Baldur's Gate 1/2 | |||||
2020-06-28 | Core/Common: Address Feedback. | Fernando Sahmkow | 21 | -58/+58 | |
2020-06-27 | NvFlinger: Clang Format. | Fernando Sahmkow | 1 | -1/+1 | |
2020-06-27 | Build System: Fix GCC & MINGW Build. | Fernando Sahmkow | 1 | -0/+4 | |
2020-06-27 | SVC: Implement 32-bits wrappers and update Dynarmic. | Fernando Sahmkow | 4 | -34/+282 | |
2020-06-27 | SVC: Add GetCurrentProcessorNumber32, CreateTransferMemory32, SetMemoryAttribute32 | Fernando Sahmkow | 2 | -6/+39 | |
2020-06-27 | ARM: Update Dynarmic and Setup A32 according to latest interface. | Fernando Sahmkow | 8 | -93/+174 | |
2020-06-27 | SVC: Add GetThreadPriority32 & SetThreadPriority32 | Fernando Sahmkow | 2 | -2/+30 | |
2020-06-27 | ArmDynarmic32: Setup CNTPCT correctly | Fernando Sahmkow | 1 | -1/+1 | |
2020-06-27 | Audio: Correct buffer release for host timing. | Fernando Sahmkow | 3 | -1/+22 | |
2020-06-27 | Common/Kernel: Corrections and small bug fixing. | Fernando Sahmkow | 2 | -8/+3 | |
2020-06-27 | Services/NvFlinger: Do vSync in a sepparate thread on Multicore. | Fernando Sahmkow | 4 | -5/+69 | |
2020-06-27 | Common/NativeClockx86: Reduce native clock accuracy further. | Fernando Sahmkow | 1 | -1/+1 | |
2020-06-27 | Tests/CoreTiming: Correct host timing tests. | Fernando Sahmkow | 2 | -157/+14 | |
2020-06-27 | ARMDynarmicInterface: Correct GCC Build Errors. | Fernando Sahmkow | 2 | -6/+6 | |
2020-06-27 | Common/AtomicOps: Correct GCC Intrinsic argument ordering. | Fernando Sahmkow | 1 | -5/+5 | |
2020-06-27 | Kernel: Correct Host Context on Threads and Scheduler. | Fernando Sahmkow | 4 | -11/+11 | |
2020-06-27 | YuzuQT: Hide Speed UI on Multicore. | Fernando Sahmkow | 1 | -1/+1 | |
2020-06-27 | Clang Format. | Fernando Sahmkow | 14 | -48/+49 | |
2020-06-27 | ARMInterface/Externals: Update dynarmic and fit to latest version. | Fernando Sahmkow | 1 | -7/+7 | |
2020-06-27 | ARMInterface: Correct rebase errors. | Fernando Sahmkow | 3 | -5/+5 | |
2020-06-27 | CoreTiming: Correct rebase bugs and other miscellaneous things. | Fernando Sahmkow | 2 | -4/+8 | |
2020-06-27 | Core: Split Microprofile Dynarmic timing per Core | Fernando Sahmkow | 1 | -3/+12 | |
2020-06-27 | General: Tune the priority of main emulation threads so they have higher priority than less important helper threads. | Fernando Sahmkow | 6 | -0/+60 | |
2020-06-27 | Dynarmic Interface: don't clear cache if JIT has not been created. | Fernando Sahmkow | 2 | -0/+6 | |
2020-06-27 | General: Correct rebase, sync gpu and context management. | Fernando Sahmkow | 9 | -32/+45 | |
2020-06-27 | CoreTiming/CycleTimer: Correct Idling. | Fernando Sahmkow | 1 | -2/+5 | |
2020-06-27 | SingleCore: Correct ticks reset to be on preemption. | Fernando Sahmkow | 1 | -1/+1 | |
2020-06-27 | General: Cleanup legacy code. | Fernando Sahmkow | 19 | -740/+8 | |
2020-06-27 | Kernel/svcBreak: Implement CacheInvalidation for Singlecore and correct svcBreak. | Fernando Sahmkow | 2 | -3/+13 | |
2020-06-27 | Bootmanager/CPU_Manager: Correct shader caches and sync GPU on OpenGL. | Fernando Sahmkow | 2 | -6/+13 | |
2020-06-27 | HLE_IPC: Correct HLE Event behavior on timeout. | Fernando Sahmkow | 3 | -1/+19 | |
2020-06-27 | SingleCore: Improve Cycle timing Behavior and replace mutex in global scheduler for spinlock. | Fernando Sahmkow | 3 | -2/+4 | |
2020-06-27 | FrameLimiting: Enable frame limiting for single core. | Fernando Sahmkow | 2 | -1/+2 | |
2020-06-27 | SingleCore: Use Cycle Timing instead of Host Timing. | Fernando Sahmkow | 15 | -80/+152 | |
2020-06-27 | Scheduler: Correct Reload/Unload | Fernando Sahmkow | 2 | -3/+5 | |
2020-06-27 | Thread: Release the ARM Interface on exitting. | Fernando Sahmkow | 3 | -1/+8 | |
2020-06-27 | General: Move ARM_Interface into Threads. | Fernando Sahmkow | 18 | -170/+136 | |
2020-06-27 | Core: Refactor ARM Interface. | Fernando Sahmkow | 10 | -42/+69 | |
2020-06-27 | X64 Clock: Reduce accuracy to be less or equal to guest accuracy. | Fernando Sahmkow | 3 | -1/+10 | |
2020-06-27 | ARM/WaitTree: Better track the CallStack for each thread. | Fernando Sahmkow | 3 | -11/+74 | |
2020-06-27 | SVC/ARM: Correct svcSendSyncRequest and cache ticks on arm interface. | Fernando Sahmkow | 3 | -5/+20 | |
2020-06-27 | SingleCore: Move Host Timing from a sepparate thread to main cpu thread. | Fernando Sahmkow | 7 | -10/+48 | |
2020-06-27 | GUI: Make multicore only work with Async and add GUI for multicore. | Fernando Sahmkow | 6 | -5/+63 | |
2020-06-27 | ARM: Addapt to new Exclusive Monitor Interface. | Fernando Sahmkow | 5 | -31/+24 | |
2020-06-27 | CPU_Manager: Correct stopping on SingleCore. | Fernando Sahmkow | 1 | -3/+8 | |
2020-06-27 | Scheduler: Correct yielding interaction with SetThreadActivity. | Fernando Sahmkow | 1 | -0/+15 | |
2020-06-27 | General: Fix microprofile on dynarmic/svc, fix wait tree showing which threads were running. | Fernando Sahmkow | 11 | -13/+87 | |
2020-06-27 | General: Fix Stop function | Fernando Sahmkow | 4 | -5/+25 | |
2020-06-27 | Kernel: Rewind on SVC change. | Fernando Sahmkow | 3 | -5/+16 | |
2020-06-27 | Kernel: Preempt Single core on redudant yields. | Fernando Sahmkow | 6 | -21/+42 | |
2020-06-27 | CPU_Manager: Unload/Reload threads on preemption on SingleCore | Fernando Sahmkow | 4 | -7/+64 | |
2020-06-27 | Synchronization: Correct wide Assertion. | Fernando Sahmkow | 1 | -2/+4 | |
2020-06-27 | General: Initial Setup for Single Core. | Fernando Sahmkow | 8 | -34/+228 | |
2020-06-27 | Scheduler: Set last running time on thread. | Fernando Sahmkow | 2 | -4/+2 | |
2020-06-27 | Kernel: Corrections to TimeManager, Scheduler and Mutex. | Fernando Sahmkow | 3 | -5/+5 | |
2020-06-27 | Kernel: Fixes, corrections and asserts to scheduler and different svcs. | Fernando Sahmkow | 8 | -38/+38 | |
2020-06-27 | Scheduler: Correct yields. | Fernando Sahmkow | 2 | -7/+25 | |
2020-06-27 | Mutex: Revert workaround due to poor exclusive memory. | Fernando Sahmkow | 1 | -9/+2 | |
2020-06-27 | ARM/Memory: Correct Exclusive Monitor and Implement Exclusive Memory Writes. | Fernando Sahmkow | 12 | -24/+325 | |
2020-06-27 | SVC: WaitSynchronization add Termination Pending Result. | Fernando Sahmkow | 2 | -1/+5 | |
2020-06-27 | Scheduler: Remove arm_interface lock and a few corrections. | Fernando Sahmkow | 2 | -17/+3 | |
2020-06-27 | Yuzu/Debuggers: Correct Wait Tree for Paused threads. | Fernando Sahmkow | 1 | -2/+10 | |
2020-06-27 | SVC: Correct SetThreadActivity. | Fernando Sahmkow | 4 | -38/+59 | |
2020-06-27 | SCC: Small corrections to CancelSynchronization | Fernando Sahmkow | 3 | -2/+14 | |
2020-06-27 | Scheduler: Correct locking for hle threads. | Fernando Sahmkow | 1 | -1/+2 | |
2020-06-27 | Scheduler: Fix HLE Threads on guard | Fernando Sahmkow | 1 | -4/+6 | |
2020-06-27 | Scheduler: Protect on closed threads. | Fernando Sahmkow | 1 | -7/+17 | |
2020-06-27 | Scheduler: Correct assert. | Fernando Sahmkow | 1 | -4/+2 | |
2020-06-27 | Core: Correct rebase. | Fernando Sahmkow | 2 | -18/+11 | |
2020-06-27 | Scheduler: Release old thread fiber before trying to switch to the next thread fiber. | Fernando Sahmkow | 2 | -11/+35 | |
2020-06-27 | NVDRV: Remove frame limiting as Host Timing already takes care. | Fernando Sahmkow | 1 | -1/+0 | |
2020-06-27 | Mutex: Correct Result writting to clear exclusivity. | Fernando Sahmkow | 1 | -3/+11 | |
2020-06-27 | SVC: Correct svcWaitForAddress and svcSignalToAddress. | Fernando Sahmkow | 4 | -68/+161 | |
2020-06-27 | Scheduler: Correct Select Threads Step 2. | Fernando Sahmkow | 1 | -0/+1 | |
2020-06-27 | Kernel: Corrections to Scheduling. | Fernando Sahmkow | 5 | -19/+23 | |
2020-06-27 | Kernel: Correct Signal on Thread Death and Setup Sync Objects on Thread for Debugging | Fernando Sahmkow | 3 | -15/+17 | |
2020-06-27 | Core: Correct HLE Event Callbacks and other issues. | Fernando Sahmkow | 5 | -37/+39 | |
2020-06-27 | Process: Protect TLS region and Modules. | Fernando Sahmkow | 1 | -0/+4 | |
2020-06-27 | General: Add Asserts | Fernando Sahmkow | 4 | -0/+24 | |
2020-06-27 | General: Add better safety for JIT use. | Fernando Sahmkow | 5 | -7/+39 | |
2020-06-27 | SVC: Correct races on physical core switching. | Fernando Sahmkow | 2 | -10/+10 | |
2020-06-27 | NVFlinger: Lock race condition between CPU, Host Timing, VSync. | Fernando Sahmkow | 3 | -0/+11 | |
2020-06-27 | SVC: Add locks to the memory management. | Fernando Sahmkow | 1 | -0/+21 | |
2020-06-27 | SVC: Correct WaitSynchronization, WaitProcessWideKey, SignalProcessWideKey. | Fernando Sahmkow | 9 | -33/+84 | |
2020-06-27 | SVC: Cleanup old methods. | Fernando Sahmkow | 1 | -13/+9 | |
2020-06-27 | CPU_Manager: Reconfigre guest threads for dynamrmic downsides | Fernando Sahmkow | 3 | -1/+7 | |
2020-06-27 | SVC: Correct SendSyncRequest. | Fernando Sahmkow | 8 | -54/+116 | |
2020-06-27 | SVC: Correct ArbitrateUnlock | Fernando Sahmkow | 3 | -33/+37 | |
2020-06-27 | SVC: Correct SignalEvent, ClearEvent, ResetSignal, WaitSynchronization, CancelSynchronization, ArbitrateLock | Fernando Sahmkow | 8 | -90/+134 | |
2020-06-27 | SVC: Remove global HLE Lock. | Fernando Sahmkow | 1 | -3/+0 | |
2020-06-27 | SVC: Correct GetThreadPriority, SetThreadPriority, GetThreadCoreMask, SetThreadCoreMask, GetCurrentProcessorNumber | Fernando Sahmkow | 5 | -15/+26 | |
2020-06-27 | SVC: Correct CreateThread, StartThread, ExitThread, SleepThread. | Fernando Sahmkow | 3 | -37/+31 | |
2020-06-27 | HostTiming: Pause the hardware clock on pause. | Fernando Sahmkow | 7 | -1/+23 | |
2020-06-27 | AudioCore: Use nanoseconds instead of cycles for buffer time. | Fernando Sahmkow | 2 | -6/+6 | |
2020-06-27 | General: Setup yuzu threads' microprofile, naming and registry. | Fernando Sahmkow | 7 | -9/+25 | |
2020-06-27 | CPU_Manager: remove debugging code. | Fernando Sahmkow | 1 | -8/+4 | |
2020-06-27 | YuzuCMD/Tester: Correct execution | Fernando Sahmkow | 2 | -6/+8 | |
2020-06-27 | General: Recover Prometheus project from harddrive failure | Fernando Sahmkow | 57 | -816/+1341 | |
This commit: Implements CPU Interrupts, Replaces Cycle Timing for Host Timing, Reworks the Kernel's Scheduler, Introduce Idle State and Suspended State, Recreates the bootmanager, Initializes Multicore system. | |||||
2020-06-27 | nfc: Update function table | VolcaEM | 1 | -3/+3 | |
This was based on Switchbrew page: https://switchbrew.org/wiki/NFC_services | |||||
2020-06-27 | ncm: Update function table | VolcaEM | 1 | -10/+10 | |
This was based on Switchbrew page: https://switchbrew.org/wiki/NCM_services ILocationResolver's 16, 17, 18 and 19 have unofficial names | |||||
2020-06-27 | mm: Update function table | VolcaEM | 1 | -16/+16 | |
This was based on Switchbrew page: https://switchbrew.org/wiki/Display_services | |||||
2020-06-27 | mig: Update function table | VolcaEM | 1 | -0/+6 | |
This was based on Switchbrew page: https://switchbrew.org/wiki/Migration_services | |||||
2020-06-27 | ldn: Update function table | VolcaEM | 1 | -0/+1 | |
This was based on Switchbrew page: https://switchbrew.org/wiki/LDN_services | |||||
2020-06-27 | Oops (fix typo) | VolcaEM | 1 | -1/+1 | |
2020-06-27 | lbl: Update function table | VolcaEM | 1 | -0/+1 | |
This was based on Switchbrew page: https://switchbrew.org/wiki/Backlight_services | |||||
2020-06-27 | grc: Update function table | VolcaEM | 1 | -0/+3 | |
This was based on Switchbrew page: https://switchbrew.org/wiki/GRC_services | |||||
2020-06-27 | friend: Update function table | VolcaEM | 1 | -0/+6 | |
2020-06-27 | Fix issues caused when changing the fullscreen hotkey | Kewlan | 1 | -4/+5 | |
2020-06-27 | left const auto&, comment punctuation. | Ameer J | 1 | -2/+2 | |
Co-authored-by: Morph <39850852+Morph1984@users.noreply.github.com> | |||||
2020-06-27 | Use better names for "Unknown"s | VolcaEM | 1 | -39/+39 | |
2020-06-27 | Update function names | VolcaEM | 1 | -4/+4 | |
2020-06-27 | btm: Give better names for unknown functions | David Marcec | 1 | -5/+5 | |
2020-06-27 | btdrv: Update function table (#4174) | VolcaEM | 1 | -83/+84 | |
* btdrv: Update function table | |||||
2020-06-27 | bpc: Update function tables (#4173) | VolcaEM | 1 | -7/+13 | |
* bpc: Update function tables This was based on Switchbrew page: https://switchbrew.org/wiki/PCV_services | |||||
2020-06-27 | bcat: Update function tables and add missing classes (#4172) | VolcaEM | 2 | -0/+5 | |
* bcat: Update function tables and add missing classes | |||||
2020-06-27 | am: Update function tables and add missing classes (#4169) | VolcaEM | 3 | -17/+19 | |
* am: Update function tables and add missing classes * Remove comments (1/5) * Remove comments (2/5) * Remove comments (3/5) * Remove comments (4/5) * Remove comments (5/5) * Remove unused classes (1/2) * Remove unused classes (2/2) | |||||
2020-06-27 | aoc: Update function table (#4170) | VolcaEM | 1 | -0/+1 | |
* aoc: Update function table * Remove comments | |||||
2020-06-27 | eupld: Update function table | VolcaEM | 1 | -0/+1 | |
This was based on Switchbrew page: https://switchbrew.org/wiki/Error_Upload_services | |||||
2020-06-27 | es: Update function table | VolcaEM | 1 | -2/+41 | |
This was based on Switchbrew page: https://switchbrew.org/wiki/ETicket_services | |||||
2020-06-27 | Update FAQ function name (2/2) | VolcaEM | 1 | -2/+2 | |
2020-06-27 | Update FAQ function name (1/2) | VolcaEM | 1 | -1/+1 | |
2020-06-27 | btm: Update function tables | VolcaEM | 1 | -71/+76 | |
This was based on Switchbrew page: https://switchbrew.org/wiki/BTM_services "No comment" edition | |||||
2020-06-27 | vk_rasterizer: Use nullptr for <pSizes> in CmdBindVertexBuffers2EXT | ReinUsesLisp | 1 | -6/+6 | |
Disable this temporarily. | |||||
2020-06-27 | vk_pipeline_cache: Avoid hashing and comparing dynamic state when possible | ReinUsesLisp | 6 | -23/+51 | |
With extended dynamic states, some bytes don't have to be collected from the pipeline key, hence we can avoid hashing and comparing them on lookups. | |||||
2020-06-27 | vulkan/fixed_pipeline_state: Move state out of individual structures | ReinUsesLisp | 4 | -121/+84 | |
2020-06-27 | vk_rasterizer: Use VK_EXT_extended_dynamic_state | ReinUsesLisp | 5 | -46/+356 | |
2020-06-27 | renderer_vulkan/wrapper: Add VK_EXT_extended_dynamic_state functions | ReinUsesLisp | 2 | -0/+64 | |
2020-06-27 | fixed_pipeline_state: Add requirements for VK_EXT_extended_dynamic_state | ReinUsesLisp | 7 | -155/+143 | |
This moves dynamic state present in VK_EXT_extended_dynamic_state to a separate structure in FixedPipelineState. This is structure is at the bottom allowing us to hash and memcmp only when the extension is not supported. | |||||
2020-06-27 | vk_device: Enable VK_EXT_extended_dynamic_state when available | ReinUsesLisp | 2 | -0/+32 | |
2020-06-27 | texture_cache: Test format compatibility before copying | ReinUsesLisp | 2 | -6/+21 | |
Avoid illegal copies. This intercepts the last step of a copy to avoid generating validation errors or corrupting the driver on some instances. We can create views and emit copies accordingly in future commits and remove this last-step validation. | |||||
2020-06-27 | video_core/compatible_formats: Table to test if two formats are legal to view or copy | ReinUsesLisp | 3 | -0/+196 | |
Add a flat table to test if it's legal to create a texture view between two formats or copy betweem them. This table is based on ARB_copy_image and ARB_texture_view. Copies are more permissive than views. | |||||
2020-06-26 | gl_buffer_cache: Copy to buffers created as STREAM_READ before downloading | ReinUsesLisp | 5 | -18/+24 | |
After marking buffers as resident, Nvidia's driver seems to take a slow path. To workaround this issue, copy to a STREAM_READ buffer and then call GetNamedBufferSubData on it. This is a temporary solution until we have asynchronous flushing. | |||||
2020-06-26 | Update function name again | VolcaEM | 1 | -1/+1 | |
2020-06-26 | Update function name (2/2) | VolcaEM | 1 | -1/+1 | |
2020-06-26 | Update function name (1/2) | VolcaEM | 1 | -1/+1 | |
2020-06-26 | Common: Fix non-conan build | Fernando Sahmkow | 1 | -1/+2 | |
2020-06-26 | caps_u: Fix GetAlbumContentsFileListForApplication stub | Morph | 1 | -9/+15 | |
2020-06-26 | caps: Use enum classes and check struct sizes on compile time | Morph | 1 | -34/+40 | |
2020-06-26 | caps: Update copyright headers | Morph | 14 | -14/+14 | |
Updated to "yuzu Emulator Project" | |||||
2020-06-26 | Add a "Mute Audio" hotkey | Kewlan | 6 | -3/+17 | |
2020-06-26 | const& to button in button array | Ameer J | 1 | -2/+2 | |
Co-authored-by: VolcaEM <63682805+VolcaEM@users.noreply.github.com> | |||||
2020-06-26 | Stop reading loop if error is encountered | Ameer | 1 | -4/+4 | |
2020-06-25 | Clang-format again | VolcaEM | 1 | -1/+1 | |
2020-06-25 | Clang-format | VolcaEM | 1 | -1/+2 | |
2020-06-25 | Remove unnecessary newline | VolcaEM | 1 | -1/+0 | |
2020-06-25 | Fix typo 2: electric boogaloo | VolcaEM | 1 | -1/+1 | |
2020-06-25 | Use QUrl (2/2) | VolcaEM | 1 | -6/+5 | |
2020-06-25 | Use QUrl (1/2) | VolcaEM | 1 | -1/+1 | |
2020-06-25 | Fix formatting | VolcaEM | 1 | -2/+2 | |
2020-06-25 | Fix typo | VolcaEM | 1 | -1/+1 | |
2020-06-25 | Add "Open Quickstart Guide" and "FAQ" buttons to the Help menu | VolcaEM | 3 | -0/+48 | |
While we're at it, also refactor the function used by OnOpenModsPage to be compatible with other URLs | |||||
2020-06-25 | gl_device: Fix IsASTCSupported | David Marcec | 1 | -1/+1 | |
Other targets were never actually checked | |||||
2020-06-25 | memory_manager: Remove useless assertion | David Marcec | 1 | -1/+0 | |
num_pages is an std::size_t. It will always be >= 0 | |||||
2020-06-25 | gl_device: Enable NV_vertex_buffer_unified_memory on Turing devices | ReinUsesLisp | 1 | -19/+1 | |
Once we make sure not to corrupt Nvidia's driver, we can safely use resident buffers on Turing devices. See GitHub pull request #4156 | |||||
2020-06-24 | hid: Stub a series of "SevenSixAxisSensor" service commands | Morph | 2 | -21/+85 | |
- Used by Captain Toad: Treasure Tracker Update 1.3.0 While we're at it, fix the input parameters for SetIsPalmaAllConnectable and SetPalmaBoostMode | |||||
2020-06-24 | padbutton enum class and struct initiailization | Ameer | 3 | -36/+32 | |
2020-06-24 | Prevent nullptr dereference on swkbd error case | David Marcec | 1 | -1/+1 | |
2020-06-24 | prepo: : Don't read extra buffer from report unless passed | David Marcec | 1 | -1/+6 | |
Prepo doesn't always pass a secondary buffer, we assume it always does which leads to a bad read. | |||||
2020-06-24 | Mark invalid IPC buffers as ASSERT_OR_EXECUTE_MSG | David Marcec | 1 | -25/+22 | |
Previously if applications would send faulty buffers(example homebrew) it would lead to us returning uninitalized data. Switching from ASSERT_MSG to ASSERT_OR_EXECUTE_MSG allows us to have a fail safe to prevent crashes but also continue execution without introducing undefined behavior | |||||
2020-06-24 | buffer_cache: Use buffer methods instead of cache virtual methods | ReinUsesLisp | 5 | -99/+90 | |
2020-06-24 | gl_stream_buffer: Use InvalidateBufferData instead unmap and map | ReinUsesLisp | 2 | -15/+5 | |
Making the stream buffer resident increases GPU usage significantly on some games. This seems to be addressed invalidating the stream buffer with InvalidateBufferData instead of using a Unmap + Map (with invalidation flags). | |||||
2020-06-24 | gl_rasterizer: Use NV_vertex_buffer_unified_memory for vertex buffer robustness | ReinUsesLisp | 3 | -9/+39 | |
Switch games are allowed to bind less data than what they use in a vertex buffer, the expected behavior here is that these values are read as zero. At the moment of writing this only D3D12, OpenGL and NVN through NV_vertex_buffer_unified_memory support vertex buffer with a size limit. In theory this could be emulated on Vulkan creating a new VkBuffer for each (handle, offset, length) tuple and binding the expected data to it. This is likely going to be slow and memory expensive when used on the vertex buffer and we have to do it on all draws because we can't know without analyzing indices when a game is going to read vertex data out of bounds. This is not a problem on OpenGL's BufferAddressRangeNV because it takes a length parameter, unlike Vulkan's CmdBindVertexBuffers that only takes buffers and offsets (the length is implicit in VkBuffer). It isn't a problem on D3D12 either, because D3D12_VERTEX_BUFFER_VIEW on IASetVertexBuffers takes SizeInBytes as a parameter (although I am not familiar with robustness on D3D12). Currently this only implements buffer ranges for vertex buffers, although indices can also be affected. A KHR_robustness profile is not created, but Nvidia's driver reads out of bound vertex data as zero anyway, this might have to be changed in the future. - Fixes SMO random triangles when capturing an enemy, getting hit, or looking at the environment on certain maps. | |||||
2020-06-24 | gl_buffer_cache: Mark buffers as resident | ReinUsesLisp | 10 | -67/+111 | |
Make stream buffer and cached buffers as resident and query their address. This allows us to use GPU addresses for several proprietary Nvidia extensions. | |||||
2020-06-24 | gl_device: Expose NV_vertex_buffer_unified_memory except on Turing | ReinUsesLisp | 2 | -1/+30 | |
Expose NV_vertex_buffer_unified_memory when the driver supports it. This commit adds a function the determine if a GL_RENDERER is a Turing GPU. This is required because on Turing GPUs Nvidia's driver crashes when the buffer is marked as resident or on DeleteBuffers. Without a synchronous debug output (single threaded driver), it's likely that the driver will crash in the first blocking call. | |||||
2020-06-24 | gl_stream_buffer: Always use a non-coherent buffer | ReinUsesLisp | 2 | -14/+10 | |
2020-06-24 | gl_stream_buffer: Always use persistent memory maps | ReinUsesLisp | 2 | -30/+14 | |
yuzu no longer supports platforms without persistent maps. | |||||
2020-06-24 | Move GetKeyCodeMapImpl to an anonymous namespace | David Marcec | 1 | -19/+19 | |
2020-06-24 | addressed issues | David Marcec | 2 | -4/+7 | |
2020-06-24 | clear mme draw mode | David Marcec | 1 | -0/+3 | |
We already draw, so we can clear it | |||||
2020-06-24 | Addressed issues | David Marcec | 5 | -13/+17 | |
2020-06-24 | Fix constbuffer for 0217920100488FF7 | David Marcec | 1 | -6/+6 | |
2020-06-24 | Macro HLE support | David Marcec | 9 | -10/+209 | |
2020-06-24 | Fixed logging output | David Marcec | 1 | -1/+1 | |
2020-06-24 | Implement GetKeyCodeMap & GetKeyCodeMap2 | David Marcec | 2 | -2/+72 | |
Closes #3919 | |||||
2020-06-24 | gl_shader_cache: Avoid use after move for program size | ReinUsesLisp | 2 | -6/+7 | |
All programs had a size of zero due to this bug, skipping invalidations. While we are at it, remove some unused forward declarations. | |||||
2020-06-23 | cleanup check access, read, and factory GetNextInput funcs. Use size rather than magic number | Ameer | 4 | -151/+101 | |
2020-06-23 | Fix deallocation of GC Adapter | Ameer | 3 | -4/+10 | |
2020-06-23 | yuzu_tester: Silence type conversion warning | Morph | 1 | -1/+1 | |
2020-06-23 | lm: Silence no return value warning | Morph | 1 | -1/+2 | |
2020-06-23 | Small quality of life indication that mapped button is GC | Ameer | 1 | -2/+2 | |
2020-06-23 | shader/half_set: Implement HSET2_IMM | ReinUsesLisp | 2 | -21/+75 | |
Add HSET2_IMM. Due to the complexity of the encoding avoid using BitField unions and read the relevant bits from the code itself. This is less error prone. | |||||
2020-06-23 | std::array and const reference passing of non-trivial objects | Ameer | 2 | -14/+13 | |
2020-06-22 | Update src/input_common/main.cpp | ameerj | 1 | -1/+1 | |
Co-authored-by: LC <mathew1800@gmail.com> update libusb submodule (hopefully windows build error fixed) | |||||
2020-06-22 | account: Update function tables and add missing classes (#4145) | VolcaEM | 5 | -42/+384 | |
* account: Update function tables and add missing classes * clang-format * Add missing "public" * Add missing public again * Add missing final | |||||
2020-06-22 | TextureCache: Fix case where layer goes off bound. | Fernando Sahmkow | 1 | -0/+3 | |
The returned layer is expected to be between 0 and the depth of the surface, anything larger is off bounds. | |||||
2020-06-22 | Reorder variables to comply with the Auzure build pipeline | unknown | 1 | -2/+2 | |
2020-06-22 | arm_dynarmic_64: Log the instruction when an exception is raised | Morph | 1 | -2/+2 | |
2020-06-22 | arm_dynarmic_32: Log under Core_ARM instead of HW_GPU | Morph | 1 | -1/+1 | |
2020-06-22 | renderer_vulkan: Update validation layer name and test before enabling | ReinUsesLisp | 3 | -5/+43 | |
Update validation layer string to VK_LAYER_KHRONOS_validation. While we are at it, properly check for available validation layers before enabling them. | |||||
2020-06-22 | Tidy up the pointers, use pair over tuple where appropriate | Ameer | 4 | -24/+22 | |
2020-06-22 | fix for sleep using stl | Ameer | 1 | -1/+3 | |
2020-06-22 | shared_ptr for the GC adapter class, constexpr constants | Ameer | 5 | -66/+52 | |
2020-06-22 | std::arrays where appropriate, clear q in adapter class, other touch ups | Ameer | 5 | -27/+15 | |
2020-06-22 | fix include thread | Ameer | 1 | -0/+1 | |
2020-06-22 | Singleton GC Adapter class, remove globals, fix naming convention | Ameer | 8 | -228/+283 | |
Fix clang formatting Manual fix for configure_input_player formatting Add missing lib usb cmake command | |||||
2020-06-21 | hid: Implement Get/ResetGyroscopeZeroDriftMode | Morph | 4 | -6/+56 | |
- Used by Captain Toad Treasure Tracker | |||||
2020-06-21 | Clang Formatting | Ameer | 9 | -182/+184 | |
2020-06-21 | Cleanup after linter | Ameer | 9 | -167/+98 | |
2020-06-21 | GC Adapter Implementation | Ameer | 18 | -161/+1159 | |
2020-06-21 | Correct function name (2/2) | VolcaEM | 1 | -2/+2 | |
2020-06-21 | Correct function name (1/2) | VolcaEM | 1 | -1/+1 | |
2020-06-21 | Clang-format | VolcaEM | 1 | -1/+1 | |
2020-06-21 | Remove unnecessary conversion | VolcaEM | 1 | -3/+2 | |
2020-06-21 | Address review comment by Lioncash | VolcaEM | 1 | -1/+1 | |
Co-authored-by: LC <mathew1800@gmail.com> | |||||
2020-06-21 | Add a "Open Mods Page" button to the GUI | VolcaEM | 3 | -0/+20 | |
2020-06-21 | gl_shader_decompiler: Enable GL_EXT_texture_shadow_lod if available | Morph | 1 | -7/+43 | |
Enable GL_EXT_texture_shadow_lod if available. If this extension is not available, such as on Intel/AMD proprietary drivers, use textureGrad as a workaround. | |||||
2020-06-21 | gl_device: Check for GL_EXT_texture_shadow_lod | Morph | 2 | -0/+7 | |
2020-06-21 | Fix: fatal error CVT1100 when compiling manifest file | FearlessTobi | 3 | -3/+3 | |
Occurs when doing a local compile in MSVC build. The compiler I'm using is as below: Microsoft Visual Studio Community 2019 Preview Version 16.6.0 Preview 5.0 Fixes this error: CVTRES : fatal error CVT1100: duplicate resource. type:MANIFEST, name:1, language:0x0409 LINK : fatal error LNK1123: failure during conversion to COFF: file invalid or corrupt I have put 0 since previous name was 1. If have other names in mind, please let me know. Co-Authored-By: dragios <dragios@users.noreply.github.com> | |||||
2020-06-20 | macro_jit_x64: Use ecx for shift register | MerryMage | 1 | -2/+2 | |
shl/shr only accept cl as their second argument | |||||
2020-06-20 | texture_cache: Fix incorrect address used in a DeduceSurface() call | Lioncash | 1 | -1/+1 | |
Previously the source was being deduced twice in a row. | |||||
2020-06-20 | software_keyboard: Eliminate trivial redundant copies | Lioncash | 1 | -2/+2 | |
We can just make use of moves here to get rid of two redundant copies | |||||
2020-06-20 | main: Append AVX and FMA instructions to cpu string | Morph | 1 | -1/+14 | |
Append AVX and FMA instructions to cpu string if the host cpu supports them | |||||
2020-06-20 | common/telemetry: Add AVX512 to telemetry | Morph | 1 | -0/+1 | |
2020-06-20 | common/cpu_detect: Add AVX512 detection | Morph | 2 | -0/+6 | |
2020-06-20 | decode/image: Implement B10G11R11F | Morph | 1 | -9/+17 | |
- Used by Kirby Star Allies | |||||
2020-06-20 | gl_arb_decompiler: Avoid several string copies | Lioncash | 1 | -32/+31 | |
Variables that are marked as const cannot have the move constructor invoked when returning from a function (the move constructor requires a non-const variable so it can "steal" the resources from it. | |||||
2020-06-20 | vulkan/wrapper: Remove noexcept from GetSurfaceCapabilitiesKHR() | Lioncash | 2 | -3/+2 | |
Check() can throw an exception if the Vulkan result isn't successful. We remove the check so that std::terminate isn't outright called and allows for better debugging (should it ever actually fail). | |||||
2020-06-20 | macro_jit_x64: Correct readability of Compile_ExtractShiftLeftImmediate() | Lioncash | 1 | -3/+3 | |
Previously dst wasn't being used. | |||||
2020-06-20 | macro_jit_x64: Correct readability of Compile_ExtractShiftLeftRegister() | Lioncash | 1 | -3/+4 | |
Previously dst wasn't being used. | |||||
2020-06-20 | macro_jit_x64: Remove unused variable | Lioncash | 1 | -2/+1 | |
Removes a completely unused label and marks another variable as unused, given it seems like it has potential uses in the future. | |||||
2020-06-20 | memory_manager: Eliminate variable shadowing | Lioncash | 2 | -24/+28 | |
Renames some variables to prevent ones in inner scopes from shadowing outer-scoped variables. The Copy* functions have no shadowing, but we rename them anyways to remain consistent with the other functions. | |||||
2020-06-20 | Add translation of "Current Boxcat Events" | David Marcec | 1 | -3/+2 | |
2020-06-20 | macro_jit_x64: Eliminate variable shadowing in Compile_ProcessResult() | Lioncash | 1 | -2/+2 | |
We can reduce the capture scope so that it's not possible for both "reg" variables to clash with one another. While we're at it, we can prevent unnecessary copies while we're at it. | |||||
2020-06-20 | buffer_cache: Eliminate local variable shadowing | Lioncash | 1 | -2/+1 | |
We can just make use of the instance in the scope above this one. | |||||
2020-06-19 | input_common/motion_emu: Remove redundant move | MerryMage | 1 | -1/+1 | |
Named return value optimization automatically applies here. | |||||
2020-06-19 | input_common/keyboard: Remove redundant move | MerryMage | 1 | -1/+1 | |
Named return value optimization automatically applies here. | |||||
2020-06-19 | mii_model: Remove redundant std::move | MerryMage | 1 | -1/+1 | |
Named return value optimization automatically applies here. | |||||
2020-06-19 | Fix compilation when not building with boxcat | David Marcec | 2 | -2/+7 | |
Fixes compilation when trying to build without boxcat enabled | |||||
2020-06-19 | macro_jit_x64: Remove unused function Read | MerryMage | 1 | -8/+4 | |
2020-06-18 | vk_rasterizer: Don't preserve contents on full screen clears | ReinUsesLisp | 2 | -7/+58 | |
There's no need to load contents from the CPU when a clear resets all the contents of the underlying memory. This is already implemented on OpenGL and the texture cache. | |||||
2020-06-18 | vk_update_descriptor: Upload descriptor sets data directly | ReinUsesLisp | 3 | -42/+30 | |
Instead of copying to a temporary payload before sending the update task to the worker thread, insert elements to the payload directly. | |||||
2020-06-18 | Tests/HostTiming: Correct GCC Compile error. | Fernando Sahmkow | 1 | -15/+14 | |
2020-06-18 | Common/Fiber: Address Feedback and Correct Memory leaks. | Fernando Sahmkow | 2 | -34/+41 | |
2020-06-18 | Common/Fiber: Implement Rewind on Boost Context. | Fernando Sahmkow | 2 | -2/+39 | |
2020-06-18 | Common/uint128: Correct MSVC Compilation in old versions. | Fernando Sahmkow | 1 | -0/+4 | |
2020-06-18 | Common/Fiber: Document fiber interexchange. | Fernando Sahmkow | 1 | -1/+4 | |
2020-06-18 | Common/Fiber: Implement Rewinding. | Fernando Sahmkow | 3 | -2/+84 | |
2020-06-18 | Common/Fiber: Additional corrections to f_context. | Fernando Sahmkow | 1 | -4/+4 | |
2020-06-18 | Common/Fiber: Correct f_context based Fibers. | Fernando Sahmkow | 1 | -6/+8 | |
2020-06-18 | Host Timing: Correct clang format. | Fernando Sahmkow | 1 | -1/+0 | |
2020-06-18 | HostTiming: Correct rebase and implement AddTicks. | Fernando Sahmkow | 2 | -1/+19 | |
2020-06-18 | Core/HostTiming: Allow events to be advanced manually. | Fernando Sahmkow | 4 | -31/+47 | |
2020-06-18 | Common/Tests: Address Feedback | Fernando Sahmkow | 9 | -39/+51 | |
2020-06-18 | Common: Make MinGW build use Windows Fibers instead of fcontext_t | Fernando Sahmkow | 2 | -4/+4 | |
2020-06-18 | Common/Tests: Clang Format. | Fernando Sahmkow | 7 | -31/+41 | |
2020-06-18 | Common: Correct fcontext fibers. | Fernando Sahmkow | 1 | -5/+4 | |
2020-06-18 | Common: Refactor & Document Wall clock. | Fernando Sahmkow | 6 | -51/+50 | |
2020-06-18 | Common: Implement WallClock Interface and implement a native clock for x64 | Fernando Sahmkow | 10 | -40/+378 | |
2020-06-18 | Tests: Add base tests to host timing | Fernando Sahmkow | 5 | -43/+243 | |
2020-06-18 | Core: Implement a Host Timer. | Fernando Sahmkow | 5 | -0/+295 | |
2020-06-18 | Common: Polish Fiber class, add comments, asserts and more tests. | Fernando Sahmkow | 5 | -25/+147 | |
2020-06-18 | Tests: Add tests for fibers and refactor/fix Fiber class | Fernando Sahmkow | 4 | -19/+247 | |
2020-06-18 | Common: Implement a basic Fiber class. | Fernando Sahmkow | 3 | -0/+204 | |
2020-06-18 | Common: Implement a basic SpinLock class | Fernando Sahmkow | 3 | -0/+68 | |
2020-06-18 | arm_dynarmic_32: Fix implicit conversion error in SetTPIDR_EL0 | ReinUsesLisp | 1 | -1/+1 | |
On MSVC builds we treat conversion warnings as errors. | |||||
2020-06-18 | bootmanager: Remove references to OpenGL for macOS | MerryMage | 2 | -2/+19 | |
OpenGL macOS headers definitions clash heavily with each other | |||||
2020-06-18 | memory_manager: Explicitly specifcy std::min<size_t> | MerryMage | 1 | -2/+2 | |
2020-06-18 | shared_font: Service::NS::EncryptSharedFont takes a size_t& | MerryMage | 1 | -1/+1 | |
2020-06-18 | vk_rasterizer: BindTransformFeedbackBuffersEXT accepts a size of type VkDeviceSize | MerryMage | 1 | -1/+1 | |
2020-06-18 | renderer_vulkan: Fix macOS GetBundleDirectory reference | MerryMage | 1 | -1/+3 | |
2020-06-18 | memory_util: boost hashes are size_t | MerryMage | 1 | -2/+2 | |
* boost::hash_value returns a size_t * boost::hash_combine takes a size_t& argument | |||||
2020-06-18 | Rename PAGE_SHIFT to PAGE_BITS | MerryMage | 2 | -10/+10 | |
macOS header files #define PAGE_SHIFT | |||||
2020-06-18 | Move SHA256Hash to its original position | VolcaEM | 1 | -2/+2 | |
It's not needed to have it in its previous position anymore | |||||
2020-06-18 | vk_sampler_cache: Emulate GL_LINEAR/NEAREST minification filters | Morph | 1 | -2/+4 | |
Emulate GL_LINEAR/NEAREST minification filters using minLod = 0 and maxLod = 0.25 during sampler creation | |||||
2020-06-18 | maxwell_to_vk: Reorder filter cases and correct mipmap_filter=None | Morph | 1 | -17/+15 | |
maxwell_to_vk: Reorder filtering modes to start with None, then Nearest, then Linear. maxwell_to_vk: Logs filter modes under UNREACHABLE_MSG instead of UNIMPLEMENTED_MSG, since any unknown filter modes are invalid and not unimplemented. maxwell_to_vk: Return VK_SAMPLER_MIPMAP_MODE_NEAREST instead of VK_SAMPLER_MIPMAP_MODE_LINEAR when mipmap_filter is None with the description from the VkSamplerCreateInfo(3) man page. | |||||
2020-06-18 | maxwell_to_gl: Miscellaneous changes | Morph | 1 | -48/+34 | |
maxwell_to_gl: Log unimplemented features under UNIMPLEMENTED_MSG instead of LOG_ERROR to bring into parity with maxwell_to_vk maxwell_to_gl: Deduplicate logging in VertexType(), merging them into one. maxwell_to_gl: Return GL_NEAREST instead of GL_LINEAR if an unknown texture filter mode is encountered. maxwell_to_gl: Log the mipmap filter mode if an unknown value is passed in. maxwell_to_gl: Reorder filtering modes to start with None, then Nearest, then Linear. | |||||
2020-06-17 | macro_jit_x64: Inline Engines::Maxwell3D::GetRegisterValue | MerryMage | 2 | -6/+18 | |
2020-06-17 | arm_dynarmic_cp15: Implement CNTPCT | MerryMage | 1 | -0/+13 | |
2020-06-17 | arm_dynarmic_cp15: Update CP15 | MerryMage | 4 | -142/+73 | |
2020-06-17 | arm_dynarmic_32: InterpreterFallback should never happen | MerryMage | 1 | -2/+3 | |
2020-06-17 | macro_jit_x64: Optimization implicitly assumes same destination | MerryMage | 1 | -1/+2 | |
2020-06-17 | macro_jit_x64: Should not skip zero registers for certain ALU ops | MerryMage | 1 | -1/+3 | |
The code generated for these ALU ops assume src_a and src_b are always valid. | |||||
2020-06-17 | Fix framebuffer size on fractional scaling display. | Kaiwen Xu | 1 | -1/+1 | |
2020-06-16 | Remove unnecessary pragmas | VolcaEM | 1 | -8/+0 | |
2020-06-16 | Revert IsValidNRO refactor but make it more readable | VolcaEM | 1 | -26/+13 | |
2020-06-16 | Update assert string | VolcaEM | 1 | -1/+1 | |
2020-06-16 | gl_device: Reserve at least 4 image bindings for fragment stage | Morph | 1 | -6/+14 | |
Due to the limitation of GL_MAX_IMAGE_UNITS being low (8) on Intel's and Nvidia's proprietary drivers, we have to reserve an appropriate amount of image bindings for each of the stages. So far games have been observed to use 4 image bindings on the fragment stage (Kirby Star Allies) and 1 on the vertex stage (TWD series). No games thus far in my limited testing used more than 4 images concurrently and across all currently active programs. This fixes shader compilation errors on Kirby Star Allies on OpenGL (GLSL/GLASM) | |||||
2020-06-15 | macro_jit_x64: Remove NEXT_PARAMETER | MerryMage | 1 | -5/+2 | |
Not required, as PARAMETERS can just be incremented directly. | |||||
2020-06-15 | macro_jit_x64: Remove unused function Compile_WriteCarry | MerryMage | 2 | -9/+0 | |
2020-06-15 | macro_jit_x64: Select better registers | MerryMage | 1 | -8/+8 | |
All registers are now callee-save registers. RBX and RBP selected for STATE and RESULT because these are most commonly accessed; this is to avoid the REX prefix. RBP not used for STATE because there are some SIB restrictions, RBX emits smaller code. | |||||
2020-06-15 | macro_jit_x64: Remove REGISTERS | MerryMage | 1 | -7/+3 | |
Unnecessary since this is just an offset from STATE. | |||||
2020-06-15 | macro_jit_x64: Remove JITState::parameters | MerryMage | 2 | -6/+3 | |
This can be passed in as an argument instead. | |||||
2020-06-15 | macro_jit_x64: Remove METHOD_ADDRESS_64 | MerryMage | 1 | -2/+1 | |
Unnecessary variable. | |||||
2020-06-15 | macro_jit_x64: Remove RESULT_64 | MerryMage | 2 | -16/+3 | |
This Reg64 codepath has the exact same behaviour as the Reg32 one. | |||||
2020-06-15 | xbyak_abi: Prefer returning a struct to using out parameters in ABI_CalculateFrameSize | MerryMage | 1 | -17/+19 | |
2020-06-15 | xbyak_abi: Register indexes should be unsigned | MerryMage | 1 | -11/+12 | |
2020-06-15 | xbyak_abi: Remove *GPS variants of stack manipulation functions | MerryMage | 2 | -42/+6 | |
2020-06-15 | xbyak_abi: Fix ABI_PushRegistersAndAdjustStack | MerryMage | 1 | -6/+2 | |
Pushing GPRs twice. | |||||
2020-06-15 | video_core/macro_jit_x64: Remove initializer in member variable | ReinUsesLisp | 1 | -2/+2 | |
Fix build time issues on gcc. Confirmed through asan that avoiding this initialization is safe. | |||||
2020-06-14 | Clang-format again | VolcaEM | 1 | -2/+2 | |
2020-06-14 | Use consistent variable names | VolcaEM | 1 | -4/+4 | |
2020-06-14 | Clang-format | VolcaEM | 1 | -1/+2 | |
2020-06-14 | Make assert strings consistent | VolcaEM | 1 | -3/+3 | |
2020-06-14 | Attempt to fix crashes in SSBU and refactor IsValidNRO | VolcaEM | 1 | -36/+59 | |
2020-06-13 | audren: Implement RendererInfo | David Marcec | 2 | -6/+26 | |
Fixes ZLA softlock | |||||
2020-06-12 | gl_arb_decompiler: Implement FSwizzleAdd | ReinUsesLisp | 1 | -4/+27 | |
2020-06-12 | gl_arb_decompiler: Implement an assembly shader decompiler | ReinUsesLisp | 7 | -1/+2093 | |
Emit code compatible with NV_gpu_program5. This should emit code compatible with Fermi, but it wasn't tested on that architecture. Pascal has some issues not present on Turing GPUs. | |||||
2020-06-11 | yuzu/configuration: Show assembly shaders check box | ReinUsesLisp | 1 | -3/+0 | |
2020-06-10 | nvdrv: Fix GetTPCMasks for ioctl3 | David Marcec | 2 | -21/+22 | |
Fixes animal crossing svcBreak on launch | |||||
2020-06-10 | kernel: Account for system resource size for memory usage | David Marcec | 1 | -2/+4 | |
GetTotalPhysicalMemoryAvailableWithoutSystemResource & GetTotalPhysicalMemoryUsedWithoutSystemResource seem to subtract the resource size from the usage. | |||||
2020-06-09 | buffer_cache: Avoid passing references of shared pointers and misc style changes | ReinUsesLisp | 9 | -174/+150 | |
Instead of using as template argument a shared pointer, use the underlying type and manage shared pointers explicitly. This can make removing shared pointers from the cache more easy. While we are at it, make some misc style changes and general improvements (like insert_or_assign instead of operator[] + operator=). | |||||
2020-06-09 | gl_rasterizer: Mark vertex buffers as dirty after buffer cache invalidation | ReinUsesLisp | 1 | -1/+10 | |
Vertex buffers bindings become invalid after the stream buffer is invalidated. We were originally doing this, but it got lost at some point. - Fixes Animal Crossing: New Horizons, but it affects everything. | |||||
2020-06-09 | buffer_cache: Return stream buffer invalidation in Map instead of Unmap | ReinUsesLisp | 1 | -7/+9 | |
We have to invalidate whatever cache is being used before uploading the data, hence it makes more sense to return this on Map instead of Unmap. | |||||
2020-06-08 | Add game versio to title bar | unknown | 2 | -13/+17 | |
2020-06-08 | texture_cache: Port original code management for 2D vs 3D textures | ReinUsesLisp | 2 | -16/+35 | |
Handle blits to images as 2D, even when they have block depth. - Fixes rendering issues on Luigi's Mansion 3 | |||||
2020-06-08 | texture_cache: Simplify blit code | ReinUsesLisp | 1 | -9/+7 | |
2020-06-08 | texture_cache: Handle 3D texture blits with one layer | ReinUsesLisp | 3 | -5/+10 | |
2020-06-08 | texture_cache: Implement rendering to 3D textures | ReinUsesLisp | 10 | -139/+191 | |
This allows rendering to 3D textures with more than one slice. Applications are allowed to render to more than one slice of a texture using gl_Layer from a VTG shader. This also requires reworking how 3D texture collisions are handled, for now, this commit allows rendering to slices but not to miplevels. When a render target attempts to write to a mipmap, we fallback to the previous implementation (copying or flushing as needed). - Fixes color correction 3D textures on UE4 games (rainbow effects). - Allows Xenoblade games to render to 3D textures directly. | |||||
2020-06-07 | rasterizer_cache: Remove files and includes | ReinUsesLisp | 7 | -269/+3 | |
The rasterizer cache is no longer used. Each cache has its own generic implementation optimized for the cached data. | |||||
2020-06-07 | vk_pipeline_cache: Use generic shader cache | ReinUsesLisp | 5 | -58/+55 | |
Trivial port the generic shader cache to Vulkan. | |||||
2020-06-07 | gl_shader_cache: Use generic shader cache | ReinUsesLisp | 4 | -93/+80 | |
Trivially port the generic shader cache to OpenGL. | |||||
2020-06-07 | shader_cache: Implement a generic shader cache | ReinUsesLisp | 2 | -0/+229 | |
Implement a generic shader cache for fast lookups and invalidations. Invalidations are cheap but expensive when a shader is invalidated. Use two mutexes instead of one to avoid locking invalidations for lookups and vice versa. When a shader has to be removed, lookups are locked as expected. | |||||
2020-06-06 | yuzu/frontend: Remove internal resolution option | Morph | 9 | -113/+3 | |
2020-06-06 | gl_device: Black list NVIDIA 443.24 for fast buffer uploads | ReinUsesLisp | 1 | -2/+10 | |
Skip fast buffer uploads on Nvidia 443.24 Vulkan beta driver on OpenGL. This driver throws the following error when calling BufferSubData or BufferData on buffers that are candidates for fast constant buffer uploads. This is the equivalens to push constants on Vulkan, except that they can access the full buffer. The error: Unknown internal debug message. The NVIDIA OpenGL driver has encountered an out of memory error. This application might behave inconsistently and fail. If this error persists on future drivers, we might have to look deeper into this issue. For now, we can black list it and log it as a temporary solution. | |||||
2020-06-06 | renderer_opengl: Only enable DEBUG_OUTPUT when graphics debugging is enabled | ReinUsesLisp | 1 | -4/+2 | |
Avoids logging when it's not relevant. This can potentially reduce driver's internal thread overhead. | |||||
2020-06-05 | shader/texture: Join separate image and sampler pairs offline | ReinUsesLisp | 16 | -88/+234 | |
Games using D3D idioms can join images and samplers when a shader executes, instead of baking them into a combined sampler image. This is also possible on Vulkan. One approach to this solution would be to use separate samplers on Vulkan and leave this unimplemented on OpenGL, but we can't do this because there's no consistent way of determining which constant buffer holds a sampler and which one an image. We could in theory find the first bit and if it's in the TIC area, it's an image; but this falls apart when an image or sampler handle use an index of zero. The used approach is to track for a LOP.OR operation (this is done at an IR level, not at an ISA level), track again the constant buffers used as source and store this pair. Then, outside of shader execution, join the sample and image pair with a bitwise or operation. This approach won't work on games that truly use separate samplers in a meaningful way. For example, pooling textures in a 2D array and determining at runtime what sampler to use. This invalidates OpenGL's disk shader cache :) - Used mostly by D3D ports to Switch | |||||
2020-06-05 | service: nvhost_vic: Ignore Submit commands. | bunnei | 2 | -1/+18 | |
2020-06-05 | nvdrv: Stub nvdec/vic ioctls to bypass nvdec movies | Zach Hilman | 4 | -3/+239 | |
2020-06-05 | shader/track: Move bindless tracking to a separate function | ReinUsesLisp | 2 | -25/+39 | |
2020-06-04 | Downgrade "handle not signaled" error to trace | David Marcec | 1 | -1/+1 | |
clogs logs quite a bit | |||||
2020-06-04 | Default init labels and use initializer list for macro engine | David Marcec | 2 | -2/+2 | |
2020-06-04 | gl_rasterizer: Use NV_transform_feedback for XFB on assembly shaders | ReinUsesLisp | 3 | -1/+96 | |
NV_transform_feedback, NV_transform_feedback2 and ARB_transform_feedback3 with NV_transform_feedback interactions allows implementing transform feedbacks as dynamic state. Maxwell implements transform feedbacks as dynamic state, so using these extensions with TransformFeedbackStreamAttribsNV allows us to properly emulate transform feedbacks without having to recompile shaders when the state changes. | |||||
2020-06-03 | Mark parameters as const | David Marcec | 8 | -11/+11 | |
2020-06-03 | Actually save the input when clearing/resetting to default | FearlessTobi | 1 | -0/+3 | |
Co-Authored-By: xperia64 <xperiancedapps@gmail.com> | |||||
2020-06-02 | Address review comments | VolcaEM | 1 | -4/+4 | |
2020-06-02 | Pass by reference instead of copying parameters | David Marcec | 4 | -7/+9 | |
2020-06-02 | vk_shader_decompiler: Implement atomic image operations | ReinUsesLisp | 1 | -40/+24 | |
Implement atomic operations on images. On GLSL these are atomicImage* functions (e.g. atomicImageAdd). | |||||
2020-06-02 | vk_rasterizer: Implement storage texels | ReinUsesLisp | 8 | -52/+120 | |
This is the equivalent of an image buffer on OpenGL. - Used by Octopath Traveler | |||||
2020-06-02 | maxwell_to_vk: Add R16UI image format | ReinUsesLisp | 2 | -71/+74 | |
- Used by Octopath Traveler | |||||
2020-06-01 | gl_shader_decompiler: Declare gl_Layer and gl_ViewportIndex within gl_PerVertex for vertex and tessellation shaders | Morph | 1 | -6/+16 | |
2020-06-01 | gl_shader_decompiler: Fix geometry shader outputs for Intel drivers | Morph | 1 | -13/+15 | |
On Intel's proprietary drivers, gl_Layer and gl_ViewportIndex are not allowed members of gl_PerVertex block, causing the shader to fail to compile. Fix this by declaring these variables outside of gl_PerVertex. | |||||
2020-06-01 | Clang-format | VolcaEM | 1 | -2/+1 | |
2020-06-01 | hid: Stub GetXpadIDs | VolcaEM | 2 | -1/+14 | |
Allows Minecraft: Nintendo Switch Edition (a.k.a. old Minecraft) to boot and go ingame | |||||
2020-06-01 | gl_device: Avoid devices with CAVEAT_SUPPORT on ASTC | ReinUsesLisp | 2 | -8/+19 | |
This avoids using Nvidia's ASTC decoder on OpenGL. The last time it was profiled, it was slower than yuzu's decoder. While we are at it, fix a bug in the texture cache when native ASTC is not supported. | |||||
2020-06-01 | glsl: Squash constant buffers into a single SSBO when we hit the limit | ReinUsesLisp | 7 | -79/+173 | |
Avoids compilation errors at the cost of shader build times and runtime performance when a game hits the limit of uniform buffers we can use. | |||||
2020-05-31 | Add comment to nrr_kind | VolcaEM | 1 | -1/+1 | |
According to Atmosphére (https://github.com/Atmosphere-NX/Atmosphere/blob/c7026b90940a1d88f9c10a6d98263bf22e654fa5/libraries/libstratosphere/include/stratosphere/ro/ro_types.hpp), nrr_kind (Atmosphére calls it "type") is 7.0.0+ | |||||
2020-05-31 | ldr: Update NRR/NRO structs | VolcaEM | 1 | -40/+72 | |
This was based on Switchbrew pages: https://switchbrew.org/wiki/NRR https://switchbrew.org/wiki/NRO | |||||
2020-05-31 | gl_device: Enable compute shaders for Intel proprietary drivers | Morph | 3 | -13/+0 | |
Previously we were disabling compute shaders on Intel's proprietary driver due to broken compute. This has been fixed in the latest Intel drivers. Re-enable compute for Intel proprietary drivers and remove the check for broken compute. | |||||
2020-05-30 | shader/other: Fix hardcoded value in S2R INVOCATION_INFO | ReinUsesLisp | 1 | -1/+1 | |
Geometry shaders built from Nvidia's compiler check for bits[16:23] to be less than or equal to 0 with VSETP to default to a "safe" value of 0x8000'0000 (safe from hardware's perspective). To avoid hitting this path in the shader, return 0x00ff'0000 from S2R INVOCATION_INFO. This seems to be the maximum number of vertices a geometry shader can emit in a primitive. | |||||
2020-05-30 | texture_cache: More relaxed reconstruction | ReinUsesLisp | 1 | -13/+9 | |
Only reupload textures when they've not been modified from the GPU. | |||||
2020-05-30 | Favor switch case over jump table | David Marcec | 2 | -18/+26 | |
Easier to read and will emit a jump table automatically. | |||||
2020-05-30 | Implement macro JIT | David Marcec | 15 | -189/+1034 | |
2020-05-30 | Add xbyak external | David Marcec | 4 | -2/+317 | |
2020-05-30 | texture_cache: Only copy textures that were modified from host | ReinUsesLisp | 1 | -2/+6 | |
2020-05-30 | texture_cache: Reload textures when number of resources mismatch | ReinUsesLisp | 1 | -0/+9 | |
2020-05-29 | vk_rasterizer: Skip transform feedbacks when extension is unavailable | ReinUsesLisp | 1 | -0/+7 | |
Avoids calling transform feedback procedures when VK_EXT_transform_feedback is not available. | |||||
2020-05-29 | texture_cache: Handle overlaps with multiple subresources | ReinUsesLisp | 1 | -27/+33 | |
Implement more surface reconstruct cases. Allow overlaps with more than one layer and mipmap and copies all of them to the new texture. - Fixes textures moving around objects on Xenoblade games | |||||
2020-05-29 | kernel: ResourceLimit::Reserve remove useless while loop | David Marcec | 1 | -5/+1 | |
Timeout is a u64, it will always be >= 0 | |||||
2020-05-28 | maxwell_3d: Reduce severity of logs that can be spammed | ReinUsesLisp | 1 | -6/+7 | |
These logs were killing performance on some games when they were spammed. Reduce them to Debug severity. | |||||
2020-05-28 | format_lookup_table: Implement G24S8 format as S8Z24 | ReinUsesLisp | 1 | -1/+2 | |
2020-05-28 | Make copying directory string more concise | lat9nq | 1 | -2/+1 | |
2020-05-28 | Address requested changes | lat9nq | 2 | -4/+4 | |
2020-05-28 | *nix systems can read any-case patch directories | lat9nq | 2 | -8/+32 | |
Changes many patch_manager functions to use a case-less variant of GetSubdirectory. Fixes patches not showing up on *nix systems when patch directories are named with odd cases, i.e. `exeFS'. | |||||
2020-05-28 | buffer_cache: Avoid copying twice on certain cases | ReinUsesLisp | 1 | -17/+23 | |
Avoid copying to a staging buffer on non-granular memory addresses. Add a callable argument to StreamBufferUpload to be able to copy to the staging buffer directly from ReadBlockUnsafe. | |||||
2020-05-27 | texture_cache: Use unordered_map::find instead of operator[] on hot code | ReinUsesLisp | 1 | -15/+19 | |
2020-05-27 | texture_cache: Use small vector for surface vectors | ReinUsesLisp | 1 | -9/+10 | |
This avoids most heap allocations when collecting surfaces into a vector. | |||||
2020-05-27 | maxwell_3d: Initialize line widths | ReinUsesLisp | 1 | -0/+2 | |
Initialize line widths to avoid setting a line width of zero. | |||||
2020-05-27 | maxwell_3d: Initialize polygon modes | ReinUsesLisp | 1 | -0/+2 | |
NVN expects this to be initialized as Fill, otherwise games that never bind a rasterizer state will log an invalid polygon mode. | |||||
2020-05-27 | Fix macOS code and change "Swapfile" to "Swap" | Morph | 2 | -3/+6 | |
2020-05-27 | shader/other: Implement MEMBAR.CTS | ReinUsesLisp | 4 | -9/+27 | |
This silences an assertion we were hitting and uses workgroup memory barriers when the game requests it. | |||||
2020-05-26 | texture_cache: Fix layered null surfaces | ReinUsesLisp | 1 | -1/+3 | |
Null texture cubes were not considered arrays, causing issues on Vulkan and OpenGL when creating views. | |||||
2020-05-26 | gl_texture_cache: Implement small texture view cache for swizzles | ReinUsesLisp | 3 | -37/+44 | |
This fixes cases where the texture swizzle was applied twice on the same draw to a texture bound to two different slots. | |||||
2020-05-26 | texture_cache: Implement depth stencil texture swizzles | ReinUsesLisp | 3 | -36/+42 | |
Stop ignoring image swizzles on depth and stencil images. This doesn't fix a known issue on Xenoblade Chronicles 2 where an OpenGL texture changes swizzles twice before being used. A proper fix would be having a small texture view cache for this like we do on Vulkan. | |||||
2020-05-26 | gl_rasterizer: Port front face flip check from Vulkan | ReinUsesLisp | 1 | -5/+20 | |
While Vulkan was assuming we had no negative viewports, OpenGL code was assuming we had them. Port the old code from Vulkan to OpenGL, checking if the first viewport is negative before flipping faces. This is not a complete implementation since we only check for the first viewport to be negative. That said, unless a game is using Vulkan, OpenGL and NVN games should be fine here, and we can always compare with our Vulkan backend to see if there's a difference. | |||||
2020-05-26 | fixed_pipeline_state: Remove unnecessary check for front faces flip | ReinUsesLisp | 1 | -2/+1 | |
The check to flip faces when viewports are negative were a left over from the old OpenGL code. This is not required on Vulkan where we have negative viewports. | |||||
2020-05-26 | gl_shader_manager: Unbind GLSL program when binding a host pipeline | ReinUsesLisp | 1 | -0/+4 | |
Fixes regression in Link's Awakening caused by 420cc13248350ef5c2d19e0b961cb4185cd16a8a | |||||
2020-05-22 | yuzu/discord_impl: Update the applicationID (#3977) | Tobias | 1 | -1/+1 | |
2020-05-22 | shader/other: Implement BAR.SYNC 0x0 | ReinUsesLisp | 4 | -0/+33 | |
Trivially implement this particular case of BAR. Unless games use OpenCL or CUDA barriers, we shouldn't hit any other case here. | |||||
2020-05-22 | shader/memory: Implement non-addition operations in RED | ReinUsesLisp | 1 | -2/+1 | |
Trivially implement these instructions. They are used in Astral Chain. | |||||
2020-05-22 | shader/other: Implement thread comparisons (NV_shader_thread_group) | ReinUsesLisp | 4 | -0/+72 | |
Hardware S2R special registers match gl_Thread*MaskNV. We can trivially implement these using Nvidia's extension on OpenGL or naively stubbing them with the ARB instructions to match. This might cause issues if the host device warp size doesn't match Nvidia's. That said, this is unlikely on proper shaders. Refer to the attached url for more documentation about these flags. https://www.khronos.org/registry/OpenGL/extensions/NV/NV_shader_thread_group.txt | |||||
2020-05-22 | shader_decompiler: Visit source nodes even when they assign to RZ | ReinUsesLisp | 2 | -2/+6 | |
Some operations like atomicMin were ignored because they returned were being stored to RZ. This operations have a side effect and it was being ignored. | |||||
2020-05-22 | vk_shader_decompiler: Don't assert for void returns | ReinUsesLisp | 1 | -2/+1 | |
Atomic instructions can be used without returning anything and this is valid code. Remove the assert. | |||||
2020-05-21 | buffer_cache: Remove unused boost headers | ReinUsesLisp | 1 | -2/+0 | |
2020-05-21 | map_interval: Add interval allocator and drop hack | ReinUsesLisp | 4 | -3/+79 | |
Drop the std::list hack to allocate memory indefinitely. Instead use a custom allocator that keeps references valid until destruction. This allocates fixed chunks of memory and puts pointers in a free list. When an allocation is no longer used put it back to the free list, this doesn't heap allocate because std::vector doesn't change the capacity. If the free list is empty, allocate a new chunk. | |||||
2020-05-21 | buffer_cache: Use boost::container::small_vector for maps in range | ReinUsesLisp | 1 | -13/+15 | |
Most overlaps in the buffer cache only contain one mapped address. We can avoid close to all heap allocations once the buffer cache is warmed up by using a small_vector with a stack size of one. | |||||
2020-05-21 | buffer_cache: Use boost::intrusive::set for caching | ReinUsesLisp | 6 | -30/+48 | |
Instead of using boost::icl::interval_map for caching, use boost::intrusive::set. interval_map is intended as a container where the keys can overlap with one another; we don't need this for caching buffers and a std::set-like data structure that allows us to search with lower_bound is enough. | |||||
2020-05-21 | buffer_cache: Remove shared pointers | ReinUsesLisp | 2 | -70/+72 | |
Removing shared pointers is a first step to be able to use intrusive objects and keep allocations close to one another in memory. | |||||
2020-05-21 | buffer_cache: Minor style changes | ReinUsesLisp | 2 | -129/+65 | |
Minor style changes. Mostly done so I avoid editing it while doing other changes. | |||||
2020-05-21 | clang-format | VolcaEM | 1 | -1/+2 | |
2020-05-21 | nifm: correct assert in CreateTemporaryNetworkProfile | VolcaEM | 1 | -1/+1 | |
This has been wrong since https://github.com/yuzu-emu/yuzu/commit/0432af5ad1ec34f02071f6fdc5fc78149b059f18 I haven't found a game that called this function (and I haven't tried this on a real Switch), and because of this I haven't been able to check if the number in assert OR the string in the assert is wrong, but one of the two is wrong: NetworkProfileData is 0x18E, while SfNetworkProfileData is 0x17C, according to Switchbrew Switchbrew doesn't officially say that NetworkProfileData's size is 0x18E but it's possible to calculate its size since Switchbrew provides the size and the offset of all the components of NetworkProfileData (which isn't currently implemented in yuzu, alongside SfNetworkProfileData) NetworkProfileData documentation: https://switchbrew.org/wiki/Network_Interface_services#NetworkProfileData SfNetworkProfileData documentation: https://switchbrew.org/wiki/Network_Interface_services#SfNetworkProfileData Since I trust ogniK's work on reversing NIFM, I'd assume this was just a typo in the string | |||||
2020-05-20 | crypto: Make KeyManager a singleton class | FearlessTobi | 13 | -21/+27 | |
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. | |||||
2020-05-19 | renderer_opengl: Add assembly program code paths | ReinUsesLisp | 12 | -109/+339 | |
Add code required to use OpenGL assembly programs based on NV_gpu_program5. Decompilation for ARB programs is intended to be added in a follow up commit. This does **not** include ARB decompilation and it's not in an usable state. The intention behind assembly programs is to reduce shader stutter significantly on drivers supporting NV_gpu_program5 (and other required extensions). Currently only Nvidia's proprietary driver supports these extensions. Add a UI option hidden for now to avoid people enabling this option accidentally. This code path has some limitations that OpenGL compatibility doesn't have: - NV_shader_storage_buffer_object is limited to 16 entries for a single OpenGL context state (I don't know if this is an intended limitation, an specification issue or I am missing something). Currently causes issues on The Legend of Zelda: Link's Awakening. - NV_parameter_buffer_object can't bind buffers using an offset different to zero. The used workaround is to copy to a temporary buffer (this doesn't happen often so it's not an issue). On the other hand, it has the following advantages: - Shaders build a lot faster. - We have control over how floating point rounding is done over individual instructions (SPIR-V on Vulkan can't do this). - Operations on shared memory can be unsigned and signed. - Transform feedbacks are dynamic state (not yet implemented). - Parameter buffers (uniform buffers) are per stage, matching NVN and hardware's behavior. - The API to bind and create assembly programs makes sense, unlike ARB_separate_shader_objects. | |||||
2020-05-19 | yuzu: Add frontend settings for assembly shaders | ReinUsesLisp | 8 | -0/+29 | |
Add settings for assembly shaders. Currently hidden to avoid users from accidentally enabled them. | |||||
2020-05-18 | maxwell_to_vk: Add format B8G8R8A8_SRGB | Morph | 2 | -2/+3 | |
Add format B8G8R8A8_SRGB and add Attachable capability for B8G8R8A8_UNORM Used by Bravely Default II | |||||
2020-05-18 | OpenGL: Enable Debug Context and Synchronous debugging when graphics debugging is enabled. | Fernando Sahmkow | 3 | -0/+9 | |
This commit aims to help easing debugging of driver crashes without having to modify existing code. | |||||
2020-05-17 | main: Log host system memory parameters | Morph | 4 | -0/+86 | |
Logs both physical memory and swapfile sizes, this is useful for support. | |||||
2020-05-16 | file_sys: Update SystemVersion archive to version 10.0.2 | David Marcec | 1 | -7/+7 | |
2020-05-16 | nv_flinger: Use enum for pixel format instead of u32 | David Marcec | 2 | -3/+11 | |
2020-05-16 | DmaPusher: Remove dead code in step | David Marcec | 2 | -9/+1 | |
2020-05-16 | vk_rasterizer: Match OpenGL's FlushAndInvalidate behavior | ReinUsesLisp | 1 | -1/+3 | |
Match OpenGL's behavior. This can fix or simplify bisecting issues on Vulkan. | |||||
2020-05-15 | frontend: Set minimum window size to 640x360 instead of 1280x720 (#3413) | Morph | 6 | -8/+36 | |
2020-05-13 | vk_rasterizer: Implement constant attributes | ReinUsesLisp | 4 | -13/+26 | |
Constant attributes (in OpenGL known disabled attributes) are not supported on Vulkan, even with extensions. To emulate this behavior we return zero on reads from disabled vertex attributes in shader code. This has no caching cost because attribute formats are not dynamic state on Vulkan and we have to store it in the pipeline cache anyway. - Fixes Animal Crossing: New Horizons terrain borders | |||||
2020-05-13 | vk_rasterizer: Remove buffer check in attribute selection | ReinUsesLisp | 1 | -4/+0 | |
This was a left over from OpenGL when disabled buffers where not properly emulated. We no longer have to assert this as it is checked in vertex buffer initialization. | |||||
2020-05-13 | time_zone: Use std::chrono::seconds for strong typing. | bunnei | 3 | -4/+5 | |
2020-05-12 | Frontend: Remove tracking for context wrapper | James Rowe | 1 | -8/+8 | |
2020-05-12 | hid: Clear keyboard states & fix logic issue | David Marcec | 1 | -3/+4 | |
Previously we never cleared the states of the entries and the key would stay held down, also looping over the key bytes for each key lead to setting every bit for the key state instead of the key we wanted | |||||
2020-05-11 | hle: service: time_zone_manager: Use current time zone setting. | bunnei | 2 | -3/+32 | |
2020-05-11 | common: Add module to get the current time zone. | bunnei | 3 | -0/+68 | |
2020-05-11 | core: settings: Add a setting for time zone. | bunnei | 8 | -10/+282 | |
2020-05-11 | fix logic error & scale sample volume based on voice volume | David Marcec | 1 | -7/+9 | |
2020-05-11 | pass by const ref instead | David Marcec | 1 | -8/+7 | |
2020-05-11 | audio_renderer: Better voice mixing and 6 channel downmixing | David Marcec | 3 | -11/+96 | |
Supersedes #3738 and #3321 | |||||
2020-05-11 | service: fsp_srv: Stub implementation of OpenMultiCommitManager. | bunnei | 2 | -1/+38 | |
2020-05-11 | yuzu: game_list: Fix 'Open Save Data Location' for device saves. | bunnei | 4 | -27/+49 | |
2020-05-11 | file_sys: savefata_factory: Update to support DeviceSaveData. | bunnei | 1 | -3/+6 | |
2020-05-11 | file_sys: control_metadata: Expose device_save_data_size. | bunnei | 2 | -0/+5 | |
2020-05-11 | Stub SendKeyboardLockKeyEvent | David Marcec | 2 | -1/+11 | |
Needed for Puchikon 4 SmileBASIC 1.0.0 | |||||
2020-05-10 | gl_shader_decompiler: Properly emulate NaN behaviour on NE | ReinUsesLisp | 1 | -0/+9 | |
"Not equal" operators on GLSL seem to behave as unordered when we expect an ordered comparison. Manually emulate this checking for LGE values (numbers, not-NaNs). | |||||
2020-05-10 | RasterizerCache: Correct documentation. | Fernando Sahmkow | 1 | -2/+2 | |
2020-05-10 | VkPipelineCache: Use a null shader on invalid address. | Fernando Sahmkow | 1 | -2/+1 | |
2020-05-10 | VideoCore: Use SyncGuestMemory mechanism for Shader/Pipeline Cache invalidation. | Fernando Sahmkow | 3 | -5/+61 | |
2020-05-09 | shader_ir: Separate float-point comparisons in ordered and unordered | ReinUsesLisp | 7 | -135/+163 | |
This allows us to use native SPIR-V instructions without having to manually check for NAN. | |||||
2020-05-08 | Replace externals with Conan (#3735) | James Rowe | 7 | -9/+10 | |
* Remove git submodules that will be loaded through conan * Move custom Find modules to their own folder * Use conan for downloading missing external dependencies * CI: Change the yuzu source folder user to the user that the containers run on * Attempt to remove dirty mingw build hack * Install conan on the msvc build * Only set release build type when using not using multi config generator * Re-add qt bundled to workaround an issue with conan qt not downloading prebuilt binaries * Add workaround for submodules that use legacy CMAKE variables * Re-add USE_BUNDLED_QT on the msvc build bot | |||||
2020-05-06 | Menubar: fix mouse tracking bug | FearlessTobi | 1 | -4/+0 | |
Co-Authored-By: Vitor K <vitor-k@users.noreply.github.com> | |||||
2020-05-05 | Update src/video_core/gpu.cpp | bunnei | 1 | -1/+1 | |
Co-authored-by: David <25727384+ogniK5377@users.noreply.github.com> | |||||
2020-05-05 | Update src/video_core/gpu.cpp | bunnei | 1 | -1/+1 | |
Co-authored-by: David <25727384+ogniK5377@users.noreply.github.com> | |||||
2020-05-05 | vk_sampler_cache: Use VK_EXT_custom_border_color when available | ReinUsesLisp | 3 | -2/+44 | |
This should fix grass interactions on Breath of the Wild on Vulkan. It is currently untested against validation layers. Nvidia's Windows 443.09 beta driver or Linux 440.66.12 is required for now. | |||||
2020-05-04 | vk_graphics_pipeline: Implement viewport swizzles with NV_viewport_swizzle | ReinUsesLisp | 8 | -0/+84 | |
2020-05-04 | gl_rasterizer: Implement viewport swizzles with NV_viewport_swizzle | ReinUsesLisp | 2 | -0/+13 | |
2020-05-04 | maxwell_3d: Add viewport swizzles | ReinUsesLisp | 2 | -1/+24 | |
2020-05-03 | kernel/memory: Remove #pragma once within cpp file | Lioncash | 1 | -2/+0 | |
This isn't necessary in a cpp file and will cause warnings on clang. | |||||
2020-05-03 | kernel/memory: Remove unused includes | Lioncash | 7 | -8/+1 | |
Prevents header churn and needing to recompile these files if these headers are ever changed in the future. | |||||
2020-05-03 | kernel/memory: Remove unused variables in memory_block_manager | Lioncash | 1 | -3/+0 | |
Prevents unused variable warnings. | |||||
2020-05-03 | kernel/memory: Make use of std::array consistently in address_space_info | Lioncash | 1 | -6/+6 | |
This allows tuning standard library implementations to enable or disable range checks at runtime, which is nicer for debugging. | |||||
2020-05-03 | kernel/memory: Resolve -Wshadow warnings | Lioncash | 1 | -4/+4 | |
Prevents variable name clashing. | |||||
2020-05-03 | kernel/memory: Amend potential encoding warnings | Lioncash | 6 | -12/+12 | |
While èis generally representable in some language encodings, in some it isn't and will result in compilation warnings occurring. To remain friendly with other language's codepages on Windows, we normalize it to an ASCII e. | |||||
2020-05-03 | hle_ipc: Eliminate core memory globals | Lioncash | 3 | -10/+16 | |
We can just pass the required instances into the constructor of the request, eliminating all usages of the global system accessor. | |||||
2020-05-03 | settings: Add anisotropic filtering level to the yuzu configuration log (#3875) | Morph | 1 | -0/+1 | |
2020-05-03 | Update src/core/hle/service/am/am.cpp | bunnei | 1 | -1/+1 | |
Co-authored-by: Mat M. <mathew1800@gmail.com> | |||||
2020-05-02 | input_common: fix build when SDL2 is disabled | FearlessTobi | 1 | -0/+6 | |
2020-05-02 | readable_event: Remove unnecessary semicolon in Signal() | Lioncash | 1 | -4/+6 | |
Resolves a -Wextra-semi warning. While we're at it, we can invert the branch to form a guard clause, unindenting all of the contained code. | |||||
2020-05-02 | vk_graphics_pipeline: Implement rasterizer_enable on Vulkan | ReinUsesLisp | 3 | -1/+3 | |
We can simply enable rasterizer discard matching the current pipeline key. | |||||
2020-05-02 | fixed_pipeline_state: explicitly use template keyword after 1f345ebe3a55 | Jan Beich | 1 | -2/+4 | |
In file included from src/video_core/renderer_opengl/renderer_opengl.cpp:25: In file included from src/./video_core/renderer_opengl/gl_rasterizer.h:26: In file included from src/./video_core/renderer_opengl/gl_fence_manager.h:11: src/./video_core/fence_manager.h:91:32: error: use 'template' keyword to treat 'Write' as a dependent template name memory_manager.Write<u32>(current_fence->GetAddress(), current_fence->GetPayload()); ^ template src/./video_core/fence_manager.h:137:32: error: use 'template' keyword to treat 'Write' as a dependent template name memory_manager.Write<u32>(current_fence->GetAddress(), current_fence->GetPayload()); ^ template | |||||
2020-05-01 | nvdrv: Fix GetGpuTime stack corruption | David Marcec | 1 | -2/+3 | |
IoctlGetGpuTime should be 16 bytes, not 8. | |||||
2020-05-01 | am: IHomeMenuFunctions:GetPopFromGeneralChannelEvent | David Marcec | 3 | -4/+20 | |
QLaunch 1.0.0 | |||||
2020-04-30 | maxwell_to_vk: implement missing signed int formats | Dan | 1 | -2/+14 | |
2020-04-30 | caps:su Stub out SetShimLibraryVersion | Jason Parker | 2 | -1/+13 | |
Used by Animal Crossing: New Horizons when trying to take a picture. | |||||
2020-04-30 | texture: Implement R8G8UI | Morph | 8 | -38/+52 | |
- Used by The Walking Dead: The Final Season | |||||
2020-04-30 | fs-srv: GetFreeSpaceSize & GetTotalSpaceSize | David Marcec | 1 | -2/+2 | |
Closes #3533 Turns out the functions were already implemented but just never added | |||||
2020-04-30 | nim: CreateServerInterface, CreateAccessorInterface, CreateAsyncInterface | David Marcec | 1 | -1/+69 | |
Closes #3026 | |||||
2020-04-30 | caps: Add missing service names to caps:su | David Marcec | 1 | -0/+3 | |
SetShimLibraryVersion, SaveScreenShotEx1 & SaveScreenShotEx2 were missing | |||||
2020-04-30 | am: GetFriendInvitationStorageChannelEvent | David Marcec | 2 | -1/+14 | |
Closes #3829 | |||||
2020-04-29 | psm: Mark as debug instead of warning | David Marcec | 1 | -7/+14 | |
No point to emulate battery life. However options are broken out if we ever want to add a setting for it | |||||
2020-04-29 | am: Properly implement GetDisplayVersion | David Marcec | 1 | -3/+14 | |
Properly implement IApplicationFunctions::GetDisplayVersion | |||||
2020-04-29 | am: IsVrModeEnabled & SetVrModeEnabled fixes | David Marcec | 2 | -16/+6 | |
Return the proper state of vr mode for IsVrModeEnabled We should not return an error for SetVrModeEnabled. When VR Mode is turned on, it signals to lbl to turn vr mode on, not return an error code | |||||
2020-04-29 | acc: Return a unique value per account for GetAccountId | David Marcec | 2 | -5/+13 | |
2020-04-29 | acc: Fix InitializeApplicationInfo | David Marcec | 2 | -22/+15 | |
We're not suppose to pop a u64, should just read the sent pid and check that | |||||
2020-04-29 | kernel: Don't fail silently | David Marcec | 7 | -0/+51 | |
2020-04-29 | vulkan: Remove unnecessary includes | Lioncash | 31 | -59/+3 | |
Reduces some header churn and reduces rebuilds when some header internals change. While we're at it we can also resolve a missing include in buffer_cache. | |||||
2020-04-29 | Don't fail silently for vi, sm, set and ns services | David Marcec | 4 | -3/+27 | |
2020-04-28 | shader/arithmetic_integer: Fix tracking issue in temporary | ReinUsesLisp | 1 | -4/+0 | |
This temporary is not needed as we mark Rd.CC + IADD.X as unimplemented. It caused issues when tracking global buffers. | |||||
2020-04-28 | Clang Format and Documentation. | Fernando Sahmkow | 10 | -10/+20 | |
2020-04-28 | MaxwellDMA: Optimize micro copies. | Fernando Sahmkow | 3 | -0/+57 | |
2020-04-28 | kernel: Bad GetInfo ids should not be marked as stubs | David Marcec | 1 | -2/+2 | |
As we currently match hardware and don't return a successful result, these should be marked as errors instead of warnings and as stubs. | |||||
2020-04-28 | Updated comment to reflect ListQualifiedUsers better | David Marcec | 1 | -1/+3 | |
2020-04-28 | style: Change AMs & Glues error codes to be dec instead of hex | David Marcec | 2 | -7/+7 | |
Consistency for the rest of the error codes in the codebase | |||||
2020-04-28 | marked stubs | David Marcec | 1 | -4/+5 | |
2020-04-28 | account: ListQualifiedUsers | David Marcec | 5 | -3/+13 | |
Closes #2844 | |||||
2020-04-28 | Audin:u ListAudioIns, OpenAudioIn, ListAudioInsAuto, OpenAudioInAuto, ListAudioInsAutoFiltered, OpenAudioInProtocolSpecified | David Marcec | 2 | -5/+93 | |
Closes #2874 | |||||
2020-04-28 | vk_rasterizer: Skip index buffer setup when vertices are zero | ReinUsesLisp | 1 | -0/+3 | |
Xenoblade 2 invokes a draw call with zero vertices. This is likely due to indirect drawing (glDrawArraysIndirect). This causes a crash in the staging buffer pool when trying to create a buffer with a size of zero. To workaround this, skip index buffer setup entirely when the number of indices is zero. | |||||
2020-04-28 | {maxwell_3d,buffer_cache}: Implement memory barriers using 3D registers | ReinUsesLisp | 13 | -16/+57 | |
Drop MemoryBarrier from the buffer cache and use Maxwell3D's register WaitForIdle. To implement this on OpenGL we just call glMemoryBarrier with the necessary bits. Vulkan lacks this synchronization primitive, so we set an event and immediately wait for it. This is not a pretty solution, but it's what Vulkan can do without submitting the current command buffer to the queue (which ends up being more expensive on the CPU). | |||||
2020-04-28 | VideoCore/GPU: Delegate subchannel engines to the dma pusher. | Fernando Sahmkow | 3 | -4/+49 | |
2020-04-28 | VideoCore/Engines: Refactor Engines CallMethod. | Fernando Sahmkow | 13 | -62/+82 | |
2020-04-28 | maxwell_3d: Fix depth clamping register | ReinUsesLisp | 5 | -8/+5 | |
Using deko3d as reference: https://github.com/devkitPro/deko3d/blob/4e47ba0013552e592a86ab7a2510d1e7dadf236a/source/maxwell/gpu_3d_state.cpp#L42 We were using bits 3 and 4 to determine depth clamping, but these are the same both enabled and disabled: state->depthClampEnable ? 0x101A : 0x181D The same happens on Nvidia's OpenGL driver, where they do something like this (default capabilities, GL 4.5 compatibility): (state & DEPTH_CLAMP) != 0 ? 0x201a : 0x281c There's always a difference between the first bits in this register, but bit 11 is consistently disabled on both deko3d/NVN and OpenGL. This commit changes yuzu's behaviour to use bit 11 to determine depth clamping. - Fixes depth issues on Super Mario Odyssey's intro. | |||||
2020-04-27 | texture_cache: Reintroduce preserve_contents accurately | ReinUsesLisp | 4 | -41/+81 | |
This reverts commit 94b0e2e5dae4e0bd0021ac2d8fe1ff904a93ee69. preserve_contents proved to be a meaningful optimization. This commit reintroduces it but properly implemented on OpenGL. We have to make sure the clear removes all the previous contents of the image. It's not currently implemented on Vulkan because we can do smart things there that's preferred to be introduced in a separate commit. | |||||
2020-04-26 | shader/memory_util: Deduplicate code | ReinUsesLisp | 9 | -159/+153 | |
Deduplicate code shared between vk_pipeline_cache and gl_shader_cache as well as shader decoder code. While we are at it, fix a bug in gl_shader_cache where compute shaders had an start offset of a stage shader. | |||||
2020-04-26 | shader/arithmetic_integer: Fix edge case and mark IADD.X Rd.CC as unimplemented | ReinUsesLisp | 1 | -1/+6 | |
IADD.X Rd.CC requires some extra logic that is not currently implemented. Abort when this is hit. | |||||
2020-04-26 | shader/arithmetic_integer: Change IAdd to UAdd to avoid signed overflow | ReinUsesLisp | 1 | -2/+2 | |
Signed integer addition overflow might be undefined behavior. It's free to change operations to UAdd and use unsigned integers to avoid potential bugs. | |||||
2020-04-26 | shader/arithmetic_integer: Implement IADD.X | ReinUsesLisp | 2 | -0/+10 | |
IADD.X takes the carry flag and adds it to the result. This is generally used to emulate 64-bit operations with 32-bit registers. | |||||
2020-04-26 | shader/arithmetic_integer: Implement CC for IADD | ReinUsesLisp | 4 | -3/+42 | |
2020-04-26 | decode/register_set_predicate: Implement CC | ReinUsesLisp | 1 | -9/+14 | |
P2R CC takes the state of condition codes and puts them into a register. We already have this implemented for PR (predicates). This commit implements CC over that. | |||||
2020-04-26 | decode/register_set_predicate: Use move for shared pointers | ReinUsesLisp | 1 | -16/+17 | |
Avoid atomic counters used by shared pointers. | |||||
2020-04-26 | services: hid: Stub StopSevenSixAxisSensor. | M&M | 2 | -1/+13 | |
- Used by The Legend of Zelda: Breath of the Wild v1.6.0 | |||||
2020-04-25 | Fix the mistake in the port and update the comment for clarity | Vitor Kiguchi | 1 | -7/+7 | |
2020-04-25 | vk_rasterizer: Pack texceptions and color formats on invalid formats | ReinUsesLisp | 2 | -5/+19 | |
Sometimes for unknown reasons NVN games can bind a render target format of 0. This may be a yuzu bug. With the commits before this the formats were specified without being "packed", assuming all formats and texceptions will be written like in the color_attachments vector. To address this issue, iterate all render targets and pack them as they are valid. This way they will match color_attachments. - Fixes validation errors and graphical issues on Breath of the Wild. | |||||
2020-04-24 | Add Restore Defaults and Clear options to hotkeys | Kewlan | 5 | -18/+116 | |
2020-04-24 | Revert: shader_decode: Fix LD, LDG when track constant buffer. | Fernando Sahmkow | 1 | -14/+6 | |
2020-04-24 | Fix -Wdeprecated-copy warning. | Markus Wick | 1 | -0/+1 | |
2020-04-24 | Fix -Werror=conversion error. | Markus Wick | 2 | -2/+2 | |
2020-04-24 | vi: Don't let uninitialized data pass as a response for SetBufferCount | David Marcec | 1 | -1/+9 | |
Currently SetBufferCount doesn't write to the out buffer which then contains uninitialized data. This leads to non-zero data which leads to responding with different error codes | |||||
2020-04-24 | physical_core: Make use of std::make_unique instead of std::make_shared in ctor | Lioncash | 4 | -8/+15 | |
We can also allow unicorn to be constructed in 32-bit mode or 64-bit mode to satisfy the need for both interpreter instances. Allows this code to compile successfully of non x86-64 architectures. | |||||
2020-04-24 | shared_memory: Amend doxygen reference | Lioncash | 2 | -5/+5 | |
Amends the parameter to match the documentation reference. Resolves a -Wdocumentation warning with clang. | |||||
2020-04-24 | svc: Re-add MapProcessCodeMemory/UnmapProcessCodeMemory | Lioncash | 1 | -2/+138 | |
These were lost in the re-implementation of the virtual memory manager. | |||||
2020-04-23 | svc: Remove unused variable | Lioncash | 1 | -3/+0 | |
Since the VMM refactor, this is no longer used or needed. | |||||
2020-04-23 | page_table: Remove unused captures | Lioncash | 1 | -2/+2 | |
Any time the lambda function is called, the permission being used in the capture would be passed in as an argument to the lambda, so the capture is unnecessary. | |||||
2020-04-23 | decode/arithmetic_half: Fix HADD2 and HMUL2 absolute and negation bits | ReinUsesLisp | 2 | -16/+37 | |
The encoding for negation and absolute value was wrong. Extracting is now done manually. Similar instructions having different encodings is the rule, not the exception. To keep sanity and readability I preferred to extract the desired bit manually. This is implemented against nxas: https://github.com/ReinUsesLisp/nxas/blob/8dbc38995711cc12206aa370145a3a02665fd989/table.h#L68 That is itself tested against nvdisasm (Nvidia's official disassembler). | |||||
2020-04-23 | shader/texture: Support multiple unknown sampler properties | ReinUsesLisp | 2 | -62/+87 | |
This allows deducing some properties from the texture instruction before asking the runtime. By doing this we can handle type mismatches in some instructions from the renderer instead of the shader decoder. Fixes texelFetch issues with games using 2D texture instructions on a 1D sampler. | |||||
2020-04-23 | shader_ir: Turn classes into data structures | ReinUsesLisp | 13 | -299/+197 | |
2020-04-23 | vk_rasterizer: Fix framebuffer creation validation errors | ReinUsesLisp | 1 | -2/+4 | |
Framebuffer creation was ignoring the number of color attachments. | |||||
2020-04-23 | vk_pipeline_cache: Unify pipeline cache keys into a single operation | ReinUsesLisp | 5 | -47/+59 | |
This allows us to call Common::CityHash and std::memcmp only once for GraphicsPipelineCacheKey. While we are at it, do the same for compute. | |||||
2020-04-23 | vk_renderpass_cache: Pack renderpass cache key to 12 bytes | ReinUsesLisp | 4 | -84/+59 | |
2020-04-23 | kernel: memory: Improve implementation of device shared memory. (#3707) | bunnei | 6 | -16/+110 | |
* kernel: memory: Improve implementation of device shared memory. * fixup! kernel: memory: Improve implementation of device shared memory. * fixup! kernel: memory: Improve implementation of device shared memory. | |||||
2020-04-23 | Clang Format. | Fernando Sahmkow | 6 | -11/+19 | |
2020-04-23 | GPU: Add Fast GPU Time Option. | Fernando Sahmkow | 7 | -1/+21 | |
2020-04-23 | Maxwell3D: Process Macros on MultiMethod. | Fernando Sahmkow | 1 | -25/+47 | |
2020-04-23 | DMAPusher: Propagate multimethod writes into the engines. | Fernando Sahmkow | 14 | -14/+164 | |
2020-04-23 | Update src/yuzu/main.cpp with missing const | Ben Russell | 1 | -1/+1 | |
Co-Authored-By: Mat M. <mathew1800@gmail.com> | |||||
2020-04-23 | Dump RomFS command to include Updates | Ben Russell | 1 | -1/+3 | |
Patch the RomFS with the selected updates before dumping. Previously the resulting RomFS only contained data from the original title. To dump the RomFS without updates the user can disable the update under Properties before choosing Dump RomFS. | |||||
2020-04-23 | Edit modifier_scale with the deadzone slider | Kewlan | 3 | -30/+52 | |
2020-04-23 | Fix format error in performance statistics | H27CK | 1 | -3/+4 | |
Formatting | |||||
2020-04-23 | vk_pipeline_cache: Fix unintentional memcpy into optional | ReinUsesLisp | 1 | -2/+4 | |
The intention behind this was to assign a float to from an uint32_t, but it was unintentionally being copied directly into the std::optional. Copy to a temporary and assign that temporary to std::optional. This can be replaced with std::bit_cast<float> once we are in C++20. | |||||
2020-04-23 | GL_Fence_Manager: use GL_TIMEOUT_IGNORED instead of a loop, | Fernando Sahmkow | 1 | -2/+1 | |
2020-04-22 | Add missing ; | H27CK | 1 | -1/+1 | |
2020-04-22 | Address Feedback. | Fernando Sahmkow | 3 | -24/+18 | |
2020-04-22 | Async GPU: Correct flushing behavior to be similar to old async GPU behavior. | Fernando Sahmkow | 3 | -0/+11 | |
2020-04-22 | MaxwellDMA: Correct copying on accuracy level. | Fernando Sahmkow | 1 | -2/+7 | |
2020-04-22 | ShaderCache/PipelineCache: Cache null shaders. | Fernando Sahmkow | 4 | -8/+31 | |
2020-04-22 | Address Feedback. | Fernando Sahmkow | 13 | -132/+117 | |
2020-04-22 | Fix GCC error. | Fernando Sahmkow | 2 | -6/+5 | |
2020-04-22 | Correct Linux Compile Error. | Fernando Sahmkow | 2 | -7/+10 | |
2020-04-22 | Clang format. | Fernando Sahmkow | 1 | -1/+2 | |
2020-04-22 | QueryCache: Only do async flushes on async gpu. | Fernando Sahmkow | 1 | -1/+4 | |
2020-04-22 | Async GPU: Only do reactive flushing on Extreme Level. | Fernando Sahmkow | 1 | -1/+1 | |
2020-04-22 | vk_fence_manager: Initial implementation | ReinUsesLisp | 8 | -12/+222 | |
2020-04-22 | QueryCache: Implement Async Flushes. | Fernando Sahmkow | 5 | -12/+77 | |
2020-04-22 | OpenGL: Guarantee writes to Buffers. | Fernando Sahmkow | 3 | -4/+2 | |
2020-04-22 | GPU: Implement Flush Requests for Async mode. | Fernando Sahmkow | 6 | -8/+70 | |
2020-04-22 | FenceManager: Manage syncpoints and rename fences to semaphores. | Fernando Sahmkow | 11 | -25/+123 | |
2020-04-22 | BufferCache: Refactor async managing. | Fernando Sahmkow | 2 | -10/+27 | |
2020-04-22 | FenceManager: Implement async buffer cache flushes on High settings | Fernando Sahmkow | 6 | -10/+69 | |
2020-04-22 | Rasterizer: Document SignalFence & ReleaseFences and setup skeletons on Vulkan. | Fernando Sahmkow | 5 | -4/+35 | |
2020-04-22 | GPU: Fix rebase errors. | Fernando Sahmkow | 2 | -4/+4 | |
2020-04-22 | Rasterizer: Disable fence managing in synchronous gpu. | Fernando Sahmkow | 2 | -1/+11 | |
2020-04-22 | ThreadManager: Sync async reads on accurate gpu. | Fernando Sahmkow | 9 | -8/+48 | |
2020-04-22 | FenceManager: Implement should wait. | Fernando Sahmkow | 2 | -2/+17 | |
2020-04-22 | GPU: Implement a Fence Manager. | Fernando Sahmkow | 6 | -23/+208 | |
2020-04-22 | OpenGL: Implement Fencing backend. | Fernando Sahmkow | 12 | -19/+94 | |
2020-04-22 | TextureCache: Flush linear textures after finishing rendering. | Fernando Sahmkow | 1 | -2/+8 | |
2020-04-22 | GPU: Delay Fences. | Fernando Sahmkow | 6 | -2/+20 | |
2020-04-22 | BufferCache: Implement OnCPUWrite and SyncGuestHost | Fernando Sahmkow | 6 | -7/+67 | |
2020-04-22 | GPU: Refactor synchronization on Async GPU | Fernando Sahmkow | 11 | -7/+56 | |
2020-04-22 | Texture Cache: Implement OnCPUWrite and SyncGuestHost | Fernando Sahmkow | 2 | -3/+63 | |
2020-04-22 | UI: Replasce accurate GPU option for GPU Accuracy Level | Fernando Sahmkow | 12 | -28/+77 | |
2020-04-22 | Add a trailing separator to the string path | Morph | 1 | -1/+1 | |
Fixes #3643 | |||||
2020-04-22 | Init SDL info structure and add dummy context | H27CK | 2 | -1/+4 | |
2020-04-22 | vk_memory_manager: Remove unified memory model flag | ReinUsesLisp | 5 | -35/+6 | |
All drivers (even Intel) seem to have a device local memory type that is not host visible. Remove this flag so all devices follow the same path. This fixes a crash when trying to map to host device local memory on integrated devices. | |||||
2020-04-22 | vk_rasterizer: Add lazy default buffer maker and use it for empty buffers | ReinUsesLisp | 3 | -4/+40 | |
Introduce a default buffer getter that lazily constructs an empty buffer. This is intended to match OpenGL's buffer 0. Use this for disabled vertex and uniform buffers. While we are at it, include vertex buffer usages for staging buffers to silence validation errors. | |||||
2020-04-22 | gl_rasterizer: Fix buffers without size | ReinUsesLisp | 3 | -8/+13 | |
On NVN buffers can be enabled but have no size. According to deko3d and the behavior we see in Animal Crossing: New Horizons these buffers get the special address of 0x1000 and limit themselves to 0xfff. Implement buffers without a size by binding a null buffer to OpenGL without a side. https://github.com/devkitPro/deko3d/blob/1d1930beea093b5a663419e93b0649719a3ca5da/source/maxwell/gpu_3d_vbo.cpp#L62-L63 | |||||
2020-04-21 | audio_renderer: Preliminary BehaviorInfo (#3736) | David | 7 | -13/+249 | |
* audio_renderer: Preliminary BehaviorInfo * clang format * Fixed IsRevisionSupported * fixed IsValidRevision * Fixed logic error & spelling errors & crash * Addressed issues | |||||
2020-04-21 | shader/arithmetic_integer: Fix LEA_IMM encoding | ReinUsesLisp | 1 | -2/+2 | |
The operand order in LEA_IMM was flipped compared to nvdisasm. Fix that using nxas as reference: https://github.com/ReinUsesLisp/nxas/blob/8dbc38995711cc12206aa370145a3a02665fd989/table.h#L122 | |||||
2020-04-21 | loader: nro: Fix process initialization using ProgramMetadata default. | bunnei | 2 | -11/+14 | |
2020-04-21 | loader: elf: Fix process initialization using ProgramMetadata default. | bunnei | 1 | -0/+5 | |
2020-04-21 | file_sys: program_metadata: Add a helper function for generating reasonable default metadata. | bunnei | 2 | -1/+16 | |
- We need this for homebrew process initialization. | |||||
2020-04-20 | service: Update function tables | Lioncash | 19 | -7/+108 | |
Keeps the service function tables up to date. Updated based off information on SwitchBrew. | |||||
2020-04-20 | npad: Lower log level for VibrateController to Debug | FearlessTobi | 1 | -1/+1 | |
2020-04-20 | audren: Lower log level for RequestUpdateImpl to Debug | FearlessTobi | 1 | -1/+1 | |
2020-04-20 | dynarmic: Add option to disable CPU JIT optimizations | MerryMage | 7 | -2/+26 | |
2020-04-20 | yuzu: Option to hide mouse on inactivity | FearlessTobi | 7 | -0/+78 | |
Co-Authored-By: Vitor K <vitor-k@users.noreply.github.com> | |||||
2020-04-20 | Initialize quad_indexed_pass before uint8_pass | Amit Prakash Ambasta | 1 | -1/+1 | |
Fixes Werror=reorder in gcc | |||||
2020-04-19 | service/time: Remove reliance on the global system accessor | Lioncash | 1 | -24/+26 | |
Eliminates usages of the global system accessor and instead passes the existing system instance into the interfaces. | |||||
2020-04-19 | dma_pusher: Remove reliance on the global system instance | Lioncash | 3 | -6/+11 | |
With this, the video core is now has no calls to the global system instance at all. | |||||
2020-04-19 | thread: FPCR.FZ is likely not 1 | MerryMage | 1 | -2/+1 | |
2020-04-19 | core: arm_unicorn: Fix interpret fallback by temporarily mapping instruction page. | bunnei | 1 | -0/+11 | |
2020-04-19 | renderer_vulkan: assume X11 if not Windows/macOS after bf1d66b7c074 | Jan Beich | 1 | -3/+3 | |
Render.Vulkan <Error> video_core/renderer_vulkan/renderer_vulkan.cpp:CreateInstance:131: Presentation not supported on this platform Render.Vulkan <Error> video_core/renderer_vulkan/renderer_vulkan.cpp:CreateSurface:378: Presentation not supported on this platform Core <Critical> core/core.cpp:Load:199: Failed to initialize system (Error 5)! | |||||
2020-04-19 | vulkan/wrapper: Sort physical devices | ReinUsesLisp | 1 | -1/+20 | |
Sort discrete GPUs over the rest, Nvidia over AMD, AMD over Intel, Intel over the rest. This gives us a somewhat consistent order when Optimus is removed (renderdoc does this when it's attached). This can break the configuration of users with an Intel GPU that manually remove Optimus on yuzu. That said, it's a very unlikely to happen. | |||||
2020-04-19 | fixed_pipeline_state: Hash and compare the whole structure | ReinUsesLisp | 2 | -105/+9 | |
Pad FixedPipelineState's size to 384 bytes to be a multiple of 16. Compare the whole struct with std::memcmp and hash with CityHash. Using CityHash instead of a naive hash should reduce the number of collisions. Improve used type traits to ensure this operation is safe. With these changes the improvements to the hashable pipeline state are: Optimized structure Hash: 89 ns Comparison: 103 ns Construction*: 164 ns Struct size: 384 bytes Original structure Hash: 148 ns Equal: 174 ns Construction*: 281 ns Size: 1384 bytes * Attribute state initialization is not measured These measures are averages taken with std::chrono::high_accuracy_clock on MSVC shipped on Visual Studio 16.6.0 Preview 2.1. | |||||
2020-04-19 | fixed_pipeline_state: Pack blending state | ReinUsesLisp | 3 | -98/+227 | |
Reduce FixedPipelineState's size to 364 bytes. | |||||
2020-04-19 | fixed_pipeline_state: Pack rasterizer state | ReinUsesLisp | 4 | -163/+155 | |
Reduce FixedPipelineState's size to 600 bytes. | |||||
2020-04-19 | fixed_pipeline_state: Pack depth stencil state | ReinUsesLisp | 3 | -97/+140 | |
Reduce FixedPipelineState's size to 632 bytes. | |||||
2020-04-19 | fixed_pipeline_state: Pack attribute state | ReinUsesLisp | 6 | -101/+85 | |
Reduce FixedPipelineState's size from 1384 to 664 bytes | |||||
2020-04-18 | video_core: gl_shader_decompiler: Fix implicit fallthrough errors. | bunnei | 1 | -0/+1 | |
2020-04-18 | service: hid: npad: Fix implicit fallthrough errors. | bunnei | 1 | -0/+2 | |
2020-04-18 | gl_shader_decompiler: Avoid copies where applicable | Lioncash | 1 | -3/+3 | |
Avoids unnecessary reference count increments where applicable and also avoids reallocating a vector. Unlikely to make a huge difference, but given how trivial of an amendment it is, why not? | |||||
2020-04-18 | time/system_clock_core: Remove unnecessary initializer | Lioncash | 1 | -1/+1 | |
This is already initialized within the class body. | |||||
2020-04-18 | service/time: Mark IsStandardNetworkSystemClockAccuracySufficient as const | Lioncash | 1 | -1/+1 | |
This doesn't modify internal member state. | |||||
2020-04-18 | service/time: Add virtual destructors where applicable | Lioncash | 3 | -2/+3 | |
Many of these implementations are used to implement a polymorphic interface. While not directly used polymorphically, this prevents virtual destruction from ever becoming an issue. | |||||
2020-04-18 | service: Remove unused RequestParser instances | Lioncash | 2 | -3/+0 | |
These aren't used, so they should be removed to reduce compilation warnings. | |||||
2020-04-18 | memory/slab_heap: Make use of static_cast over reinterpret_cast | Lioncash | 1 | -2/+2 | |
Casting from void* with static_cast is permitted by the standard, so we can just make use of that instead. | |||||
2020-04-18 | loader/nso: Resolve moves not occurring in DecompressSegment | Lioncash | 1 | -1/+1 | |
Given the std::vector was const, an automatic move out of the function could not occur. We can allow automatic return value optimizations to occur by making the buffer non-const. | |||||
2020-04-18 | am: Resolve ineffective moves | Lioncash | 1 | -2/+2 | |
Previously const objects were being std::moved, which results in no move actually occurring. This resolves that. | |||||
2020-04-17 | video_code: Fix implicit switch fallthrough. | Markus Wick | 1 | -0/+2 | |
Since yesterday, this breaks the build on linux. So let's fix it. | |||||
2020-04-17 | vk_stream_buffer: Fix out of memory on boot on recent Nvidia drivers | ReinUsesLisp | 2 | -33/+48 | |
Nvidia recently introduced a new memory type for data streaming (awesome!), but yuzu was assuming that all heaps had enough memory for the assumed stream buffer size (256 MiB). This worked fine on AMD but Nvidia's new memory heap was smaller than 256 MiB. This commit changes this assumption and allocates a bit less than the size of the preferred heap, with a maximum of 256 MiB (to avoid allocating all system memory on integrated devices). - Fixes a crash on NVIDIA 450.82.0.0 | |||||
2020-04-17 | Revert "gl_shader_cache: Use CompileDepth::FullDecompile on GLSL" | Rodrigo Locatti | 1 | -3/+1 | |
2020-04-17 | core: hle: Address various feedback & code cleanup. | bunnei | 11 | -251/+153 | |
- Should be no functional changes. | |||||
2020-04-17 | core: device_memory: Remove incorrect usage of constexpr. | bunnei | 1 | -2/+6 | |
2020-04-17 | memory: Add copyright notice for Atmosphere where applicable. | bunnei | 6 | -0/+18 | |
2020-04-17 | kernel: Remove old VMManager class. | bunnei | 3 | -1973/+0 | |
2020-04-17 | loader: nso: Fix loader size and arguments. | bunnei | 3 | -25/+47 | |
2020-04-17 | loader: elf/kip/nro: Updates for new VMM. | bunnei | 3 | -5/+7 | |
2020-04-17 | service: ldr: Updates for new VMM. | bunnei | 1 | -150/+215 | |
- Includes removing some service impls. that are untested. | |||||
2020-04-17 | kernel: memory: page_table: Simplify GetPhysicalAddr impl. | bunnei | 4 | -19/+6 | |
2020-04-17 | kernel: svc: Updates for new VMM. | bunnei | 1 | -488/+116 | |
- Includes removing some SVC impls. that are untested. | |||||
2020-04-17 | core: memory: Fix memory access on page boundaries. | bunnei | 1 | -6/+39 | |
- Fixes Super Smash Bros. Ultimate. | |||||
2020-04-17 | video_core: memory_manager: Updates for Common::PageTable changes. | bunnei | 2 | -67/+34 | |
2020-04-17 | core: memory: Updates for new VMM. | bunnei | 2 | -114/+53 | |
2020-04-17 | common: page_table: Update to use VirtualBuffer and simplify. | bunnei | 2 | -53/+18 | |
2020-04-17 | core: gdbstub: Updates for new VMM. | bunnei | 1 | -2/+2 | |
2020-04-17 | core: reporter: Updates for new VMM. | bunnei | 1 | -3/+5 | |
2020-04-17 | memory: cheat_engine: Updates for new VMM. | bunnei | 1 | -5/+8 | |
2020-04-17 | arm_test_common: Updates for new VMM. | bunnei | 1 | -6/+2 | |
2020-04-17 | kernel: process: Updates for new VMM. | bunnei | 2 | -79/+151 | |
2020-04-17 | service: pl_u: Update for new shared memory layout. | bunnei | 1 | -7/+5 | |
2020-04-17 | service: time: Update for new shared memory layout. | bunnei | 1 | -3/+2 | |
2020-04-17 | service: hid: Update for new shared memory layout. | bunnei | 1 | -3/+2 | |
2020-04-17 | service: irs: Update for new shared memory layout. | bunnei | 1 | -3/+3 | |
2020-04-17 | kernel: resource_limit: Reserve physical memory. | bunnei | 1 | -1/+6 | |
2020-04-17 | kernel: Initialize memory layout for new VMM. | bunnei | 2 | -0/+159 | |
2020-04-17 | core: system: Rename GetDeviceManager -> DeviceManager. | bunnei | 3 | -7/+7 | |
- More consistent with other system components. | |||||
2020-04-17 | kernel: transfer_memory: Refactor for new VMM. | bunnei | 2 | -130/+16 | |
2020-04-17 | core: Construct/Destruct DeviceMemory on Init/Shutdown. | bunnei | 1 | -4/+7 | |
2020-04-17 | kernel: shared_memory: Refactor for new VMM. | bunnei | 2 | -220/+58 | |
2020-04-17 | core: device_memory: Update to use VirtualBuffer class. | bunnei | 2 | -39/+12 | |
2020-04-17 | common: Add VirtualBuffer class, to abstract memory virtualization. | bunnei | 3 | -0/+112 | |
2020-04-17 | kernel: errors: Add ERR_OUT_OF_RESOURCES. | bunnei | 1 | -0/+1 | |
2020-04-17 | kernel: process_capability: Update to use Memory::PageTable. | bunnei | 2 | -23/+25 | |
2020-04-17 | kernel: memory: Add PageTable class, to manage process address space. | bunnei | 3 | -0/+1510 | |
2020-04-17 | kernel: memory: Add MemoryLayout class, to build physical memory layout. | bunnei | 2 | -0/+74 | |
2020-04-17 | kernel: memory: Add MemoryManager class, to manage page heaps. | bunnei | 3 | -0/+276 | |
2020-04-17 | kernel: memory: Add MemoryBlockManager class, to manage memory blocks. | bunnei | 3 | -0/+256 | |
2020-04-17 | kernel: memory: Add PageHeap class, to manage a heap of pages. | bunnei | 3 | -0/+483 | |
2020-04-17 | kernel: memory: Add PageLinkedList class, to manage a list of pages. | bunnei | 2 | -0/+94 | |
2020-04-17 | kernel: memory: Add system_control code, which will be used for ASLR support. | bunnei | 3 | -0/+61 | |
2020-04-17 | physical_memory: Add missing include for <vector>. | bunnei | 1 | -0/+2 | |
2020-04-17 | kernel: memory: Add MemoryBlock class, for managing memory blocks and their state. | bunnei | 2 | -0/+316 | |
2020-04-17 | kernel: memory: Add memory_types.h, for things that are commonly used in memory code. | bunnei | 2 | -0/+19 | |
2020-04-17 | kernel: memory: Add SlabHeap class, for managing memory heaps. | bunnei | 2 | -0/+162 | |
- This will be used for TLS pages, among other things. | |||||
2020-04-17 | kernel: memory: Add AddressSpaceInfo class, for managing the memory address space. | bunnei | 3 | -0/+166 | |
2020-04-17 | core: device_manager: Add a simple class to manage device RAM. | bunnei | 5 | -1/+118 | |
2020-04-17 | dynarmic: Enable strict alignment checks. | bunnei | 1 | -1/+4 | |
- Also add a missing include. | |||||
2020-04-17 | common: scope_exit: Implement mechanism for canceling a scope exit. | bunnei | 1 | -1/+8 | |
2020-04-17 | core: memory: Move to Core::Memory namespace. | bunnei | 37 | -98/+100 | |
- helpful to disambiguate Kernel::Memory namespace. | |||||
2020-04-17 | common: alignment: Add a helper function for generic alignment checking. | bunnei | 1 | -0/+7 | |
2020-04-17 | core: kernel: Add svc_types header to include SVC-specific types. | bunnei | 3 | -0/+70 | |
2020-04-17 | core: kernel: Move SVC to its own namesapce. | bunnei | 5 | -9/+9 | |
2020-04-17 | kernel: resource_limit: Improvements to implementation. | bunnei | 2 | -12/+50 | |
2020-04-17 | loader: nso: Fix loading of static objects to be properly sized and aligned. | bunnei | 1 | -19/+9 | |
2020-04-17 | common: common_funcs: Add a macro for defining enum flag operators. | bunnei | 1 | -0/+32 | |
2020-04-17 | process: SetupMainThread: Zero out argument on process start. | bunnei | 1 | -0/+2 | |
2020-04-17 | arm_interface: Ensure ThreadContext is zero'd out. | bunnei | 1 | -16/+16 | |
2020-04-17 | CMakeLists: Make missing declarations a compile-time error | Lioncash | 1 | -0/+1 | |
Ensures that our code always has its linkage explicit. | |||||
2020-04-17 | General: Resolve warnings related to missing declarations | Lioncash | 9 | -24/+25 | |
2020-04-17 | gdbstub: Fix some gdbstub jankiness | MerryMage | 1 | -4/+3 | |
1. Ensure that register information available to gdbstub is most up-to-date. 2. There's no reason to check for current_thread == thread when emitting a trap. Doing this results in random hangs whenever a step happens upon a thread switch. | |||||
2020-04-17 | key_manager: Resolve missing field initializer warning | Lioncash | 1 | -1/+2 | |
2020-04-17 | decode/memory: Resolve unused variable warning | Lioncash | 1 | -1/+1 | |
Only the first element of the returned pair is ever used. | |||||
2020-04-17 | decode/texture: Resolve unused variable warnings. | Lioncash | 1 | -5/+7 | |
Some variables aren't used, so we can remove these. Unfortunately, diagnostics are still reported on structured bindings even when annotated with [[maybe_unused]], so we need to unpack the elements that we want to use manually. | |||||
2020-04-17 | decode/texture: Collapse loop down into std::generate | Lioncash | 1 | -3/+1 | |
Same behavior, less code. | |||||
2020-04-17 | decode/texture: Eliminate trivial missing field initializer warnings | Lioncash | 1 | -3/+4 | |
We can just specify the initializers. | |||||
2020-04-17 | time_zone_manager: Resolve sign conversion warnings | Lioncash | 1 | -2/+2 | |
ttis and ats will never exceed the length of INT32_MAX in our case, so this is safe. | |||||
2020-04-17 | CMakeLists: Enable -Wmissing-declarations on Linux builds | Lioncash | 1 | -0/+1 | |
Allows catching cases where internal linkage isn't specified for helper functions when they should be marked as such. | |||||
2020-04-17 | hle_ipc: Remove std::size_t casts where applicable | Lioncash | 2 | -21/+23 | |
These were added in the change that enabled -Wextra on linux builds so as not to introduce interface changes in the same change as a build-system flag addition. Now that the flags are enabled, we can freely change the interface to make these unnecessary. | |||||
2020-04-17 | maxwell_3d: Initialize format attributes constant as one | ReinUsesLisp | 1 | -0/+4 | |
nouveau expects this to be true but it doesn't set it. | |||||
2020-04-17 | vk_compute_pass: Implement indexed quads | ReinUsesLisp | 5 | -12/+280 | |
Implement indexed quads (GL_QUADS used with glDrawElements*) with a compute pass conversion. The compute shader converts from uint8/uint16/uint32 indices to uint32. The format is passed through push constants to avoid having different variants of the same shader. - Used by Fast RMX - Used by Xenoblade Chronicles 2 (it still has graphical due to synchronization issues on Vulkan) | |||||
2020-04-16 | externals: Move LibreSSL linking to httplib. | Markus Wick | 2 | -11/+3 | |
Neither core nor web_services use OpenSSL nor LibreSSL. However they need to link them as it's a requirement of httplib. So let's declare this within httplib instead of core and web_services. | |||||
2020-04-16 | input_common: Use the CMake target instead of the variable. | Markus Wick | 1 | -1/+1 | |
2020-04-16 | buffer_cache: Return handles instead of pointer to handles | ReinUsesLisp | 14 | -228/+90 | |
The original idea of returning pointers is that handles can be moved. The problem is that the implementation didn't take that in mind and made everything harder to work with. This commit drops pointer to handles and returns the handles themselves. While it is still true that handles can be invalidated, this way we get an old handle instead of a dangling pointer. This problem can be solved in the future with sparse buffers. | |||||
2020-04-16 | decode/shift: Remove unused variable within Shift() | Lioncash | 1 | -1/+0 | |
Removes a redundant variable that is already satisfied by the IsFull() utility function. | |||||
2020-04-16 | surface_view: Add missing operator!= to ViewParams | Lioncash | 2 | -0/+5 | |
Provides logical symmetry to the interface. | |||||
2020-04-16 | surface_base: Make IsInside() a const member function | Lioncash | 1 | -2/+2 | |
This doesn't modify internal state, so this can be made const. | |||||
2020-04-16 | texture_cache/format_lookup_table: Fix incorrect green, blue, and alpha indices | Lioncash | 1 | -3/+3 | |
Previously these were all using the red component to derive the indices, which is definitely not intentional. | |||||
2020-04-16 | control_flow: Make use of std::move in TryInspectAddress() | Lioncash | 1 | -3/+3 | |
Eliminates redundant atomic reference count increments and decrements. | |||||
2020-04-16 | video_core: Amend doxygen comment references | Lioncash | 2 | -5/+5 | |
Fixes broken documentation references. | |||||
2020-04-16 | decode/image: Fix typo in assert in GetComponentSize() | Lioncash | 1 | -3/+3 | |
2020-04-16 | gl_query_cache: Resolve use-after-move in CachedQuery move assignment operator | Lioncash | 1 | -1/+1 | |
Avoids potential invalid junk data from being read. | |||||
2020-04-16 | decoder/image: Fix incorrect G24R8 component sizes in GetComponentSize() | Lioncash | 1 | -2/+2 | |
The components' sizes were mismatched. This corrects that. | |||||
2020-04-16 | gl_device: Mark stage_swizzle as constexpr | Lioncash | 1 | -1/+1 | |
Previously this was mutable even though it shouldn't be. | |||||
2020-04-16 | track: Eliminate redundant copies | Lioncash | 1 | -5/+6 | |
Two variables can be references, while two others can be std::moved. Makes for 4 less atomic reference count increments and decrements. | |||||
2020-04-16 | CMakeLists: Specify -Wextra on linux builds | Lioncash | 26 | -70/+93 | |
Allows reporting more cases where logic errors may exist, such as implicit fallthrough cases, etc. We currently ignore unused parameters, since we currently have many cases where this is intentional (virtual interfaces). While we're at it, we can also tidy up any existing code that causes warnings. This also uncovered a few bugs as well. | |||||
2020-04-15 | file_util: Early-exit in WriteArray and ReadArray if specified lengths are zero | Lioncash | 2 | -9/+33 | |
It's undefined behavior to pass a null pointer to std::fread and std::fwrite, even if the length passed in is zero, so we must perform the precondition checking ourselves. A common case where this can occur is when passing in the data of an empty std::vector and size, as an empty vector will typically have a null internal buffer. While we're at it, we can move the implementation out of line and add debug checks against passing in nullptr to std::fread and std::fwrite. | |||||
2020-04-15 | CMakeLists: Make -Wreorder a compile-time error | Lioncash | 4 | -5/+7 | |
This can result in silent logic bugs within code, and given the amount of times these kind of warnings are caused, they should be flagged at compile-time so no new code is submitted with them. | |||||
2020-04-15 | kernel/thread: Resolve -Wswitch warnings | Lioncash | 1 | -0/+2 | |
2020-04-15 | Texture Cache: Read current data when flushing a 3D segment. | Fernando Sahmkow | 1 | -0/+6 | |
This PR corrects flushing of 3D segments when data of other segments is mixed, this aims to preserve the data in place. | |||||
2020-04-15 | maxwell_to_vk: Add uint16 vertex formats | ReinUsesLisp | 1 | -0/+8 | |
2020-04-15 | maxwell_to_vk: Add missing breaks | ReinUsesLisp | 1 | -0/+2 | |
Avoid invalid fallbacks. | |||||
2020-04-15 | vk_blit_screen: Initialize all members in VkPipelineViewportStateCreateInfo | ReinUsesLisp | 1 | -0/+2 | |
When the dynamic state is specified, pViewports and pScissors are ignored, quoting the specification: pViewports is a pointer to an array of VkViewport structures, defining the viewport transforms. If the viewport state is dynamic, this member is ignored. That said, AMD's proprietary driver itself seem to read it regardless of what the specification says. | |||||
2020-04-15 | Texture Cache: Only do buffer copies on accurate GPU. (#3634) | Fernando Sahmkow | 1 | -1/+3 | |
This is a simple optimization as Buffer Copies are mostly used for texture recycling. They are, however, useful when games abuse undefined behavior but most 3D APIs forbid it. | |||||
2020-04-15 | service: time: Implement CalculateStandardUserSystemClockDifferenceByUser. | bunnei | 3 | -1/+25 | |
- Used by Animal Crossing: New Horizons. | |||||
2020-04-15 | Revert "gl_shader_decompiler: Implement merges with bitfieldInsert" | ReinUsesLisp | 1 | -2/+4 | |
This reverts commit 05cf27083608bebd3ee4c38f2f948c8f2030f881. Apparently the first approach using floats instead of bitfieldInert worked better for Fire Emblem: Three Houses. Reverting to get that behavior back. | |||||
2020-04-15 | shader/arithmetic: Add FCMP_CR variant | ReinUsesLisp | 2 | -3/+6 | |
Adds another variant of FCMP. | |||||
2020-04-14 | gl_rasterizer: Implement constant vertex attributes | ReinUsesLisp | 2 | -2/+6 | |
Credits go to gdkchan from Ryujinx for finding constant attributes are used in retail games. | |||||
2020-04-14 | file_sys: patch_manager: Return early when there are no layers to apply. | bunnei | 1 | -0/+6 | |
2020-04-14 | service: friend: Stub IFriendService::GetBlockedUserListIds. | bunnei | 1 | -1/+10 | |
- This is safe to stub, as there should be no adverse consequences from reporting no blocked users. | |||||
2020-04-14 | vk_rasterizer: Default to 1 viewports with a size of 0 | ReinUsesLisp | 1 | -3/+6 | |
Silence validation layer errors. | |||||
2020-04-14 | gl_shader_cache: Use CompileDepth::FullDecompile on GLSL | ReinUsesLisp | 1 | -1/+3 | |
From my testing on a Splatoon 2 shader that takes 3800ms on average to compile changing to FullDecompile reduces it to 900ms on average. The shader decoder will automatically fallback to a more naive method if it can't use full decompile. | |||||
2020-04-14 | renderer_vulkan: Integrate Nvidia Nsight Aftermath on Windows | ReinUsesLisp | 9 | -22/+360 | |
Adds optional support for Nsight Aftermath. It is enabled through ENABLE_NSIGHT_AFTERMATH in cmake. A path to the SDK has to be provided by the environment variable NSIGHT_AFTERMATH_SDK. Nsight Aftermath allows an application to generate "minidumps" of the GPU state when a device loss happens. By analysing these on Nsight we can know what a game was doing and why it triggered a device loss. The dump is generated inside %APPDATA%\yuzu\log\gpucrash and this directory is deleted every time a new instance is initialized with Nsight enabled. To enable it on yuzu there has a to be a driver and device capable of running Nsight Aftermath on Vulkan. That means only Turing based GPUs on the latest stable driver, beta drivers won't work for now. It is manually enabled in Configuration>Debug>Enable Graphics Debugging because when using all debugging capabilities there is a runtime cost. | |||||
2020-04-14 | yuzu/main: Add better popup texts and remove duplicated actions | FearlessTobi | 3 | -64/+18 | |
Makes popup texts more compact and clear and also links our quickstart guide now. Also removes OnMenuSelectEmulatedDirectory from the File dropdown, as the action already exists in the Filesystem tab and provides better visual feedback there. | |||||
2020-04-13 | gl_texture_cache: Fix layered texture attachment base level | ReinUsesLisp | 1 | -1/+1 | |
The base level is already included in the texture view. If we specify the base level in the texture again, this will end up in the incorrect level and potentially out of bounds. | |||||
2020-04-13 | renderer_vulkan: Remove Nvidia checkpoints | ReinUsesLisp | 4 | -34/+0 | |
2020-04-13 | renderer_vulkan: Catch device losses in more places | ReinUsesLisp | 3 | -21/+29 | |
2020-04-13 | gl_rasterizer: Implement line widths and smooth lines | ReinUsesLisp | 5 | -2/+33 | |
Implements "legacy" features from OpenGL present on hardware such as smooth lines and line width. | |||||
2020-04-13 | gl_shader_decompiler: Implement merges with bitfieldInsert | ReinUsesLisp | 1 | -4/+2 | |
This also fixes Turing issues but it avoids doing more bitcasts. This should improve the generated code while also avoiding more points where compilers can flush floats. | |||||
2020-04-12 | gl_shader_decompiler: Improve generated code in HMergeH* | ReinUsesLisp | 1 | -6/+8 | |
Avoiding bitwise expressions, this fixes Turing issues in shaders using half float merges that affected several games. | |||||
2020-04-12 | shader/video: Partially implement VMNMX | ReinUsesLisp | 3 | -0/+116 | |
Implements the common usages for VMNMX. Inputs with a different size than 32 bits are not supported and sign mismatches aren't supported either. VMNMX works as follows: It grabs Ra and Rb and applies a maximum/minimum on them (this is defined by .MX), having in mind the input sign. This result can then be saturated. After the intermediate result is calculated, it applies another operation on it using Rc. These operations are merges, accumulations or another min/max pass. This instruction allows to implement with a more flexible approach GCN's min3 and max3 instructions (for instance). | |||||
2020-04-12 | video_core: Add MSAA registers in 3D engine and TIC | ReinUsesLisp | 2 | -6/+76 | |
This adds the registers used for multisampling. It doesn't implement anything for now. | |||||
2020-04-11 | texture_cache: Remove preserve_contents | ReinUsesLisp | 3 | -47/+31 | |
preserve_contents was always true. We can't assume we don't have to preserve clears because scissored and color masked clears exist. This removes preserve_contents and assumes it as true at all times. | |||||
2020-04-11 | renderer_vulkan: Drop Vulkan-Hpp | ReinUsesLisp | 51 | -2272/+2881 | |
2020-04-10 | Buffer queue: Correct behavior of free buffer. | Fernando Sahmkow | 2 | -9/+33 | |
This corrects the behavior of free buffer after witnessing it in an unrelated hardware test. I haven't found any games affected by it but in name of better accuracy we'll correct such behavior. | |||||
2020-04-10 | service/vi: Partially implement BufferQueue disconnect | ReinUsesLisp | 3 | -10/+44 | |
2020-04-10 | shader/texture: Remove type mismatches management from shader decoder | ReinUsesLisp | 1 | -14/+0 | |
Since commit e22816a5bb we handle type mismatches from the CPU. We don't need to hack our shader decoder due to game bugs anymore. Removed in this commit. | |||||
2020-04-09 | astc: Hard code bit depth changes to 8 and use fast replicate | ReinUsesLisp | 1 | -21/+15 | |
2020-04-09 | common/file_util: Allow access to files on network shares | Ben Russell | 1 | -1/+8 | |
On Windows, network shares use paths like \\server\share\file which were being broken by FileUtil::SanitizePath() removing double slashes. Changed the code in SanitizePath to permit a double-backslash if it occurs at the start of a filepath (on Windows only). | |||||
2020-04-09 | astc: Use boost's static_vector to avoid heap allocations | ReinUsesLisp | 1 | -10/+14 | |
2020-04-09 | astc: Implement a fast precompiled alternative for Replicate | ReinUsesLisp | 1 | -2/+57 | |
2020-04-09 | astc: Move Replicate to a constexpr LUT when possible | ReinUsesLisp | 1 | -8/+38 | |
2020-04-09 | astc: Make InputBitStream constexpr | ReinUsesLisp | 1 | -11/+11 | |
2020-04-09 | astc: OutputBitStream style changes and make it constexpr | ReinUsesLisp | 1 | -32/+26 | |
2020-04-09 | gl_texture_cache: Attach view instead of base texture for layered attachments | ReinUsesLisp | 1 | -2/+2 | |
This way we are not ignoring the base layer of the current texture. | |||||
2020-04-09 | VkRasterizer: Eliminate Legacy code. | Fernando Sahmkow | 1 | -1/+0 | |
2020-04-09 | Memory: Correct GCC errors. | Fernando Sahmkow | 2 | -2/+3 | |
2020-04-08 | Memory: Address Feedback. | Fernando Sahmkow | 4 | -4/+75 | |
2020-04-08 | GPUMemoryManager: Improve safety of memory reads. | Fernando Sahmkow | 3 | -55/+47 | |
2020-04-08 | Place SL and SR in the right most column. | Kewlan | 1 | -2/+2 | |
2020-04-08 | qt/bootmanager: Remove unnecessary glBindFramebuffer | ReinUsesLisp | 1 | -1/+0 | |
Presentation context always has GL_DRAW_FRAMEBUFFER_BINDING as zero. There is no need to bind the default framebuffer constantly. According to Nsight this was using ~0.7ms per frame and it broke renderdoc captures. | |||||
2020-04-08 | video_core/textures: Move GetMaxAnisotropy to cpp file | ReinUsesLisp | 2 | -19/+23 | |
2020-04-08 | video_core/texture: Use a LUT to convert sRGB texture borders | ReinUsesLisp | 3 | -9/+61 | |
This is a reversed look up table extracted from https://gist.github.com/rygorous/2203834#file-gistfile1-cpp-L41-L62 that is used in https://github.com/devkitPro/deko3d/blob/04d4e9e587fa3dc5447b43d273bc45f440226e41/source/maxwell/tsc_generate.cpp#L38 Games usually bind 0xFD expecting a float texture border of 1.0f. The conversion previous to this commit was multiplying the uint8 sRGB texture border color by 255. This is close to 1.0f but when that difference matters, some graphical glitches appear. This look up table is manually changed in the edges, clamping towards 0.0f and 1.0f. While we are at it, move this logic to its own translation unit. | |||||
2020-04-07 | Addressed feedback: switched to snake case and fixed clang-format errors | SilverBeamx | 2 | -5/+6 | |
2020-04-07 | Addressed feedback: removed CMake hack in favor of building the necessary strings via the supplied title format | SilverBeamx | 2 | -2/+14 | |
2020-04-07 | yuzu: Drop SDL2 and Qt frontend Vulkan requirements | ReinUsesLisp | 16 | -314/+371 | |
Create Vulkan instances and surfaces from the Vulkan backend. | |||||
2020-04-07 | address nit. | Nguyen Dac Nam | 1 | -1/+1 | |
2020-04-07 | renderer_vulkan: Query device names from the backend | ReinUsesLisp | 4 | -35/+79 | |
2020-04-07 | common/dynamic_library: Import and adapt helper from Dolphin | ReinUsesLisp | 3 | -0/+183 | |
2020-04-07 | shader/conversion: Implement I2I sign extension, saturation and selection | ReinUsesLisp | 2 | -14/+101 | |
Reimplements I2I adding sign extension, saturation (clamp source value to the destination), selection and destination sizes that are not 32 bits wide. It doesn't implement CC yet. | |||||
2020-04-07 | Apply suggestions from code review | Nguyen Dac Nam | 1 | -9/+9 | |
Co-Authored-By: Rodrigo Locatti <reinuseslisp@airmail.cc> | |||||
2020-04-07 | file_sys: fix LayeredFS error when loading some games made with… (#3602) | enler | 1 | -1/+2 | |
* fix LayeredFS error when loading some games made with the Unity | |||||
2020-04-06 | Clang Format. | Fernando Sahmkow | 1 | -6/+3 | |
2020-04-06 | Shader/Pipeline Cache: Use VAddr instead of physical memory for addressing. | Fernando Sahmkow | 7 | -87/+62 | |
2020-04-06 | Query Cache: Use VAddr instead of physical memory for adressing. | Fernando Sahmkow | 3 | -23/+22 | |
2020-04-06 | Buffer Cache: Use vAddr instead of physical memory. | Fernando Sahmkow | 12 | -106/+254 | |
2020-04-06 | Texture Cache: Use vAddr instead of physical memory for caching. | Fernando Sahmkow | 5 | -130/+81 | |
2020-04-06 | GPU: Setup Flush/Invalidate to use VAddr instead of CacheAddr | Fernando Sahmkow | 14 | -67/+77 | |
2020-04-06 | shader_decode: SULD.D using std::pair instead of out parameter | namkazy | 2 | -19/+15 | |
2020-04-06 | shader_decode: SULD.D avoid duplicate code block. | namkazy | 1 | -39/+2 | |
2020-04-06 | shader_decode: SULD.D fix conversion error. | namkazy | 1 | -3/+3 | |
2020-04-06 | shader_decode: SULD.D implement bits64 and reverse shader ir init method to removed shader stage. | namkazy | 5 | -46/+105 | |
2020-04-06 | shader/memory: Implement RED.E.ADD | ReinUsesLisp | 5 | -28/+99 | |
Implements a reduction operation. It's an atomic operation that doesn't return a value. This commit introduces another primitive because some shading languages might have a primitive for reduction operations. | |||||
2020-04-06 | shader/memory: Add "using std::move" | ReinUsesLisp | 1 | -11/+13 | |
2020-04-06 | shader/memory: Minor fixes in ATOM | ReinUsesLisp | 1 | -32/+30 | |
2020-04-06 | yuzu: Fixes to game list sorting | FearlessTobi | 2 | -8/+22 | |
Should fix citra-emu/citra#4593. As the issue might not be entirely clear, I'll offer a short explanation from what I understood from it and found from experimentation. Currently yuzu offers the user the option to change the text that's displayed in the "Name" column in the game list. Generally, it is expected that the items are sorted based on the displayed text, but yuzu would sort them by title instead. Made it so that an access to SortRole returns the same as DisplayRole. There shouldn't be any UI changes, only change in behaviour. Also fixes a bug with directory sorting, where having the directories out of order would enable you to try to "move up" to the addDirectory button, which would crash the emulator. Co-Authored-By: Vitor K <vitor-k@users.noreply.github.com> | |||||
2020-04-05 | silent warning (conversion error) | namkazy | 1 | -3/+2 | |
2020-04-05 | shader_decode: SULD.D -> SINT actually same as UNORM. | namkazy | 1 | -5/+4 | |
2020-04-05 | shader_decode: SULD.D fix decode SNORM component | namkazy | 1 | -10/+9 | |
2020-04-05 | clang-format | namkazy | 1 | -2/+2 | |
2020-04-05 | shader_decode: get sampler descriptor from registry. | namkazy | 1 | -77/+93 | |
2020-04-05 | yuzu/configuration: Only assert that all buttons exist when we are handling the click for a button device | FearlessTobi | 2 | -14/+16 | |
This fixes failed assertions that were present in yuzu master code for 18 months. | |||||
2020-04-05 | yuzu/configure_input_simple: Fix "Docked Joycons" controller profile | FearlessTobi | 1 | -4/+5 | |
This was incorrectly using PlayerIndex 1 when calling the ConfigureDialog. | |||||
2020-04-05 | tweaking. | namkazy | 1 | -3/+3 | |
2020-04-05 | clang-format | Nguyen Dac Nam | 1 | -2/+1 | |
2020-04-05 | cleanup unuse params | namkazy | 1 | -8/+6 | |
2020-04-05 | cleanup debug code. | namkazy | 1 | -14/+3 | |
2020-04-05 | reimplement get component type, uncomment mistaken code | namkazy | 1 | -18/+93 | |
2020-04-05 | remove disable optimize | namkazy | 1 | -2/+0 | |
2020-04-05 | [wip] reimplement SULD.D | namkazy | 1 | -22/+229 | |
2020-04-05 | add shader stage when init shader ir | namkazy | 4 | -9/+12 | |
2020-04-05 | clang-fix | Nguyen Dac Nam | 1 | -1/+1 | |
2020-04-05 | shader: image - import PredCondition | Nguyen Dac Nam | 1 | -0/+1 | |
2020-04-05 | shader: SULD.D bits32 implement more complexer method. | Nguyen Dac Nam | 1 | -4/+28 | |
2020-04-05 | shader: SULD.D import StoreType | Nguyen Dac Nam | 1 | -0/+1 | |
2020-04-05 | shader: implement SULD.D bits32 | Nguyen Dac Nam | 1 | -11/+27 | |
2020-04-04 | shader/other: Add error message for some S2R registers | ReinUsesLisp | 1 | -0/+6 | |
2020-04-04 | shader_bytecode: Rename MOV_SYS to S2R | ReinUsesLisp | 2 | -5/+5 | |
2020-04-04 | shader_bytecode: Add encoding for BAR | ReinUsesLisp | 1 | -0/+2 | |
2020-04-04 | shader_ir: Add error message for EXIT.FCSM_TR | ReinUsesLisp | 1 | -0/+3 | |
2020-04-04 | shader_bytecode: Add encoding for VOTE.VTG | ReinUsesLisp | 1 | -0/+2 | |
2020-04-04 | Revert "Merge pull request #3499 from ReinUsesLisp/depth-2d-array" | ReinUsesLisp | 1 | -4/+2 | |
This reverts commit 41905ee467b24172ba93e3fcd665bb4e4806a45a, reversing changes made to 35145bd529c3517e2c366efc764a762092d96edf. It causes regressions in several games. | |||||
2020-04-02 | shader/memory: Silence no return value warning | ReinUsesLisp | 1 | -0/+3 | |
Silences a warning about control paths not all returning a value. | |||||
2020-04-02 | shader_decompiler: Remove FragCoord.w hack and change IPA implementation | ReinUsesLisp | 4 | -68/+74 | |
Credits go to gdkchan and Ryujinx. The pull request used for this can be found here: https://github.com/Ryujinx/Ryujinx/pull/1082 yuzu was already using the header for interpolation, but it was missing the FragCoord.w multiplication described in the linked pull request. This commit finally removes the FragCoord.w == 1.0f hack from the shader decompiler. While we are at it, this commit renames some enumerations to match Nvidia's documentation (linked below) and fixes component declaration order in the shader program header (z and w were swapped). https://github.com/NVIDIA/open-gpu-doc/blob/master/Shader-Program-Header/Shader-Program-Header.html | |||||
2020-04-01 | gl_texture_cache: Fix software ASTC fallback | ReinUsesLisp | 1 | -7/+12 | |
2020-04-01 | vk_device: Add missing ASTC queries | ReinUsesLisp | 1 | -14/+29 | |
2020-04-01 | video_core: Use native ASTC when available | ReinUsesLisp | 10 | -281/+176 | |
2020-04-01 | gl_device: Detect if ASTC is reported and expose it | ReinUsesLisp | 2 | -0/+31 | |
2020-04-01 | common: Port some changes from dolphin (#5127) | Vitor K | 2 | -15/+16 | |
* IOFile: Make the move constructor and move assignment operator noexcept Certain parts of the standard library try to determine whether or not a transfer operation should either be a copy or a move. The prevalent notion of move constructors/assignment operators is that they should not throw, they simply move an already existing resource somewhere else. This is typically done with 'std::move_if_noexcept'. Like the name says, if a type's move constructor is noexcept, then the functions retrieves an r-value reference (for move semantics), or an l-value (for copy semantics) if it is not noexcept. As IOFile deletes the copy constructor and copy assignment operators, using IOFile with certain parts of the standard library can fail in unexcepted ways (especially when used with various container implementations). This prevents that. * fix various instances of -1 being assigned to unsigned types * do not assign in conditional statements * File/IOFile: Check _tfopen_s properly * common/file_util.cpp: address review comments Co-authored-by: Lioncash <mathew1800@gmail.com> Co-authored-by: Shawn Hoffman <godisgovernment@gmail.com> Co-authored-by: Sepalani <sepalani@hotmail.fr> | |||||
2020-04-01 | renderer_vulkan/wrapper: Add vkEnumerateInstanceExtensionProperties wrapper | ReinUsesLisp | 2 | -0/+17 | |
2020-04-01 | renderer_vulkan/wrapper: Add command buffer handle | ReinUsesLisp | 1 | -0/+192 | |
2020-04-01 | renderer_vulkan/wrapper: Add physical device handle | ReinUsesLisp | 2 | -0/+123 | |
2020-04-01 | renderer_vulkan/wrapper: Add device handle | ReinUsesLisp | 2 | -0/+277 | |
2020-04-01 | renderer_vulkan/wrapper: Add swapchain handle | ReinUsesLisp | 2 | -0/+15 | |
2020-04-01 | renderer_vulkan/wrapper: Add fence handle | ReinUsesLisp | 1 | -0/+17 | |
2020-04-01 | renderer_vulkan/wrapper: Add device memory handle | ReinUsesLisp | 1 | -0/+15 | |
2020-04-01 | renderer_vulkan/wrapper: Add pool handles | ReinUsesLisp | 2 | -0/+47 | |
2020-04-01 | renderer_vulkan/wrapper: Add buffer and image handles | ReinUsesLisp | 2 | -0/+24 | |
2020-04-01 | renderer_vulkan/wrapper: Add queue handle | ReinUsesLisp | 2 | -0/+36 | |
2020-04-01 | renderer_vulkan/wrapper: Add instance handle | ReinUsesLisp | 2 | -0/+87 | |
2020-04-01 | capsrv: Split Capture services into individual files and stub GetAlbumContentsFileListForApplication (#3571) | Morph | 15 | -151/+536 | |
* Organize capture services into individual files * Stub GetAlbumContentsFileListForApplication * Address feedback | |||||
2020-03-31 | gl_rasterizer: Mark cleared textures as dirty | ReinUsesLisp | 1 | -2/+5 | |
Fixes a potential edge case where cleared textures read from the CPU were not flushed. | |||||
2020-03-31 | clang-format | Nguyen Dac Nam | 1 | -2/+1 | |
2020-03-31 | shader_decode: fix by suggestion | Nguyen Dac Nam | 1 | -27/+22 | |
2020-03-30 | Frontend: Don't call DoneCurrent if the context isnt already current | James Rowe | 2 | -2/+13 | |
2020-03-30 | clang-format | namkazy | 1 | -3/+3 | |
2020-03-30 | gl_decompiler: min/max op not implement yet | namkazy | 1 | -0/+4 | |
2020-03-30 | shader_decode: ATOM/ATOMS: add function to avoid code repetition | namkazy | 2 | -70/+53 | |
2020-03-30 | shader_decode: merge GlobalAtomicOp to AtomicOp | namkazy | 1 | -13/+1 | |
2020-03-30 | shader_decode: implement ATOM operation for S32 and U32 | Nguyen Dac Nam | 1 | -6/+39 | |
2020-03-30 | clang-format | namkazy | 1 | -3/+3 | |
2020-03-30 | shader_decode: implement ATOMS instr partial. | Nguyen Dac Nam | 1 | -10/+42 | |
2020-03-30 | vk_decompiler: add atomic op and handler function. | Nguyen Dac Nam | 1 | -6/+25 | |
2020-03-30 | gl_decompiler: add atomic op | Nguyen Dac Nam | 1 | -0/+16 | |
2020-03-30 | shader: node - update correct comment | Nguyen Dac Nam | 1 | -15/+15 | |
2020-03-30 | shader_decode: add Atomic op for common usage | Nguyen Dac Nam | 1 | -1/+15 | |
2020-03-29 | Re-order the shoulder buttons both in the configuration menu, and in the code. | Kewlan | 1 | -36/+36 | |
2020-03-28 | shader_bytecode: Fix I2I_IMM encoding | ReinUsesLisp | 1 | -1/+1 | |
2020-03-28 | renderer_vulkan/wrapper: Address feedback | ReinUsesLisp | 1 | -3/+24 | |
2020-03-28 | shader/lea: Simplify generated LEA code | ReinUsesLisp | 1 | -3/+2 | |
2020-03-28 | yuzu: fix the stuck in fullscreen mode bug | FearlessTobi | 1 | -0/+8 | |
Co-Authored-By: Valentin Vanelslande <vvanelslandedev@gmail.com> | |||||
2020-03-27 | shader/lea: Fix op_a and op_b usages | ReinUsesLisp | 1 | -2/+2 | |
They were swapped. | |||||
2020-03-27 | shader/lea: Remove const and use move when possible | ReinUsesLisp | 1 | -11/+5 | |
2020-03-27 | Set render window to also accept focus via tabbing (Qt::StrongFocus) (#5089) | Vitor K | 1 | -1/+1 | |
2020-03-27 | services: hid: Stub InitializeSevenSixAxisSensor. | bunnei | 2 | -1/+9 | |
- Used by Super Smash Bros. Ultimate v7.0.0. | |||||
2020-03-27 | services: time: Implement CalculateSpanBetween. | bunnei | 3 | -1/+31 | |
- Used by Super Smash Bros. Ultimate. | |||||
2020-03-27 | am: Implement VR related APIs | perillamint | 2 | -3/+42 | |
Implement (and stub) VR related APIs in AM sysmodule. This fixes issue #2938 | |||||
2020-03-27 | renderer_vulkan/wrapper: Add owning handles | ReinUsesLisp | 1 | -0/+18 | |
2020-03-27 | renderer_vulkan/wrapper: Add pool allocations owning templated class | ReinUsesLisp | 1 | -0/+81 | |
2020-03-27 | renderer_vulkan/wrapper: Add owning handle templated class | ReinUsesLisp | 1 | -0/+144 | |
2020-03-27 | renderer_vulkan/wrapper: Add destroy and free overload set | ReinUsesLisp | 2 | -0/+133 | |
2020-03-27 | renderer_vulkan/wrapper: Add dispatch table and loaders | ReinUsesLisp | 2 | -0/+283 | |
2020-03-27 | renderer_vulkan/wrapper: Add exception class | ReinUsesLisp | 2 | -0/+34 | |
2020-03-27 | renderer_vulkan/wrapper: Add ToString function for VkResult | ReinUsesLisp | 3 | -0/+91 | |
2020-03-27 | renderer_vulkan/wrapper: Add Vulakn wrapper and a span helper | ReinUsesLisp | 2 | -0/+84 | |
The intention behind a Vulkan wrapper is to drop Vulkan-Hpp. The issues with Vulkan-Hpp are: - Regular breaks of the API. - Copy constructors that do the same as the aggregates (fixed recently) - External dynamic dispatch that is hard to remove - Alias KHR handles with non-KHR handles making it impossible to use smart handles on Vulkan 1.0 instances with extensions that were included on Vulkan 1.1. - Dynamic dispatchers silently change size depending on preprocessor definitions. Different files will have different dispatch definitions, generating all kinds of hard to debug memory issues. In other words, Vulkan-Hpp is not "production ready" for our needs and this wrapper aims to replace it without losing RAII and exception safety. | |||||
2020-03-27 | engines/const_buffer_engine_interface: Store image format type | ReinUsesLisp | 1 | -4/+10 | |
This information is required to properly implement SULD.B. It might also be handy for all image operations, since it would allow us to implement them on devices that require the image format to be specified (on desktop, this would be AMD on OpenGL and Intel on OpenGL and Vulkan). | |||||
2020-03-27 | maxwell_to_vk: implement signedscaled vertex formats | Dan | 1 | -0/+20 | |
2020-03-26 | services: ldr: Fix MemoryState for read/write regions of NROs. | bunnei | 1 | -5/+15 | |
- Fixes #3541, used by Final Fantasy VIII Remastered. | |||||
2020-03-26 | Address review and fix broken yuzu-tester build | James Rowe | 11 | -102/+83 | |
2020-03-26 | shader/conversion: Fix F2F rounding operations with different sizes | ReinUsesLisp | 1 | -5/+10 | |
Rounding operations only matter when the conversion size of source and destination is the same, i.e. .F16.F16, .F32.F32 and .F64.F64. When there is a mismatch (.F16.F32), these bits are used for IEEE rounding, we don't emulate this because GLSL and SPIR-V don't support configuring it per operation. | |||||
2020-03-26 | gl_rasterizer: Update stencil test regardless of it being disabled | ReinUsesLisp | 1 | -5/+1 | |
2020-03-26 | gl_rasterizer: Synchronize stencil testing on clears | ReinUsesLisp | 1 | -0/+1 | |
2020-03-25 | Frontend/GPU: Refactor context management | James Rowe | 29 | -418/+361 | |
Changes the GraphicsContext to be managed by the GPU core. This eliminates the need for the frontends to fool around with tricky MakeCurrent/DoneCurrent calls that are dependent on the settings (such as async gpu option). This also refactors out the need to use QWidget::fromWindowContainer as that caused issues with focus and input handling. Now we use a regular QWidget and just access the native windowHandle() directly. Another change is removing the debug tool setting in FrameMailbox. Instead of trying to block the frontend until a new frame is ready, the core will now take over presentation and draw directly to the window if the renderer detects that its hooked by NSight or RenderDoc Lastly, since it was in the way, I removed ScopeAcquireWindowContext and replaced it with a simple subclass in GraphicsContext that achieves the same result | |||||
2020-03-23 | sm/controller: Increase PointerBufferSize | FearlessTobi | 1 | -1/+1 | |
This increases the PointerBufferSize as a lager one is required by some services. This change is still not hw-accurate, but it is proven to work in Ryujinx. Instead of using a hardcoded size, we should figure out the specific values for each service in the future. Some of them can be taken from Atmosphere: https://github.com/Atmosphere-NX/Atmosphere/search?q=PointerBufferSize. | |||||
2020-03-23 | audio_core: Accept Audren REV8 | FearlessTobi | 1 | -1/+1 | |
According to Ryujinx, REV8 only added changes on Performance buffer and Wavebuffer DSP command generation. As we don't support any of those, we can just increment the revision number for now. | |||||
2020-03-23 | xmad: fix clang build error | makigumo | 1 | -4/+5 | |
2020-03-22 | apply replay logic to all writes. remove replay from MacroInterpreter::Send (@fincs) | namkazy | 2 | -12/+9 | |
2020-03-22 | core/web_browser: Allow WebApplet to exit gracefully when an error occurs | FearlessTobi | 1 | -0/+6 | |
Currently, yuzu just freezes when an error occurs while Initializing the WebApplet. From a user perspective, this obviously isn't great as the game just softlocks. With this change, yuzu will call the Finalize method, so to the game it seems like as the user just exited the WebApplet normally. This works around https://github.com/yuzu-emu/yuzu/issues/2852. | |||||
2020-03-22 | maxwell_3d: change declaration order | namkazy | 1 | -1/+3 | |
2020-03-22 | maxwell_3d: init shadow_state | namkazy | 1 | -0/+2 | |
2020-03-22 | gl_rasterizer: Use transformed viewport for depth ranges | ReinUsesLisp | 1 | -4/+6 | |
Implement depth ranges using the transformed viewport instead of the generic one. This matches the current Vulkan implementation but doesn't support negative depth ranges. An update to glad is required for this. | |||||
2020-03-22 | maxwell_3d: this seem more correct. | namkazy | 1 | -2/+2 | |
2020-03-22 | maxwell_3d: update comments for shadow ram usage | namkazy | 3 | -2/+6 | |
2020-03-22 | marco_interpreter: write hw value when shadow ram requested | Nguyen Dac Nam | 1 | -0/+6 | |
2020-03-22 | maxwell_3d: track shadow ram ctrl and hw reg value | Nguyen Dac Nam | 1 | -0/+10 | |
2020-03-22 | maxwell_3d: implement MME shadow RAM | Nguyen Dac Nam | 1 | -1/+14 | |
2020-03-19 | set: implement GetRegionCode | Dan | 8 | -9/+72 | |
2020-03-19 | vk_texture_cache: Silence misc warnings | ReinUsesLisp | 1 | -3/+3 | |
2020-03-19 | vk_staging_buffer_pool: Silence unused constant warning | ReinUsesLisp | 1 | -1/+1 | |
2020-03-19 | vk_rasterizer: Remove unused variable | ReinUsesLisp | 1 | -2/+0 | |
2020-03-19 | vk_pipeline_cache: Remove unused variable | ReinUsesLisp | 1 | -1/+0 | |
2020-03-19 | maxwell_to_vk: Sielence -Wswitch warning | ReinUsesLisp | 1 | -0/+2 | |
2020-03-19 | gl_shader_decompiler: Remove deprecated function and its usages | ReinUsesLisp | 1 | -11/+8 | |
2020-03-19 | gl_rasterizer: Silence misc warnings | ReinUsesLisp | 1 | -7/+2 | |
2020-03-19 | kepler_compute: Remove unused variables | ReinUsesLisp | 1 | -8/+0 | |
2020-03-18 | time_zone_content_manager: Fix out of bounds read | ReinUsesLisp | 1 | -1/+1 | |
There were cases where raw_data didn't contain enough space to hold the zero terminator. This was caught with -fsanitize=address. | |||||
2020-03-18 | input_common/udp: Fix clang build issues | ReinUsesLisp | 1 | -1/+2 | |
2020-03-18 | astc: Fix clang build issues | ReinUsesLisp | 1 | -12/+12 | |
2020-03-18 | gl_shader_decompiler: Don't redeclare gl_VertexID and gl_InstanceID | ReinUsesLisp | 1 | -8/+0 | |
2020-03-17 | yuzu: Save sound output mode and set it to Stereo by default | FearlessTobi | 3 | -0/+7 | |
2020-03-17 | bcat: Disable Boxcat backend by default | FearlessTobi | 2 | -2/+2 | |
This commit disables the Boxcat backend by default for new users of yuzu. There's several reasons as to why this is done: 1. Boxcat currently only actually has an impact on 3 games and doesn't influence any core mechanics of them 2. It causes a plethora of issues when enabled such as games like Crash Team Racing, Diablo 3 and Tales of Vesperia not booting at all or hanging 3. It causes https://github.com/yuzu-emu/yuzu/issues/2957 to happen. This makes the configuration menu totally unusable for many Linux users of yuzu I think those points show that currently the negative impact of Boxcat outweighs its benefits and should therefore be disabled by default. For users who are eager to use the extra features provided by it, they can still just turn it on in the settings. | |||||
2020-03-17 | input_common/udp: Fix Linux build by using a backwards compatible way of error checking | FearlessTobi | 1 | -1/+1 | |
Should fix https://github.com/yuzu-emu/yuzu/issues/3487. error_code::failed is a function which has been introduced in Boost 1.69. This version of boost hasn't landed in most major distros yet. | |||||
2020-03-17 | gdbstub: small logic bug fix with defer_start | Gauvain "GovanifY" Roussel-Tarbouriech | 1 | -2/+4 | |
2020-03-17 | gdbstub: Ensure gdbstub doesn't drop packets crucial to initialization | Gauvain "GovanifY" Roussel-Tarbouriech | 3 | -2/+16 | |
2020-03-16 | renderer_opengl: Move some logic to an anonymous namespace | ReinUsesLisp | 1 | -151/+151 | |
2020-03-16 | renderer_opengl: Detect Nvidia Nsight as a debugging tool | ReinUsesLisp | 3 | -7/+22 | |
Use getenv to detect Nsight. | |||||
2020-03-16 | gl_shader_decompiler: Implement legacy varyings | ReinUsesLisp | 1 | -6/+57 | |
Legacy varyings are special attributes carried over in hardware from the OpenGL 1 and OpenGL 2 days. These were generally used instead of the generic attributes we use today. They are deprecated or removed from most APIs, but Nvidia still ships them in hardware. To implement these, this commit maps them 1:1 to OpenGL compatibility. | |||||
2020-03-16 | shader/shader_ir: Track usage in input attribute and of legacy varyings | ReinUsesLisp | 3 | -34/+64 | |
2020-03-16 | shader/shader_ir: Fix clip distance usage stores | ReinUsesLisp | 1 | -2/+1 | |
2020-03-16 | shader/shader_ir: Change declare output attribute to a switch | ReinUsesLisp | 1 | -9/+9 | |
2020-03-15 | maxwell_to_vk: Implement RG32 and RGB32 integer vertex formats | ReinUsesLisp | 1 | -0/+4 | |
2020-03-15 | vk_rasterizer: Implement layered clears | ReinUsesLisp | 1 | -2/+2 | |
2020-03-15 | vk_shader_decompiler: fix linux build | makigumo | 1 | -1/+1 | |
2020-03-15 | vk_rasterizer: Fix vertex range assert | ReinUsesLisp | 1 | -1/+1 | |
End can be equal to start in CalculateVertexArraysSize. This is quite common when the vertex size is zero. | |||||
2020-03-15 | vk_rasterizer: Reimplement clears with vkCmdClearAttachments | ReinUsesLisp | 4 | -45/+53 | |
2020-03-14 | renderer_opengl: Keep presentation frames in lock-step when GPU debugging. | bunnei | 1 | -1/+32 | |
- Fixes renderdoc with OpenGL renderer. | |||||
2020-03-14 | gl_device: Add option to check GL_EXT_debug_tool. | bunnei | 2 | -0/+6 | |
2020-03-14 | DirtyFlags: relax need to set render_targets as dirty | Fernando Sahmkow | 4 | -13/+0 | |
The texture cache already takes care of setting a render target to dirty when invalidated. | |||||
2020-03-14 | PageTable: move backing addresses to a children class as the CPU page table does not need them. | Fernando Sahmkow | 3 | -4/+25 | |
This PR aims to reduce the memory usage in the CPU page table by moving GPU specific parameters into a child class. This saves 1Gb of Memory for most games. | |||||
2020-03-14 | astc: Fix typos from search and replace | ReinUsesLisp | 1 | -3/+3 | |
2020-03-14 | astc: Minor changes to InputBitStream | ReinUsesLisp | 1 | -28/+34 | |
2020-03-14 | astc: Pass val in Replicate by copy | ReinUsesLisp | 1 | -1/+1 | |
2020-03-14 | astc: Call std::vector:reserve on decodedClolorValues to avoid reallocating | ReinUsesLisp | 1 | -0/+2 | |
2020-03-14 | clang-format | Nguyen Dac Nam | 1 | -2/+1 | |
2020-03-14 | nit | Nguyen Dac Nam | 1 | -1/+1 | |
2020-03-14 | astc: Call std::vector::reserve on texelWeightValues to avoid reallocating | ReinUsesLisp | 1 | -0/+2 | |
2020-03-14 | astc: Create a LUT at compile time for encoding values | ReinUsesLisp | 1 | -7/+19 | |
2020-03-14 | astc: Make IntegerEncodedValue a trivial structure | ReinUsesLisp | 1 | -212/+177 | |
2020-03-14 | astc: Make IntegerEncodedValue constructor constexpr | ReinUsesLisp | 1 | -5/+6 | |
2020-03-14 | astc: Make IntegerEncodedValue trivially copyable | ReinUsesLisp | 1 | -9/+2 | |
2020-03-14 | astc: Rename C types to common_types | ReinUsesLisp | 1 | -79/+78 | |
2020-03-14 | astc: Move Popcnt to an anonymous namespace and make it constexpr | ReinUsesLisp | 1 | -9/+13 | |
2020-03-14 | astc: Use common types instead of stdint.h integer types | ReinUsesLisp | 1 | -284/+282 | |
2020-03-14 | astc: Use 'enum class' instead of 'enum' for EIntegerEncoding | ReinUsesLisp | 1 | -25/+25 | |
2020-03-13 | vk/gl_shader_decompiler: Silence assertion on compute | ReinUsesLisp | 2 | -6/+12 | |
2020-03-13 | vk_shader_decompiler: Fix default varying regression | ReinUsesLisp | 1 | -2/+6 | |
2020-03-13 | maxwell_3d: Add padding words to XFB entries | ReinUsesLisp | 1 | -2/+4 | |
Use INSERT_UNION_PADDING_WORDS instead of alignas to ensure a size requirement. | |||||
2020-03-13 | gl_shader_decompiler: Fix implicit conversion errors | ReinUsesLisp | 1 | -3/+3 | |
2020-03-13 | vk_shader_decompiler: Fix implicit type conversion | Rodrigo Locatti | 1 | -1/+1 | |
Co-Authored-By: Mat M. <mathew1800@gmail.com> | |||||
2020-03-13 | vk_rasterizer: Implement transform feedback binding zero | ReinUsesLisp | 2 | -0/+46 | |
2020-03-13 | vk_shader_decompiler: Add XFB decorations to generic varyings | ReinUsesLisp | 1 | -16/+89 | |
2020-03-13 | vk_device: Enable VK_EXT_transform_feedback when available | ReinUsesLisp | 2 | -7/+40 | |
2020-03-13 | vk_device: Shrink formatless capability name size | ReinUsesLisp | 3 | -26/+23 | |
2020-03-13 | shader/transform_feedback: Expose buffer stride | ReinUsesLisp | 3 | -1/+4 | |
2020-03-13 | vk_shader_decompiler: Use registry for specialization | ReinUsesLisp | 4 | -31/+37 | |
2020-03-13 | gl_rasterizer: Implement transform feedback bindings | ReinUsesLisp | 3 | -10/+83 | |
2020-03-13 | gl_shader_decompiler: Decorate output attributes with XFB layout | ReinUsesLisp | 1 | -29/+105 | |
We sometimes have to slice attributes in different parts. This is needed for example in instances where the game feedbacks 3 components but writes 4 from the shader (something that is possible with GL_NV_transform_feedback). | |||||
2020-03-13 | shader/transform_feedback: Add host API friendly TFB builder | ReinUsesLisp | 4 | -0/+140 | |
2020-03-13 | nit & remove some optional param | Nguyen Dac Nam | 1 | -10/+11 | |
2020-03-13 | shader_decode: implement XMAD mode CSfu | Nguyen Dac Nam | 1 | -9/+41 | |
2020-03-13 | fix formatting | makigumo | 1 | -1/+1 | |
2020-03-13 | maxwell_to_vk: add vertex format eA2B10G10R10UnormPack32 | makigumo | 1 | -1/+3 | |
2020-03-13 | clang-format | Nguyen Dac Nam | 1 | -4/+8 | |
2020-03-13 | Apply suggestions from code review | Nguyen Dac Nam | 1 | -5/+5 | |
Co-Authored-By: Mat M. <mathew1800@gmail.com> | |||||
2020-03-13 | shader_decode: BFE add ref of reverse parallel method. | Nguyen Dac Nam | 1 | -0/+3 | |
2020-03-13 | shader_decode: implement BREV on BFE | Nguyen Dac Nam | 1 | -6/+25 | |
Implement reverse parallel follow: https://graphics.stanford.edu/~seander/bithacks.html#ReverseParallel | |||||
2020-03-13 | shader_bytecode: update BFE instructions struct. | Nguyen Dac Nam | 1 | -8/+3 | |
2020-03-13 | node_helper: add IBitfieldExtract case | Nguyen Dac Nam | 1 | -0/+2 | |
2020-03-13 | shader_decode: Reimplement BFE instructions | Nguyen Dac Nam | 1 | -25/+27 | |
2020-03-13 | gl_shader_decompiler: Initialize gl_Position on vertex shaders | ReinUsesLisp | 1 | -0/+4 | |
2020-03-13 | gl_shader_decompiler: Add missing {} on smem GLSL emission | ReinUsesLisp | 1 | -1/+1 | |
2020-03-13 | video_core: Implement RGBA16_SNORM | ReinUsesLisp | 8 | -69/+84 | |
Implement RGBA16_SNORM with the current API. Nothing special here. | |||||
2020-03-12 | texture_cache: Report incompatible textures as black | ReinUsesLisp | 1 | -2/+39 | |
Some games bind incompatible texture types to certain types. For example Astral Chain binds a 2D texture with 1 layer (non-array) to a cubemap slot (that's how it's used in the shader). After testing this in hardware, the expected "undefined behavior" is to report all pixels as black. We already have a path for reporting black textures in the texture cache. When textures types are incompatible, this commit binds these kind of textures. This is done on the API agnostic texture cache so no extra code has to be inserted on OpenGL or Vulkan. As a side effect, this fixes invalidations of ASTC textures on Astral Chain. This happened because yuzu detected a cube texture and forced 6 faces, generating a texture larger than what the TIC reported. | |||||
2020-03-12 | texture_cache/surface_params: Force depth=1 on 2D textures | ReinUsesLisp | 1 | -2/+4 | |
Sometimes games will sample a 2D array TIC with a 2D access in the shader. This causes bad interactions with the rest of the texture cache. To emulate what the game wants to do, force a depth=1 on 2D textures (not 2D arrays) and let the texture cache handle the rest. | |||||
2020-03-12 | gl_shader_decompiler: Add layer component to texelFetch | ReinUsesLisp | 1 | -6/+9 | |
TexelFetch was not emitting the array component generating invalid GLSL. | |||||
2020-03-12 | NVFlinger: Do the microprofile Flip after processing a valid frame. | Fernando Sahmkow | 1 | -2/+2 | |
2020-03-12 | gl_shader_decompiler: Fix regression in render target declarations | ReinUsesLisp | 1 | -12/+2 | |
A previous commit introduced a way to declare as few render targets as possible. Turns out this introduced a regression in some games. | |||||
2020-03-11 | framebuffer_layout.h: drop the use of enum for screen dimensions. | Vitor Kiguchi | 2 | -10/+10 | |
+clang format | |||||
2020-03-11 | gl_shader_manager: Fix interaction between graphics and compute | ReinUsesLisp | 4 | -29/+39 | |
After a compute shader was set to the pipeline, no graphics shader was invoked again. To address this use glUseProgram to bind compute shaders (without state tracking) and call glUseProgram(0) when transitioning out of it back to the graphics pipeline. | |||||
2020-03-10 | gl_rasterizer: Implement polygon modes and fill rectangles | ReinUsesLisp | 7 | -2/+99 | |
2020-03-09 | engines/maxwell_3d: Add TFB registers and store them in shader registry | ReinUsesLisp | 4 | -6/+45 | |
2020-03-09 | shader/registry: Address feedback | ReinUsesLisp | 3 | -13/+18 | |
2020-03-09 | gl_shader_decompiler: Add identifier to decompiled code | ReinUsesLisp | 3 | -8/+16 | |
2020-03-09 | gl_shader_decompiler: Roll back to GLSL core 430 | ReinUsesLisp | 1 | -1/+1 | |
RenderDoc won't build shaders if we use GLSL compatibility. | |||||
2020-03-09 | const_buffer_engine_interface: Store component types | ReinUsesLisp | 4 | -46/+27 | |
This is required for Vulkan. Sampling integer textures with float handles is illegal. | |||||
2020-03-09 | yuzu/loading_screen: Remove unused shader progress mode | ReinUsesLisp | 2 | -17/+1 | |
2020-03-09 | gl_shader_cache: Reduce registry consistency to debug assert | ReinUsesLisp | 1 | -3/+1 | |
Registry consistency is something that practically can't happen and it has a measurable runtime cost. Reduce it to a DEBUG_ASSERT. | |||||
2020-03-09 | shader/registry: Cache tessellation state | ReinUsesLisp | 3 | -3/+10 | |
2020-03-09 | shader/registry: Store graphics and compute metadata | ReinUsesLisp | 8 | -75/+176 | |
Store information GLSL forces us to provide but it's dynamic state in hardware (workgroup sizes, primitive topology, shared memory size). | |||||
2020-03-09 | video_core: Rename "const buffer locker" to "registry" | ReinUsesLisp | 16 | -95/+100 | |
2020-03-09 | gl_shader_cache: Rework shader cache and remove post-specializations | ReinUsesLisp | 18 | -1094/+544 | |
Instead of pre-specializing shaders and then post-specializing them, drop the later and only "specialize" the shader while decoding it. | |||||
2020-03-08 | textures: Fix anisotropy hack | ReinUsesLisp | 1 | -14/+16 | |
Previous code could generate an anisotropy value way higher than x16. | |||||
2020-03-08 | cubeb_sink: Don't discard other channels when performing downmixing | FearlessTobi | 1 | -3/+17 | |
Previously, when performing downmixing, we would discard all channels except the left and right one. This implementation respects them when mixing down to Stereo. It is taken from this document: http://www.atsc.org/wp-content/uploads/2015/03/A52-201212-17.pdf. Fixes Luigis Mansion 3 cutscene and Bayonetta audio. | |||||
2020-03-08 | vk_reasterizer: fix mistype on SetupGraphicsImages | Nguyen Dac Nam | 1 | -1/+1 | |
This should use Maxwell3D engine. Fixed some GPU error on Kirby and maybe other games. | |||||
2020-03-06 | vk_rasterizer: Support disabled uniform buffers | ReinUsesLisp | 2 | -1/+9 | |
2020-03-06 | maxwell_to_vk: Remove Storage capability for A1B5G5R5U | ReinUsesLisp | 1 | -1/+1 | |
2020-03-04 | input/udp - Add minor error handling to prevent bad input from crashing | James Rowe | 1 | -4/+13 | |
2020-03-04 | Frontend/SDL - Provide proper default for UDP input | James Rowe | 1 | -1/+1 | |
When the default file is read in, the settings default value is only used when the key is missing. As it was, the key existed, but the value was empty string causing it to accept that as a value to pass into the core | |||||
2020-03-04 | input/udp - Dont log on invalid packet received | James Rowe | 1 | -1/+0 | |
2020-03-03 | core: hle: Implement separate A32/A64 SVC interfaces. | bunnei | 2 | -107/+380 | |
2020-03-03 | core: Implement separate A32/A64 ARM interfaces. | bunnei | 21 | -122/+454 | |
2020-03-03 | core: loader: Remove check for 32-bit. | bunnei | 1 | -6/+0 | |
2020-03-03 | core: dynarmic: Add CP15 from Citra. | bunnei | 3 | -0/+234 | |
2020-02-29 | nit: move comment to right place. | Nguyen Dac Nam | 1 | -2/+2 | |
2020-02-28 | video_core/dirty_flags: Address feedback | ReinUsesLisp | 1 | -4/+4 | |
2020-02-28 | renderer_opengl: Fix edge-case where alpha testing might cull presentation | ReinUsesLisp | 2 | -0/+7 | |
2020-02-28 | gl_texture_cache: Remove blending disable on blits | ReinUsesLisp | 1 | -5/+0 | |
Blending doesn't affect blits. Rasterizer discard does, update the commentaries. | |||||
2020-02-28 | gl_rasterizer: Don't disable blending on clears | ReinUsesLisp | 1 | -4/+0 | |
Blending doesn't affect clears. | |||||
2020-02-28 | dirty_flags: Deduplicate code between OpenGL and Vulkan | ReinUsesLisp | 5 | -77/+73 | |
2020-02-28 | vk_rasterizer: Pass Maxwell registers to dynamic updates | ReinUsesLisp | 2 | -26/+21 | |
2020-02-28 | state_tracker: Remove type traits with named structures | ReinUsesLisp | 4 | -18/+22 | |
2020-02-28 | vk_state_tracker: Implement dirty flags for stencil properties | ReinUsesLisp | 3 | -0/+21 | |
2020-02-28 | vk_state_tracker: Implement dirty flags for depth bounds | ReinUsesLisp | 3 | -0/+14 | |
2020-02-28 | vk_state_tracker: Implement dirty flags for blend constants | ReinUsesLisp | 3 | -0/+14 | |
2020-02-28 | vk_state_tracker: Implement dirty flags for depth bias | ReinUsesLisp | 3 | -0/+17 | |
2020-02-28 | vk_state_tracker: Implement dirty flags for scissors | ReinUsesLisp | 3 | -0/+14 | |
2020-02-28 | vk_state_tracker: Initial implementation | ReinUsesLisp | 10 | -52/+198 | |
Add support for render targets and viewports. | |||||
2020-02-28 | gl_rasterizer: Remove num vertex buffers magic number | ReinUsesLisp | 1 | -2/+4 | |
2020-02-28 | gl_rasterizer: Only apply polygon offset clamp if enabled | ReinUsesLisp | 1 | -3/+6 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for depth clamp enabling | ReinUsesLisp | 3 | -3/+15 | |
2020-02-28 | gl_rasterizer: Disable scissor 0 when scissor is not used on clear | ReinUsesLisp | 1 | -0/+3 | |
2020-02-28 | gl_rasterizer: Notify depth mask changes on clear | ReinUsesLisp | 2 | -1/+6 | |
2020-02-28 | gl_rasterizer: Minor sort changes to clearing | ReinUsesLisp | 1 | -11/+9 | |
2020-02-28 | maxwell_3d: Use two tables instead of three for dirty flags | ReinUsesLisp | 1 | -1/+1 | |
2020-02-28 | gl_state_tracker: Track state of index buffers | ReinUsesLisp | 4 | -5/+23 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for clip control | ReinUsesLisp | 5 | -15/+31 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for point sizes | ReinUsesLisp | 3 | -4/+25 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for fragment color clamp | ReinUsesLisp | 3 | -2/+14 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for logic op | ReinUsesLisp | 4 | -2/+22 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for sRGB | ReinUsesLisp | 5 | -2/+21 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for rasterize enable | ReinUsesLisp | 5 | -2/+21 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for multisample | ReinUsesLisp | 3 | -0/+13 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for alpha testing | ReinUsesLisp | 4 | -6/+24 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for polygon offsets | ReinUsesLisp | 4 | -2/+24 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for primitive restart | ReinUsesLisp | 3 | -5/+19 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for stencil testing | ReinUsesLisp | 4 | -3/+29 | |
2020-02-28 | gl_state_tracker: Implement depth dirty flags | ReinUsesLisp | 4 | -6/+31 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for front face and culling | ReinUsesLisp | 4 | -7/+38 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for blending | ReinUsesLisp | 5 | -14/+67 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for clip distances and shaders | ReinUsesLisp | 7 | -14/+43 | |
2020-02-28 | gl_state_tracker: Add dirty flags for buffers and divisors | ReinUsesLisp | 4 | -22/+56 | |
2020-02-28 | maxwell_3d: Change write dirty flags to a bitset | ReinUsesLisp | 3 | -16/+16 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for vertex formats | ReinUsesLisp | 4 | -9/+44 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for color masks | ReinUsesLisp | 4 | -9/+53 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for scissors | ReinUsesLisp | 5 | -10/+58 | |
2020-02-28 | gl_state_tracker: Implement dirty flags for viewports | ReinUsesLisp | 4 | -9/+54 | |
2020-02-28 | renderer_opengl: Reintroduce dirty flags for render targets | ReinUsesLisp | 9 | -13/+195 | |
2020-02-28 | maxwell_3d: Flatten cull and front face registers | ReinUsesLisp | 8 | -50/+47 | |
2020-02-28 | video_core: Reintroduce dirty flags infrastructure | ReinUsesLisp | 10 | -1/+72 | |
2020-02-28 | gl_state: Remove completely | ReinUsesLisp | 13 | -152/+4 | |
2020-02-28 | gl_state: Remove program tracking | ReinUsesLisp | 9 | -94/+62 | |
2020-02-28 | gl_state: Remove framebuffer tracking | ReinUsesLisp | 7 | -82/+23 | |
2020-02-28 | gl_state: Remove image tracking | ReinUsesLisp | 5 | -24/+12 | |
2020-02-28 | gl_state: Remove texture and sampler tracking | ReinUsesLisp | 5 | -60/+8 | |
2020-02-28 | gl_state: Remove blend state tracking | ReinUsesLisp | 5 | -104/+28 | |
2020-02-28 | gl_state: Remove stencil test tracking | ReinUsesLisp | 4 | -92/+18 | |
2020-02-28 | gl_state: Remove clip control tracking | ReinUsesLisp | 5 | -19/+8 | |
2020-02-28 | gl_state: Remove clip distances tracking | ReinUsesLisp | 4 | -29/+3 | |
2020-02-28 | gl_state: Remove rasterizer disable tracking | ReinUsesLisp | 6 | -13/+8 | |
2020-02-28 | gl_state: Remove viewport and depth range tracking | ReinUsesLisp | 7 | -101/+39 | |
2020-02-28 | gl_state: Remove scissor test tracking | ReinUsesLisp | 6 | -69/+12 | |
2020-02-28 | gl_state: Remove color mask tracking | ReinUsesLisp | 4 | -40/+12 | |
2020-02-28 | gl_state: Remove clamp framebuffer color tracking | ReinUsesLisp | 3 | -17/+6 | |
This commit doesn't reset it for screen draws because clamping doesn't change anything there. | |||||
2020-02-28 | gl_state: Remove multisample tracking | ReinUsesLisp | 3 | -16/+2 | |
2020-02-28 | gl_state: Remove framebuffer sRGB tracking | ReinUsesLisp | 6 | -21/+25 | |
2020-02-28 | gl_state: Remove VAO cache and tracking | ReinUsesLisp | 10 | -153/+53 | |
2020-02-28 | gl_state: Remove depth clamp tracking | ReinUsesLisp | 4 | -25/+13 | |
2020-02-28 | gl_state: Remove depth tracking | ReinUsesLisp | 4 | -34/+7 | |
2020-02-28 | gl_state: Remove primitive restart tracking | ReinUsesLisp | 3 | -18/+2 | |
2020-02-28 | gl_state: Remove logic op tracker | ReinUsesLisp | 4 | -24/+5 | |
2020-02-28 | gl_state: Remove blend color tracking | ReinUsesLisp | 3 | -18/+1 | |
2020-02-28 | gl_state: Remove polygon offset tracking | ReinUsesLisp | 4 | -39/+7 | |
2020-02-28 | gl_state: Remove alpha test tracking | ReinUsesLisp | 4 | -21/+4 | |
2020-02-28 | gl_state: Remove cull mode tracking | ReinUsesLisp | 4 | -19/+4 | |
2020-02-28 | gl_state: Remove front face tracking | ReinUsesLisp | 4 | -6/+5 | |
2020-02-28 | gl_state: Remove point size tracking | ReinUsesLisp | 3 | -22/+4 | |
2020-02-28 | gl_rasterizer: Add oglEnablei helper | ReinUsesLisp | 1 | -0/+4 | |
2020-02-28 | gl_rasterizer: Add OpenGL enable/disable helper | ReinUsesLisp | 1 | -0/+4 | |
2020-02-28 | gl_rasterizer: Remove dirty flags | ReinUsesLisp | 18 | -457/+7 | |
2020-02-28 | common/math_util: Support float type rectangles | ReinUsesLisp | 1 | -2/+14 | |
2020-02-28 | renderer_opengl: Fix SRGB presentation frame tracking. | bunnei | 2 | -5/+2 | |
- Fixes SRGB in Super Smash Bros. Ultimate. | |||||
2020-02-28 | shader_decode: Fix LD, LDG when track constant buffer | Nguyen Dac Nam | 1 | -4/+12 | |
2020-02-28 | shader_decode: keep it search on all code | Nguyen Dac Nam | 1 | -4/+12 | |
It fixed opcode LD, LDG on Pokemon Sword that can't find the constant buffer. Not sure if it helps any on visual. | |||||
2020-02-28 | Create an "Advanced" tab in the graphics configuration tab and add anisotropic filtering levels. | Morph | 16 | -35/+245 | |
2020-02-28 | renderer_opengl: Reduce swap chain size to 3. | bunnei | 1 | -3/+2 | |
2020-02-27 | AM/ICommonStateGetter: Stub SetLcdBacklighOffEnabled (#3454) | Morph | 2 | -2/+14 | |
* Stub SetLcdBacklighOffEnabled Used by Super Smash Bros. Ultimate We require backlight services to be implemented to turn on/off the backlight. * Address feedback | |||||
2020-02-27 | shader: FMUL switch to using LUT (#3441) | Nguyen Dac Nam | 1 | -19/+14 | |
* shader: add FmulPostFactor LUT table * shader: FMUL apply LUT * Update src/video_core/engines/shader_bytecode.h Co-Authored-By: Mat M. <mathew1800@gmail.com> * nit: mistype * clang-format & add missing import * shader: remove post factor LUT. * shader: move post factor LUT to function and fix incorrect order. * clang-format * shader: FMUL: add static to post factor LUT * nit: typo Co-authored-by: Mat M. <mathew1800@gmail.com> | |||||
2020-02-27 | renderer_opengl: Use more concise lock syntax. | bunnei | 1 | -4/+4 | |
2020-02-27 | renderer_opengl: Move Frame/FrameMailbox to OpenGL namespace. | bunnei | 3 | -77/+42 | |
2020-02-26 | vk_swapchain: Silence TOCTOU race condition | ReinUsesLisp | 1 | -9/+12 | |
It's possible that the window is resized from the moment we ask for its size to the moment a swapchain is created, causing validation issues. To workaround this Vulkan issue request the capabilities again just before creating the swapchain, making the race condition less likely. | |||||
2020-02-26 | ARM_Interface: Cache the JITs instead of deleting/recreating. | Fernando Sahmkow | 2 | -4/+19 | |
This was a bug inherited from citra which was fixed by then at some time. This commit corrects such bug and ensures JITs are correctly recycled. | |||||
2020-02-26 | renderer_opengl: Create gl_framebuffer_data if empty. | bunnei | 1 | -1/+2 | |
2020-02-26 | frontend: qt: bootmanager: Acquire a shared context in main emu thread. | bunnei | 2 | -12/+12 | |
2020-02-26 | frontend: qt: bootmanager: Vulkan: Restore support for VK backend. | bunnei | 5 | -113/+145 | |
2020-02-26 | frontend: qt: bootmanager: OpenGL: Implement separate presentation thread. | bunnei | 2 | -222/+254 | |
2020-02-26 | frontent: qt: main: Various updates/refactoring for separate presentation thread. | bunnei | 2 | -29/+27 | |
2020-02-26 | core: frontend: Refactor scope_acquire_window_context to scope_acquire_context. | bunnei | 7 | -29/+32 | |
2020-02-26 | frontend: sdl2: emu_window: Implement separate presentation thread. | bunnei | 10 | -62/+79 | |
2020-02-26 | renderer_opengl: Add texture mailbox support for presenter thread. | bunnei | 4 | -35/+269 | |
2020-02-26 | renderer_opengl: Add OGLRenderbuffer to resource/state management. | bunnei | 4 | -0/+62 | |
2020-02-26 | core: frontend: emu_window: Add TextureMailbox class. | bunnei | 1 | -0/+41 | |
2020-02-26 | core: settings: Add setting to enable vsync, which is on by default. | bunnei | 8 | -0/+25 | |
2020-02-25 | video_core/surface: Add R32_SINT render target format | ReinUsesLisp | 2 | -0/+3 | |
2020-02-25 | video_core/gpu: Remove unused functions | ReinUsesLisp | 2 | -71/+0 | |
2020-02-24 | yuzu: Remove exit lock for game pausing | FearlessTobi | 1 | -5/+0 | |
This removes the "exit lock" popup from yuzu when pausing a game. Motivation The exit lock feature is broken in many ways and doesn't work properly in a lot of games, causing it to appear every time you want to pause the game or stop it, even in places where it wouldn't on Switch. Additionally, the feature of pausing a game doesn't exist like this on Switch and yuzu should be guaranteed to be deterministic anyway, so pausing the emulation shouldn't be able to interrupt any critical processes in any way. | |||||
2020-02-24 | vk_shader_decompiler: Implement indexed textures | ReinUsesLisp | 6 | -54/+99 | |
Implement accessing textures through an index. It uses the same interface as OpenGL, the main difference is that Vulkan bindings are forced to be arrayed (the binding index doesn't change for stacked textures in SPIR-V). | |||||
2020-02-24 | shader: Simplify indexed sampler usages | ReinUsesLisp | 2 | -20/+8 | |
2020-02-24 | video_core: Implement more scaler attribute formats | ReinUsesLisp | 3 | -4/+40 | |
While changing this, fix assert in vk_shader_decompiler. We now know scaled formats are expected to be float in shaders attributes. | |||||
2020-02-23 | audio_core: interpolate: Improvements to fix audio crackling. | bunnei | 2 | -23/+38 | |
- Fixes audio crackling in Crash Team Racing Nitro-Fueled, Super Mario Odyssey, and others. - Addresses followup issues from #3310. | |||||
2020-02-22 | Scheduler: Inline global scheduler in Scheduler Lock. | Fernando Sahmkow | 1 | -4/+2 | |
2020-02-22 | Kernel: Correct pending feedback. | Fernando Sahmkow | 1 | -3/+4 | |
2020-02-22 | System: Expose Host thread registering routines from kernel. | Fernando Sahmkow | 2 | -0/+14 | |
2020-02-22 | Kernel: Address Feedback. | Fernando Sahmkow | 6 | -30/+47 | |
2020-02-22 | Kernel: Implement Scheduler locks | Fernando Sahmkow | 2 | -0/+89 | |
2020-02-22 | Kernel: Implement Time Manager. | Fernando Sahmkow | 5 | -1/+98 | |
2020-02-22 | Kernel: Rename ThreadCallbackHandleTable and Setup Thread Ids on Kernel. | Fernando Sahmkow | 5 | -24/+107 | |
2020-02-22 | Kernel: Make global scheduler depend on KernelCore | Fernando Sahmkow | 4 | -8/+24 | |
2020-02-22 | audio_core: interpolate: Fix include for climits (Linux build break). | bunnei | 1 | -1/+1 | |
2020-02-21 | shader/texture: Fix illegal 3D texture assert | ReinUsesLisp | 1 | -1/+1 | |
Fix typo in the illegal 3D texture assert logic. We care about catching arrayed 3D textures or 3D shadow textures, not regular 3D textures. | |||||
2020-02-21 | nit: add const to where it need. | Nguyen Dac Nam | 1 | -14/+14 | |
2020-02-21 | shader: implement LOP3 fast replace for old function | Nguyen Dac Nam | 1 | -36/+58 | |
ref: https://devtalk.nvidia.com/default/topic/1070081/cuda-programming-and-performance/reverse-lut-for-lop3-lut/ | |||||
2020-02-21 | vk_device: remove left over from other branch | Nguyen Dac Nam | 1 | -1/+0 | |
2020-02-20 | clang-format | Nguyen Dac Nam | 1 | -1/+1 | |
2020-02-20 | shader_decompiler: only add StorageImageReadWithoutFormat when available | Nguyen Dac Nam | 1 | -1/+4 | |
2020-02-20 | video_core: memory_manager: Flush/invalidate asynchronously on Unmap. | bunnei | 1 | -1/+10 | |
- Minor perf improvement. | |||||
2020-02-19 | shader_decompiler: add check in case of device not support ShaderStorageImageReadWithoutFormat | Nguyen Dac Nam | 1 | -0/+4 | |
2020-02-19 | vk_device: setup shaderStorageImageReadWithoutFormat | Nguyen Dac Nam | 1 | -0/+5 | |
2020-02-19 | vk_device: add check for shaderStorageImageReadWithoutFormat | Nguyen Dac Nam | 1 | -0/+7 | |
2020-02-19 | shader_conversion: I2F : add Assert for case src_size is Short | Nguyen Dac Nam | 1 | -0/+3 | |
2020-02-19 | fix warning | Nguyen Dac Nam | 1 | -1/+1 | |
2020-02-19 | clang-format fix | Nguyen Dac Nam | 1 | -1/+1 | |
2020-02-19 | shader_conversion: add conversion I2F for Short | Nguyen Dac Nam | 1 | -9/+6 | |
2020-02-19 | vk_shader: add Capability StorageImageReadWithoutFormat | Nguyen Dac Nam | 1 | -0/+1 | |
2020-02-19 | httplib compatibility | Brian Clinkenbeard | 2 | -7/+7 | |
2020-02-19 | vk_shader: Implement function ImageLoad (Used by Kirby Start Allies) | Nguyen Dac Nam | 1 | -2/+6 | |
Please enter the commit message for your changes. Lines starting | |||||
2020-02-18 | fixups mistake auto commit. | Nguyen Dac Nam | 1 | -9/+0 | |
2020-02-18 | Update code structure | Nguyen Dac Nam | 1 | -0/+7 | |
Co-Authored-By: Mat M. <mathew1800@gmail.com> | |||||
2020-02-18 | add vertex UnsignedInt size RGBA | Nguyen Dac Nam | 1 | -0/+2 | |
2020-02-18 | add eBc2SrgbBlock to formats | Nguyen Dac Nam | 1 | -0/+1 | |
2020-02-18 | vulkan: add DXT23_SRGB | Nguyen Dac Nam | 1 | -1/+1 | |
2020-02-18 | renderer_vulkan: Add the rest of case for TryConvertBorderColor | Nguyen Dac Nam | 1 | -3/+10 | |
2020-02-18 | analog_from_button get direction implementation | CJBok | 2 | -5/+19 | |
2020-02-16 | texture_cache: Implement layered framebuffer attachments | ReinUsesLisp | 8 | -51/+74 | |
Layered framebuffer attachments is a feature that allows applications to write attach layered textures to a single attachment. What layer the fragments are written to is decided from the shader using gl_Layer. | |||||
2020-02-16 | vk_shader_decompiler: Implement Layer output attribute | ReinUsesLisp | 1 | -6/+30 | |
SPIR-V's Layer is GLSL's gl_Layer. It lets the application choose from a shader stage (vertex, tessellation or geometry) which framebuffer layer write the output fragments to. | |||||
2020-02-16 | texture_cache: Avoid matches in 3D textures | ReinUsesLisp | 1 | -8/+11 | |
Code before this commit was trying to match 3D textures with another target. Fix that. | |||||
2020-02-16 | surface_base: Implement texture buffer flushes | ReinUsesLisp | 2 | -0/+11 | |
Implement downloads to guest memory from texture buffers on the generic cache and OpenGL. | |||||
2020-02-16 | IUserLocalCommunicationService: add function Initialize2 | Nguyen Dac Nam | 1 | -1/+9 | |
2020-02-16 | HLE: correct function name of IUserLocalCommunicationService | Nguyen Dac Nam | 1 | -1/+1 | |
402: function name should be Initialize2 (7.0.0+) not SetOperationMode Follow by: https://switchbrew.org/wiki/LDN_services#IUserLocalCommunicationService | |||||
2020-02-16 | nvhost_gpu: implement ChannelSetTimeslice | namkazy | 2 | -0/+20 | |
2020-02-15 | Revert "video_core: memory_manager: Use GPU interface for cache functions." | bunnei | 3 | -9/+14 | |
2020-02-15 | texture: Implement R32I | ReinUsesLisp | 6 | -34/+46 | |
2020-02-15 | shader/texture: Allow 2D shadow arrays and simplify code | ReinUsesLisp | 1 | -43/+28 | |
Shadow sampler 2D arrays are supported on OpenGL, so there's no reason to forbid these. Enable textureLod usage on these. Minor style changes. | |||||
2020-02-14 | maxwell_3d: Unify draw methods | ReinUsesLisp | 6 | -36/+6 | |
Pass instanced state of a draw invocation as an argument instead of having two separate virtual methods. | |||||
2020-02-14 | query_cache: Address feedback | ReinUsesLisp | 2 | -16/+18 | |
2020-02-14 | query_cache: Fix ambiguity in CacheAddr getter | ReinUsesLisp | 1 | -4/+5 | |
2020-02-14 | query_cache: Add a recursive mutex for concurrent usage | ReinUsesLisp | 1 | -0/+6 | |
2020-02-14 | vk_query_cache: Implement generic query cache on Vulkan | ReinUsesLisp | 11 | -20/+327 | |
2020-02-14 | query_cache: Abstract OpenGL implementation | ReinUsesLisp | 4 | -339/+394 | |
Abstract the current OpenGL implementation into the VideoCommon namespace and reimplement it on top of that. Doing this avoids repeating code and logic in the Vulkan implementation. | |||||
2020-02-14 | gl_query_cache: Optimize query cache | ReinUsesLisp | 6 | -79/+217 | |
Use a custom cache instead of relying on a ranged cache. | |||||
2020-02-14 | gl_query_cache: Implement host queries using a deferred cache | ReinUsesLisp | 7 | -86/+328 | |
Instead of waiting immediately for executed commands, defer the query until the guest CPU reads it. This way we get closer to what the guest program is doing. To archive this we have to build a dependency queue, because host APIs (like OpenGL and Vulkan) use ranged queries instead of counters like NVN. Waiting for queries implicitly uses fences and this requires a command being queued, otherwise the driver will lock waiting until a timeout. To fix this when there are no commands queued, we explicitly call glFlush. | |||||
2020-02-14 | gl_rasterizer: Sort method declarations | ReinUsesLisp | 1 | -16/+15 | |
2020-02-14 | gl_rasterizer: Add queued commands counter | ReinUsesLisp | 2 | -0/+16 | |
Keep track of the queued OpenGL commands that can signal a fence if waited on. As a side effect, we avoid calls to glFlush when no commands are queued. | |||||
2020-02-14 | maxwell_3d: Slow implementation of passed samples (query 21) | ReinUsesLisp | 8 | -17/+201 | |
Implements GL_SAMPLES_PASSED by waiting immediately for queries. | |||||
2020-02-14 | Add 4:3 aspect ratio and address feedback | Morph | 5 | -12/+20 | |
2020-02-14 | Core: Correct compilition in GCC | Fernando Sahmkow | 1 | -0/+2 | |
2020-02-14 | Address feedback | Morph | 2 | -18/+26 | |
2020-02-14 | Use enumeration instead of magic numbers | Morph | 2 | -5/+11 | |
2020-02-14 | Add following aspect ratios: 16:9, 21:9, Stretch to Window | Morph | 9 | -2/+62 | |
Available as a drop down within the configure graphics tab. | |||||
2020-02-14 | gl_resource_manager: Add managed query class | ReinUsesLisp | 2 | -0/+42 | |
2020-02-14 | gl_rasterizer: Use the least generic OpenGL draw function possible | ReinUsesLisp | 1 | -8/+28 | |
This may help some implementations. | |||||
2020-02-14 | vk_shader_decompiler: Fix vertex id and instance id | ReinUsesLisp | 1 | -4/+13 | |
Vulkan's VertexIndex and InstanceIndex don't match with hardware. This is because Nvidia implements gl_VertexID and gl_InstanceID. The math that relates these is: gl_VertexIndex = gl_BaseVertex + gl_VertexID gl_InstanceIndex = gl_InstanceIndex + gl_InstanceID To emulate it using what Vulkan's SPIR-V offers (the *Index variants) this commit substracts gl_Base* from gl_*Index to obtain the OpenGL and hardware's equivalent. | |||||
2020-02-14 | Core: Address Feedback | Fernando Sahmkow | 6 | -24/+50 | |
2020-02-13 | GPU: Address Feedback. | Fernando Sahmkow | 2 | -11/+10 | |
2020-02-12 | address_arbiter: Collapse loops in InsertThread() and RemoveThread() | Lioncash | 1 | -19/+17 | |
Same behavior, but without the need to explicitly loop through everything manually. | |||||
2020-02-12 | address_arbiter: Simplify GetThreadsWaitingOnAddress() | Lioncash | 2 | -10/+9 | |
Simplifies the overall function and also allows for it to become a const-qualified member function. | |||||
2020-02-12 | bcat/backend: Make formatting of passphrase consistent in NullBackend::SetPassphrase() | Lioncash | 1 | -1/+1 | |
Aligns the '=' to be consistent with the rest of the logs within this source file. | |||||
2020-02-12 | bcat/backend: Prevent fmt exception in debug log within NullBackend::Clear() | Lioncash | 1 | -1/+1 | |
A formatting specifier within Clear wasn't being used, which will cause fmt to throw an exception. This fixes that. | |||||
2020-02-12 | kernel/thread: Remove trivial usages of the global system accessor | Lioncash | 1 | -2/+2 | |
We can just use the kernel member variable directly instead of going through the system to obtain the same thing. | |||||
2020-02-12 | Core: Set all hardware emulation constants in a single file. | Fernando Sahmkow | 17 | -53/+88 | |
2020-02-11 | Kernel: Refactor synchronization to better match RE | Fernando Sahmkow | 23 | -80/+212 | |
2020-02-11 | update hwopus DecodeInterleaved for FW 7.0.0+ | makigumo | 1 | -2/+4 | |
trivial change, see https://switchbrew.org/wiki/Audio_services#IHardwareOpusDecoder | |||||
2020-02-11 | Kernel: Change WaitObject to Synchronization object. In order to better reflect RE. | Fernando Sahmkow | 22 | -98/+110 | |
2020-02-10 | GPU: Implement GPU Clock correctly. | Fernando Sahmkow | 3 | -2/+17 | |
2020-02-10 | Maxwell3D: Correct query reporting. | Fernando Sahmkow | 2 | -51/+58 | |
2020-02-09 | Remove option "Show files with type 'Unknown'" | Morph | 5 | -15/+1 | |
2020-02-08 | hle: services: Use std::shared_ptr instead of copy by value. | bunnei | 9 | -50/+52 | |
2020-02-08 | gpu_thread: Use MPSCQueue for GPU commands. | bunnei | 1 | -1/+1 | |
- Necessary for multiple service threads. | |||||
2020-02-08 | video_core: memory_manager: Use GPU interface for cache functions. | bunnei | 3 | -14/+9 | |
2020-02-06 | kernel: transfer_memory: Properly reserve and reset memory region. | bunnei | 5 | -40/+116 | |
2020-02-06 | wait_object: Make wait behavior only require one object to signal. | Zach Hilman | 1 | -11/+2 | |
- This was holdover from citra. | |||||
2020-02-06 | am: Correct IPC object count mismatch. | bunnei | 1 | -6/+4 | |
2020-02-06 | services: am: Clear events on PopOutData and PopInteractiveOutData. | bunnei | 1 | -0/+2 | |
2020-02-06 | am: Refactor IStorage interface. | bunnei | 7 | -43/+81 | |
2020-02-06 | applets: software_keyboard: Signal state change on end of interactive session. | bunnei | 1 | -0/+1 | |
2020-02-06 | applets: software_keyboard: Minor cleanup. | bunnei | 1 | -2/+2 | |
2020-02-06 | services: prepo: Fix IPC interface with SaveReport/SaveReportWithUser. | bunnei | 1 | -15/+15 | |
2020-02-06 | hle_ipc: Add error checking to read/write buffer access. | bunnei | 1 | -8/+42 | |
2020-02-05 | shader/decode: Fix constant buffer offsets | ReinUsesLisp | 3 | -5/+5 | |
Some instances were using cbuf34.offset instead of cbuf34.GetOffset(). This returned the an invalid offset. Address those instances and rename offset to "shifted_offset" to avoid future bugs. | |||||
2020-02-05 | maxwell_to_gl: Implement R8G8_USCALED | ReinUsesLisp | 1 | -0/+8 | |
2020-02-05 | maxwell_to_gl: Reduce unimplemented formats to LOG_ERROR | ReinUsesLisp | 1 | -8/+4 | |
2020-02-04 | vk_rasterizer: Use noexcept variants of std::bitset | ReinUsesLisp | 1 | -4/+5 | |
Removes bounds checking from "texceptions" instances. | |||||
2020-02-04 | gl_rasterizer: Implement GL_POINT_SPRITE | ReinUsesLisp | 4 | -1/+9 | |
OpenGL core defaults to GL_POINT_SPRITE, meanwhile on OpenGL compatibility we have to explicitly enable it. This fixes gl_PointCoord's behaviour. | |||||
2020-02-03 | input_common/udp: Ensure that UDP is shut down within Shutdown() | Lioncash | 1 | -0/+1 | |
Previously the UDP backend would never actually get shut down. | |||||
2020-02-03 | input_common/udp: Add missing override specifiers | Lioncash | 1 | -2/+2 | |
Prevents trivial warnings and ensures interfaces are properly maintained between the base class. | |||||
2020-02-03 | input_common/udp: std::move SocketCallback instances where applicable | Lioncash | 1 | -2/+2 | |
std::function is allowed to heap allocate if the size of the captures associated with each lambda exceed a certain threshold. This prevents potentially unnecessary reallocations from occurring. | |||||
2020-02-03 | input_common/udp: std::move shared_ptr within Client constructor | Lioncash | 1 | -1/+1 | |
Gets rid of a trivially avoidable atomic reference count increment and decrement. | |||||
2020-02-03 | udp/client: Replace deprecated from_string() call with make_address_v4() | Lioncash | 1 | -2/+2 | |
Future-proofs code if boost is ever updated. | |||||
2020-02-03 | input_common/udp: Silence -Wreorder warning for Socket | Lioncash | 1 | -4/+3 | |
Amends the constructor initializer list to specify the order of its elements in the same order that initialization would occur. | |||||
2020-02-03 | input_common/udp: Remove unnecessary inclusions | Lioncash | 4 | -8/+4 | |
2020-02-03 | input_common/udp: Add missing header guard | Lioncash | 1 | -0/+2 | |
2020-02-02 | maxwell_3d: Fix stencil back mask | ReinUsesLisp | 1 | -3/+3 | |
2020-02-02 | shader: Remove curly braces initializers on shared pointers | ReinUsesLisp | 5 | -12/+12 | |
2020-02-02 | shader/shift: Implement SHIFT_RIGHT_{IMM,R} | ReinUsesLisp | 1 | -26/+58 | |
Shifts a pair of registers to the right and returns the low register. | |||||
2020-02-02 | shader/shift: Implement SHF_LEFT_{IMM,R} | ReinUsesLisp | 2 | -10/+89 | |
Shifts a pair of registers to the left and returns the high register. | |||||
2020-01-31 | Revert "system_archive: Fix Korean and Chinese fonts" | bunnei | 5 | -880167/+27164 | |
2020-01-31 | core/arm: Remove usage of global GetCurrentThread() | Lioncash | 2 | -2/+4 | |
Now both CPU backends go through their referenced system instance to obtain the current thread. | |||||
2020-01-31 | kernel/physical_core: Make use of std::unique_ptr | Lioncash | 2 | -4/+10 | |
shared_ptr was used in 2d1984c20c75e03ec79eeb3806b12efa1679b977 due to a misunderstanding of how the language generates move constructors and move assignment operators. If a destructor is user-provided, then the compiler won't generate the move constructor and move assignment operators by default--they must be explicitly opted into. The reason for the compilation errors is due to the fact that the language will fall back to attempting to use the copy constructor/copy assignment operators if the respective move constructor or move assignment operator is unavailable. Given that we explicitly opt into them now, the the move constructor and move assignment operators will be generated as expected. | |||||
2020-01-31 | core/cpu_manager: Remove unused includes | Lioncash | 1 | -2/+0 | |
Nothing from these headers are used within this source file, so we can remove them. | |||||
2020-01-31 | kernel/physical_core: Remove unused kernel reference member variable | Lioncash | 3 | -11/+7 | |
This isn't used within the class, so it can be removed to simplify the overall interface. While we're in the same area, we can simplify a unique_ptr reset() call. | |||||
2020-01-30 | gl_rasterizer: Fix instanced draw arrays | ReinUsesLisp | 2 | -106/+28 | |
glDrawArrays was being used when the draw had a base instance specified. This commit removes the draw parameters abstraction and fixes the mentioned issue. | |||||
2020-01-29 | yuzu/bootmanager: Define Vulkan widget only when enabled | ReinUsesLisp | 1 | -0/+2 | |
2020-01-29 | yuzu_cmd: Fix memcpy on Vulkan handlers | ReinUsesLisp | 2 | -9/+10 | |
2020-01-29 | yuzu: Implement Vulkan frontend | ReinUsesLisp | 24 | -171/+1089 | |
Adds a Qt and SDL2 frontend for Vulkan. It also finishes the missing bits on Vulkan initialization. | |||||
2020-01-29 | web_service/telemetry_json: Report USER_CONFIG | ReinUsesLisp | 1 | -0/+1 | |
2020-01-29 | settings: Add settings for graphics backend | ReinUsesLisp | 6 | -3/+48 | |
2020-01-29 | core: Only wait for idle on gpu_core when it was initialized | ReinUsesLisp | 1 | -1/+3 | |
This fixes crashes when a Vulkan device fails to initialize. | |||||
2020-01-29 | shader/other: Fix skips for SYNC and BRK | ReinUsesLisp | 1 | -2/+2 | |
2020-01-29 | shader/other: Stub S2R LaneId | ReinUsesLisp | 1 | -1/+4 | |
2020-01-29 | buffer_cache: Delay buffer destructions | ReinUsesLisp | 1 | -1/+4 | |
Delay buffer destruction some extra frames to avoid destroying buffers that are still being used from older frames. This happens on Nvidia's driver with mailbox. | |||||
2020-01-29 | clang | CJBok | 1 | -2/+2 | |
2020-01-29 | minor corrections | CJBok | 1 | -2/+2 | |
2020-01-28 | GUI: Togglable graphics settings buttons in status bar | CJBok | 2 | -7/+95 | |
2020-01-28 | gl_shader_decompiler: Remove UNIMPLEMENTED for gl_PointSize | ReinUsesLisp | 1 | -1/+0 | |
This was implemented by a previous commit and it's no longer required. | |||||
2020-01-28 | gl_texture_cache: Silence implicit sign cast warnings | ReinUsesLisp | 1 | -3/+6 | |
2020-01-27 | System: Address Feedback | Fernando Sahmkow | 11 | -24/+30 | |
2020-01-27 | shader/bfi: Implement register-constant buffer variant | ReinUsesLisp | 2 | -2/+7 | |
It's the same as the variant that was implemented, but it takes the operands from another source. | |||||
2020-01-27 | shader/arithmetic: Implement FCMP | ReinUsesLisp | 2 | -1/+17 | |
Compares the third operand with zero, then selects between the first and second. | |||||
2020-01-27 | texture_cache/surface_base: Fix layered break down | ReinUsesLisp | 1 | -1/+1 | |
Layered break downs was passing "layer" as a "depth" parameter. This commit addresses that. | |||||
2020-01-27 | gl_texture_cache: Properly implement depth/stencil sampling | ReinUsesLisp | 1 | -4/+27 | |
This addresses the long standing issue of compatibility vs. core profiles on OpenGL, properly implementing depth vs. stencil sampling depending on the texture swizzle. | |||||
2020-01-26 | System: Correct PrepareReschedule. | Fernando Sahmkow | 1 | -1/+1 | |
2020-01-26 | Kernel: Remove a few global instances from the kernel. | Fernando Sahmkow | 2 | -2/+2 | |
2020-01-26 | Core: Refactor CpuCoreManager to CpuManager and Cpu to Core Manager. | Fernando Sahmkow | 15 | -128/+115 | |
This commit instends on better naming the new purpose of this classes. | |||||
2020-01-26 | ArmInterface: Delegate Exclusive monitor factory to exclusive monitor interfasce. | Fernando Sahmkow | 3 | -16/+24 | |
2020-01-26 | shader/memory: Implement ATOM.ADD | ReinUsesLisp | 5 | -39/+86 | |
ATOM operates atomically on global memory. For now only add ATOM.ADD since that's what was found in commercial games. This asserts for ATOM.ADD.S32 (handling the others as unimplemented), although ATOM.ADD.U32 shouldn't be any different. This change forces us to change the default type on SPIR-V storage buffers from float to uint. We could also alias the buffers, but it's simpler for now to just use uint. While we are at it, abstract the code to avoid repetition. | |||||
2020-01-25 | Core: Refactor CPU Management. | Fernando Sahmkow | 10 | -224/+168 | |
This commit moves ARM Interface and Scheduler handling into the kernel. | |||||
2020-01-25 | Shader_IR: Address feedback. | Fernando Sahmkow | 10 | -36/+40 | |
2020-01-25 | shader/memory: Implement STL.S16 and STS.S16 | ReinUsesLisp | 1 | -3/+10 | |
2020-01-25 | shader/memory: Implement unaligned LDL.S16 and LDS.S16 | ReinUsesLisp | 1 | -5/+3 | |
2020-01-25 | shader/memory: Move unaligned load/store to functions | ReinUsesLisp | 1 | -18/+27 | |
2020-01-25 | shader/memory: Implement LDL.S16 and LDS.S16 | ReinUsesLisp | 1 | -12/+23 | |
2020-01-25 | bsd: Stub several more functions. | bunnei | 2 | -4/+48 | |
- Required for Little Town Hero to boot further. | |||||
2020-01-24 | Disable clang-format for font files | FearlessTobi | 3 | -0/+6 | |
2020-01-24 | Shader_IR: Change name of TrackSampler function so it does not confuse with the type. | Fernando Sahmkow | 3 | -7/+10 | |
2020-01-24 | Shader_IR: Corrections, styling and extras. | Fernando Sahmkow | 1 | -2/+4 | |
2020-01-24 | Shader_IR: Correct Custom Variable assignment. | Fernando Sahmkow | 2 | -0/+4 | |
2020-01-24 | Shader_IR: Propagate bindless index into the GL compiler. | Fernando Sahmkow | 5 | -24/+54 | |
2020-01-24 | Shader_IR: Implement Injectable Custom Variables to the IR. | Fernando Sahmkow | 5 | -1/+70 | |
2020-01-24 | GL Backend: Introduce indexed samplers into the GL backend | Fernando Sahmkow | 2 | -10/+39 | |
2020-01-24 | Shader_IR: deduce size of indexed samplers | Fernando Sahmkow | 4 | -8/+60 | |
2020-01-24 | Shader_IR: Setup Indexed Samplers on the IR | Fernando Sahmkow | 1 | -20/+46 | |
2020-01-24 | Shader_IR: Implement initial code for tracking indexed samplers. | Fernando Sahmkow | 4 | -0/+139 | |
2020-01-24 | Shader_IR: Address Feedback | Fernando Sahmkow | 5 | -35/+37 | |
2020-01-24 | Shader_IR: Allow constant access of guest driver. | Fernando Sahmkow | 7 | -1/+18 | |
2020-01-24 | Shader_IR: Address Feedback | Fernando Sahmkow | 4 | -21/+29 | |
2020-01-24 | Guest_driver: Correct compiling errors in GCC. | Fernando Sahmkow | 2 | -1/+5 | |
2020-01-24 | Shader_IR: Store Bound buffer on Shader Usage | Fernando Sahmkow | 5 | -5/+41 | |
2020-01-24 | GPU: Implement guest driver profile and deduce texture handler sizes. | Fernando Sahmkow | 13 | -0/+127 | |
2020-01-24 | Kernel: Implement Physical Core. | Fernando Sahmkow | 2 | -0/+81 | |
2020-01-24 | vk_shader_decompiler: Disable default values on unwritten render targets | ReinUsesLisp | 3 | -19/+16 | |
Some games like The Legend of Zelda: Breath of the Wild assign render targets without writing them from the fragment shader. This generates Vulkan validation errors, so silence these I previously introduced a commit to set "vec4(0, 0, 0, 1)" for these attachments. The problem is that this is not what games expect. This commit reverts that change. | |||||
2020-01-24 | audio_core: Switch to a faster interpolation technique | FearlessTobi | 2 | -48/+159 | |
2020-01-24 | yuzu/configuration: create UI tab and move gamelist settings there | FearlessTobi | 8 | -104/+76 | |
2020-01-23 | common/logging: don't use regex for path trimming | BreadFish64 | 4 | -36/+23 | |
2020-01-23 | Replace GetString with Get function | FearlessTobi | 1 | -2/+2 | |
This should hopefully fix compilation errors. | |||||
2020-01-23 | Address second part of review comments | FearlessTobi | 4 | -14/+18 | |
2020-01-23 | Address review comments | FearlessTobi | 4 | -65/+72 | |
2020-01-23 | Input: UDP Client to provide motion and touch controls | fearlessTobi | 13 | -4/+897 | |
An implementation of the cemuhook motion/touch protocol, this adds the ability for users to connect several different devices to citra to send direct motion and touch data to citra. Co-Authored-By: jroweboy <jroweboy@gmail.com> | |||||
2020-01-23 | service: time: Implement ToPosixTimeWithMyRule. | bunnei | 4 | -1/+34 | |
- Used by Pokemon Mystery Dungeon. | |||||
2020-01-23 | loader: provide default arguments (zero byte) to NSOs | Michael Scire | 2 | -3/+10 | |
Certain newer unity games (Terraria, Pokemon Mystery Dungeon) require that the argument region be populated. Failure to do so results in an integer underflow in argument count, and eventually an unmapped read at 0x800000000. Providing this default fixes this. Note that the behavior of official software is as yet unverified, arguments-wise. | |||||
2020-01-22 | GUI: fix minor issues with dark themes | Bartosz Kaszubowski | 1 | -3/+3 | |
GUI: rename and reorder themes | |||||
2020-01-21 | gl_shader_cache: Disable fastmath on Nvidia | ReinUsesLisp | 1 | -0/+4 | |
2020-01-20 | vk_blit_screen: Address feedback | ReinUsesLisp | 4 | -22/+25 | |
2020-01-20 | time: Fix month off-by-one error. | bunnei | 1 | -2/+2 | |
- Fixes timestamp in ZLA and Astral Chain saves. | |||||
2020-01-20 | yuzu_qt: config: Move audio to its own tab. | bunnei | 1 | -3/+3 | |
- We have some important audio settings, makes them more discoverable. | |||||
2020-01-20 | vk_blit_screen: Initial implementation | ReinUsesLisp | 3 | -0/+745 | |
This abstraction takes care of presenting accelerated and non-accelerated or "framebuffer" images to the Vulkan swapchain. | |||||
2020-01-19 | GUI/gamelist: add "None" as an option for second row and remove dynamically duplicate row options (#3309) | Bartosz Kaszubowski | 3 | -14/+53 | |
* GUI/gamelist: add "None" as an option for second row and remove duplicated row options * fix clang-format warnings | |||||
2020-01-19 | vk_shader_decompiler: Implement UAtomicAdd (ATOMS) on SPIR-V | ReinUsesLisp | 1 | -3/+11 | |
Also updates sirit to include atomic instructions. | |||||
2020-01-19 | system_archive: Fix Chinese font | FearlessTobi | 2 | -13582/+694524 | |
Adds the proper OSS font for the Chinese language. | |||||
2020-01-19 | system_archive: Fix Korean font | FearlessTobi | 2 | -13582/+185637 | |
Fixes Korean fonts when using Open-source system archives. | |||||
2020-01-19 | CMake: Create thin archives on Linux | Léo Lam | 1 | -0/+9 | |
This significantly reduces unnecessary disk writes and space usage when building Citra. libcore.a is now only ~1MB rather than several hundred megabytes. | |||||
2020-01-18 | gl_state: Use bool instead of GLboolean | ReinUsesLisp | 2 | -3/+3 | |
This fixes template resolution considering GLboolean an integer instead of a bool. | |||||
2020-01-18 | vk_graphics_pipeline: Set front facing properly | ReinUsesLisp | 2 | -2/+2 | |
Front face was being forced to a certain value when cull face is disabled. Set a default value on initialization and drop the forcefully set front facing value with culling disabled. | |||||
2020-01-18 | core/memory: Create a special MapMemoryRegion for physical memory. | Markus Wick | 4 | -4/+31 | |
This allows us to create a fastmem arena within the memory.cpp helpers. | |||||
2020-01-18 | core/hle: Simplify PhysicalMemory usage in vm_manager. | Markus Wick | 1 | -23/+11 | |
2020-01-18 | core/loaders: Simplify PhysicalMemory usage. | Markus Wick | 3 | -8/+12 | |
It is currently a std::vector, however we might want to replace it with a more fancy allocator. So we can't use the C++ iterators any more. | |||||
2020-01-18 | Remove unused CPU Vendor string and telemtry field | James Rowe | 3 | -114/+0 | |
The information is duplicated in the brand string and the telemetry field is unused | |||||
2020-01-18 | vk_rasterizer: Address feedback | ReinUsesLisp | 2 | -25/+32 | |
2020-01-18 | gl_shader_decompiler: Fix decompilation of condition codes | ReinUsesLisp | 1 | -27/+5 | |
Use Visit instead of reimplementing it. Fixes unimplemented negations for condition codes. | |||||
2020-01-18 | Add headbar icon on Linux | TotalCaesar659 | 1 | -1/+1 | |
2020-01-17 | vk_rasterizer: Implement Vulkan's rasterizer | ReinUsesLisp | 3 | -1/+1386 | |
This abstraction is Vulkan's equivalent to OpenGL's rasterizer. It takes care of joining all parts of the backend and rendering accordingly on demand. | |||||
2020-01-17 | renderer_vulkan: Add header as placeholder | ReinUsesLisp | 2 | -0/+73 | |
2020-01-16 | vk_texture_cache: Address feedback | ReinUsesLisp | 2 | -22/+8 | |
2020-01-16 | shader/memory: Implement ATOMS.ADD.U32 | ReinUsesLisp | 5 | -3/+74 | |
2020-01-16 | format_lookup_table: Fix ZF32_X24S8 component types | ReinUsesLisp | 1 | -1/+1 | |
Component types for ZF32_X24S8 were using UNORM. Drivers will set FLOAT, UINT, UNORM, UNORM; causing a format mismatch. This commit addresses that. | |||||
2020-01-16 | vk_texture_cache: Fix typo in commentary | Rodrigo Locatti | 1 | -1/+1 | |
Co-Authored-By: MysticExile <30736337+MysticExile@users.noreply.github.com> | |||||
2020-01-16 | maxwell_3d: Make dirty_pointers private | Lioncash | 1 | -2/+2 | |
This isn't used outside of the class itself, so we can make it private for the time being. | |||||
2020-01-16 | Fix git version in scm_rev.cpp | James Rowe | 1 | -0/+5 | |
2020-01-15 | gl_state: Implement PROGRAM_POINT_SIZE | ReinUsesLisp | 4 | -2/+13 | |
For gl_PointSize to have effect we have to activate GL_PROGRAM_POINT_SIZE. | |||||
2020-01-15 | renderer_opengl/utils: Remove unused header inclusions | Lioncash | 1 | -3/+0 | |
Nothing from these headers are used, so they can be removed. | |||||
2020-01-15 | renderer_opengl/utils: Forward declare private structs | Lioncash | 2 | -12/+16 | |
Keeps the definitions hidden and allows changes to the structs without needing to recompile all users of classes containing said structs. | |||||
2020-01-15 | Moved analog direction logic to sdl_impl | CJBok | 3 | -9/+48 | |
2020-01-14 | Corrected directional states sensitivity | CJBok | 1 | -9/+9 | |
2020-01-14 | gl_texture_cache: Use local variables to simplify DownloadTexture | ReinUsesLisp | 1 | -6/+4 | |
2020-01-14 | gl_texture_cache: Fix format for RGBX16F | ReinUsesLisp | 1 | -1/+1 | |
2020-01-14 | gl_texture_cache: Use Snorm internal format for RG8S | ReinUsesLisp | 1 | -1/+1 | |
2020-01-14 | gl_texture_cache: Use Snorm internal format for ABGR8S | ReinUsesLisp | 1 | -1/+1 | |
2020-01-14 | control_flow: Silence -Wreorder warning for CFGRebuildState | Lioncash | 1 | -1/+1 | |
Organizes the initializer list in the same order that the variables would actually be initialized in. | |||||
2020-01-14 | gl_shader_cache: Remove unused STAGE_RESERVED_UBOS constant | Lioncash | 1 | -3/+0 | |
Given this isn't used, this can be removed entirely. | |||||
2020-01-14 | gl_shader_cache: std::move entries in CachedShader constructor | Lioncash | 1 | -3/+4 | |
Avoids several reallocations of std::vector instances where applicable. | |||||
2020-01-14 | gl_shader_cache: Remove unused entries variable in BuildShader() | Lioncash | 1 | -1/+0 | |
Eliminates a few unnecessary constructions of std::vectors. | |||||
2020-01-14 | vk_texture_cache: Implement generic texture cache on Vulkan | ReinUsesLisp | 4 | -1/+733 | |
It currently ignores PBO linearizations since these should be dropped as soon as possible on OpenGL. | |||||
2020-01-14 | texture_cache/surface_params: Make GetNumLayers public | ReinUsesLisp | 1 | -4/+5 | |
2020-01-13 | GUI: add few missing hotkeys to main menu | Bartosz Kaszubowski | 2 | -0/+17 | |
2020-01-12 | GUI/configure: resize hotkeys column to content | Bartosz Kaszubowski | 1 | -0/+1 | |
2020-01-11 | core/kernel: Fix GetTotalPhysicalMemoryUsed. | Markus Wick | 1 | -2/+2 | |
module._memory was already moved over to a new shared_ptr. So code_memory_size was not increased at all. This lowers the heap space and so saves a bit of memory, usually between 50 to 100 MB. This fixes a regression of c0a01f3adc466d07fc27020048e82cca60988970 | |||||
2020-01-11 | vk_compute_pass: Address feedback | Rodrigo Locatti | 1 | -0/+2 | |
Comment hardcoded SPIR-V modules. | |||||
2020-01-10 | maxwell_to_vk: Implement GL_CLAMP hacking Nvidia's driver | ReinUsesLisp | 3 | -6/+11 | |
Nvidia's driver defaults invalid enumerations to GL_CLAMP. Vulkan doesn't expose GL_CLAMP through its API, but we can hack it on Nvidia's driver using the internal driver defaults. | |||||
2020-01-09 | shader_ir/texture: Simplify AOFFI code | ReinUsesLisp | 1 | -10/+6 | |
2020-01-09 | shader_ir/memory: Implement u16 and u8 for STG and LDG | ReinUsesLisp | 2 | -34/+52 | |
Using the same technique we used for u8 on LDG, implement u16. In the case of STG, load memory and insert the value we want to set into it with bitfieldInsert. Then set that value. | |||||
2020-01-09 | hid: Fix analog sticks directional states | CJBok | 1 | -12/+12 | |
2020-01-08 | vk_compute_pass: Add compute passes to emulate missing Vulkan features | ReinUsesLisp | 3 | -0/+416 | |
This currently only supports quad arrays and u8 indices. In the future we can remove quad arrays with a table written from the CPU, but this was used to bootstrap the other passes helpers and it was left in the code. The blob code is generated from the "shaders/" directory. Read the instructions there to know how to generate the SPIR-V. | |||||
2020-01-08 | vk_shader_util: Add helper to build SPIR-V shaders | ReinUsesLisp | 3 | -0/+53 | |
2020-01-07 | vk_pipeline_cache: Initial implementation | ReinUsesLisp | 2 | -1/+460 | |
Given a pipeline key, this cache returns a pipeline abstraction (for graphics or compute). | |||||
2020-01-07 | vk_graphics_pipeline: Initial implementation | ReinUsesLisp | 4 | -0/+395 | |
This abstractio represents the state of the 3D engine at a given draw. Instead of changing individual bits of the pipeline how it's done in APIs like D3D11, OpenGL and NVN; on Vulkan we are forced to put everything together into a single, immutable object. It takes advantage of the few dynamic states Vulkan offers. | |||||
2020-01-07 | vk_compute_pipeline: Initial implementation | ReinUsesLisp | 4 | -0/+219 | |
This abstraction represents a Vulkan compute pipeline. | |||||
2020-01-07 | vk_pipeline_cache: Add file and define descriptor update template filler | ReinUsesLisp | 3 | -0/+67 | |
This function allows us to share code between compute and graphics pipelines compilation. | |||||
2020-01-07 | fixed_pipeline_state: Add depth clamp | ReinUsesLisp | 2 | -10/+18 | |
2020-01-07 | vk_rasterizer: Add placeholder | ReinUsesLisp | 2 | -0/+14 | |
2020-01-06 | vk_renderpass_cache: Initial implementation | ReinUsesLisp | 3 | -0/+199 | |
The renderpass cache is used to avoid creating renderpasses on each draw. The hashed structure is not currently optimized. | |||||
2020-01-06 | vk_update_descriptor: Initial implementation | ReinUsesLisp | 3 | -1/+146 | |
The update descriptor is used to store in flat memory a large chunk of staging data used to update descriptor sets through templates. It provides a push interface to easily insert descriptors following the current pipeline. The order used in the descriptor update template has to be implicitly followed. We can catch bugs here using validation layers. | |||||
2020-01-06 | vk_stream_buffer/vk_buffer_cache: Avoid halting and use generic cache | ReinUsesLisp | 4 | -62/+340 | |
The stream buffer before this commit once it was full (no more bytes to write before looping) waiting for all previous operations to finish. This was a temporary solution and had a noticeable performance penalty in performance (from what a profiler showed). To avoid this mark with fences usages of the stream buffer and once it loops wait for them to be signaled. On average this will never wait. Each fence knows where its usage finishes, resulting in a non-paged stream buffer. On the other side, the buffer cache is reimplemented using the generic buffer cache. It makes use of the staging buffer pool and the new stream buffer. | |||||
2020-01-06 | vk_memory_manager: Misc changes | ReinUsesLisp | 2 | -88/+142 | |
* Allocate memory in discrete exponentially increasing chunks until the 128 MiB threshold. Allocations larger thant that increase linearly by 256 MiB (depending on the required size). This allows to use small allocations for small resources. * Move memory maps to a RAII abstraction. To optimize for debugging tools (like RenderDoc) users will map/unmap on usage. If this ever becomes a noticeable overhead (from my profiling it doesn't) we can transparently move to persistent memory maps without harming the API, getting optimal performance for both gameplay and debugging. * Improve messages on exceptional situations. * Fix typos "requeriments" -> "requirements". * Small style changes. | |||||
2020-01-06 | vk_buffer_cache: Temporarily remove buffer cache | ReinUsesLisp | 2 | -226/+0 | |
This is intended for a follow up commit to avoid circular dependencies. | |||||
2020-01-06 | yuzu/bootmanager: Remove {glx,wgl}MakeCurrent on SwapBuffers | ReinUsesLisp | 1 | -9/+2 | |
MakeCurrent is a costly (according to Nsight's profiler it takes a tenth of a millisecond to complete), and we don't have a reason to call it because: - Qt no longer signals a warning if it's not called - yuzu no longer supports macOS | |||||
2020-01-05 | service: time: Implement GetStandardLocalSystemClock. | bunnei | 3 | -1/+9 | |
2020-01-04 | time: Remove overflow error checking (currently breaks ADO builds). | bunnei | 2 | -18/+2 | |
2020-01-04 | service: time: Implement GetClockSnapshotFromSystemClockContext. | bunnei | 3 | -3/+27 | |
2020-01-04 | service: time: Implement IsStandardNetworkSystemClockAccuracySufficient. | bunnei | 5 | -1/+51 | |
2020-01-04 | system_archive: Add a basic HLE implementation for time zone binary. | bunnei | 4 | -1/+675 | |
2020-01-04 | service: time: Rewrite implementation of glue services. | bunnei | 35 | -444/+2834 | |
2020-01-04 | Shader_IR: Address Feedback | Fernando Sahmkow | 5 | -38/+19 | |
2020-01-04 | core: Initialize several structs that make use of Common::UUID. | bunnei | 5 | -100/+101 | |
2020-01-04 | Shader_IR: Implement TXD Array. | Fernando Sahmkow | 1 | -5/+12 | |
This commit extends the compilation of TXD to support array samplers on TXD. | |||||
2020-01-04 | service: vi: Implement CloseLayer. | bunnei | 5 | -11/+48 | |
- Needed for Undertale. | |||||
2020-01-03 | Update src/video_core/renderer_vulkan/vk_descriptor_pool.cpp | Rodrigo Locatti | 1 | -1/+1 | |
Co-Authored-By: Mat M. <mathew1800@gmail.com> | |||||
2020-01-03 | const correction | CJBok | 1 | -1/+1 | |
2020-01-03 | clang | CJBok | 1 | -22/+22 | |
2020-01-03 | Update configure_input_player.cpp | CJBok | 1 | -23/+23 | |
2020-01-03 | Added deadzone controls for sdl engine at input settings | CJBok | 3 | -24/+129 | |
2020-01-03 | yuzu: Remove Maxwell debugger | ReinUsesLisp | 14 | -640/+0 | |
This was carried from Citra and wasn't really used on yuzu. It also adds some runtime overhead. This commit removes it from yuzu's codebase. | |||||
2020-01-01 | vk_descriptor_pool: Initial implementation | ReinUsesLisp | 3 | -0/+147 | |
Create a large descriptor pool where we allocate all our descriptors from. It has to be wide enough to support any pipeline, hence its large numbers. If the descritor pool is filled, we allocate more memory at that moment. This way we can take advantage of permissive drivers like Nvidia's that allocate more descriptors than what the spec requires. | |||||
2020-01-01 | core/memory + arm/dynarmic: Use a global offset within our arm page table. | Markus Wick | 2 | -9/+17 | |
This saves us two x64 instructions per load/store instruction. TODO: Clean up our memory code. We can use this optimization here as well. | |||||
2019-12-30 | Shader_IR: add the ability to amend code in the shader ir. | Fernando Sahmkow | 5 | -3/+72 | |
This commit introduces a mechanism by which shader IR code can be amended and extended. This useful for track algorithms where certain information can derived from before the track such as indexes to array samplers. | |||||
2019-12-30 | vk_image: Avoid unnecesary equals | Rodrigo Locatti | 1 | -1/+1 | |
2019-12-30 | video_core: Block in WaitFence. | Markus Wick | 3 | -5/+9 | |
This function is called rarely and blocks quite often for a long time. So don't waste power and let the CPU sleep. This might also increase the performance as the other cores might be allowed to clock higher. | |||||
2019-12-29 | vk_staging_buffer_pool: Initialize last epoch to zero | Rodrigo Locatti | 1 | -1/+1 | |
2019-12-26 | gl_rasterizer: Allow rendering without fragment shader | ReinUsesLisp | 2 | -0/+7 | |
Rendering without a fragment shader is usually used in depth-only passes. | |||||
2019-12-25 | vk_staging_buffer_pool: Add a staging pool for temporary operations | ReinUsesLisp | 3 | -0/+212 | |
The job of this abstraction is to provide staging buffers for temporary operations. Think of image uploads or buffer uploads to device memory. It automatically deletes unused buffers. | |||||
2019-12-25 | vk_image: Add an image object abstraction | ReinUsesLisp | 3 | -0/+192 | |
This object's job is to contain an image and manage its transitions. Since Nvidia hardware doesn't know what a transition is but Vulkan requires them anyway, we have to state track image subresources individually. To avoid the overhead of tracking each subresource in images with many subresources (think of cubemap arrays with several mipmaps), this commit tracks when subresources have diverged. As long as this doesn't happen we can check the state of the first subresource (that will be shared with all subresources) and update accordingly. Image transitions are deferred to the scheduler command buffer. | |||||
2019-12-25 | NvServices: Correct Ioctl Remap. | Fernando Sahmkow | 2 | -3/+5 | |
This commit corrects a padding value in Ioctl Remap that was actually an offset to the mapping address. | |||||
2019-12-24 | fixed_pipeline_state: Define symetric operator!= and mark as noexcept | ReinUsesLisp | 2 | -40/+92 | |
Marks as noexcept Hash, operator== and operator!= for consistency. | |||||
2019-12-23 | fixed_pipeline_state: Define structure and loaders | ReinUsesLisp | 3 | -0/+528 | |
The intention behind this hasheable structure is to describe the state of fixed function pipeline state that gets compiled to a single graphics pipeline state object. This is all dynamic state in OpenGL but Vulkan wants it in an immutable state, even if hardware can edit it freely. In this commit the structure is defined in an optimized state (it uses booleans, has paddings and many data entries that can be packed to single integers). This is intentional as an initial implementation that is easier to debug, implement and review. It will be optimized in later stages, or it might change if Vulkan gets more dynamic states. | |||||
2019-12-23 | maxwell_3d: Add depth bounds registers | ReinUsesLisp | 1 | -6/+14 | |
2019-12-23 | maxwell_to_gl: Implement missing primitive topologies | ReinUsesLisp | 1 | -4/+18 | |
Many of these topologies are exclusively available in OpenGL. | |||||
2019-12-22 | Texture Cache: Improve documentation | Fernando Sahmkow | 2 | -4/+5 | |
2019-12-22 | Texture Cache: Address Feedback | Fernando Sahmkow | 2 | -11/+11 | |
2019-12-22 | Texture Cache: Add HLE methods for building 3D textures within the GPU in certain scenarios. | Fernando Sahmkow | 4 | -1/+143 | |
This commit adds a series of HLE methods for handling 3D textures in general. This helps games that generate 3D textures on every frame and may reduce loading times for certain games. | |||||
2019-12-21 | gl_shader_cache: Update commentary for shared memory | ReinUsesLisp | 1 | -9/+6 | |
Remove false commentary. Not dividing by 4 the size of shared memory is not a hack; it describes the number of integers, not bytes. While we are at it sort the generated code to put preprocessor lines on the top. | |||||
2019-12-21 | gl_shader_cache: Remove unused entry in GetPrimitiveDescription | ReinUsesLisp | 1 | -11/+9 | |
2019-12-21 | vk_shader_decompiler: Use Visit instead of reimplementing it | ReinUsesLisp | 1 | -23/+1 | |
ExprCondCode visit implements the generic Visit. Use this instead of that one. As an intended side effect this fixes unwritten memory usages in cases when a negation of a condition code is used. | |||||
2019-12-20 | shader/p2r: Implement P2R Pr | ReinUsesLisp | 1 | -1/+15 | |
P2R dumps predicate or condition codes state to a register. This is useful for unit testing. | |||||
2019-12-20 | shader/r2p: Refactor P2R to support P2R | ReinUsesLisp | 2 | -17/+33 | |
2019-12-19 | vk_resource_manager: Add entry to VKFence to test its usage | ReinUsesLisp | 1 | -0/+8 | |
2019-12-19 | vk_reosurce_manager: Add assert for releasing fences | ReinUsesLisp | 1 | -0/+1 | |
Notify the programmer when a request to release a fence is invalid because the fence is already free. | |||||
2019-12-19 | vk_resource_manager: Implement VKFenceWatch move constructor | ReinUsesLisp | 2 | -0/+32 | |
This allows us to put VKFenceWatch inside a std::vector without storing it in heap. On move we have to signal the fences where the new protected resource is, adding some overhead. | |||||
2019-12-19 | vk_device: Add entry to catch device losses | ReinUsesLisp | 3 | -1/+40 | |
VK_NV_device_diagnostic_checkpoints allows us to push data to a Vulkan queue and then query it even after a device loss. This allows us to push the current pipeline object and see what was the call that killed the device. | |||||
2019-12-19 | vk_shader_decompiler: Fix full decompilation | ReinUsesLisp | 1 | -3/+5 | |
When full decompilation was enabled, labels were not being inserted and instructions were misused. Fix these bugs. | |||||
2019-12-19 | vk_shader_decompiler: Skip NDC correction when it is native | ReinUsesLisp | 2 | -1/+2 | |
Avoid changing gl_Position when the NDC used by the game is [0, 1] (Vulkan's native). | |||||
2019-12-19 | vk_shader_decompiler: Normalize output fragment attachments | ReinUsesLisp | 2 | -12/+12 | |
Some games write from fragment shaders to an unexistant framebuffer attachment or they don't write to one when it exists in the framebuffer. Fix this by skipping writes or adding zeroes. | |||||
2019-12-19 | vk_device: Add query for RGBA8Uint | ReinUsesLisp | 1 | -0/+1 | |
2019-12-19 | vk_shader_decompiler: Update sirit and implement Texture AOFFI | ReinUsesLisp | 1 | -22/+30 | |
2019-12-18 | gl_rasterizer: Implement RASTERIZE_ENABLE | ReinUsesLisp | 6 | -4/+28 | |
RASTERIZE_ENABLE is the opposite of GL_RASTERIZER_DISCARD. Implement it naturally using this. NVN games expect rasterize to be enabled by default, reflect that in our initial GPU state. | |||||
2019-12-18 | shader/memory: Implement LDG.U8 and unaligned U8 loads | ReinUsesLisp | 1 | -6/+32 | |
LDG can load single bytes instead of full integers or packs of integers. These have the advantage of loading bytes that are not aligned to 4 bytes. To emulate these this commit gets the byte being referenced (by doing "address & 3" and then using that to extract the byte from the loaded integer: result = bitfieldExtract(loaded_integer, (address % 4) * 8, 8) | |||||
2019-12-18 | shader/conversion: Implement byte selector in I2F | ReinUsesLisp | 1 | -2/+13 | |
I2F's byte selector is used to choose what bytes to convert to float. e.g. if the input is 0xaabbccdd and the selector is ".B3" it will convert 0xaa. The default (when it's not shown in nvdisasm) is ".B0", in that example the default would convert 0xdd to float. | |||||
2019-12-18 | shader/texture: Properly shrink unused entries in size mismatches | ReinUsesLisp | 1 | -4/+9 | |
When a image format mismatches we were inserting zeroes to the texture itself. This was not handling cases were the mismatch uses less coordinates than the guest shader code. Address that by resizing the vector. | |||||
2019-12-18 | gl_shader_decompiler: Add missing DeclareImages | ReinUsesLisp | 1 | -0/+1 | |
2019-12-18 | shader_bytecode: Fix TLD4S encoding | ReinUsesLisp | 1 | -1/+1 | |
2019-12-17 | common: SPSCQueue: Notify after incrementing queue size. | bunnei | 1 | -2/+9 | |
2019-12-16 | renderer_vulkan/shader: Add helper GLSL shaders | ReinUsesLisp | 4 | -0/+122 | |
These shaders are used to specify code that is not dynamically generated in the Vulkan backend. Instead of packing it inside the build system, it's manually built and copied to the C++ file to avoid adding unnecessary build time dependencies. quad_array should be dropped in the future since it can be emulated with a memory pool generated from the CPU. | |||||
2019-12-16 | shader/texture: Implement TLD4.PTP | ReinUsesLisp | 5 | -56/+120 | |
2019-12-16 | shader/texture: Enable arrayed TLD4 | ReinUsesLisp | 1 | -1/+0 | |
2019-12-16 | gl_shader_decompiler: Rename "sepparate" to "separate" | ReinUsesLisp | 1 | -3/+3 | |
2019-12-16 | shader/texture: Implement AOFFI for TLD4S | ReinUsesLisp | 1 | -13/+18 | |
2019-12-16 | shader/texture: Remove unnecesary parenthesis | ReinUsesLisp | 1 | -2/+2 | |
2019-12-13 | maxwell_to_vk: Improve image format table and add more formats | ReinUsesLisp | 2 | -89/+127 | |
A1B5G5R5 uses A1R5G5B5. This is flipped with image view swizzles; flushing is still not properly implemented on Vulkan for this particular format. | |||||
2019-12-13 | maxwell_to_vk: Implement more vertex formats | ReinUsesLisp | 1 | -7/+81 | |
2019-12-13 | maxwell_to_vk: Implement more primitive topologies | ReinUsesLisp | 2 | -2/+11 | |
Add an extra argument to query device capabilities in the future. The intention behind this is to use native quads, quad strips, line loops and polygons if these are released for Vulkan. | |||||
2019-12-13 | maxwell_to_vk: Approach GL_CLAMP closer to the GL spec | ReinUsesLisp | 3 | -9/+17 | |
The OpenGL spec defines GL_CLAMP's formula similarly to CLAMP_TO_EDGE and CLAMP_TO_BORDER depending on the filter mode used. It doesn't exactly behave like this, but it's the closest we can get with what Vulkan offers without emulating it by injecting shader code. | |||||
2019-12-13 | maxwell_to_vk: Use VK_EXT_index_type_uint8 when available | ReinUsesLisp | 2 | -4/+7 | |
2019-12-13 | vk_scheduler: Delegate commands to a worker thread and state track | ReinUsesLisp | 2 | -37/+311 | |
Introduce a worker thread approach for delegating Vulkan work derived from dxvk's approach. https://github.com/doitsujin/dxvk Now that the scheduler is what handles all Vulkan work related to command streaming, store state tracking in itself. This way we can know when to reupload Vulkan dynamic state to the queue (since this one is invalidated between command buffers unlike NVN). We can also store the renderpass state and graphics pipeline bound to avoid redundant binds and renderpass begins/ends. | |||||
2019-12-12 | Shader_IR: Correct TLD4S Depth Compare. | Fernando Sahmkow | 2 | -9/+16 | |
2019-12-12 | Shader_Ir: Correct TLD4S encoding and implement f16 flag. | Fernando Sahmkow | 3 | -11/+15 | |
2019-12-12 | Gl_Shader_compiler: Correct Depth Compare for Texture Gather operations. | Fernando Sahmkow | 1 | -8/+21 | |
2019-12-12 | Shader_Ir: default failed tracks on bindless samplers to null values. | Fernando Sahmkow | 2 | -24/+77 | |
2019-12-11 | Gl_Rasterizer: Skip Tesselation Control and Eval stages as they are un implemented. | Fernando Sahmkow | 1 | -0/+8 | |
This commit ensures the OGL backend does not execute tesselation shader stages as they are currently unimplemented. | |||||
2019-12-11 | Added missing include | Joel Holdsworth | 1 | -0/+1 | |
2019-12-11 | Kernel: Correct behavior of Address Arbiter threads. (#3165) | Fernando Sahmkow | 3 | -24/+67 | |
* Kernel: Correct behavior of Address Arbiter threads. This corrects arbitration threads to behave just like in Horizon OS. They are added into a container and released according to what priority they had when added. Horizon OS does not reorder them if their priority changes. * Kernel: Address Feedback. | |||||
2019-12-11 | kernel/svc: Correct function signature of SignalProcessWideKey | Lioncash | 2 | -9/+6 | |
This function doesn't actually return a result code, so we can amend the signature of it to match. | |||||
2019-12-11 | gl_device: Enable compute shaders for Intel Mesa drivers | ReinUsesLisp | 1 | -1/+4 | |
Previously we naively checked for "Intel" in GL_VENDOR, but this includes both Intel's proprietary driver and the mesa driver. Re-enable compute shaders for mesa. | |||||
2019-12-11 | gl_shader_cache: Add missing new-line on emitted GLSL | ReinUsesLisp | 1 | -2/+2 | |
Add missing new-line. This caused shaders using local memory and shared memory to inject a preprocessor GLSL line after an expression (resulting in invalid code). It looked like this: shared uint smem[8];#define LOCAL_MEMORY_SIZE 16 It should look like this (addressed by this commit): shared uint smem[8]; \#define LOCAL_MEMORY_SIZE 16 | |||||
2019-12-11 | Maxwell3D: Implement Depth Mode. | Fernando Sahmkow | 4 | -8/+15 | |
This commit finishes adding depth mode that was reverted before due to other unresolved issues. | |||||
2019-12-10 | shader: Implement MEMBAR.GL | ReinUsesLisp | 5 | -1/+46 | |
Implement using memoryBarrier in GLSL and OpMemoryBarrier on SPIR-V. | |||||
2019-12-10 | vk_shader_decompiler: Fix build issues on old gcc versions | ReinUsesLisp | 1 | -2/+3 | |
2019-12-10 | vk_shader_decompiler: Reduce YNegate's severity | ReinUsesLisp | 1 | -1/+1 | |
2019-12-10 | shader_ir/other: Implement S2R InvocationId | ReinUsesLisp | 4 | -0/+9 | |
2019-12-10 | vk_shader_decompiler: Misc changes | ReinUsesLisp | 2 | -697/+1648 | |
Update Sirit and its usage in vk_shader_decompiler. Highlights: - Implement tessellation shaders - Implement geometry shaders - Implement some missing features - Use native half float instructions when available. | |||||
2019-12-10 | shader: Keep track of shaders using warp instructions | ReinUsesLisp | 2 | -0/+8 | |
2019-12-10 | shader_ir/memory: Implement patch stores | ReinUsesLisp | 4 | -20/+38 | |
2019-12-09 | vk_device: Misc changes | ReinUsesLisp | 2 | -117/+276 | |
- Setup more features and requirements. - Improve logging for missing features. - Collect telemetry parameters. - Add queries for more image formats. - Query push constants limits. - Optionally enable some extensions. | |||||
2019-12-09 | externals: Update Vulkan-Headers | ReinUsesLisp | 2 | -2/+14 | |
2019-12-08 | kernel: Remove unnecessary includes | Lioncash | 15 | -11/+17 | |
Over the course of the changes to the kernel code, a few includes are no longer necessary, particularly with the change over to std::shared_ptr from Boost's intrusive_ptr. | |||||
2019-12-08 | kernel/svc: Provide implementations for svcDumpInfo/svcDumpInfoNew | Lioncash | 2 | -2/+24 | |
These are fairly trivial to implement, we can just do nothing. This also provides a spot for us to potentially dump out any relevant info in the future (e.g. for debugging purposes with homebrew, etc). While we're at it, we can also correct the names of both of these supervisor calls. | |||||
2019-12-07 | vk_swapchain: Add support for swapping sRGB | ReinUsesLisp | 2 | -24/+31 | |
We don't know until the game is running if it's using an sRGB color space or not. Add support for hot-swapping swapchain surface formats. | |||||
2019-12-07 | maxwell_3d: Add tessellation tess level registers | ReinUsesLisp | 1 | -1/+6 | |
2019-12-07 | maxwell_3d: Add tessellation mode register | ReinUsesLisp | 1 | -1/+28 | |
2019-12-07 | maxwell_3d: Add patch vertices register | ReinUsesLisp | 1 | -1/+4 | |
2019-12-07 | shader_bytecode: Remove corrupted character | ReinUsesLisp | 1 | -1/+1 | |
2019-12-05 | CpuCore: Clear exclusive state after doing a run in dynarmic. | Fernando Sahmkow | 2 | -1/+2 | |
This commit corrects an error in which a Core could remain with an exclusive state after running, leaving space for possible race conditions between changing cores. | |||||
2019-12-02 | telemetry_session: Report renderer backend | ReinUsesLisp | 1 | -0/+1 | |
We only have OpenGL as an option for now. Hardcode the entry. | |||||
2019-12-02 | telemetry_session: Use temporary to avoid writing the same enum | ReinUsesLisp | 1 | -16/+11 | |
2019-11-29 | texture_cache/surface_base: Fix out of bounds texture views | ReinUsesLisp | 1 | -7/+4 | |
Some texture views were being created out of bounds (with more layers or mipmaps than what the original texture has). This is because of a miscalculation in mipmap bounding. end_layer and end_mipmap are out of bounds (e.g. layer 6 in a cubemap), there's no need to add one more there. Fixes OpenGL errors and Vulkan crashes on Splatoon 2. | |||||
2019-11-29 | gl_framebuffer_cache: Optimize framebuffer key | ReinUsesLisp | 3 | -46/+60 | |
Pack color attachment enumerations into a single u32. To determine the number of buffers, the highest color attachment with a shared pointer that doesn't point to null is used. | |||||
2019-11-29 | gl_rasterizer: Re-enable framebuffer cache for clear buffers | ReinUsesLisp | 3 | -32/+15 | |
2019-11-29 | renderer_opengl: Make ScreenRectVertex's constructor constexpr | ReinUsesLisp | 1 | -12/+7 | |
2019-11-29 | renderer_opengl: Remove C casts | ReinUsesLisp | 1 | -4/+5 | |
2019-11-29 | renderer_opengl: Use explicit binding for presentation shaders | ReinUsesLisp | 2 | -34/+20 | |
2019-11-29 | renderer_opengl: Drop macros for message decorations | ReinUsesLisp | 1 | -21/+26 | |
2019-11-29 | renderer_opengl: Move static definitions to anonymous namespace | ReinUsesLisp | 1 | -62/+66 | |
2019-11-29 | renderer_opengl: Move commentaries to header file | ReinUsesLisp | 2 | -20/+13 | |
2019-11-28 | kernel: Implement a more accurate IPC dispatch. | bunnei | 19 | -167/+246 | |
2019-11-28 | patch_manager: Adds check for disabled cheats to prevent them from being enabled (#3178) | Morph | 1 | -5/+11 | |
* Adds check for disabled cheats to prevent them from being added to the CheatList * Address feedback | |||||
2019-11-27 | video_core/gpu_thread: Tidy up SwapBuffers() | Lioncash | 1 | -2/+1 | |
We can just use std::nullopt and std::make_optional to make this a little bit less noisy. | |||||
2019-11-27 | video_core/const_buffer_locker: Make use of std::tie in HasEqualKeys() | Lioncash | 1 | -2/+3 | |
Tidies it up a little bit visually. | |||||
2019-11-27 | video_core/const_buffer_locker: Remove unused includes | Lioncash | 2 | -2/+2 | |
2019-11-27 | video_core/const_buffer_locker: Remove #pragma once from cpp file | Lioncash | 1 | -2/+0 | |
Silences a compiler warning. | |||||
2019-11-27 | filesys/romfs: Remove unused includes | Lioncash | 2 | -4/+2 | |
These inclusions aren't used at all within the public interface, so they can be removed. | |||||
2019-11-27 | filesys/romfs: Make ProcessFile and ProcessDirectory internally linked | Lioncash | 1 | -2/+3 | |
These functions aren't used outside of this file, so we can place them within an anonymous namespace. | |||||
2019-11-27 | file_sys/directory: Make EntryType an enum class | Lioncash | 2 | -3/+3 | |
This can trivially be an enum class rather than a regular enum, making it more strongly typed. | |||||
2019-11-27 | core/memory; Migrate over SetCurrentPageTable() to the Memory class | Lioncash | 3 | -26/+34 | |
Now that literally every other API function is converted over to the Memory class, we can just move the file-local page table into the Memory implementation class, finally getting rid of global state within the memory code. | |||||
2019-11-27 | core/memory: Migrate over GetPointerFromVMA() to the Memory class | Lioncash | 1 | -36/+36 | |
Now that everything else is migrated over, this is essentially just code relocation and conversion of a global accessor to the class member variable. All that remains is to migrate over the page table. | |||||
2019-11-27 | core/memory: Migrate over Write{8, 16, 32, 64, Block} to the Memory class | Lioncash | 14 | -153/+298 | |
The Write functions are used slightly less than the Read functions, which make these a bit nicer to move over. The only adjustments we really need to make here are to Dynarmic's exclusive monitor instance. We need to keep a reference to the currently active memory instance to perform exclusive read/write operations. | |||||
2019-11-27 | core/memory: Migrate over Read{8, 16, 32, 64, Block} to the Memory class | Lioncash | 19 | -178/+305 | |
With all of the trivial parts of the memory interface moved over, we can get right into moving over the bits that are used. Note that this does require the use of GetInstance from the global system instance to be used within hle_ipc.cpp and the gdbstub. This is fine for the time being, as they both already rely on the global system instance in other functions. These will be removed in a change directed at both of these respectively. For now, it's sufficient, as it still accomplishes the goal of de-globalizing the memory code. | |||||
2019-11-27 | core/memory: Migrate over ZeroBlock() and CopyBlock() to the Memory class | Lioncash | 2 | -91/+161 | |
These currently aren't used anywhere in the codebase, so these are very trivial to move over to the Memory class. | |||||
2019-11-27 | core/memory: Migrate over RasterizerMarkRegionCached() to the Memory class | Lioncash | 3 | -70/+79 | |
This is only used within the accelerated rasterizer in two places, so this is also a very trivial migration. | |||||
2019-11-27 | core/memory: Migrate over ReadCString() to the Memory class | Lioncash | 3 | -18/+40 | |
This only had one usage spot, so this is fairly straightforward to convert over. | |||||
2019-11-27 | core/memory: Migrate over GetPointer() | Lioncash | 7 | -25/+53 | |
With all of the interfaces ready for migration, it's trivial to migrate over GetPointer(). | |||||
2019-11-27 | core: Prepare various classes for memory read/write migration | Lioncash | 24 | -61/+108 | |
Amends a few interfaces to be able to handle the migration over to the new Memory class by passing the class by reference as a function parameter where necessary. Notably, within the filesystem services, this eliminates two ReadBlock() calls by using the helper functions of HLERequestContext to do that for us. | |||||
2019-11-27 | core/memory: Move memory read/write implementation functions into an anonymous namespace | Lioncash | 1 | -97/+98 | |
These will eventually be migrated into the main Memory class, but for now, we put them in an anonymous namespace, so that the other functions that use them, can be migrated over separately. | |||||
2019-11-27 | core/memory: Migrate over address checking functions to the new Memory class | Lioncash | 6 | -39/+70 | |
A fairly straightforward migration. These member functions can just be mostly moved verbatim with minor changes. We already have the necessary plumbing in places that they're used. IsKernelVirtualAddress() can remain a non-member function, since it doesn't rely on class state in any form. | |||||
2019-11-27 | core/memory: Migrate over memory mapping functions to the new Memory class | Lioncash | 6 | -128/+180 | |
Migrates all of the direct mapping facilities over to the new memory class. In the process, this also obsoletes the need for memory_setup.h, so we can remove it entirely from the project. | |||||
2019-11-27 | core/memory: Introduce skeleton of Memory class | Lioncash | 4 | -3/+56 | |
Currently, the main memory management code is one of the remaining places where we have global state. The next series of changes will aim to rectify this. This change simply introduces the main skeleton of the class that will contain all the necessary state. | |||||
2019-11-27 | core_timing: Use better reference tracking for EventType. (#3159) | bunnei | 17 | -161/+103 | |
* core_timing: Use better reference tracking for EventType. - Moves ownership of the event to the caller, ensuring we don't fire events for destroyed objects. - Removes need for unique names - we won't be using this for save states anyways. | |||||
2019-11-26 | gl_shader_decompiler: Fix casts from fp32 to f16 | ReinUsesLisp | 1 | -1/+2 | |
Casts from f32 to f16 zeroes the higher half of the target register. | |||||
2019-11-26 | kernel: Fix reference management for client/server session. | bunnei | 3 | -20/+18 | |
- Fixes shutdown crash and crash in Pokemon SwSh. | |||||
2019-11-25 | gl_device: Deduce indexing bug from device instead of heuristic | ReinUsesLisp | 2 | -48/+2 | |
The heuristic to detect AMD's driver was not working properly since it also included Intel. Instead of using heuristics to detect it, compare the GL_VENDOR string. | |||||
2019-11-25 | kernel: Replace usage of boost::intrusive_ptr with std::shared_ptr for kernel objects. (#3154) | bunnei | 74 | -378/+377 | |
* kernel: Replace usage of boost::intrusive_ptr with std::shared_ptr for kernel objects. - See https://github.com/citra-emu/citra/pull/4710 for details. | |||||
2019-11-24 | gl_texture_cache: Apply sRGB on blits | ReinUsesLisp | 1 | -0/+1 | |
glBlitFramebuffer keeps in mind GL_FRAMEBUFFER_SRGB's state. Enable this depending on the target surface pixel format. | |||||
2019-11-23 | Update svc.cpp | bunnei | 1 | -0/+1 | |
2019-11-23 | svc: GetSystemTick should return cntpct_el0, not core ticks. | bunnei | 1 | -1/+3 | |
2019-11-23 | gpu_thread: Don't spin wait if there are no GPU commands. | bunnei | 1 | -17/+15 | |
2019-11-23 | fix clang-format and lambda capture | Weiyi Wang | 1 | -1/+2 | |
2019-11-23 | unfold UNREACHABLE implementation for dumb compilers | Weiyi Wang | 1 | -2/+2 | |
We relies on UNREACHABLE's noreturn attribute to eliminate parent's "no return value" warning. However, this was wrapped in a `if(!false)` block, which compilers may not unfold to recognize the noreturn nature. | |||||
2019-11-23 | gl_device: Reserve base bindings on limited devices | ReinUsesLisp | 1 | -36/+76 | |
SSBOs and other resources are limited per pipeline on Intel and AMD. Heuristically reserve resources per stage having in mind the reported OpenGL limits. | |||||
2019-11-23 | gl_state: Skip null texture binds | ReinUsesLisp | 1 | -1/+5 | |
glBindTextureUnit doesn't support null textures. Skip binding these. | |||||
2019-11-23 | gl_rasterizer: Disable compute shaders on Intel | ReinUsesLisp | 3 | -0/+12 | |
Intel's proprietary driver enters in a corrupt state when compute shaders are executed. For now, disable these. | |||||
2019-11-23 | gl_shader_cache: Hack shared memory size | ReinUsesLisp | 1 | -2/+3 | |
The current shared memory size seems to be smaller than what the game actually uses. This makes Nvidia's driver consistently blow up; in the case of FE3H it made it explode on Qt's SwapBuffers while SDL2 worked just fine. For now keep this hack since it's still progress over the previous hardcoded shared memory size. | |||||
2019-11-23 | gl_shader_decompiler: Normalize image bindings | ReinUsesLisp | 3 | -33/+19 | |
2019-11-23 | gl_shader_decompiler: Normalize cbuf bindings | ReinUsesLisp | 2 | -10/+6 | |
Stage and compute shaders were using a different binding counter. Normalize these. | |||||
2019-11-23 | gl_rasterizer: Add missing cbuf counter reset on compute | ReinUsesLisp | 1 | -0/+2 | |
2019-11-23 | gl_shader_cache: Remove dynamic BaseBinding specialization | ReinUsesLisp | 16 | -192/+200 | |
2019-11-23 | video_core: Unify ProgramType and ShaderStage into ShaderType | ReinUsesLisp | 22 | -289/+262 | |
2019-11-23 | gl_rasterizer: Bind graphics images to draw commands | ReinUsesLisp | 4 | -33/+54 | |
Images were not being bound to draw invocations because these would require a cache invalidation. | |||||
2019-11-23 | gl_shader_cache: Specialize local memory size for compute shaders | ReinUsesLisp | 6 | -21/+32 | |
Local memory size in compute shaders was stubbed with an arbitary size. This commit specializes local memory size from guest GPU parameters. | |||||
2019-11-23 | gl_shader_cache: Specialize shared memory size | ReinUsesLisp | 5 | -29/+25 | |
Shared memory was being declared with an undefined size. Specialize from guest GPU parameters the compute shader's shared memory size. | |||||
2019-11-23 | gl_shader_cache: Specialize shader workgroup | ReinUsesLisp | 6 | -68/+74 | |
Drop the usage of ARB_compute_variable_group_size and specialize compute shaders instead. This permits compute to run on AMD and Intel proprietary drivers. | |||||
2019-11-23 | shader/texture: Handle TLDS texture type mismatches | ReinUsesLisp | 1 | -1/+10 | |
Some games like "Fire Emblem: Three Houses" bind 2D textures to offsets used by instructions of 1D textures. To handle the discrepancy this commit uses the the texture type from the binding and modifies the emitted code IR to build a valid backend expression. E.g.: Bound texture is 2D and instruction is 1D, the emitted IR samples a 2D texture in the coordinate ivec2(X, 0). | |||||
2019-11-23 | shader/texture: Deduce texture buffers from locker | ReinUsesLisp | 9 | -174/+107 | |
Instead of specializing shaders to separate texture buffers from 1D textures, use the locker to deduce them while they are being decoded. | |||||
2019-11-21 | Kernel: Optimize condition variable threads management. | Fernando Sahmkow | 4 | -24/+21 | |
2019-11-21 | Kernel: Correct SignalProcessWideKey | Fernando Sahmkow | 1 | -6/+2 | |
When the target is 0, all threads must be processed. | |||||
2019-11-21 | Kernel: Correct behavior of Condition Variables to be more similar to real hardware. | Fernando Sahmkow | 5 | -15/+74 | |
This commit ensures cond var threads act exactly as they do in the real console. The original implementation uses an RBTree and the behavior of cond var threads is that at the same priority level they act like a FIFO. | |||||
2019-11-20 | buffer_cache: Remove brace initialized for objects with default constructor | ReinUsesLisp | 1 | -10/+10 | |
2019-11-20 | Texture_Cache: Redo invalid Surfaces handling. | Fernando Sahmkow | 3 | -32/+101 | |
This commit aims to redo the full setup of invalid textures and guarantee correct behavior across backends in the case of finding one by using black dummy textures that match the target of the expected texture. | |||||
2019-11-20 | shader/other: Reduce DEPBAR log severity | ReinUsesLisp | 1 | -1/+1 | |
While DEPBAR is stubbed it doesn't change anything from our end. Shading languages handle what this instruction does implicitly. We are not getting anything out fo this log except noise. | |||||
2019-11-20 | gl_shader_gen: Apply default value to gl_Position | ReinUsesLisp | 1 | -0/+1 | |
Nvidia has sane default output values for varyings, but the other vendors don't apply these. To properly emulate this we would have to analyze the shader header. For the time being, apply the same default Nvidia applies so we get the same behaviour on non-Nvidia drivers. | |||||
2019-11-19 | citra_qt/main.ui: remove unused actions "Load Symbol Map..." and... | Tobias | 1 | -13/+0 | |
..."Select Game Directory..." Co-authored-by: vvanelslande <vvanelslandedev@gmail.com> | |||||
2019-11-18 | Shader_IR: Address Feedback | Fernando Sahmkow | 3 | -11/+9 | |
2019-11-16 | Kernel: Correct Cancel Synchronization. | Fernando Sahmkow | 3 | -2/+19 | |
This commit corrects the behavior of cancel synchronization when the thread is running/ready and ensures the next wait is cancelled as it's suppose to. | |||||
2019-11-16 | Revert "common/bit_field: Silence sign-conversion warnings" | Rodrigo Locatti | 1 | -3/+2 | |
2019-11-15 | common/logging: Silence no return value warnings | ReinUsesLisp | 1 | -2/+6 | |
2019-11-15 | common/bit_field: Silence sign-conversion warnings | Lioncash | 1 | -2/+3 | |
We can just use numeric_limits instead of relying on wraparound behavior here. | |||||
2019-11-15 | format_lookup_table: Address feedback | ReinUsesLisp | 2 | -30/+24 | |
format_lookup_table: Drop bitfields format_lookup_table: Use std::array for definition table format_lookup_table: Include <limits> instead of <numeric> | |||||
2019-11-15 | texture_cache: Use a table instead of switch for texture formats | ReinUsesLisp | 9 | -261/+290 | |
Use a large flat array to look up texture formats. This allows us to properly implement formats with different component types. It should also be faster. | |||||
2019-11-14 | common_funcs: Remove semicolons from INSERT_PADDING_* macros | Lioncash | 1 | -4/+6 | |
Makes code that uses the macros consistent by requiring the lines to be terminated with a semicolon. | |||||
2019-11-14 | service/am: Remove unnecessary Skip calls | Lioncash | 1 | -8/+16 | |
We can simplify these by wrapping the necessary members in structs and then simply reading out the whole struct. | |||||
2019-11-14 | texture_cache: Drop abstracted ComponentType | ReinUsesLisp | 8 | -294/+158 | |
Abstracted ComponentType was not being used in a meaningful way. This commit drops its usage. There is one place where it was being used to test compatibility between two cached surfaces, but this one is implied in the pixel format. Removing the component type test doesn't change the behaviour. | |||||
2019-11-14 | am: Stub QueryApplicationPlayStatistics | Lioncash | 2 | -5/+14 | |
Maintains implementation parity between QueryApplicationPlayStatistics and QueryApplicationPlayStatisticsByUid. These function the same behaviorally underneath the hood, with the only difference being that one allows specifying a UID. | |||||
2019-11-14 | correct the implementation of RGBA16UI | greggameplayer | 1 | -0/+2 | |
2019-11-14 | Shader_IR: Implement TXD instruction. | Fernando Sahmkow | 5 | -8/+120 | |
2019-11-14 | Shader_IR: Implement FLO instruction. | Fernando Sahmkow | 5 | -0/+35 | |
2019-11-14 | Shader_Bytecode: Add encodings for FLO, SHF and TXD | Fernando Sahmkow | 1 | -0/+18 | |
2019-11-13 | common/hash: Remove unused HashableStruct | Lioncash | 1 | -35/+0 | |
This is unused, so it can be removed. There's better ways of ensuring zeroed out padding bits, like using zero-initialization, anyhow. | |||||
2019-11-13 | maxwell_3d: Fix stencil_back_func_mask offset | ReinUsesLisp | 1 | -3/+3 | |
stencil_back_func_mask and stencil_back_mask were misplaced. This commit addresses that issue. | |||||
2019-11-13 | xts_archive: Remove redundant std::string constructor | Lioncash | 1 | -2/+1 | |
We can just call the .data() member of path instead of constructing a completely new string. | |||||
2019-11-13 | common_funcs: silence sign-conversion warnings in MakeMagic() | Lioncash | 1 | -1/+1 | |
We can trivially resolve these by casting the characters to unsigned values and then shifting the bits. | |||||
2019-11-12 | service: Update function tables | Lioncash | 33 | -7/+192 | |
Keeps the function tables up to date. Updated based off information from Switchbrew. | |||||
2019-11-12 | key_manager: Make use of IOFile in WriteKeyToFile() | Lioncash | 1 | -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). | |||||
2019-11-12 | core: Migrate off deprecated mbedtls functions | Lioncash | 7 | -12/+12 | |
These functions are marked for deprecation and it's recommended that the *_ret variants be used instead. | |||||
2019-11-12 | externals: Update httplib | Lioncash | 1 | -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. | |||||
2019-11-12 | service: Resolve sign conversion errors | Lioncash | 15 | -58/+55 | |
These are fairly trivial to resolve and most of the changes entail using RESULT_UNKNOWN over ResultCode(-1). | |||||
2019-11-12 | perf_stats: Resolve implicit int to double conversion error | Lioncash | 1 | -1/+1 | |
We simply need to turn the literal argument to std::accumulate into a double, rather than an int. | |||||
2019-11-12 | loader; Resolve sign conversion/truncation errors | Lioncash | 3 | -6/+6 | |
2019-11-12 | gdbstub: Resolve sign conversion errors | Lioncash | 1 | -1/+2 | |
2019-11-12 | kernel: Resolve sign conversion warnings | Lioncash | 4 | -72/+60 | |
Uncovered a bug within Thread's SetCoreAndAffinityMask() where an unsigned variable (ideal_core) was being compared against "< 0", which would always be a false condition. We can also get rid of an unused function (GetNextProcessorId) which contained a sign mismatch warning. | |||||
2019-11-12 | file_sys: Resolve sign conversion warnings | Lioncash | 4 | -12/+10 | |
Resolves a few trivial sign conversion/mismatch errors. | |||||
2019-11-12 | result: Add default error code for the ResultCode(-1) case | Lioncash | 1 | -1/+9 | |
Will be used to reduce the overall duplication of the same magic value all over the codebase in following changes. | |||||
2019-11-12 | crypto: Resolve sign-conversion warnings | Lioncash | 2 | -11/+12 | |
2019-11-12 | result: Resolve sign-coversion warnings | Lioncash | 1 | -1/+1 | |
The constructor was implicitly using signed->unsigned conversions to produce 0xFFFFFFFF. We can just specify this explicitly with UINT32_MAX. | |||||
2019-11-12 | arm_unicorn: Resolve sign conversion warnings | Lioncash | 3 | -8/+10 | |
While we're at it, this also resolves a type truncation warning as well, given the code was truncating from a 64-bit value to a 32-bit one. | |||||
2019-11-12 | CMakeLists: Make most implicit type conversion warnings errors on MSVC | Lioncash | 1 | -0/+17 | |
Quite frequently there have been cases where code has been merged into the core that produces warning. In order to prevent this from occurring, we can make the compiler flag these cases and allow our CI to flag down any code that would generate these warnings. This is beneficial given silent conversions from signed/unsigned can result in logic bugs. This forces one writing changes to be explicit about when signedness conversions are desirable, rather than leaving it up to readers' interpretation. Currently the codebase isn't in a state where it will build successfully with this change applied, but this will be addressed in subsequent follow-up changes. This set of changes will focus on making it build properly with these changes for MSVC as a starting point for basic coverage. | |||||
2019-11-11 | video_core: Enable sign conversion warnings | Rodrigo Locatti | 1 | -1/+1 | |
Enable sign conversion warnings but don't treat them as errors. | |||||
2019-11-11 | Implement stub for QueryApplicationPlayStatisticsByUid | Michael Scire | 2 | -0/+10 | |
2019-11-09 | web-service: Port citra's updated web_backend code. | bunnei | 2 | -18/+57 | |
2019-11-09 | yuzu: configure_web: Use Base64 encoded token for simplifying user experience. | bunnei | 2 | -32/+53 | |
2019-11-08 | video_core: Treat implicit conversions as errors | ReinUsesLisp | 1 | -0/+6 | |
2019-11-08 | video_core: Silence implicit conversion warnings | ReinUsesLisp | 9 | -53/+62 | |
2019-11-08 | gl_shader_cache: Fix locker constructors | ReinUsesLisp | 1 | -2/+4 | |
Properly pass engine when a shader is being constructed from memory. | |||||
2019-11-08 | gl_shader_cache: Enable extensions only when available | ReinUsesLisp | 1 | -6/+14 | |
Silence GLSL compilation warnings. | |||||
2019-11-08 | gl_shader_decompiler: Add safe fallbacks when ARB_shader_ballot is not available | ReinUsesLisp | 3 | -5/+28 | |
2019-11-08 | shader_ir/warp: Implement FSWZADD | ReinUsesLisp | 5 | -0/+44 | |
2019-11-08 | gl_shader_decompiler: Reimplement shuffles with platform agnostic intrinsics | ReinUsesLisp | 5 | -122/+49 | |
2019-11-07 | GLSLDecompiler: Correct Texture Gather Offset. | Fernando Sahmkow | 1 | -1/+1 | |
This commit corrects the argument ordering in textureGatherOffset. | |||||
2019-11-07 | buffer_cache: Add missing includes (#3079) | Morph | 1 | -0/+4 | |
`boost::make_iterator_range` is available when `boost/range/iterator_range.hpp` is included. Also include `boost/icl/interval_map.hpp` and `boost/icl/interval_set.hpp`. | |||||
2019-11-07 | gl_rasterizer: Remove front facing hack | ReinUsesLisp | 1 | -12/+0 | |
2019-11-07 | gl_shader_decompiler: Fix typo "y_negate"->"y_direction" | ReinUsesLisp | 1 | -1/+1 | |
2019-11-07 | gl_shader_manager: Remove unused variable in SetFromRegs | ReinUsesLisp | 1 | -1/+0 | |
2019-11-07 | yuzu_cmd: Use string_view instead of string for extensions | ReinUsesLisp | 1 | -3/+3 | |
Avoids potential allocations due to the usage of std::string on strings that we know at compile time. Most of these might fit in SSO, but it adds complexity that can be easily avoided with string views. | |||||
2019-11-07 | gl_rasterizer: Emulate viewport flipping with ARB_clip_control | ReinUsesLisp | 9 | -76/+57 | |
Emulates negative y viewports with ARB_clip_control. This allows us to more easily emulated pipelines with tessellation and/or geometry shader stages. It also avoids corrupting games with transform feedbacks and negative viewports (gl_Position.y was being modified). | |||||
2019-11-07 | shader/control_flow: Specify constness on caller lambdas | Rodrigo Locatti | 1 | -11/+12 | |
Update src/video_core/shader/control_flow.cpp Co-Authored-By: Mat M. <mathew1800@gmail.com> Update src/video_core/shader/control_flow.cpp Co-Authored-By: Mat M. <mathew1800@gmail.com> Update src/video_core/shader/control_flow.cpp Co-Authored-By: Mat M. <mathew1800@gmail.com> Update src/video_core/shader/control_flow.cpp Co-Authored-By: Mat M. <mathew1800@gmail.com> Update src/video_core/shader/control_flow.cpp Co-Authored-By: Mat M. <mathew1800@gmail.com> Update src/video_core/shader/control_flow.cpp Co-Authored-By: Mat M. <mathew1800@gmail.com> | |||||
2019-11-07 | shader/control_flow: Use callable template instead of std::function | ReinUsesLisp | 1 | -6/+5 | |
2019-11-07 | shader/control_flow: Abstract repeated code chunks in BRX tracking | ReinUsesLisp | 1 | -93/+101 | |
Remove copied and pasted for cycles into a common templated function. | |||||
2019-11-07 | shader/control_flow: Silence Intellisense cast warnings | ReinUsesLisp | 1 | -1/+1 | |
2019-11-07 | shader/control_flow: Remove brace initializer in std containers | ReinUsesLisp | 1 | -9/+9 | |
These containers have a default constructor. | |||||
2019-11-07 | shader/decode: Reduce severity of arithmetic rounding warnings | ReinUsesLisp | 6 | -15/+17 | |
2019-11-07 | shader/arithmetic: Reduce RRO stub severity | ReinUsesLisp | 1 | -1/+2 | |
2019-11-07 | shader/texture: Remove NODEP warnings | ReinUsesLisp | 1 | -35/+0 | |
These warnings don't offer meaningful information while decoding shaders. Remove them. | |||||
2019-11-07 | nifm: Only return that there's an internet connection when there's a BCATServer | Fernando Sahmkow | 1 | -3/+17 | |
This helps games that need internet for other purposes boot as the rest of our internet infrastructure is incomplete. | |||||
2019-11-06 | ci: Populate build repository from Azure environment | Zach Hilman | 1 | -11/+2 | |
2019-11-04 | common_func: Use std::array for INSERT_PADDING_* macros. | bunnei | 14 | -158/+166 | |
- Zero initialization here is useful for determinism. | |||||
2019-11-03 | Revert "common_func: Use std::array for INSERT_PADDING_* macros." | bunnei | 1 | -3/+2 | |
2019-11-03 | common_func: Use std::array for INSERT_PADDING_* macros. | bunnei | 1 | -2/+3 | |
- Zero initialization here is useful for determinism. | |||||
2019-11-03 | kernel: readable_event: Signal only once. | bunnei | 1 | -2/+4 | |
2019-11-03 | kernel: events: Remove ResetType::Automatic. | bunnei | 25 | -109/+48 | |
- This does not actually seem to exist in the real kernel - games reset these automatically. # Conflicts: # src/core/hle/service/am/applets/applets.cpp # src/core/hle/service/filesystem/fsp_srv.cpp | |||||
2019-11-03 | kernel: readable_event: Initialize members. | bunnei | 1 | -1/+1 | |
2019-11-03 | common/bit_field: Remove FORCE_INLINE calls | Tobias | 1 | -2/+2 | |
See bunneis comment here https://github.com/citra-emu/citra/pull/4629#discussion_r258533167. They were supposed to be removed by him, but he missed them. | |||||
2019-11-03 | core/am: Stub InitializeApplicationCopyrightFrameBuffer, SetApplicationCopyrightImage and SetApplicationCopyrightVisibility | FearlessTobi | 2 | -3/+31 | |
These commands require Screenshots to be implemented anyway, so they are safe to stub for now. | |||||
2019-11-03 | citra_qt: add amiibo drag and drop support | FearlessTobi | 2 | -4/+18 | |
Co-Authored-By: Valentin Vanelslande <vvanelslandedev@gmail.com> | |||||
2019-11-02 | gl_rasterizer: Re-enable stream buffer memory due to global memory | ReinUsesLisp | 1 | -14/+8 | |
Global memory is still using the stream buffer when it shouldn't. As a temporary fix re-enable the stream buffer on compute. | |||||
2019-11-02 | gl_rasterizer: Upload constant buffers with glNamedBufferSubData | ReinUsesLisp | 6 | -19/+84 | |
Nvidia's OpenGL driver maps gl(Named)BufferSubData with some requirements to a fast. This path has an extra memcpy but updates the buffer without orphaning or waiting for previous calls. It can be seen as a better model for "push constants" that can upload a whole UBO instead of 256 bytes. This path has some requirements established here: http://on-demand.gputechconf.com/gtc/2014/presentations/S4379-opengl-44-scene-rendering-techniques.pdf#page=24 Instead of using the stream buffer, this commits moves constant buffers uploads to calls of glNamedBufferSubData and from my testing it brings a performance improvement. This is disabled when the vendor is not Nvidia since it brings performance regressions. | |||||
2019-10-31 | Shader_IR: Fix regression on TLD4 | Fernando Sahmkow | 2 | -5/+4 | |
Originally on the last commit I thought TLD4 acted the same as TLD4S and didn't have a mask. It actually does have a component mask. This commit corrects that. | |||||
2019-10-30 | Shader_IR: Fix TLD4 and add Bindless Variant. | Fernando Sahmkow | 3 | -11/+55 | |
This commit fixes an issue where not all 4 results of tld4 were being written, the color component was defaulted to red, among other things. It also implements the bindless variant. | |||||
2019-10-30 | gl_state: Use std::array::fill instead of std::fill | Rodrigo Locatti | 1 | -1/+1 | |
Co-Authored-By: Mat M. <mathew1800@gmail.com> | |||||
2019-10-30 | gl_state: Move dirty checks to individual apply calls instead of Apply | ReinUsesLisp | 2 | -66/+74 | |
This requires removing constness from some methods, but for consistency it's removed in all methods. | |||||
2019-10-30 | gl_state: Remove ApplyDefaultState | ReinUsesLisp | 3 | -17/+1 | |
OpenGL has defaults values we can trust. Remove these. | |||||
2019-10-30 | gl_state: Change SetDefaultViewports to use default constructor | ReinUsesLisp | 1 | -13/+2 | |
2019-10-30 | gl_state: Minor style changes | ReinUsesLisp | 1 | -3/+5 | |
2019-10-30 | gl_state: Remove unused Citra TextureUnits | ReinUsesLisp | 1 | -23/+0 | |
2019-10-30 | gl_state: Move initializers from constructor to class declaration | ReinUsesLisp | 2 | -170/+75 | |
2019-10-30 | shader/node: Unpack bindless texture encoding | ReinUsesLisp | 8 | -142/+116 | |
Bindless textures were using u64 to pack the buffer and offset from where they come from. Drop this in favor of separated entries in the struct. Remove the usage of std::set in favor of std::list (it's not std::vector to avoid reference invalidations) for samplers and images. | |||||
2019-10-28 | scheduler: Mark parameter of AskForReselectionOrMarkRedundant() as const | Lioncash | 2 | -5/+5 | |
This is only compared against, so it can be made const. | |||||
2019-10-28 | maxwell_3d/kepler_compute: Remove unused arguments in GetTexture | ReinUsesLisp | 5 | -37/+20 | |
2019-10-28 | video_core/textures: Remove unused index entry in FullTextureInfo | ReinUsesLisp | 2 | -2/+0 | |
2019-10-28 | maxwell_3d: Remove unused method GetStageTextures | ReinUsesLisp | 2 | -42/+0 | |
2019-10-28 | scheduler: Silence sign conversion warnings | Lioncash | 1 | -5/+5 | |
2019-10-28 | scheduler: Initialize class members directly where applicable | Lioncash | 2 | -6/+4 | |
Reduces the overall amount of code. | |||||
2019-10-28 | scheduler: Amend documentation comments | Lioncash | 2 | -75/+59 | |
Adjusts the formatting of a few of the comments an ensures they get recognized as proper Doxygen comments. | |||||
2019-10-27 | Video_Core: Implement texture format E5B9G9R9_SHAREDEXP. | Fernando Sahmkow | 4 | -5/+22 | |
This commit implements the E5B9G9R9 Texture format into the general system and OpenGL backend. | |||||
2019-10-27 | maxwell_3d: Silence implicit conversion warnings | ReinUsesLisp | 2 | -24/+25 | |
While we are at it, unify types for dirty reg pointers. | |||||
2019-10-27 | rasterizer_accelerated: Add intermediary for GPU rasterizers | ReinUsesLisp | 5 | -45/+98 | |
Add an intermediary class that implements common functions across GPU accelerated rasterizers. This avoids code repetition on different backends. | |||||
2019-10-27 | astc: Silence implicit conversion warnings | ReinUsesLisp | 1 | -7/+8 | |
2019-10-26 | Shader_IR: Address Feedback. | Fernando Sahmkow | 9 | -56/+66 | |
2019-10-25 | Shader_IR: Clang format | Fernando Sahmkow | 1 | -2/+1 | |
2019-10-25 | gl_shader_cache: Implement locker variants invalidation | ReinUsesLisp | 4 | -44/+104 | |
2019-10-25 | gl_shader_disk_cache: Store and load fast BRX | ReinUsesLisp | 6 | -50/+210 | |
2019-10-25 | const_buffer_locker: Minor style changes | ReinUsesLisp | 2 | -152/+76 | |
2019-10-25 | gl_shader_decompiler: Move entries to a separate function | ReinUsesLisp | 15 | -722/+420 | |
2019-10-25 | Shader_IR: Implement Fast BRX and allow multi-branches in the CFG. | Fernando Sahmkow | 1 | -1/+1 | |
2019-10-25 | Shader_IR: Correct typo in Consistent method. | Fernando Sahmkow | 2 | -2/+2 | |
2019-10-25 | Shader_IR: allow lookup of texture samplers within the shader_ir for instructions that don't provide it | Fernando Sahmkow | 9 | -46/+363 | |
2019-10-25 | Shader_IR: Implement Fast BRX and allow multi-branches in the CFG. | Fernando Sahmkow | 7 | -130/+258 | |
2019-10-25 | Shader_Cache: setup connection of ConstBufferLocker | Fernando Sahmkow | 10 | -43/+82 | |
2019-10-25 | VideoCore: Unify const buffer accessing along engines and provide ConstBufferLocker class to shaders. | Fernando Sahmkow | 12 | -13/+183 | |
2019-10-25 | Shader_IR: Implement BRX tracking. | Fernando Sahmkow | 1 | -0/+113 | |
2019-10-24 | shader_bytecode: Make Matcher constexpr capable | Lioncash | 1 | -13/+13 | |
Greatly shrinks the amount of generated code for GetDecodeTable(). Collapses an assembly output of 9000+ lines down to ~3621 with Clang, and 6513 down to ~2616 with GCC, given it's now allowed to construct all the entries as a sequence of constant data. | |||||
2019-10-24 | shader_ir: Use std::array with pair instead of unordered_map | Lioncash | 1 | -53/+67 | |
Given the overall size of the maps are very small, we can use arrays of pairs here instead of always heap allocating a new map every time the functions are called. Given the small size of the maps, the difference in container lookups are negligible, especially given the entries are already sorted. | |||||
2019-10-24 | video_core/shader: Resolve instances of variable shadowing | Lioncash | 6 | -11/+12 | |
Silences a few -Wshadow warnings. | |||||
2019-10-22 | savedata_factory: Automatically create certain savedata | Zach Hilman | 1 | -0/+12 | |
After further hardware investigation, it appears that some games, perhaps those more lazily coded, will not call EnsureSaveData, meaning that they expect the normal (current) save to be automatically made. Additionally, some games do not create a cache or temporary save before use. In these 3 specific instances, the save is created automatically for the game if it doesn't exist. | |||||
2019-10-22 | Shader_Ir: Fix TLD4S from using a component mask. | Fernando Sahmkow | 2 | -5/+5 | |
TLD4S always outputs 4 values, the previous code checked a component mask and omitted those values that weren't part of it. This commit corrects that and makes sure all 4 values are set. | |||||
2019-10-22 | shader_ir/memory: Ignore global memory when tracking fails | ReinUsesLisp | 2 | -18/+26 | |
Ignore global memory operations instead of invoking undefined behaviour when constant buffer tracking fails and we are blasting through asserts, ignore the operation. In the case of LDG this means filling the destination registers with zeroes; for STG this means ignore the instruction as a whole. The default behaviour is still to abort execution on failure. | |||||
2019-10-20 | maxwell_3d: Reduce FlushMMEInlineDraw logging to Trace | ReinUsesLisp | 1 | -1/+1 | |
2019-10-19 | core: Fix clang-format errors. | bunnei | 1 | -9/+10 | |
2019-10-18 | Fix null pointer deref. | Nicolae-Andrei Cociorba | 1 | -10/+12 | |
2019-10-18 | video_core/shader/ast: Make ShowCurrentState() and SanityCheck() const member functions | Lioncash | 2 | -5/+5 | |
These can also trivially be made const member functions, with the addition of a few consts. | |||||
2019-10-18 | video_core/shader/ast: Make ASTManager::Print a const member function | Lioncash | 2 | -3/+3 | |
Given all visiting functions never modify the nodes, we can trivially make this a const member function. | |||||
2019-10-18 | video_core/shader/ast: Make ExprPrinter members private | Lioncash | 1 | -1/+2 | |
This member already has an accessor, so there's no need for it to be public. | |||||
2019-10-18 | video_core/shader/ast: Make Indent() return a string_view | Lioncash | 1 | -14/+24 | |
The returned string is simply a substring of our constexpr tabs string_view, so we can just use a string_view here as well, since the original string_view is guaranteed to always exist. Now the function is fully non-allocating. | |||||
2019-10-18 | video_core/shader/ast: Make Indent() private | Lioncash | 1 | -9/+9 | |
It's never used outside of this class, so we can narrow its scope down. | |||||
2019-10-18 | video_core/shader/ast: Rename Ident() to Indent() | Lioncash | 1 | -13/+13 | |
This can be confusing, given "ident" is generally used as a shorthand for "identifier". | |||||
2019-10-18 | video_core/shader/ast: Make use of fmt where applicable | Lioncash | 1 | -14/+14 | |
Makes a few strings nicer to read and also eliminates a bit of string churn with operator+. | |||||
2019-10-18 | vk_shader_decompiler: Mark operator() function parameters as const references | Lioncash | 1 | -21/+23 | |
These parameters aren't actually modified in any way, so they can be made const references. | |||||
2019-10-18 | dmnt_cheat_vm: Correct register Restore and ClearRegs behavior | Lioncash | 1 | -2/+2 | |
Previously these were performing the same behavior as the Save and ClearSaved opcode types. | |||||
2019-10-18 | Fermi2D: Use a different formula for delimiting blit areas. | Fernando Sahmkow | 1 | -14/+28 | |
2019-10-18 | hid/npad: Fix incorrect connection boolean value in ConnectAllDisconnectedControllers() | Lioncash | 1 | -1/+1 | |
We should be setting the connection state to true, otherwise we aren't actually making the controllers connected like the function name indicates. | |||||
2019-10-18 | hid/npad: Add missing break in default case | Lioncash | 1 | -0/+1 | |
While not an issue, it does prevent fallthrough from occurring if anything is ever added after this case (unlikely to occur, but this turns a trivial "should not cause issues" into a definite "won't cause issues). | |||||
2019-10-18 | hid/npad: Replace std::for_each with ranged for loops | Lioncash | 1 | -13/+12 | |
Performs the same behavior, but is built into the core language itself. No functional change. | |||||
2019-10-18 | hid/npad: Remove redundant non-const variant of IsControllerSupported() | Lioncash | 2 | -34/+5 | |
The const qualified variant can also be called in non-const contexts, so we can remove the non-const variant to eliminate a bit of code duplication. | |||||
2019-10-18 | hid/npad: Move function declarations | Lioncash | 1 | -5/+6 | |
Clearly separate these from the variable declarations to make them more visible. | |||||
2019-10-17 | video_core/macro_interpreter: Make definitions of most private enums/unions hidden | Lioncash | 2 | -72/+79 | |
This allows the implementation of these types to change without requiring a rebuild of everything that includes the macro interpreter header. | |||||
2019-10-17 | core/core: Resolve -Wreorder warnings | Lioncash | 1 | -2/+2 | |
Amends the initializer lists to be ordered in the same manner that they're declared within the class. | |||||
2019-10-17 | core/memory/cheat_engine: Resolve -Wreorder warnings | Lioncash | 1 | -4/+3 | |
Amends the initializer lists to be ordered in the same manner that they're declared within the class. | |||||
2019-10-17 | apm/controller: Make SetPerformanceConfiguration() use an array of pairs over a map | Lioncash | 1 | -14/+34 | |
While a map is an OK way to do lookups (and usually recommended in most cases), this is a map that lives for the entire duration of the program and only deallocates its contents when the program terminates. Given the total size of the map is quite small, we can simply use a std::array of pairs and utilize std::find_if to perform the same behavior without loss of performance. This eliminates a static constructor and places the data into the read-only segment. While we're at it, we can also handle malformed inputs instead of directly dereferencing the resulting iterator. | |||||
2019-10-17 | apm/controller: Make GetCurrentPerformanceMode() a const member function | Lioncash | 2 | -2/+2 | |
This doesn't modify instance state, so it can be made const qualified. | |||||
2019-10-17 | Fermi2D: limit blit area to only available area | Fernando Sahmkow | 1 | -4/+14 | |
Normaly OpenGL does not care if the areas exceed the texture regions but other backends such as Vulkan do care about the limits of this areas. This PR crops the areas of the blit in order that they don't surpass the limits of the textures. This should help Vulkan and faulty OpenGL drivers | |||||
2019-10-16 | video_core/surface: Add missing break in PixelFormatFromTextureFormat() | Lioncash | 1 | -0/+1 | |
Prevents fallthrough into the following case. | |||||
2019-10-16 | vk_shader_decompiler: Resolve fallthrough within ExprDecompiler's ExprCondCode operator() | Lioncash | 1 | -0/+3 | |
This would previously result in NeverExecute and UnusedIndex being treated as regular predicates. | |||||
2019-10-16 | gl_shader_decompiler: Resolve fallthrough within ExprDecompiler's ExprCondCode operator() | Lioncash | 1 | -0/+3 | |
This would previously result in NeverExecute and UnusedIndex being treated as regular predicates. | |||||
2019-10-16 | texture_cache: Avoid unnecessary surface copies within PickStrategy() and TryReconstructSurface() | Lioncash | 1 | -2/+2 | |
We can take these by const reference and avoid making unnecessary copies, preventing some atomic reference count increments and decrements. | |||||
2019-10-16 | control_flow: Silence truncation warnings | Lioncash | 2 | -4/+4 | |
This can be trivially fixed by making the input size a size_t. CFGRebuildState's constructor parameter is already a std::size_t, so this just makes the size type fully conform with it. | |||||
2019-10-16 | gl_shader_decompiler: Make ExprDecompiler's GetResult() a const member function | Lioncash | 1 | -1/+1 | |
This is only ever used to read, but not write, the resulting string, so we can enforce this by making it a const member function. | |||||
2019-10-16 | gl_shader_decompiler: Use a std::string_view with GetDeclarationWithSuffix() | Lioncash | 1 | -1/+1 | |
This allows the function to be completely non-allocating for inputs of all sizes (i.e. there's no heap cost for an input to convert to a std::string_view). | |||||
2019-10-16 | gl_shader_decompiler: Fold flow_var constant into GetFlowVariable() | Lioncash | 1 | -3/+1 | |
This is only ever used within this function, so we can narrow it's scope down. | |||||
2019-10-16 | gl_shader_decompiler: Mark ASTDecompiler/ExprDecompiler parameters as const references where applicable | Lioncash | 1 | -21/+21 | |
These member functions don't actually modify the input parameter, so we can make this explicit with the use of const. | |||||
2019-10-16 | gl_shader_decompiler: Pass by reference to GenerateTextureArgument() | Lioncash | 1 | -2/+2 | |
Avoids an unnecessary atomic reference count increment and decrement. | |||||
2019-10-16 | gl_shader_decompiler: Use std::holds_alternative within GenerateTexture() | Lioncash | 1 | -1/+1 | |
This only ever queries if the type exists within the variant, but doesn't actually do anything with the return value. We can just use std::holds_alternative for this use case. | |||||
2019-10-16 | shader/node: std::move Meta instance within OperationNode constructor | Lioncash | 1 | -1/+1 | |
Allows usages of the constructor to avoid an unnecessary copy. | |||||
2019-10-16 | gl_shader_decompiler: Avoid unnecessary copies of MetaImage | Lioncash | 1 | -4/+4 | |
MetaImage contains a std::vector, so copying here could result in unnecessary reallocations. Given the operation lives throughout the entire scope, this is safe to do. | |||||
2019-10-15 | maxwell_3d: Silence truncation warnings | Lioncash | 1 | -1/+2 | |
A trivial warning caused by not using size_t as the argument types instead of u32. | |||||
2019-10-15 | video_core/gpu: Remove use of the global system accessor | Lioncash | 1 | -1/+1 | |
We can just make use of the reference member variable instead of accessing the global system instance. | |||||
2019-10-15 | bcat: Remove use of global system accessors | Lioncash | 6 | -29/+55 | |
Removes all uses of the global system accessor within the BCAT interface. | |||||
2019-10-15 | video_core/texture_cache: Amend Doxygen references | Lioncash | 1 | -57/+78 | |
Amends the doxygen comments so that they properly resolve. While we're at it, we can correct some typos and fix up some of the comments' formatting in order to make them slightly nicer to read. | |||||
2019-10-15 | common/algorithm: Add description comment indicating intended algorithms | Lioncash | 1 | -0/+5 | |
Makes it explicit that the header is intended for iterator-based algorithms that can ideally operate on any type. | |||||
2019-10-15 | common: Rename binary_find.h to algorithm.h | Lioncash | 4 | -4/+5 | |
Makes the header more general for other potential algorithms in the future. While we're at it, include a missing <functional> include to satisfy the use of std::less. | |||||
2019-10-15 | Kernel Thread: Cleanup THREADPROCESSORID_DONT_UPDATE. | Fernando Sahmkow | 2 | -4/+1 | |
2019-10-15 | Kernel: Address Feedback 2 | Fernando Sahmkow | 2 | -9/+6 | |
2019-10-15 | Kernel: Clang Format | Fernando Sahmkow | 2 | -5/+5 | |
2019-10-15 | Kernel: Reverse global accessor removal. | Fernando Sahmkow | 4 | -23/+9 | |
2019-10-15 | Kernel: Address Feedback. | Fernando Sahmkow | 6 | -67/+98 | |
2019-10-15 | Kernel Scheduler: Make sure the global scheduler shutdowns correctly. | Fernando Sahmkow | 7 | -0/+31 | |
2019-10-15 | Kernel_Thread: Eliminate most global accessors. | Fernando Sahmkow | 1 | -11/+11 | |
2019-10-15 | KernelSVC: Assert that condition variable address is aligned to 4 bytes. | Fernando Sahmkow | 1 | -0/+4 | |
2019-10-15 | Kernel: Correct Paused scheduling | Fernando Sahmkow | 1 | -3/+1 | |
2019-10-15 | Kernel: Corrections to Wait Objects clearing in which a thread could still be signalled after a timeout or a cancel. | Fernando Sahmkow | 3 | -3/+4 | |
2019-10-15 | Kernel: Correct redundant yields to only advance time forward. | Fernando Sahmkow | 1 | -3/+5 | |
2019-10-15 | Kernel: Corrections to ModifyByWaitingCountAndSignalToAddressIfEqual | Fernando Sahmkow | 1 | -5/+13 | |
2019-10-15 | Kernel: Correct Results in Condition Variables and Mutexes | Fernando Sahmkow | 3 | -24/+17 | |
2019-10-15 | Kernel: Clang Format | Fernando Sahmkow | 2 | -2/+3 | |
2019-10-15 | Kernel: Remove global system accessor from WaitObject | Fernando Sahmkow | 4 | -2/+17 | |
2019-10-15 | Scheduler: Implement Yield Count and Core migration on Thread Preemption. | Fernando Sahmkow | 2 | -5/+85 | |
2019-10-15 | Scheduler: Corrections to YieldAndBalanceLoad and Yield bombing protection. | Fernando Sahmkow | 2 | -8/+8 | |
2019-10-15 | Kernel: Initial implementation of thread preemption. | Fernando Sahmkow | 3 | -0/+30 | |
2019-10-15 | Scheduler: Add protections for Yield bombing | Fernando Sahmkow | 5 | -24/+31 | |
In case of redundant yields, the scheduler will now idle the core for it's timeslice, in order to avoid continuously yielding the same thing over and over. | |||||
2019-10-15 | Kernel: Style and Corrections | Fernando Sahmkow | 12 | -96/+137 | |
2019-10-15 | Correct PrepareReschedule | Fernando Sahmkow | 6 | -38/+29 | |
2019-10-15 | Comment and reorganize the scheduler | Fernando Sahmkow | 2 | -98/+104 | |
2019-10-15 | Add PrepareReschedule where required. | Fernando Sahmkow | 3 | -16/+18 | |
2019-10-15 | Correct compiling errors and addapt to the new interface. | Fernando Sahmkow | 3 | -27/+15 | |
2019-10-15 | Correct Supervisor Calls to work with the new scheduler, | Fernando Sahmkow | 1 | -26/+41 | |
2019-10-15 | Redesign CPU Cores to work with the new scheduler | Fernando Sahmkow | 2 | -13/+12 | |
2019-10-15 | Add interfacing to the Global Scheduler | Fernando Sahmkow | 4 | -0/+34 | |
2019-10-15 | Addapt thread class to the new Scheduler | Fernando Sahmkow | 2 | -60/+237 | |
2019-10-15 | Implement a new Core Scheduler | Fernando Sahmkow | 2 | -258/+411 | |
2019-10-13 | card_image: Implement system update commands in XCI | Zach Hilman | 2 | -3/+37 | |
2019-10-13 | pl_u: Fix mismatched rebase size error in font encryption | Zach Hilman | 3 | -19/+17 | |
2019-10-13 | pl_u: Use kernel physical memory | Zach Hilman | 2 | -4/+8 | |
2019-10-13 | pl_u: Remove excess static qualifier | Zach Hilman | 1 | -1/+1 | |
2019-10-13 | pl_u: Use OSS system archives if real archives don't exist | Zach Hilman | 2 | -112/+48 | |
2019-10-13 | system_archive: Synthesize shared fonts system archives | Zach Hilman | 3 | -5/+101 | |
2019-10-13 | externals: Move OSS font data to file_sys in core | Zach Hilman | 13 | -1/+73324 | |
2019-10-12 | nvflinger/buffer_queue: Remove use of a global system accessor | Lioncash | 3 | -4/+8 | |
2019-10-12 | Core_Timing: Address Remaining feedback. | Fernando Sahmkow | 1 | -5/+4 | |
2019-10-12 | Core_Timing: Fix tests. | Fernando Sahmkow | 1 | -2/+2 | |
2019-10-11 | Core_Timing: Address Feedback and suppress warnings. | Fernando Sahmkow | 5 | -13/+12 | |
2019-10-11 | AsyncGpu: Address Feedback | Fernando Sahmkow | 2 | -2/+2 | |
2019-10-10 | fixed clang format & addressed feedback | FreddyFunk | 1 | -26/+24 | |
2019-10-10 | yuzu/configure_input_player: Fix input handling for ZL and ZR from controllers with analog triggers | FreddyFunk | 1 | -7/+23 | |
2019-10-09 | Surfaces: Implement R4G4B4A4U format. | Fernando Sahmkow | 4 | -24/+41 | |
2019-10-09 | Surfaces: Implement ASTC 6x6 10x10 12x12 8x6 6x5 | Fernando Sahmkow | 4 | -70/+185 | |
2019-10-09 | Core Timing: Correct Idle and remove lefting pragma | Fernando Sahmkow | 1 | -2/+1 | |
2019-10-09 | Core Timing: General corrections and added tests. | Fernando Sahmkow | 3 | -7/+165 | |
2019-10-09 | Tests: Eliminate old Core Timing Tests | Fernando Sahmkow | 1 | -193/+0 | |
2019-10-09 | Core Timing: Rework Core Timing to run all cores evenly. | Fernando Sahmkow | 6 | -38/+89 | |
2019-10-07 | shader/half_set_predicate: Fix HSETP2 for constant buffers | ReinUsesLisp | 1 | -0/+2 | |
HSETP2 when used with a constant buffer parses the second operand type as F32. This is not configurable. | |||||
2019-10-07 | shader/half_set_predicate: Reduce DEBUG_ASSERT to LOG_DEBUG | ReinUsesLisp | 1 | -1/+2 | |
2019-10-07 | hid: Implement DeactivateNpad | Morph | 2 | -1/+13 | |
Makes use of the already existing DeactivateController function. | |||||
2019-10-07 | hid: Stub SetNpadJoyAssignmentModeSingle and reorganize service commands | Morph | 2 | -92/+126 | |
2019-10-07 | alignment: Resolve allocator construction issues on debug | Lioncash | 1 | -0/+5 | |
This was related to the source allocator being passed into the constructor potentially having a different type than allocator being constructed. We simply need to provide a constructor to handle this case. This resolves issues related to the allocator causing debug builds on MSVC to fail. | |||||
2019-10-07 | alignment: Specify trait definitions within the allocator | Lioncash | 1 | -0/+5 | |
Allows containers and other data structures to consider optimizations based off of them. We satisfy all of these requirements anyways. | |||||
2019-10-06 | gl_shader_disk_cache: Properly ignore existing cache | ReinUsesLisp | 2 | -16/+17 | |
Previously old entries where appended to the file even if the shader cache was ignored at boot. Address that issue. | |||||
2019-10-06 | bcat/module: Silence truncation warnings | Lioncash | 1 | -3/+3 | |
We need to perform explicit casts here, otherwise we're implicitly truncating a 64-bit type to a 32-bit one. | |||||
2019-10-06 | bcat: Take std::function instance by value in NullBackend's constructor | Lioncash | 2 | -2/+2 | |
Without this, the std::move within the constructor initializer list won't be able to actually perform a move. | |||||
2019-10-06 | bcat: In-class initialize ProgressServiceBackend's impl member | Lioncash | 2 | -2/+2 | |
Allows us to remove a constructor initializer list. | |||||
2019-10-06 | bcat: Make ProgressServiceBackend's constructor take a std::string_view | Lioncash | 2 | -3/+7 | |
Given the string is appended to another, we can make it a view so a redundant full copy of the string isn't made. | |||||
2019-10-06 | qt: Fix game name format error | Zach Hilman | 1 | -2/+2 | |
2019-10-06 | bcat: Make ProgressServiceBackend's GetEvent() const | Lioncash | 2 | -2/+2 | |
This member function doesn't modify internal member state, so it can be marked const. | |||||
2019-10-06 | boxcat: Silence an unused variable warning | Lioncash | 1 | -1/+2 | |
On parse errors, we can log out the explanatory string indicating what the parsing error was, rather than just ignoring the variable and returning an overly broad error code. | |||||
2019-10-06 | core/core: Remove unused header | Lioncash | 1 | -1/+0 | |
This isn't used anywhere in either the cpp or header file. | |||||
2019-10-06 | core: Remove Core::CurrentProcess() | Lioncash | 5 | -13/+11 | |
This only encourages the use of the global system instance (which will be phased out long-term). Instead, we use the direct system function call directly to remove the appealing but discouraged short-hand. | |||||
2019-10-06 | hle/service: Replace global system instance calls with instance-based ones | Lioncash | 14 | -51/+76 | |
Migrates the HLE service code off the use of directly accessing the global system instance where trivially able to do so. This removes all usages of Core::CurrentProcess from the service code, only 8 occurrences of this function exist elsewhere. There's still quite a bit of "System::GetInstance()" being used, however this was able to replace a few instances. | |||||
2019-10-05 | video_core/control_flow: Eliminate variable shadowing warnings | Lioncash | 1 | -6/+6 | |
2019-10-05 | video_core/control_flow: Eliminate pessimizing moves | Lioncash | 1 | -5/+8 | |
These can inhibit the ability of a compiler to perform RVO. | |||||
2019-10-05 | video_core/ast: Unindent most of IsFullyDecompiled() by one level | Lioncash | 1 | -12/+12 | |
2019-10-05 | video_core/ast: Make ShowCurrentState() take a string_view instead of std::string | Lioncash | 2 | -2/+2 | |
Allows the function to be non-allocating in terms of the output string. | |||||
2019-10-05 | video_core/ast: Eliminate variable shadowing warnings | Lioncash | 1 | -3/+3 | |
2019-10-05 | video_core/ast: Replace std::string with a constexpr std::string_view | Lioncash | 1 | -3/+1 | |
Same behavior, but without the need to heap allocate | |||||
2019-10-05 | video_core/ast: Default the move constructor and assignment operator | Lioncash | 2 | -26/+2 | |
This is behaviorally equivalent and also fixes a bug where some members weren't being moved over. | |||||
2019-10-05 | video_core/{ast, expr}: Organize forward declaration | Lioncash | 2 | -10/+10 | |
Keeps them alphabetically sorted for readability. | |||||
2019-10-05 | video_core/expr: Supply operator!= along with operator== | Lioncash | 2 | -1/+32 | |
Provides logical symmetry to the interface. | |||||
2019-10-05 | video_core/{ast, expr}: Use std::move where applicable | Lioncash | 4 | -45/+47 | |
Avoids unnecessary atomic reference count increments and decrements. | |||||
2019-10-05 | video_core/ast: Supply const accessors for data where applicable | Lioncash | 2 | -37/+41 | |
Provides const equivalents of data accessors for use within const contexts. | |||||
2019-10-05 | qt: Change titlebar formatting | Zach Hilman | 1 | -6/+15 | |
2019-10-05 | common: Add additional SCM revision fields | Zach Hilman | 3 | -0/+21 | |
2019-10-05 | maxwell_3d: Add dirty flags for depth bounds values | ReinUsesLisp | 2 | -1/+10 | |
This is useful in Vulkan where we want to update depth bounds without caring if it's enabled or disabled through vkCmdSetDepthBounds. | |||||
2019-10-05 | GL_Renderer: Remove lefting snippet. | Fernando Sahmkow | 1 | -2/+0 | |
2019-10-05 | NvFlinger: Remove leftover from corrections and clang format. | Fernando Sahmkow | 1 | -4/+0 | |
2019-10-05 | Gl_Rasterizer: Protect CPU Memory mapping from multiple threads. | Fernando Sahmkow | 2 | -0/+4 | |
2019-10-05 | Core: Wait for GPU to be idle before shutting down. | Fernando Sahmkow | 7 | -0/+19 | |
2019-10-05 | Nvdrv: Correct Event setup in Nvdrv | Fernando Sahmkow | 2 | -23/+14 | |
Events are supposed to be cleared on quering. This fixes that issue. | |||||
2019-10-05 | NVFlinger: Reverse the change that only signaled events on buffer acquire. | Fernando Sahmkow | 2 | -20/+1 | |
This has been hardware tested and it seems that NVFlinger will still signal even if there are no buffers to present. | |||||
2019-10-05 | Nvdrv: Do framelimiting only in the CPU Thread | Fernando Sahmkow | 2 | -3/+4 | |
2019-10-05 | NvFlinger: Don't swap buffers if a frame is missing and always trigger event in sync gpu. | Fernando Sahmkow | 1 | -1/+3 | |
2019-10-05 | GPU_Async: Correct fences, display events and more. | Fernando Sahmkow | 6 | -21/+38 | |
This commit uses guest fences on vSync event instead of an articial fake fence we had. It also corrects to keep signaling display events while loading the game as the OS is suppose to send buffers to vSync during that time. | |||||
2019-10-05 | Nvdrv: Correct Async regression and avoid signaling empty buffer vsyncs | Fernando Sahmkow | 2 | -3/+9 | |
2019-10-05 | audio/audout_u: Change formatting for old clang-format versions | ReinUsesLisp | 1 | -1/+1 | |
2019-10-05 | yuzu/game_list_worker: Silence warnings | ReinUsesLisp | 2 | -8/+9 | |
2019-10-05 | yuzu/game_list: Silence -Wswitch and -Wunused-variable | ReinUsesLisp | 2 | -5/+12 | |
2019-10-05 | yuzu/configure_service: Silence -Wswitch | ReinUsesLisp | 1 | -0/+2 | |
2019-10-05 | yuzu_tester: Remove unused variable | ReinUsesLisp | 1 | -1/+0 | |
2019-10-05 | service/nvdrv: Silence -Wswitch | ReinUsesLisp | 4 | -4/+10 | |
2019-10-05 | service/nfp: Silence -Wunused and -Wswitch | ReinUsesLisp | 1 | -4/+5 | |
2019-10-05 | service/hid: Silence -Wunused and -Wswitch | ReinUsesLisp | 15 | -23/+18 | |
2019-10-05 | service/am: Silence -Wreorder | ReinUsesLisp | 1 | -2/+1 | |
2019-10-05 | service/hid: Remove unused system reference | ReinUsesLisp | 2 | -2/+1 | |
2019-10-05 | service/friend: Remove unused field | ReinUsesLisp | 1 | -1/+0 | |
2019-10-05 | service/filesystem: Silence -Wunused-variable | ReinUsesLisp | 1 | -1/+1 | |
2019-10-05 | service/bcat: Silence -Wreorder and -Wunused | ReinUsesLisp | 2 | -2/+2 | |
2019-10-05 | service/audio: Silence -Wunused | ReinUsesLisp | 1 | -1/+1 | |
2019-10-05 | service/apm: Silence -Wunused and -Wreorder | ReinUsesLisp | 2 | -4/+5 | |
2019-10-05 | common/file_util: Silence -Wswitch | ReinUsesLisp | 1 | -1/+2 | |
2019-10-05 | Texture_Cache: Blit Deduction corrections and simplifications. | Fernando Sahmkow | 1 | -18/+20 | |
2019-10-05 | TextureCache: Add the ability to deduce if two textures are depth on blit. | Fernando Sahmkow | 1 | -2/+142 | |
2019-10-05 | Shader_ir: Address feedback | Fernando Sahmkow | 6 | -65/+24 | |
2019-10-05 | Shader_Ir: Address Feedback and clang format. | Fernando Sahmkow | 4 | -68/+68 | |
2019-10-05 | vk_shader_decompiler: Correct Branches inside conditionals. | Fernando Sahmkow | 1 | -1/+11 | |
2019-10-05 | vk_shader_decompiler: Clean code and be const correct. | Fernando Sahmkow | 2 | -8/+6 | |
2019-10-05 | Shader_IR: clean up AST handling and add documentation. | Fernando Sahmkow | 1 | -2/+6 | |
2019-10-05 | Shader_IR: Correct OutwardMoves for Ifs | Fernando Sahmkow | 1 | -22/+11 | |
2019-10-05 | vk_shader_compiler: Don't enclose branches with if(true) to avoid crashing AMD | Fernando Sahmkow | 1 | -16/+33 | |
2019-10-05 | gl_shader_decompiler: Refactor and address feedback. | Fernando Sahmkow | 1 | -17/+18 | |
2019-10-05 | Shader_IR: corrections and clang-format | Fernando Sahmkow | 2 | -70/+64 | |
2019-10-05 | vk_shader_compiler: Correct SPIR-V AST Decompiling | Fernando Sahmkow | 1 | -4/+11 | |
2019-10-05 | Shader_IR: allow else derivation to be optional. | Fernando Sahmkow | 7 | -10/+18 | |
2019-10-05 | vk_shader_compiler: Implement the decompiler in SPIR-V | Fernando Sahmkow | 3 | -23/+301 | |
2019-10-05 | Shader_IR: mark labels as unused for partial decompile. | Fernando Sahmkow | 2 | -3/+9 | |
2019-10-05 | Shader_Ir: Refactor Decompilation process and allow multiple decompilation modes. | Fernando Sahmkow | 14 | -82/+336 | |
2019-10-05 | gl_shader_decompiler: Implement AST decompiling | Fernando Sahmkow | 11 | -63/+358 | |
2019-10-05 | shader_ir: Declare Manager and pass it to appropiate programs. | Fernando Sahmkow | 7 | -104/+214 | |
2019-10-05 | shader_ir: Corrections to outward movements and misc stuffs | Fernando Sahmkow | 7 | -58/+310 | |
2019-10-05 | shader_ir: Add basic goto elimination | Fernando Sahmkow | 2 | -38/+484 | |
2019-10-05 | shader_ir: Initial Decompile Setup | Fernando Sahmkow | 6 | -5/+510 | |
2019-10-05 | SDL: Fix missing header | Fernando Sahmkow | 1 | -0/+1 | |
This fixes linux and mingw builds. | |||||
2019-10-02 | [crypto] Use IsAllZeroArray helper function | vperus | 1 | -1/+1 | |
2019-10-02 | qt: Add service dialog | Zach Hilman | 5 | -17/+20 | |
2019-10-01 | boxcat: Use updated game-asset API URL and tags | Zach Hilman | 1 | -6/+6 | |
2019-10-01 | bcat: Add FSC accessors for BCAT data | Zach Hilman | 10 | -31/+51 | |
Ports BCAT to use FSC interface | |||||
2019-10-01 | gl_rasterizer: Fix polygon offset units | ReinUsesLisp | 1 | -1/+3 | |
For some reason hardware divides polygon offset units by two. This is visible since drivers multiply the application requested polygon offset by two. | |||||
2019-09-30 | boxcat: Implement events global field | Zach Hilman | 6 | -30/+43 | |
2019-09-30 | bcat: Implement DeliveryCacheProgressImpl structure | Zach Hilman | 6 | -88/+314 | |
Huge thanks to lioncash for re-ing this for me. | |||||
2019-09-30 | boxcat: Use Etag header names for file digest | Zach Hilman | 2 | -24/+21 | |
2019-09-30 | boxcat: Add downloading and client for launch parameter data | Zach Hilman | 2 | -16/+77 | |
2019-09-30 | bcat: Add backend function for BCAT Indirect (launch parameter) | Zach Hilman | 2 | -0/+11 | |
Returns the data that should be returned by PopLaunchParameter kind=ApplicationSpecific. | |||||
2019-09-30 | bcat: Expose CreateBackendFromSettings helper function | Zach Hilman | 2 | -2/+2 | |
2019-09-30 | am: Unstub PopLaunchParameter and add bcat connection for app-specific data | Zach Hilman | 2 | -16/+52 | |
Previously we were simply returning the account-preselect structure all times but if passed with a different mode the game expects application-specific data. This also adds a hook for BCAT into this allowing us to send the launch parameter through bcat, | |||||
2019-09-30 | configure_service: Allow Qt to open external links | Zach Hilman | 1 | -0/+3 | |
2019-09-30 | yuzu: Add UI tab to configure BCAT services | Zach Hilman | 6 | -0/+302 | |
Also displays current events if boxcat is selected. | |||||
2019-09-30 | bcat: Implement cmd 90201 ClearDeliveryCacheStorage | Zach Hilman | 1 | -1/+23 | |
Takes a title ID and simply deletes all the data for that title ID's bcat. Invokes the respective backend command. | |||||
2019-09-30 | bcat: Implement cmd 30100 SetPassphrase | Zach Hilman | 1 | -1/+33 | |
Takes a title ID and passphrase (0x40 byte string) and passes it to the backend. | |||||
2019-09-30 | bcat: Implement cmd RequestSyncDeliveryCache and variant | Zach Hilman | 1 | -2/+70 | |
Variant also supports only updating a single directory. These just both invoke backend commands. | |||||
2019-09-30 | bcat: Implement IDeliveryCacheProgressService commands | Zach Hilman | 1 | -0/+131 | |
Used to query completion status and events for the current delivery task. | |||||
2019-09-30 | bcat: Implement IDeliveryCacheFileService commands | Zach Hilman | 1 | -0/+117 | |
Used to read the contents of files and access their metadata. | |||||
2019-09-30 | bcat: Implement IDeliveryCacheDirectoryService commands | Zach Hilman | 1 | -0/+99 | |
Used to list and get directories at the root level. | |||||
2019-09-30 | bcat: Implement IDeliveryCacheStorageService commands | Zach Hilman | 1 | -0/+58 | |
Used to create subclasses to manage files and directories and to list directories. | |||||
2019-09-30 | bcat: Add commands to create IDeliveryCacheStorageService | Zach Hilman | 3 | -2/+32 | |
Used to access contents of download. | |||||
2019-09-30 | module: Create BCAT backend based upon Settings value on construction | Zach Hilman | 3 | -1/+36 | |
2019-09-30 | bcat: Add BCAT backend for Boxcat service | Zach Hilman | 2 | -0/+407 | |
Downloads content from yuzu servers and unpacks it into the temporary directory provided. Fully supports all Backend features except passphrase. | |||||
2019-09-30 | bcat: Add backend class to generify the functions of BCAT | Zach Hilman | 2 | -0/+100 | |
Provides the most abstract simplified functions of BCAT as functions. Also includes a NullBackend class which is just a no-op. | |||||
2019-09-30 | settings: Add option to set BCAT backend | Zach Hilman | 6 | -0/+34 | |
2019-09-30 | nifm: Signal to applications that internet access is available | Zach Hilman | 1 | -3/+10 | |
2019-09-30 | core/loader: Track the NSO build ID of the current process | Zach Hilman | 3 | -0/+14 | |
2019-09-30 | applets: Add accessor for AppletFrontendSet | Zach Hilman | 2 | -0/+6 | |
Allows other services to call applets without using LLE. | |||||
2019-09-30 | filesystem: Add getter for BCAT temporary directory | Zach Hilman | 3 | -0/+16 | |
2019-09-30 | vfs: Add function to extract ZIP file into virtual filesystem | Zach Hilman | 2 | -0/+96 | |
2019-09-30 | Revert "arm_dynarmic: Check if jit is nullptr when preparing reschedule" | bunnei | 1 | -3/+0 | |
2019-09-29 | Services::ES fix casting warnings | FreddyFunk | 1 | -6/+6 | |
2019-09-26 | yuzu: Pause when in background | FearlessTobi | 6 | -0/+38 | |
Co-Authored-By: Vitor K <vitor-k@users.noreply.github.com> | |||||
2019-09-24 | Signal styleset changes at a better time | David Marcec | 1 | -8/+2 | |
We should signal when a net controller is added and our event should be manual, not automatic. | |||||
2019-09-24 | gl_shader_decompiler: Add tailing return for HUnpack2 | ReinUsesLisp | 1 | -0/+2 | |
2019-09-24 | gl_shader_decompiler: Fix clang build issues | ReinUsesLisp | 1 | -26/+23 | |
2019-09-23 | card_image: Add accessors for raw partitions in XCI | Zach Hilman | 2 | -0/+36 | |
2019-09-23 | card_image: Lazily load partitions in XCI | Zach Hilman | 2 | -26/+41 | |
2019-09-23 | pfs: Provide accessors for file sizes and offsets | Zach Hilman | 2 | -0/+17 | |
2019-09-22 | cmake: Add SCM detection for Azure | Zach Hilman | 1 | -0/+3 | |
2019-09-22 | lm: Flush manager output on core shutdown | Zach Hilman | 5 | -11/+15 | |
2019-09-22 | lm: Rename Initialize to Log and implement with manager/reporter | Zach Hilman | 1 | -140/+22 | |
Allows saving and clearer output of data. | |||||
2019-09-22 | lm: Implement manager class to output to reporter | Zach Hilman | 2 | -0/+233 | |
2019-09-22 | core: Add LM::Manager to system | Zach Hilman | 6 | -19/+39 | |
Allows centralized control over logging mechanisms. | |||||
2019-09-22 | reporter: Add log output for packaged lm log data | Zach Hilman | 2 | -0/+69 | |
Takes the vector from head to tail of log data and saves it. | |||||
2019-09-22 | qt_themes: add two colorful themes | FearlessTobi | 2 | -1/+3 | |
These two colorful themes are based on the Default and Dark themes, and contain icons that are colored rather than black and white. These icons come from icons8.com and they have been slightly revised by me. I'm pretty sure I was licensed to use them for Citra. Co-Authored-By: Pengfei Zhu <zhupengfei321@sina.cn> | |||||
2019-09-22 | main: Use const on all variable initializations | Zach Hilman | 1 | -2/+2 | |
2019-09-22 | Add FPS to SDL title bar | jroweboy | 3 | -2/+17 | |
Also fix a small issue with incorrect shutdown ordering in SDL. Previously the system would still be running so the telemetry task didn't launch and detached_tasks would assert(count == 0) | |||||
2019-09-22 | Add missing include | FearlessTobi | 1 | -0/+1 | |
2019-09-22 | removed comment | David Marcec | 1 | -1/+0 | |
2019-09-22 | Rebased | David Marcec | 3 | -11/+19 | |
2019-09-22 | service/acc: Lower log severity from INFO to DEBUG | FearlessTobi | 1 | -7/+7 | |
According to ogniK, this should have always been Debug and not Info. | |||||
2019-09-22 | Maxwell3D: Corrections and refactors to MME instance refactor | Fernando Sahmkow | 4 | -44/+46 | |
2019-09-22 | removed unneeded semicolon | David Marcec | 1 | -1/+1 | |
2019-09-22 | Revert "Merge pull request #2709 from DarkLordZach/oss-ext-fonts-1" | David Marcec | 18 | -73477/+123 | |
This reverts commit fa1c60c33ef88c6cd0b72da46842dc9098db712d, reversing changes made to e34899067b60a69bca02761bd1290c6824bb559a. | |||||
2019-09-22 | Removed reference to core timing to nvflinger and used system instead | David Marcec | 1 | -1/+1 | |
2019-09-22 | marked controller constructors as explicit | David Marcec | 8 | -8/+8 | |
2019-09-22 | Rebase | David Marcec | 25 | -62/+75 | |
2019-09-22 | Rebase | David Marcec | 5 | -20/+21 | |
2019-09-22 | Deglobalize System: Vi | David Marcec | 3 | -8/+8 | |
2019-09-22 | Deglobalize System: Time | David Marcec | 4 | -14/+21 | |
2019-09-22 | Rebase | David Marcec | 2 | -8/+12 | |
2019-09-22 | Deglobalize System: NvFlinger | David Marcec | 2 | -6/+7 | |
2019-09-22 | Rebase | David Marcec | 4 | -8/+12 | |
2019-09-22 | Deglobalize System: Nim | David Marcec | 2 | -7/+12 | |
2019-09-22 | Deglobalize System: Nifm | David Marcec | 2 | -13/+23 | |
2019-09-22 | Deglobalize System: NFP | David Marcec | 4 | -14/+16 | |
2019-09-22 | Deglobalize System: LDR | David Marcec | 2 | -6/+7 | |
2019-09-22 | Deglobalize System: IRS | David Marcec | 3 | -5/+6 | |
2019-09-22 | Deglobalize System: Hid | David Marcec | 20 | -37/+44 | |
2019-09-22 | Deglobalize System: Friend | David Marcec | 4 | -22/+24 | |
2019-09-22 | Deglobalize System: Fatal | David Marcec | 6 | -20/+29 | |
2019-09-22 | Deglobalize System: Btm | David Marcec | 2 | -7/+13 | |
2019-09-22 | Deglobalize System: Btdrv | David Marcec | 2 | -5/+9 | |
2019-09-22 | Deglobalize System: Aoc | David Marcec | 2 | -11/+13 | |
2019-09-22 | Deglobalize System: Am | David Marcec | 1 | -1/+1 | |
2019-09-22 | pl_u: Use kernel physical memory | Zach Hilman | 2 | -4/+8 | |
2019-09-22 | qt: Prompt user for confirmation if exit lock is active | Zach Hilman | 3 | -1/+44 | |
2019-09-22 | dmnt_cheat_vm: Default initialize structure values | Zach Hilman | 3 | -89/+88 | |
2019-09-22 | server side clang format fix2 | David Marcec | 1 | -18/+18 | |
2019-09-22 | am: Implement ISelfController ExitLock commands | Zach Hilman | 1 | -2/+6 | |
2019-09-22 | am: Implement ISelfController Exit | Zach Hilman | 4 | -4/+20 | |
Closes the current application. | |||||
2019-09-22 | am: Add RequestExit event to AppletMessageQueue | Zach Hilman | 2 | -0/+6 | |
Tested against libnx, signals to games to begin cleanup. | |||||
2019-09-22 | core: Track system exit lock status | Zach Hilman | 2 | -0/+15 | |
Used to determine if yuzu should confirm before pausing or stopping a game. | |||||
2019-09-22 | Use clang-format provided by build server | David Marcec | 1 | -20/+18 | |
2019-09-22 | pl_u: Remove excess static qualifier | Zach Hilman | 1 | -1/+1 | |
2019-09-22 | pl_u: Use OSS system archives if real archives don't exist | Zach Hilman | 3 | -111/+42 | |
2019-09-22 | dmnt_cheat_vm: Make Cheat VM compliant to code style | Zach Hilman | 4 | -870/+862 | |
2019-09-22 | core: Initialize cheats after load to avoid VMManager crash | Zach Hilman | 1 | -0/+5 | |
This used to occur due to the VMManager being nullptr at the time cheats were registered (during load, but before it was done). This is bypassed by not accessing the VMManager for offset data until load is complete, | |||||
2019-09-22 | core: Update RegisterCheatList for new VM | Zach Hilman | 2 | -11/+16 | |
2019-09-22 | patch_manager: Update cheat parsing for new VM | Zach Hilman | 2 | -15/+20 | |
2019-09-22 | nso: Pass build ID directly | Zach Hilman | 1 | -2/+1 | |
As opposed to converting to string and then back to hex array | |||||
2019-09-22 | cheat_engine: Move to memory and strip VM | Zach Hilman | 5 | -728/+325 | |
This is to go with the Atmosphere VM port, now it just contains the callbacks needed for the interface between DmntCheatVm and yuzu, along with the cheat parsers. | |||||
2019-09-22 | memory: Port Atmosphere's DmntCheatVm | Zach Hilman | 3 | -0/+1598 | |
This was done because the current VM contained many inaccuracies and this also allows cheats to have identical behavior between hardware and yuzu. | |||||
2019-09-22 | log: Add logging class for Cheat Engine | Zach Hilman | 2 | -0/+2 | |
This is better than just using something like Common.Filesystem or Common.Memory | |||||
2019-09-22 | Fix clang-format | FearlessTobi | 2 | -2/+2 | |
2019-09-22 | fermi_2d: Lower surface copy log severity to DEBUG | FearlessTobi | 1 | -1/+1 | |
2019-09-22 | video_core: Implement RGBX16F PixelFormat | FearlessTobi | 7 | -22/+37 | |
2019-09-22 | system_archive: Synthesize shared fonts system archives | Zach Hilman | 3 | -5/+101 | |
2019-09-22 | pl_u: Expose method to encrypt TTF to BFTTF | Zach Hilman | 2 | -14/+14 | |
2019-09-22 | externals: Move OSS font data to file_sys in core | Zach Hilman | 13 | -1/+73324 | |
2019-09-22 | prepo: Remove system global accessors | Zach Hilman | 3 | -15/+18 | |
2019-09-22 | prepo: Implement SaveReport New and System variants | Zach Hilman | 1 | -15/+71 | |
2019-09-22 | reporter: Differentiate between Old, New, and System play reports | Zach Hilman | 2 | -5/+15 | |
2019-09-22 | configure_debug: Move reporting option to logging | Zach Hilman | 15 | -63/+64 | |
2019-09-21 | config: Remove Dump options from configure_debug | Zach Hilman | 4 | -47/+39 | |
2019-09-21 | filesystem: Add const qualification to various accessors | Zach Hilman | 10 | -83/+94 | |
2019-09-21 | yuzu: Add UI to manage filesystem paths and sizes | Zach Hilman | 6 | -1/+627 | |
2019-09-21 | core: Store FileSystemController in core | Zach Hilman | 2 | -0/+32 | |
2019-09-21 | settings: Add options for managing gamecard emulation | Zach Hilman | 4 | -2/+67 | |
2019-09-21 | settings: Add options for setting storage sizes | Zach Hilman | 3 | -1/+57 | |
2019-09-21 | yuzu: Port old usages of Filesystem namespace to FilesystemController | Zach Hilman | 14 | -46/+106 | |
2019-09-21 | settings: Update LogSettings to show NAND/SDMC paths from FileUtil | Zach Hilman | 1 | -2/+3 | |
2019-09-21 | card_image: Add accessors for gamecard certificate | Zach Hilman | 2 | -0/+9 | |
Used by fsp-srv/IDeviceOperator | |||||
2019-09-21 | card_image: Add functions to query gamecard update partition | Zach Hilman | 2 | -0/+24 | |
Includes version and meta title ID, used by fsp-srv/IDeviceOperator | |||||
2019-09-21 | content_archive: Add accessors for Rights ID and SDK Version | Zach Hilman | 2 | -0/+10 | |
2019-09-21 | partition_data_manager: Add accessor for decrypted PRODINFO partition | Zach Hilman | 2 | -0/+5 | |
2019-09-21 | services: Pass FileSystemController as reference to services that need it | Zach Hilman | 11 | -20/+47 | |
2019-09-21 | am: Unstub IApplicationFunctions EnsureSaveData (20) | Zach Hilman | 1 | -8/+14 | |
Creates a default save data for the application given a user ID. | |||||
2019-09-21 | filesystem: Pass Size Getter functions to IFileSystem for sizes | Zach Hilman | 3 | -20/+31 | |
2019-09-21 | sdmc_factory: Add SD Card size getters | Zach Hilman | 2 | -0/+12 | |
2019-09-21 | bis_factory: Add getters for NAND partition sizes | Zach Hilman | 2 | -0/+38 | |
2019-09-21 | filesystem: Add FileSystemController to deglobalize FS services | Zach Hilman | 2 | -58/+359 | |
2019-09-21 | submisson_package: Fix edge case with improperly sized filenames | Zach Hilman | 1 | -1/+2 | |
Prevents a crash if the filename is less than 9 characters long. | |||||
2019-09-21 | sdmc_factory: Add accessor for SDMC Album directory | Zach Hilman | 2 | -0/+6 | |
2019-09-21 | sdmc_factory: Add accessor for SDMC PlaceholderCache | Zach Hilman | 2 | -1/+10 | |
2019-09-21 | sdmc_factory: Add accessor for content directory | Zach Hilman | 2 | -0/+7 | |
2019-09-21 | savedata_factory: Implement savedata creation and don't create dir on open | Zach Hilman | 2 | -26/+40 | |
Matches hardware behavior and eliminates some nasty behavior we were doing that wasn't hw-accurate at all. | |||||
2019-09-21 | patch_manager: Add short-circuit edge-case to GetPatchVersionNames | Zach Hilman | 1 | -0/+2 | |
If title ID is 0, there are no add ons, prevents wasting time looking for them. | |||||
2019-09-21 | patch_manager: Add error checking to load dir to prevent crashes | Zach Hilman | 1 | -0/+15 | |
Prevents a crash if the load dir would be nullptr, instead logs an error and returns appropriately. | |||||
2019-09-21 | registered_cache: Process *.cnmt.nca files | Zach Hilman | 1 | -16/+23 | |
Needed to use the RegisteredCache/PlaceholderCache on gamecards. | |||||
2019-09-21 | registered_cache: Implement PlaceholderCache to manage placeholder and installing content | Zach Hilman | 2 | -0/+175 | |
2019-09-21 | bis_factory: Fix mod loader edge-case with homebrew title IDs | Zach Hilman | 1 | -1/+1 | |
Fixes a bug where homebrew that has a title ID with the update bit set can cause issues with the PatchManager | |||||
2019-09-21 | bis_factory: Add accessors for BIS placeholder caches | Zach Hilman | 2 | -1/+20 | |
2019-09-21 | bis_factory: Add accessor for NAND Image Directory | Zach Hilman | 2 | -0/+6 | |
2019-09-21 | bis_factory: Add accessors for BIS content directories | Zach Hilman | 2 | -0/+11 | |
2019-09-21 | bis_factory: Add accessors for BIS partitions | Zach Hilman | 2 | -0/+61 | |
2019-09-21 | gl_shader_decompiler: Use uint for images and fix SUATOM | ReinUsesLisp | 7 | -188/+93 | |
In the process remove implementation of SUATOM.MIN and SUATOM.MAX as these require a distinction between U32 and S32. These have to be implemented with imageCompSwap loop. | |||||
2019-09-21 | shader/image: Implement SULD and remove irrelevant code | ReinUsesLisp | 10 | -47/+110 | |
* Implement SULD as float. * Remove conditional declaration of GL_ARB_shader_viewport_layer_array. | |||||
2019-09-21 | shader_bytecode: Add SULD encoding | ReinUsesLisp | 1 | -0/+2 | |
2019-09-21 | Shader_IR: ICMP corrections and fixes | Fernando Sahmkow | 2 | -6/+11 | |
2019-09-21 | Added Host CPU and OS to log | pbarilla | 1 | -0/+8 | |
2019-09-21 | Swapped TID and Game name to make it easier to parse | David Marcec | 1 | -1/+1 | |
2019-09-21 | Log the current title id and game name which is booting | David Marcec | 1 | -3/+3 | |
Spit out a LOG_INFO of the current game name and it's title id in the log. This helps to read log files and figure out which games have which issues | |||||
2019-09-21 | Used revision 5 instead of 7, marked constexpr as static | David Marcec | 1 | -2/+2 | |
2019-09-21 | Mark DrawArrays as LOG_TRACE | David Marcec | 1 | -1/+1 | |
There's no reason to clog logs with DrawArray. | |||||
2019-09-21 | Mark KickOffPb & SubmitGPFIFO as trace | David Marcec | 1 | -4/+4 | |
These functions are not stubbed and are called fairly often. Due to the nature of how often they're called, we should keep them marked as LOG_TRACE instead of LOG_DEBUG or LOG_WARNING | |||||
2019-09-20 | Rasterizer: Correct introduced bug where a conditional render wouldn't stop a draw call from executing | Fernando Sahmkow | 1 | -10/+16 | |
2019-09-20 | Shader_IR: Implement ICMP. | Fernando Sahmkow | 2 | -0/+37 | |
2019-09-20 | Added frame_count for REV7 audio renderer | David Marcec | 2 | -11/+24 | |
Added framecount | |||||
2019-09-20 | disable clang-format temp | David Marcec | 1 | -0/+2 | |
2019-09-19 | Rasterizer: Refactor and simplify DrawBatch Interface. | Fernando Sahmkow | 4 | -35/+16 | |
2019-09-19 | Rasterizer: Address Feedback and conscerns. | Fernando Sahmkow | 1 | -11/+11 | |
2019-09-19 | Rasterizer: Refactor draw calls, remove deadcode and clean up. | Fernando Sahmkow | 3 | -106/+68 | |
2019-09-19 | VideoCore: Corrections to the MME Inliner and removal of hacky instance management. | Fernando Sahmkow | 6 | -31/+81 | |
2019-09-19 | Video Core: initial Implementation of InstanceDraw Packaging | Fernando Sahmkow | 7 | -11/+192 | |
2019-09-19 | Initial implementation of Ioctl2 & Ioctl3 | David Marcec | 24 | -63/+143 | |
Purpose of Ioctl2 and Ioctl3 is to prevent the passing of raw pointers through ioctls | |||||
2019-09-19 | Core/Memory: Only FlushAndInvalidate GPU if the page is marked as RasterizerCachedMemory | Fernando Sahmkow | 1 | -2/+7 | |
This commit avoids Invalidating and Flushing the GPU if the page is not marked as a RasterizerCache Page. | |||||
2019-09-17 | shader_ir/warp: Implement SHFL | ReinUsesLisp | 6 | -9/+182 | |
2019-09-17 | maxwell_to_gl: Fix mipmap filtering | ReinUsesLisp | 1 | -2/+2 | |
OpenGL texture filters follow GL_<texture_filter>_MIPMAP_<mipmap_filter> but we were using them in the opposite way. | |||||
2019-09-17 | gl_rasterizer: Remove unused code paths from ConfigureFramebuffers | ReinUsesLisp | 4 | -121/+33 | |
2019-09-17 | When docked mode is checked, uncheck "joycons docked" | Morph | 1 | -0/+2 | |
2019-09-15 | maxwell_3d: Update firmware 4 call stub commentary | Rodrigo Locatti | 1 | -1/+2 | |
2019-09-13 | vk_device: Add miscellaneous features and minor style changes | ReinUsesLisp | 3 | -111/+258 | |
* Increase minimum Vulkan requirements * Require VK_EXT_vertex_attribute_divisor * Require depthClamp, samplerAnisotropy and largePoints features * Search and expose VK_KHR_uniform_buffer_standard_layout * Search and expose VK_EXT_index_type_uint8 * Search and expose native float16 arithmetics * Track current driver with VK_KHR_driver_properties * Query and expose SSBO alignment * Query more image formats * Improve logging overall * Minor style changes * Minor rephrasing of commentaries | |||||
2019-09-13 | video_core/surface: Add function to detect sRGB surfaces | ReinUsesLisp | 2 | -0/+22 | |
This is required for proper conversion to RGBA8_UNORM or RGBA8_SRGB surfaces when a backend can target both native and converted ASTC. | |||||
2019-09-11 | renderer_opengl: Fix rebase mistake | ReinUsesLisp | 1 | -1/+1 | |
2019-09-11 | shader/image: Implement SUATOM and fix SUST | ReinUsesLisp | 7 | -69/+329 | |
2019-09-11 | gl_rasterizer: Correct sRGB Fix regression | Fernando Sahmkow | 1 | -0/+12 | |
2019-09-11 | renderer_opengl: Fix sRGB blits | ReinUsesLisp | 6 | -43/+10 | |
Removes the sRGB hack of tracking if a frame used an sRGB rendertarget to apply at least once to blit the final texture as sRGB. Instead of doing this apply sRGB if the presented image has sRGB. Also enable sRGB by default on Maxwell3D registers as some games seem to assume this. | |||||
2019-09-10 | Address review comments | FearlessTobi | 2 | -6/+9 | |
2019-09-10 | Add frametime logging for tracking performance over time | fearlessTobi | 7 | -10/+90 | |
Co-Authored-By: jroweboy <jroweboy@gmail.com> | |||||
2019-09-07 | nro: Implement ReadControlData | Nick Renieris | 2 | -0/+10 | |
With this, the "Developer" field in the Properties for homebrew is now populated. Signed-off-by: Nick Renieris <velocityra@gmail.com> | |||||
2019-09-06 | gl_shader_decompiler: Avoid writing output attribute when unimplemented | ReinUsesLisp | 1 | -10/+14 | |
2019-09-06 | gl_shader_decompiler: Keep track of written images and mark them as modified | ReinUsesLisp | 7 | -62/+92 | |
2019-09-06 | texture_cache: Minor changes | ReinUsesLisp | 4 | -19/+17 | |
2019-09-06 | gl_rasterizer: Apply textures and images state | ReinUsesLisp | 1 | -0/+2 | |
2019-09-06 | gl_rasterizer: Add samplers to compute dispatches | ReinUsesLisp | 2 | -3/+36 | |
2019-09-06 | gl_rasterizer: Minor code changes | ReinUsesLisp | 2 | -20/+31 | |
2019-09-06 | gl_state: Split textures and samplers into two arrays | ReinUsesLisp | 4 | -91/+39 | |
2019-09-06 | gl_rasterizer: Implement image bindings | ReinUsesLisp | 5 | -32/+106 | |
2019-09-06 | gl_state: Add support for glBindImageTextures | ReinUsesLisp | 2 | -0/+24 | |
2019-09-06 | texture_cache: Pass TIC to texture cache | ReinUsesLisp | 4 | -27/+25 | |
2019-09-06 | kepler_compute: Implement texture queries | ReinUsesLisp | 5 | -5/+99 | |
2019-09-06 | gl_rasterizer: Split SetupTextures | ReinUsesLisp | 2 | -22/+38 | |
2019-09-05 | gl_shader_decompiler: Implement shared memory | ReinUsesLisp | 1 | -0/+23 | |
2019-09-05 | shader_ir: Implement LD_S | ReinUsesLisp | 1 | -10/+13 | |
Loads from shared memory. | |||||
2019-09-05 | shader_ir: Implement ST_S | ReinUsesLisp | 4 | -11/+45 | |
This instruction writes to a memory buffer shared with threads within the same work group. It is known as "shared" memory in GLSL. | |||||
2019-09-05 | Address review comments | FearlessTobi | 1 | -1/+4 | |
2019-09-05 | service/am: Remove usages of global system accessors | Lioncash | 17 | -97/+143 | |
Avoids the use of global accessors, removing the reliance on global state. This also makes dependencies explicit in the interface, as opposed to being hidden | |||||
2019-09-05 | yuzu/configure: move speed limiter to general | FearlessTobi | 4 | -33/+36 | |
The speed limiter being a frame limiter is an implmentation detail and can be changed in the future. What user care about is that it limit the emulation speed in genenral (not just graphics but also audio+input) Co-Authored-By: Weiyi Wang <wwylele@gmail.com> | |||||
2019-09-05 | kernel/vm_manager: Correct doxygen comment parameter tags for MapPhysicalMemory/UnmapPhysicalMemory | Lioncash | 1 | -4/+4 | |
Corrects the parameter names within the doxygen comments so that they resolve properly. | |||||
2019-09-05 | kernel/vm_manager: Move variables closer to usage spots in MapPhysicalMemory/UnmapPhysicalMemory | Lioncash | 1 | -16/+10 | |
Narrows the scope of variables down to where they're only necessary. | |||||
2019-09-04 | gl_shader_decompiler: Fixup slow path | ReinUsesLisp | 1 | -1/+1 | |
2019-09-04 | AM: Stub IApplicationFunctions::GetGpuErrorDetectedSystemEvent (#2827) | mailwl | 2 | -0/+16 | |
* AM: Implement IApplicationFunctions::GetGpuErrorDetectedSystemEvent * Remove unneeded event clear * Fix event name | |||||
2019-09-04 | configure_dialog: reverse tab map to avoid logic based on user-facing/translatable text | fearlessTobi | 1 | -20/+24 | |
Co-Authored-By: Weiyi Wang <wwylele@gmail.com> | |||||
2019-09-04 | Fix clang-format | Ethan | 1 | -1/+1 | |
2019-09-04 | Fix uisettings include | fearlessTobi | 1 | -1/+1 | |
2019-09-04 | Limit the size of directory icons, fix text when icon size is none | fearlessTobi | 2 | -4/+3 | |
2019-09-04 | Change QList to QVector | fearlessTobi | 5 | -16/+19 | |
2019-09-04 | Separate UserNand and Sdmc directories | fearlessTobi | 5 | -32/+59 | |
2019-09-04 | Address more trivial review comments | fearlessTobi | 4 | -25/+18 | |
2019-09-04 | Address trivial review comments | fearlessTobi | 7 | -53/+59 | |
2019-09-04 | yuzu: Add support for multiple game directories | fearlessTobi | 12 | -195/+666 | |
Ported from https://github.com/citra-emu/citra/pull/3617. | |||||
2019-09-04 | ditto | Morph1984 | 1 | -1/+1 | |
Co-Authored-By: David <25727384+ogniK5377@users.noreply.github.com> | |||||
2019-09-04 | IsVibrationEnabled() as a const member func | Morph1984 | 1 | -1/+1 | |
2019-09-04 | clang-format | Morph1984 | 1 | -2/+2 | |
2019-09-04 | Update npad.h | Morph1984 | 1 | -0/+1 | |
2019-09-04 | Update npad.cpp | Morph1984 | 1 | -0/+6 | |
2019-09-04 | Update hid.h | Morph1984 | 1 | -0/+2 | |
2019-09-04 | Update hid.cpp | Morph1984 | 1 | -2/+23 | |
2019-09-04 | gl_rasterizer: Fix stencil testing | ReinUsesLisp | 1 | -11/+11 | |
* Fix stencil dirty flags tracking when stencil is disabled * Attach stencil on clears (previously it only attached depth) * Attach stencil on drawing regardless of stencil testing being enabled | |||||
2019-09-04 | Revert "Revert #2466" and stub FirmwareCall 4 | ReinUsesLisp | 3 | -4/+19 | |
2019-09-04 | shader/shift: Implement SHR wrapped and clamped variants | ReinUsesLisp | 2 | -6/+17 | |
Nvidia defaults to wrapped shifts, but this is undefined behaviour on OpenGL's spec. Explicitly mask/clamp according to what the guest shader requires. | |||||
2019-09-04 | maxwell_3d: Avoid moving macro_params | ReinUsesLisp | 4 | -12/+24 | |
2019-09-04 | gl_shader_cache: Remove special casing for geometry shaders | ReinUsesLisp | 2 | -80/+9 | |
Now that ProgramVariants holds the primitive topology we no longer need to keep track of individual geometry shaders topologies. | |||||
2019-09-04 | half_set_predicate: Fix predicate assignments | ReinUsesLisp | 1 | -10/+9 | |
2019-09-04 | gl_device: Disable precise in fragment shaders on bugged drivers | ReinUsesLisp | 3 | -15/+43 | |
2019-09-04 | gl_shader_decompiler: Fixup AMD's slow path type | ReinUsesLisp | 1 | -1/+1 | |
2019-09-04 | gl_shader_decompiler: Rework GLSL decompiler type system | ReinUsesLisp | 1 | -416/+505 | |
GLSL decompiler type system was broken. We converted all return values to float except for some cases where returning we couldn't and implicitly broke the rule of returning floats (e.g. for bools or bool pairs). Instead of doing this introduce class Expression that knows what type a return value has and when a consumer wants to use the string it asks for it with a required type, emitting a runtime error if types are incompatible. This has the disadvantage that there's more C++ code, but we can emit better GLSL code that's easier to read. | |||||
2019-09-04 | Add Kernel::EventPair audio_input_device_switch_event; | Morph1984 | 1 | -0/+1 | |
2019-09-04 | remove <f32> | Morph1984 | 1 | -1/+1 | |
We can remove this since its already a f32 value | |||||
2019-09-04 | audren_u: Stub IAudioDevice::QueryAudioDeviceInputEvent | Morph1984 | 1 | -1/+14 | |
2019-09-04 | explicitly represent 1 as a float (1.0f instead of 1) | Morph1984 | 1 | -1/+1 | |
2019-09-04 | Change u32 -> f32 | Morph1984 | 1 | -1/+1 | |
Volume is a f32 value. (SwIPC describes it as a u32, but it is actually f32 as corroborated by switchbrew docs and SetAudioDeviceOutputVolume) ```cpp const f32 volume = rp.Pop<f32>(); ``` | |||||
2019-09-04 | configuration/config: Add missing screenshot path read | fearlessTobi | 1 | -0/+1 | |
I missed this in my original PR (https://github.com/yuzu-emu/yuzu/pull/1886). | |||||
2019-09-03 | Fix to Windows sleep issues | fearlessTobi | 2 | -0/+22 | |
Co-Authored-By: Vitor K <vitor-k@users.noreply.github.com> | |||||
2019-09-03 | Add cancel option to analog stick configuration | fearlessTobi | 1 | -7/+10 | |
Co-Authored-By: Vitor K <vitor-k@users.noreply.github.com> | |||||
2019-09-03 | service/audio/audren_u: Stub IAudioDevice::GetAudioDeviceOutputVolume | Morph1984 | 1 | -2/+15 | |
2019-09-01 | maxwell_3d: Fix macro binding cursor | ReinUsesLisp | 2 | -10/+4 | |
2019-08-30 | video_core: Silent miscellaneous warnings (#2820) | Rodrigo Locatti | 23 | -48/+22 | |
* texture_cache/surface_params: Remove unused local variable * rasterizer_interface: Add missing documentation commentary * maxwell_dma: Remove unused rasterizer reference * video_core/gpu: Sort member declaration order to silent -Wreorder warning * fermi_2d: Remove unused MemoryManager reference * video_core: Silent unused variable warnings * buffer_cache: Silent -Wreorder warnings * kepler_memory: Remove unused MemoryManager reference * gl_texture_cache: Add missing override * buffer_cache: Add missing include * shader/decode: Remove unused variables | |||||
2019-08-30 | kernel/vm_manager: Correct behavior in failure case of UnmapPhysicalMemory() | Lioncash | 1 | -0/+2 | |
If an unmapping operation fails, we shouldn't be decrementing the amount of memory mapped and returning that the operation was successful. We should actually be returning the error code in this case. | |||||
2019-08-30 | kernel/vm_manager: Reserve memory ahead of time for slow path in MergeAdjacentVMA | Lioncash | 1 | -1/+4 | |
Avoids potentially expensive (depending on the size of the memory block) allocations by reserving the necessary memory before performing both insertions. This avoids scenarios where the second insert may cause a reallocation to occur. | |||||
2019-08-30 | kernel/vm_manager: std::move shared_ptr instance in MergeAdjacentVMA | Lioncash | 1 | -1/+1 | |
Avoids an unnecessary atomic reference count increment and decrement. | |||||
2019-08-30 | kernel/vm_manager: Deduplicate iterator creation in MergeAdjacentVMA | Lioncash | 1 | -7/+10 | |
Avoids needing to read the same long sequence of code in both code paths. Also makes it slightly nicer to read and debug, as the locals will be able to be shown in the debugger. | |||||
2019-08-30 | kernel/vm_manager: Simplify some std::vector constructor calls | Lioncash | 1 | -2/+2 | |
Same behavior, one less magic constant to read. | |||||
2019-08-30 | kernel/vm_manager: Simplify some assertion messages | Lioncash | 1 | -10/+10 | |
Assertions already log out the function name, so there's no need to manually include the function name in the assertion strings. | |||||
2019-08-30 | gl_buffer_cache: Add missing include | ReinUsesLisp | 1 | -0/+1 | |
RasterizerInterface was considered an incomplete object by clang. | |||||
2019-08-29 | accommodate for fmt update | Ethan | 2 | -2/+2 | |
2019-08-28 | shader_ir/conversion: Split int and float selector and implement F2F H1 | ReinUsesLisp | 2 | -19/+24 | |
2019-08-28 | shader_ir/conversion: Implement F2I F16 Ra.H1 | ReinUsesLisp | 2 | -6/+17 | |
2019-08-28 | float_set_predicate: Add missing negation bit for the second operand | ReinUsesLisp | 2 | -4/+6 | |
2019-08-22 | Guard unistd.h with MacOS only macro | Weiyi Wang | 1 | -1/+3 | |
Fix compile error on Windows caused by #4877 Weird, I thought I saw this guard during the code review... | |||||
2019-08-22 | citra_qt: on osx chdir to bundle dir to allow detection of user folder | B3n30 | 1 | -0/+6 | |
2019-08-21 | shader_ir: Implement VOTE | ReinUsesLisp | 12 | -1/+163 | |
Implement VOTE using Nvidia's intrinsics. Documentation about these can be found here https://developer.nvidia.com/reading-between-threads-shader-intrinsics Instead of using portable ARB instructions I opted to use Nvidia intrinsics because these are the closest we have to how Tegra X1 hardware renders. To stub VOTE on non-Nvidia drivers (including nouveau) this commit simulates a GPU with a warp size of one, returning what is meaningful for the instruction being emulated: * anyThreadNV(value) -> value * allThreadsNV(value) -> value * allThreadsEqualNV(value) -> true ballotARB, also known as "uint64_t(activeThreadsNV())", emits VOTE.ANY Rd, PT, PT; on nouveau's compiler. This doesn't match exactly to Nvidia's code VOTE.ALL Rd, PT, PT; Which is emulated with activeThreadsNV() by this commit. In theory this shouldn't really matter since .ANY, .ALL and .EQ affect the predicates (set to PT on those cases) and not the registers. | |||||
2019-08-21 | Buffer Cache: Adress Feedback. | Fernando Sahmkow | 2 | -7/+6 | |
2019-08-21 | Buffer_Cache: Implement flushing. | Fernando Sahmkow | 2 | -1/+30 | |
2019-08-21 | Buffer_Cache: Implement barriers. | Fernando Sahmkow | 1 | -0/+4 | |
2019-08-21 | Buffer_Cache: Optimize and track written areas. | Fernando Sahmkow | 2 | -12/+104 | |
2019-08-21 | BufferCache: Rework mapping caching. | Fernando Sahmkow | 2 | -49/+76 | |
2019-08-21 | Buffer_Cache: Fixes and optimizations. | Fernando Sahmkow | 2 | -68/+38 | |
2019-08-21 | Video_Core: Implement a new Buffer Cache | Fernando Sahmkow | 9 | -327/+560 | |
2019-08-21 | renderer_opengl: Implement RGB565 framebuffer format | ReinUsesLisp | 3 | -3/+9 | |
2019-08-21 | renderer_opengl: Use block linear swizzling for CPU framebuffers | ReinUsesLisp | 3 | -150/+33 | |
2019-08-21 | renderer_opengl: Use VideoCore pixel format | ReinUsesLisp | 3 | -23/+11 | |
2019-08-21 | gpu: Change optional<reference_wrapper<T>> to T* for FramebufferConfig | ReinUsesLisp | 11 | -32/+22 | |
2019-08-17 | Fixup! #2772 missed this one file | James Rowe | 1 | -1/+1 | |
2019-08-09 | yuzu/CMakeLists: Remove qt5_wrap_ui macro usage | Lioncash | 16 | -44/+39 | |
We can simply enable CMAKE_AUTOUIC and let CMake take care of handling the UI code generation for targets. As part of letting CMake automatically handle the header file parsing, we must not name includes with "ui_*" unless they're related to the output of the Qt UIC compiler. Because of this, we need to rename ui_settings, given it would conflict with this restriction. | |||||
2019-08-04 | shader_ir: Implement NOP | ReinUsesLisp | 2 | -0/+13 | |
2019-08-04 | half_set_predicate: Fix HSETP2_C constant buffer offset | ReinUsesLisp | 1 | -1/+1 | |
2019-08-02 | Qt: Fixed behaviour of buttons by connecting functors to correct signals | Silent | 7 | -21/+21 | |
Following screens got fixes: - Configure/Debug - Configure/Input | |||||
2019-07-30 | yuzu-tester/yuzu: Correct format string | Lioncash | 1 | -1/+1 | |
Prevents an invalid formatting exception from being thrown. | |||||
2019-07-30 | yuzu-tester/yuzu: Remove unused variable | Lioncash | 1 | -1/+0 | |
Gets rid of a compilation warning. | |||||
2019-07-26 | GPU: Flush commands on every dma pusher step. | Fernando Sahmkow | 6 | -0/+15 | |
This commit ensures that the host gpu is constantly fed with commands to work with, while the guest gpu keeps producing the rest of the commands. This reduces syncing time between host and guest gpu. | |||||
2019-07-26 | decode/half_set_predicate: Fix predicates | ReinUsesLisp | 1 | -3/+3 | |
2019-07-26 | MaxwellDMA: Fixes, corrections and relaxations. | Fernando Sahmkow | 3 | -23/+36 | |
This commit fixes offsets on Linear -> Tiled copies, corrects z pos fortiled->linear copies, corrects bytes_per_pixel calculation in tiled -> linear copies and relaxes some limitations set by latest dma fixes refactors. | |||||
2019-07-22 | shader/decode: Implement S2R Tic | ReinUsesLisp | 3 | -0/+15 | |
2019-07-20 | Shader_Ir: Implement F16 Variants of F2F, F2I, I2F. | Fernando Sahmkow | 5 | -18/+75 | |
This commit takes care of implementing the F16 Variants of the conversion instructions and makes sure conversions are done. | |||||
2019-07-20 | Maxwell3D: Reorganize and address feedback | Fernando Sahmkow | 3 | -20/+33 | |
2019-07-20 | Shader_Ir: Change Debug Asserts for Log Warnings | Fernando Sahmkow | 3 | -10/+17 | |
2019-07-20 | Common/Alignment: Add noexcept where required. | Fernando Sahmkow | 1 | -5/+5 | |
2019-07-20 | shader/half_set_predicate: Fix HSETP2 implementation | ReinUsesLisp | 4 | -44/+23 | |
2019-07-20 | shader/half_set_predicate: Implement missing HSETP2 variants | ReinUsesLisp | 2 | -19/+49 | |
2019-07-19 | Kernel: Address Feedback | Fernando Sahmkow | 3 | -6/+11 | |
2019-07-19 | Common: Correct alignment allocator to work on C++14 or higher. | Fernando Sahmkow | 1 | -37/+19 | |
2019-07-19 | VM_Manager: Align allocated memory to 256bytes | Fernando Sahmkow | 15 | -36/+131 | |
This commit ensures that all backing memory allocated for the Guest CPU is aligned to 256 bytes. This due to how gpu memory works and the heavy constraints it has in the alignment of physical memory. | |||||
2019-07-19 | service/audren_u: Handle audio USB output revision queries in ListAudioDeviceName() | Lioncash | 2 | -16/+45 | |
Audio devices use the supplied revision information in order to determine if USB audio output is able to be supported. In this case, we can only really handle using this revision information in ListAudioDeviceName(), where it checks if USB audio output is supported before supplying it as a device name. A few other scenarios exist where the revision info is checked, such as: - Early exiting from SetAudioDeviceOutputVolume if USB audio is attempted to be set when that device is unsupported. - Early exiting and returning 0.0f in GetAudioDeviceOutputVolume when USB output volume is queried and it's an unsupported device. - Falling back to AHUB headphones in GetActiveAudioDeviceName when the device type is USB output, but is unsupported based off the revision info. In order for these changes to also be implemented, a few other changes to the interface need to be made. Given we now properly handle everything about ListAudioDeviceName(), we no longer need to describe it as a stubbed function. | |||||
2019-07-19 | service/audren_u: Move revision testing code out of AudRenU | Lioncash | 2 | -63/+63 | |
The revision querying facilities are used by more than just audren. e.g. audio devices can use this to test whether or not USB audio output is supported. This will be used within the following change. | |||||
2019-07-19 | service/audio: Remove global system accessors | Lioncash | 7 | -34/+54 | |
Trims out the lingering reliance on global state out of the audio code. | |||||
2019-07-19 | service/audren_u: Remove unnecessary return value from GetActiveAudioDeviceName() | Lioncash | 1 | -2/+1 | |
This service function only ever returns a result and nothing more. | |||||
2019-07-19 | service/audren_u: Report proper device names | Lioncash | 1 | -6/+29 | |
AudioDevice and AudioInterface aren't valid device names on the Switch. We should also be returning consistent names in GetActiveAudioDeviceName(). While we're at it, we can also handle proper name output in ListAudioDeviceName, by returning all the available devices on the Switch. | |||||
2019-07-19 | video_core/control_flow: Provide operator!= for types with operator== | Lioncash | 1 | -4/+21 | |
Provides operational symmetry for the respective structures. | |||||
2019-07-19 | video_core/control_flow: Prevent sign conversion in TryGetBlock() | Lioncash | 1 | -1/+1 | |
The return value is a u32, not an s32, so this would result in an implicit signedness conversion. | |||||
2019-07-19 | video_core/control_flow: Remove unnecessary BlockStack copy constructor | Lioncash | 1 | -2/+1 | |
This is the default behavior of the copy constructor, so it doesn't need to be specified. While we're at it we can make the other non-default constructor explicit. | |||||
2019-07-19 | video_core/control_flow: Use std::move where applicable | Lioncash | 1 | -10/+15 | |
Results in less work being done where avoidable. | |||||
2019-07-19 | video_core/control_flow: Use the prefix variant of operator++ for iterators | Lioncash | 1 | -2/+2 | |
Same thing, but potentially allows a standard library implementation to pick a more efficient codepath. | |||||
2019-07-19 | video_core/control_flow: Use empty() member function for checking emptiness | Lioncash | 1 | -2/+2 | |
It's what it's there for. | |||||
2019-07-19 | video_core: Resolve -Wreorder warnings | Lioncash | 2 | -4/+3 | |
Ensures that the constructor members are always initialized in the order that they're declared in. | |||||
2019-07-19 | video_core/control_flow: Make program_size for ScanFlow() a std::size_t | Lioncash | 2 | -5/+4 | |
Prevents a truncation warning from occurring with MSVC. Also the internal data structures already treat it as a size_t, so this is just a discrepancy in the interface. | |||||
2019-07-19 | video_core/control_flow: Place all internally linked types/functions within an anonymous namespace | Lioncash | 1 | -1/+2 | |
Previously, quite a few functions were being linked with external linkage. | |||||
2019-07-19 | video_core/shader/decode: Prevent sign-conversion warnings | Lioncash | 1 | -2/+2 | |
Makes it explicit that the conversions here are intentional. | |||||
2019-07-18 | Shader_Ir: correct clang format | Fernando Sahmkow | 1 | -2/+2 | |
2019-07-18 | GPU: Add missing puller methods. | Fernando Sahmkow | 2 | -14/+15 | |
This adds some missing puller methods. We don't assert them as these are nop operations for us. | |||||
2019-07-18 | MaxwellDMA/KeplerCopy: Downgrade DMA log message to Trace. | Fernando Sahmkow | 1 | -1/+1 | |
This log was just to know which games used DMA. It's no longer important. | |||||
2019-07-18 | Gl_Texture_Cache: Remove assert on component type in GetFormatTuple | Fernando Sahmkow | 1 | -1/+0 | |
Textures can have different components types in different orders. This assert was completely inprecise and the effectiveness of such is better handled by case and within the texture cache. | |||||
2019-07-18 | Shader_Ir: Downgrade precision and rounding asserts to debug asserts. | Fernando Sahmkow | 5 | -10/+10 | |
This commit reduces the sevirity of asserts for FP precision and rounding as this are well known and have little to no consequences in gpu's accuracy. | |||||
2019-07-18 | gl_shader_decompiler: Rename bufferImage to imageBuffer | ReinUsesLisp | 1 | -1/+1 | |
The online OpenGL documentation is wrong. The type definition is imageBuffer. | |||||
2019-07-18 | gl_shader_cache: Fix newline on buffer preprocessor definitions | ReinUsesLisp | 1 | -2/+6 | |
2019-07-18 | textures: Fix texture buffer size calculation | ReinUsesLisp | 1 | -1/+1 | |
2019-07-18 | gl_texture_cache: Do not set texture parameters to buffers | ReinUsesLisp | 1 | -0/+3 | |
2019-07-18 | gl_texture_cache: Add missing break in CreateTexture | ReinUsesLisp | 1 | -0/+1 | |
2019-07-18 | Kernel: Downgrade WaitForAddress and SignalToAddress messages to Trace. | Fernando Sahmkow | 1 | -4/+4 | |
This messages were originally set as warnning since few games used these svcs and it was needed for debugging. This is no longer the case. | |||||
2019-07-17 | GL_State: Feedback and fixes | Fernando Sahmkow | 4 | -14/+27 | |
2019-07-17 | Maxwell3D: Address Feedback | Fernando Sahmkow | 5 | -17/+13 | |
2019-07-17 | Texture_Cache: Rebase Fixes | Fernando Sahmkow | 1 | -6/+0 | |
2019-07-17 | GL_Rasterizer: Corrections to Clearing. | Fernando Sahmkow | 4 | -12/+28 | |
2019-07-17 | Maxwell3D: Correct marking dirtiness on CB upload | Fernando Sahmkow | 1 | -0/+1 | |
2019-07-17 | GL_Rasterizer: Rework RenderTarget/DepthBuffer clearing | Fernando Sahmkow | 3 | -7/+63 | |
2019-07-17 | Maxwell3D: Implement State Dirty Flags. | Fernando Sahmkow | 6 | -44/+199 | |
2019-07-17 | Maxwell3D: Rework CBData Upload | Fernando Sahmkow | 2 | -8/+45 | |
2019-07-17 | Maxwell3D: Rework the dirty system to be more consistant and scaleable | Fernando Sahmkow | 10 | -80/+211 | |
2019-07-17 | maxwell3d: Implement Conditional Rendering | Fernando Sahmkow | 3 | -2/+100 | |
Conditional Rendering takes care of conditionaly clearing or drawing depending on a set of queries. This PR implements the query checks to stablish if things can be rendered or not. | |||||
2019-07-17 | shader_ir: std::move Node instance where applicable | Lioncash | 4 | -60/+67 | |
These are std::shared_ptr instances underneath the hood, which means copying them isn't as cheap as a regular pointer. Particularly so on weakly-ordered systems. This avoids atomic reference count increments and decrements where they aren't necessary for the core set of operations. | |||||
2019-07-17 | shader_ir: Rename Get/SetTemporal to Get/SetTemporary | Lioncash | 5 | -36/+36 | |
This is more accurate in terms of describing what the functions are actually doing. Temporal relates to time, not the setting of a temporary itself. | |||||
2019-07-17 | shader_ir: Remove unused includes | Lioncash | 1 | -3/+0 | |
Removes unnecessary header dependencies. | |||||
2019-07-16 | Shader_Ir: Correct tracking to track from right to left | Fernando Sahmkow | 1 | -2/+2 | |
2019-07-16 | shader/decode/other: Correct branch indirect argument within BRA handling | Lioncash | 1 | -1/+1 | |
This appears to have been a copy/paste error introduced within 8a6fc529a968e007f01464abadd32f9b5eb0a26c | |||||
2019-07-16 | gl_shader_cache: Fix clang-format issues | ReinUsesLisp | 2 | -4/+2 | |
2019-07-15 | gl_shader_decompiler: Stub local memory size | ReinUsesLisp | 1 | -8/+14 | |
2019-07-15 | gl_shader_cache: Address review commentaries | ReinUsesLisp | 4 | -13/+12 | |
2019-07-15 | gl_shader_cache: Address CI issues | ReinUsesLisp | 2 | -3/+3 | |
2019-07-15 | gl_rasterizer: Implement compute shaders | ReinUsesLisp | 15 | -136/+350 | |
2019-07-15 | shader: Allow tracking of indirect buffers without variable offset | ReinUsesLisp | 6 | -35/+36 | |
While changing this code, simplify tracking code to allow returning the base address node, this way callers don't have to manually rebuild it on each invocation. | |||||
2019-07-14 | Texture_Cache: Address Feedback | Fernando Sahmkow | 3 | -13/+17 | |
2019-07-14 | Texture_Cache: Remove some unprecise fallback case and clang format | Fernando Sahmkow | 2 | -13/+5 | |
2019-07-14 | Texture_Cache: Force Framebuffer reset if an active render target is unregistered. | Fernando Sahmkow | 3 | -10/+36 | |
2019-07-14 | GPU: Add a microprofile for macro interpreter | Fernando Sahmkow | 2 | -1/+6 | |
2019-07-14 | GL_State: Add a microprofile timer to OpenGL state. | Fernando Sahmkow | 1 | -0/+4 | |
2019-07-14 | Gl_Texture_Cache: Measure Buffer Copy Times | Fernando Sahmkow | 1 | -0/+2 | |
2019-07-14 | Texture_Cache: Correct Linear Structural Match. | Fernando Sahmkow | 1 | -3/+6 | |
2019-07-13 | core: Remove CurrentArmInterface() global accessor | Lioncash | 2 | -7/+6 | |
Replaces the final usage of the global accessor function and removes it. Removes one more enabler of global state. | |||||
2019-07-12 | Clang format | David Marcec | 3 | -4/+8 | |
2019-07-12 | Addressed issues | David Marcec | 2 | -2/+2 | |
2019-07-12 | "AudioRenderer" thread should have a unique name | David Marcec | 4 | -7/+8 | |
Creating multiple "AudioRenderer" threads cause the previous thread to be overwritten. The thread will name be renamed to AudioRenderer-InstanceX, where X is the current instance number. | |||||
2019-07-12 | Remove unicorn mappings/unmappings | Michael Scire | 1 | -19/+0 | |
2019-07-11 | gl_shader_decompiler: Fix gl_PointSize redeclaration | ReinUsesLisp | 1 | -1/+1 | |
2019-07-11 | service/am: Implement IsAutoSleepDisabled | Lioncash | 2 | -1/+10 | |
This simply queries whether or not auto-sleep facilities are disabled and has no special handling. It's a basic getter function. | |||||
2019-07-11 | service/am: Implement SetAutoSleepDisabled | Lioncash | 2 | -1/+23 | |
Provides a basic implementation of SetAutoSleepDisabled. Until idle handling is implemented, this is about the best we can do. In the meantime, provide a rough documenting of specifics that occur when this function is called on actual hardware. | |||||
2019-07-11 | yuzu: Remove setting for using Unicorn | Lioncash | 9 | -29/+6 | |
The JIT is mature enough that this setting can be removed, falling back to Unicorn only on unsupported architectures. Any missing features from Unicorn (of which there are extremely few), are mostly developer-oriented, which most users don't care about. Features should be coordinated with the JIT, not the interpreter, anyhow. | |||||
2019-07-11 | core/arm: Remove obsolete Unicorn memory mapping | Lioncash | 6 | -51/+0 | |
This was initially necessary when AArch64 JIT emulation was in its infancy and all memory-related instructions weren't implemented. Given the JIT now has all of these facilities implemented, we can remove these functions from the CPU interface. | |||||
2019-07-11 | Restore memory perms on svcUnmapMemory/UnloadNro | Michael Scire | 2 | -7/+34 | |
Prior to PR, Yuzu did not restore memory to RW- on unmap of mirrored memory or unloading of NRO. (In fact, in the NRO case, the memory was unmapped instead of reprotected to --- on Load, so it was actually lost entirely...) This PR addresses that, and restores memory to RW- as it should. This fixes a crash in Super Smash Bros when creating a World of Light save for the first time, and possibly other games/circumstances. | |||||
2019-07-11 | gl_shader_decompiler: Fix conditional usage of GL_ARB_shader_viewport_layer_array | ReinUsesLisp | 1 | -2/+3 | |
2019-07-10 | system_archive: Add open-source reimplementation of MiiModel data | Zach Hilman | 4 | -1/+63 | |
2019-07-10 | mii: Handle logging of unknown database source | Zach Hilman | 1 | -0/+4 | |
2019-07-09 | shader_ir: Add comments on missing instruction. | Fernando Sahmkow | 2 | -2/+9 | |
Also shows Nvidia's address space on comments. | |||||
2019-07-09 | prefer system reference over global accessor | Michael Scire | 3 | -9/+13 | |
2019-07-09 | shader_ir: limit explorastion to best known program size. | Fernando Sahmkow | 1 | -1/+1 | |
2019-07-09 | control_flow: Correct block breaking algorithm. | Fernando Sahmkow | 1 | -17/+17 | |
2019-07-09 | control_flow: Assert shaders bigger than limit. | Fernando Sahmkow | 1 | -0/+2 | |
2019-07-09 | control_flow: Address feedback. | Fernando Sahmkow | 1 | -89/+37 | |
2019-07-09 | shader_ir: Correct parsing of scheduling instructions and correct sizing | Fernando Sahmkow | 2 | -13/+30 | |
2019-07-09 | shader_ir: Correct max sizing | Fernando Sahmkow | 2 | -2/+2 | |
2019-07-09 | shader_ir: Remove unnecessary constructors and use optional for ScanFlow result | Fernando Sahmkow | 3 | -28/+17 | |
2019-07-09 | shader_ir: Corrections, documenting and asserting control_flow | Fernando Sahmkow | 3 | -52/+54 | |
2019-07-09 | shader_ir: Unify blocks in decompiled shaders. | Fernando Sahmkow | 7 | -58/+85 | |
2019-07-09 | shader_ir: Decompile Flow Stack | Fernando Sahmkow | 4 | -11/+206 | |
2019-07-09 | shader_ir: propagate shader size to the IR | Fernando Sahmkow | 6 | -17/+28 | |
2019-07-09 | shader_ir: Implement BRX & BRA.CC | Fernando Sahmkow | 6 | -4/+76 | |
2019-07-09 | shader_ir: Remove the old scanner. | Fernando Sahmkow | 2 | -77/+0 | |
2019-07-09 | shader_ir: Implement a new shader scanner | Fernando Sahmkow | 5 | -16/+475 | |
2019-07-09 | IFriendService::GetFriendList | David Marcec | 1 | -1/+34 | |
We don't have any friends implemented in Yuzu yet so it doesn't make sense to return any friends. For now we'll be returning 0 friends however the information provided will allow a proper implementation of this cmd when needed. | |||||
2019-07-09 | gl_rasterizer: Amend documentation comment for ConfigureFramebuffers() | Lioncash | 1 | -7/+9 | |
must_reconfigure isn't a parameter for this function any more, so it can be replaced with current_state. While we're at it, we can make the parameters of the declaration match the same name as the ones in the definition. | |||||
2019-07-09 | Prevent merging of device mapped memory blocks. | Michael Scire | 2 | -1/+28 | |
This sets the DeviceMapped attribute for GPU-mapped memory blocks, and prevents merging device mapped blocks. This prevents memory mapped from the gpu from having its backing address changed by block coalesce. | |||||
2019-07-08 | addressed issues | David Marcec | 1 | -6/+7 | |
2019-07-08 | addressed issue | David Marcec | 1 | -1/+1 | |
2019-07-08 | key_manager: Convert Ticket union to std::variant | Zach Hilman | 3 | -57/+88 | |
2019-07-08 | es: Populate/synthesize tickets on construction | Zach Hilman | 3 | -15/+17 | |
2019-07-08 | key_manager: Add structure for Ticket parsing | Zach Hilman | 3 | -44/+194 | |
2019-07-08 | es: Implement ETicket GetPersonalizedTicketData (17) | Zach Hilman | 1 | -1/+21 | |
Copies the raw personal ticket data into the buffer provided. | |||||
2019-07-08 | es: Implement ETicket GetCommonTicketData (16) | Zach Hilman | 1 | -1/+20 | |
Copies the raw common ticket data for the specified rights ID into the buffer provided. | |||||
2019-07-08 | es: Implement ETicket GetPersonalizedTicketSize (15) | Zach Hilman | 1 | -1/+17 | |
Returns the size of the buffer needed to hold the personal ticket associated with the rights ID. | |||||
2019-07-08 | es: Implement ETicket GetCommonTicketSize (14) | Zach Hilman | 1 | -1/+17 | |
Returns the size of the buffer needed to hold the common ticket associated with the rights ID. | |||||
2019-07-08 | es: Implement ETicket ListPersonalizedTicket (12) | Zach Hilman | 1 | -1/+24 | |
Returns an application-specific number of entries of personal tickets, starting at offset 0. | |||||
2019-07-08 | es: Implement ETicket ListCommonTicket (11) | Zach Hilman | 1 | -1/+24 | |
Returns an application specified count of entries of common tickets, starting at offset 0. | |||||
2019-07-08 | es: Implement ETicket CountPersonalizedTicket (10) | Zach Hilman | 1 | -1/+12 | |
Returns the number of personalized (console/user-unique) tickets in the KeyManager. | |||||
2019-07-08 | es: Implement ETicket CountCommonTicket (9) | Zach Hilman | 1 | -1/+12 | |
Returns the number of common (non-console-unique) tickets in the KeyManager. | |||||
2019-07-08 | es: Implement ETicket GetTitleKey (8) | Zach Hilman | 1 | -1/+27 | |
Takes a rights ID as input and returns the associated title key, if it exists. | |||||
2019-07-08 | es: Implement ETicket ImportTicket (1) | Zach Hilman | 1 | -1/+45 | |
Takes a ticket and certificate and installs it to the KeyManager. | |||||
2019-07-08 | key_manager: Add accessors/helpers for ticket management | Zach Hilman | 2 | -14/+100 | |
2019-07-08 | key_manager: Add equality operator for RSAKeyPair | Zach Hilman | 1 | -0/+7 | |
2019-07-08 | gl_shader_decompiler: Implement gl_ViewportIndex and gl_Layer in vertex shaders | ReinUsesLisp | 10 | -40/+136 | |
This commit implements gl_ViewportIndex and gl_Layer in vertex and geometry shaders. In the case it's used in a vertex shader, it requires ARB_shader_viewport_layer_array. This extension is available on AMD and Nvidia devices (mesa and proprietary drivers), but not available on Intel on any platform. At the moment of writing this description I don't know if this is a hardware limitation or a driver limitation. In the case that ARB_shader_viewport_layer_array is not available, writes to these registers on a vertex shader are ignored, with the appropriate logging. | |||||
2019-07-07 | Remove unused member function declaration | Michael Scire | 1 | -9/+0 | |
2019-07-07 | physmem: add helpers, cleanup logic. | Michael Scire | 2 | -171/+170 | |
2019-07-07 | Delete decode_integer_set.cpp | Tobias | 1 | -0/+0 | |
2019-07-07 | clang-format fixes | Michael Scire | 2 | -3/+3 | |
2019-07-07 | shader/texture: Add F16 support for TLDS | ReinUsesLisp | 2 | -2/+9 | |
2019-07-07 | address review commentary | Michael Scire | 5 | -36/+42 | |
2019-07-07 | Implement MapPhysicalMemory/UnmapPhysicalMemory | Michael Scire | 8 | -21/+475 | |
This implements svcMapPhysicalMemory/svcUnmapPhysicalMemory for Yuzu, which can be used to map memory at a desired address by games since 3.0.0. It also properly parses SystemResourceSize from NPDM, and makes information available via svcGetInfo. This is needed for games like Super Smash Bros. and Diablo 3 -- this PR's implementation does not run into the "ASCII reads" issue mentioned in the comments of #2626, which was caused by the following bugs in Yuzu's memory management that this PR also addresses: * Yuzu's memory coalescing does not properly merge blocks. This results in a polluted address space/svcQueryMemory results that would be impossible to replicate on hardware, which can lead to game code making the wrong assumptions about memory layout. * This implements better merging for AllocatedMemoryBlocks. * Yuzu's implementation of svcMirrorMemory unprotected the entire virtual memory range containing the range being mirrored. This could lead to games attempting to map data at that unprotected range/attempting to access that range after yuzu improperly unmapped it. * This PR fixes it by simply calling ReprotectRange instead of Reprotect. | |||||
2019-07-07 | kernel/process: Allocate the process' TLS region during initialization | Lioncash | 3 | -3/+14 | |
Prior to execution within a process beginning, the process establishes its own TLS region for uses (as far as I can tell) related to exception handling. Now that TLS creation was decoupled from threads themselves, we can add this behavior to our Process class. This is also good, as it allows us to remove a stub within svcGetInfo, namely querying the address of that region. | |||||
2019-07-07 | kernel/process: Move main thread stack allocation to its own function | Lioncash | 2 | -12/+17 | |
Keeps this particular set of behavior isolated to its own function. | |||||
2019-07-07 | vk_sampler_cache: Remove unused includes | Lioncash | 1 | -3/+0 | |
These are no longer used within this header, so they can be removed. | |||||
2019-07-07 | video_core: Add missing override specifiers | Lioncash | 2 | -4/+4 | |
2019-07-07 | yuzu/main: Make error messages within OnCoreError more localization-friendly | Lioncash | 1 | -7/+8 | |
Previously, a translated string was being appended onto another string in a manner that doesn't allow the translator to control where the appended text is placed. This can be a nuisance for languages where grammar and text ordering differs from English. We now append the strings via the format strings themselves, which allows translators to reorder where the text will be placed. | |||||
2019-07-07 | vk_scheduler: Drop execution context in favor of views | ReinUsesLisp | 6 | -50/+60 | |
Instead of passing by copy an execution context through out the whole Vulkan call hierarchy, use a command buffer view and fence view approach. This internally dereferences the command buffer or fence forcing the user to be unable to use an outdated version of it on normal usage. It is still possible to keep store an outdated if it is casted to VKFence& or vk::CommandBuffer. While changing this file, add an extra parameter for Flush and Finish to allow releasing the fence from this calls. | |||||
2019-07-07 | mii: Implement IDatabaseService SetInterfaceVersion | Zach Hilman | 1 | -1/+15 | |
Appears to set a member variable used to affect the API that games access, and the method used to store data. | |||||
2019-07-06 | clang-format fixes | Michael Scire | 1 | -4/+5 | |
2019-07-06 | am: Implement GetAccumulatedSuspendedTickValue | Michael Scire | 2 | -7/+19 | |
2019-07-06 | memory: Remove unused includes | Lioncash | 1 | -2/+0 | |
These aren't used within the central memory management code, so they can be removed. | |||||
2019-07-06 | memory: Remove unused PageTable forward declaration | Lioncash | 1 | -4/+0 | |
This isn't used by anything in the header file, so it can be removed. | |||||
2019-07-06 | kernel/vm_manager: Rename 'new map' to 'stack' | Lioncash | 3 | -37/+37 | |
Provides a more accurate name for the memory region and also disambiguates between the map and new map regions of memory, making it easier to understand. | |||||
2019-07-06 | buffer_cache: Avoid [[nodiscard]] to make clang-format happy | ReinUsesLisp | 1 | -5/+4 | |
2019-07-06 | buffer_cache: Try to fix MinGW build | ReinUsesLisp | 1 | -1/+1 | |
2019-07-06 | gl_rasterizer: Fix nullptr dereference on disabled buffers | ReinUsesLisp | 3 | -5/+5 | |
2019-07-06 | gl_rasterizer: Minor style changes | ReinUsesLisp | 4 | -32/+22 | |
2019-07-06 | gl_rasterizer: Fix vertex and index data invalidations | ReinUsesLisp | 4 | -8/+67 | |
2019-07-06 | gl_buffer_cache: Implement with generic buffer cache | ReinUsesLisp | 8 | -291/+92 | |
2019-07-06 | buffer_cache: Implement a generic buffer cache | ReinUsesLisp | 2 | -0/+301 | |
Implements a templated class with a similar approach to our current generic texture cache. It is designed to be compatible with Vulkan and OpenGL, | |||||
2019-07-06 | gl_buffer_cache: Remove global system getters | ReinUsesLisp | 3 | -9/+14 | |
2019-07-06 | gl_device: Query SSBO alignment | ReinUsesLisp | 2 | -0/+6 | |
2019-07-06 | gl_buffer_cache: Implement flushing | ReinUsesLisp | 2 | -2/+11 | |
2019-07-06 | gl_rasterizer: Drop gl_global_cache in favor of gl_buffer_cache | ReinUsesLisp | 7 | -206/+35 | |
2019-07-06 | gl_buffer_cache: Rework to support internalized buffers | ReinUsesLisp | 3 | -65/+174 | |
2019-07-06 | gl_buffer_cache: Store in CachedBufferEntry the used buffer handle | ReinUsesLisp | 2 | -23/+30 | |
2019-07-06 | gl_buffer_cache: Return used buffer from Upload function | ReinUsesLisp | 4 | -36/+35 | |
2019-07-06 | gl_rasterizer: Add some commentaries | ReinUsesLisp | 1 | -0/+5 | |
2019-07-06 | gl_rasterizer: Make DrawParameters rasterizer instance const | ReinUsesLisp | 1 | -1/+1 | |
2019-07-06 | gl_rasterizer: Move index buffer uploading to its own method | ReinUsesLisp | 2 | -7/+18 | |
2019-07-06 | kernel/vm_manager: Handle stack/TLS IO region placement better | Lioncash | 1 | -2/+13 | |
Handles the placement of the stack a little nicer compared to the previous code, which was off in a few ways. e.g. The stack (new map) region, shouldn't be the width of the entire address space if the size of the region calculation ends up being zero. It should be placed at the same location as the TLS IO region and also have the same size. In the event the TLS IO region contains a size of zero, we should also be doing the same thing. This fixes our memory layout a little bit and also resolves some cases where assertions can trigger due to the memory layout being incorrect. | |||||
2019-07-05 | core/reporter: Allow moves into SaveToFile() | Lioncash | 1 | -1/+1 | |
Taking the json instance as a constant reference, makes all moves into the parameter non-functional, resulting in copies. Taking it by value allows moves to function. | |||||
2019-07-05 | core/reporter: Add missing includes and forward declarations | Lioncash | 2 | -1/+9 | |
Adds missing inclusions to prevent potential compilation issues. | |||||
2019-07-05 | core/reporter: Remove unnecessary namespace qualifiers | Lioncash | 2 | -3/+3 | |
The Reporter class is part of the Core namespace, so the System class doesn't need to be qualified. | |||||
2019-07-05 | core/reporter: Remove pessimizing move in GetHLERequestContextData() | Lioncash | 1 | -1/+1 | |
This can inhibit copy-elision, so we can remove this redundant move. | |||||
2019-07-05 | core/reporter: Make bracing consistent | Lioncash | 1 | -8/+18 | |
Makes all control statements braced, regardless of their size, making code more uniform. | |||||
2019-07-05 | core/reporter: Return in error case in SaveToFile() | Lioncash | 1 | -1/+3 | |
If the path couldn't be created, then we shouldn't be attempting to save the file. | |||||
2019-07-05 | NVServices: Correct delayed responses. | Fernando Sahmkow | 1 | -24/+19 | |
2019-07-05 | Nv_Host_Ctrl: Correct difference calculation | Fernando Sahmkow | 1 | -5/+7 | |
2019-07-05 | NVServices: Address Feedback | Fernando Sahmkow | 8 | -21/+38 | |
2019-07-05 | NVServices: Styling, define constructors as explicit and corrections | Fernando Sahmkow | 24 | -65/+73 | |
2019-07-05 | NVFlinger: Correct GCC compile error | Fernando Sahmkow | 8 | -23/+22 | |
2019-07-05 | NVServices: Make NVEvents Automatic according to documentation. | Fernando Sahmkow | 4 | -7/+13 | |
2019-07-05 | NVServices: Correct CtrlEventWaitSync to block the ipc until timeout. | Fernando Sahmkow | 23 | -31/+104 | |
2019-07-05 | GPU: Correct Interrupts to interrupt on syncpt/value instead of event, mirroring hardware | Fernando Sahmkow | 12 | -48/+45 | |
2019-07-05 | nvflinger: Make the force 30 fps still force 30 fps | Fernando Sahmkow | 1 | -1/+1 | |
2019-07-05 | nv_services: Fixes to event liberation. | Fernando Sahmkow | 1 | -6/+14 | |
2019-07-05 | nvflinger: Acquire buffers in the same order as they were queued. | Fernando Sahmkow | 2 | -3/+11 | |
2019-07-05 | nv_services: Deglobalize NvServices | Fernando Sahmkow | 23 | -51/+65 | |
2019-07-05 | gpu_asynch: Simplify synchronization to a simpler consumer->producer scheme. | Fernando Sahmkow | 2 | -47/+3 | |
2019-07-05 | nv_host_ctrl: Make Sync GPU variant always return synced result. | Fernando Sahmkow | 5 | -5/+16 | |
2019-07-05 | Async GPU: do invalidate as synced operation | Fernando Sahmkow | 1 | -6/+1 | |
Async GPU: Always invalidate synced. | |||||
2019-07-05 | Gpu: use an std mutex instead of a spin_lock to guard syncpoints | Fernando Sahmkow | 2 | -6/+6 | |
2019-07-05 | nvhost_ctrl: Corrections to event handling | Fernando Sahmkow | 2 | -8/+12 | |
2019-07-05 | Gpu: Mark areas as protected. | Fernando Sahmkow | 3 | -0/+19 | |
2019-07-05 | nv_services: Stub CtrlEventSignal | Fernando Sahmkow | 4 | -13/+48 | |
2019-07-05 | Gpu: Implement Hardware Interrupt Manager and manage GPU interrupts | Fernando Sahmkow | 13 | -13/+90 | |
2019-07-05 | nv_services: Implement NvQueryEvent, NvCtrlEventWait, NvEventRegister, NvEventUnregister | Fernando Sahmkow | 7 | -17/+192 | |
2019-07-05 | nv_services: Create GPU channels correctly | Fernando Sahmkow | 2 | -2/+5 | |
2019-07-05 | video_core: Implement GPU side Syncpoints | Fernando Sahmkow | 6 | -9/+84 | |
2019-07-05 | nv_services: Correct buffer queue fencing and GPFifo fencing | Fernando Sahmkow | 8 | -57/+70 | |
2019-07-05 | nvflinger: Implement swap intervals | Fernando Sahmkow | 5 | -8/+21 | |
2019-07-05 | texture_cache: Address Feedback | Fernando Sahmkow | 7 | -22/+35 | |
2019-07-05 | texture_cache: Correct Texture Buffer Uploading | Fernando Sahmkow | 3 | -2/+18 | |
2019-07-04 | yuzu: Remove CPU Jit setting from the UI | fearlessTobi | 11 | -36/+12 | |
A normal user shouldn't change this, as it will slow down the emulation and can lead to bugs or crashes. The renaming is done in order to prevent users from leaving this on without a way to turn it off from the UI. | |||||
2019-07-04 | gl_shader_cache: Make CachedShader constructor private | Zach Hilman | 2 | -5/+5 | |
Fixes missing review comments introduced. | |||||
2019-07-04 | kernel/process: Default initialize all member variables | Lioncash | 1 | -2/+2 | |
Ensures a Process instance is always created with a deterministic initial state. | |||||
2019-07-04 | kernel/process: Decouple TLS handling from threads | Lioncash | 4 | -66/+97 | |
Extracts out all of the thread local storage management from thread instances themselves and makes the owning process handle the management of the memory. This brings the memory management slightly more in line with how the kernel handles these allocations. Furthermore, this also makes the TLS page management a little more readable compared to the lingering implementation that was carried over from Citra. | |||||
2019-07-04 | kernel/vm_manager: Add overload of FindFreeRegion() that operates on a boundary | Lioncash | 2 | -13/+49 | |
This will be necessary for making our TLS slot management slightly more straightforward. This can also be utilized for other purposes in the future. We can implement the existing simpler overload in terms of this one anyways, we just pass the beginning and end of the ASLR region as the boundaries. | |||||
2019-07-03 | acc_su: Implement GetProfileEditor (205) | Zach Hilman | 3 | -1/+13 | |
Takes a UUID of a user and provides and interface that allows RW access to user data/settings. | |||||
2019-07-03 | acc: Implement IProfileEditor-specific commands 'Store' and 'StoreWithImage' | Zach Hilman | 1 | -1/+73 | |
Verified with IDA | |||||
2019-07-03 | profile_manager: Add setter for ProfileBase and ProfileData | Zach Hilman | 2 | -0/+13 | |
Needed by IProfileEditor 'Store' and 'StoreWithImage' | |||||
2019-07-03 | acc: Add IProfileCommon for IProfile and IProfileEditor | Zach Hilman | 1 | -8/+31 | |
Since 2/3 of the commands are shared, this is likely how its done on HW. | |||||
2019-07-02 | file_sys: Rename other ContentRecordType members | Bakugo | 5 | -7/+8 | |
2019-07-01 | audren: Only manage wave buffers with a size | David Marcec | 1 | -3/+5 | |
We shouldn't be incrementing if wave buffers are empty. They are considered invalid/unused wave buffers. This fixes the issue of certain sounds looping when they shouldn't | |||||
2019-07-01 | rasterizer_cache: Protect inherited caches from submission level | Fernando Sahmkow | 3 | -1/+5 | |
2019-07-01 | IAudioDevice::QueryAudioDeviceOutputEvent | David Marcec | 1 | -3/+16 | |
The event should only be signaled when an output audio device gets changed. Example, Speaker to USB headset. We don't identify different devices internally yet so there's no need to signal the event yet. | |||||
2019-07-01 | file_sys/registered_cache: Improve missing metadata error | Bakugo | 1 | -2/+2 | |
This can happen when installing NSPs too, not just XCIs. | |||||
2019-07-01 | file_sys/submission_package: Don't warn about missing DeltaFragment NCAs | Bakugo | 1 | -4/+7 | |
DeltaFragments are not useful to us and are often not included in patch NSPs. | |||||
2019-07-01 | file_sys/registered_cache: Ignore DeltaFragment NCAs during installation | Bakugo | 1 | -0/+3 | |
DeltaFragments are only used to download and apply partial patches on a real console, and are not useful to us at all. Most patch NSPs do not include them, and when they do, it's a waste of space to install them. | |||||
2019-07-01 | file_sys: Rename ContentRecordType::Patch to DeltaFragment | Bakugo | 1 | -1/+1 | |
Avoids potential confusion, since patches and DeltaFragments are not the same thing. Actual full patches are listed under the Program type. | |||||
2019-07-01 | hid:StartLrAssignmentMode, hid:StopLrAssignmentMode, hid:SwapNpadAssignment | David Marcec | 6 | -3/+99 | |
StartLrAssignmentMode and StopLrAssignmentMode don't require any implementation as it's just used for showing the screen of changing the controller orientation if the user wishes to do so. Ever since #1634 this has not been needed as users can specify the controller orientation from the config and swap at any time. We store a private member just in case this gets used for anything extra in the future | |||||
2019-06-30 | texture_cache: Pack sibling queries inside a method | ReinUsesLisp | 1 | -6/+8 | |
2019-06-30 | texture_cache: Use std::vector reservation for sampled_textures | ReinUsesLisp | 1 | -17/+10 | |
2019-06-30 | texture_cache: Style changes | ReinUsesLisp | 3 | -17/+13 | |
2019-06-29 | texture_cache: Use std::array for siblings_table | ReinUsesLisp | 1 | -10/+13 | |
2019-06-29 | texture_cache: Address feedback | ReinUsesLisp | 4 | -30/+13 | |
2019-06-29 | am: Implement SetCpuBoostMode in terms of APM | Zach Hilman | 5 | -13/+26 | |
2019-06-29 | core: Keep instance of APM Controller | Zach Hilman | 2 | -0/+20 | |
2019-06-29 | apm: Implement SetCpuBoostMode | Zach Hilman | 2 | -0/+14 | |
2019-06-29 | apm: Add getters for performance config and mode | Zach Hilman | 2 | -33/+49 | |
2019-06-29 | apm: Add apm:am service | Zach Hilman | 2 | -11/+9 | |
8.0.0+ identical version of apm | |||||
2019-06-29 | apm: Add Controller class to manage speed data and application | Zach Hilman | 3 | -0/+140 | |
2019-06-29 | fsp-srv: Implement GetAccessLogVersionInfo | Zach Hilman | 2 | -3/+14 | |
Returns some misc. data about logging to help the game determine if it should log. | |||||
2019-06-29 | reporter: Add report class for filesystem access logs | Zach Hilman | 2 | -0/+25 | |
2019-06-29 | fsp-srv: Implement OutputAccessLogToSdCard | Zach Hilman | 7 | -27/+62 | |
Allows games to log data to the SD. | |||||
2019-06-29 | set: Implement GetQuestFlag | Zach Hilman | 2 | -1/+10 | |
Simply returns a true/false value indicating if the system is a kiosk system. This has been mapped to a config option for the purposes of yuzu. | |||||
2019-06-29 | settings: Add config option for kiosk (quest) mode | Zach Hilman | 6 | -1/+26 | |
2019-06-28 | Attemp clang format fix? | David Marcec | 1 | -1/+0 | |
Seems to be an issue with clang format | |||||
2019-06-28 | Added errors.h to cmakelist | David Marcec | 1 | -0/+1 | |
2019-06-28 | Addressed issues | David Marcec | 2 | -13/+13 | |
2019-06-28 | Addressed issues | David Marcec | 2 | -17/+12 | |
2019-06-27 | Implemented InitializeApplicationInfo & InitializeApplicationInfoRestricted | David Marcec | 4 | -6/+114 | |
InitializeApplicationInfoRestricted will need further implementation as it's checking for other user requirements about the game. As we're emulating, we're assuming the user owns the game so we skip these checks currently, implementation will need to be added further on | |||||
2019-06-27 | pm: Implement pm:shell and pm:dmnt GetApplicationPid | Zach Hilman | 3 | -7/+33 | |
Returns the process ID of the current application or 0 if no app is running. | |||||
2019-06-27 | pm: Implement pm:dmnt GetTitlePid | Zach Hilman | 1 | -7/+36 | |
Takes a title ID and searches for a matching process, returning error if it doesn't exist, otherwise the process ID. | |||||
2019-06-27 | pm: Implement pm:info GetTitleId | Zach Hilman | 1 | -2/+47 | |
Searches the process list for a process with the specified ID, returning the title ID if it exists. | |||||
2019-06-26 | Addressed issues | David Marcec | 5 | -37/+53 | |
2019-06-26 | glue: Correct missing bytes in ApplicationLaunchParameter | Zach Hilman | 7 | -37/+71 | |
2019-06-26 | texture_cache: Correct variable naming. | Fernando Sahmkow | 1 | -3/+3 | |
2019-06-26 | gl_texture_cache: Correct asserts | Fernando Sahmkow | 2 | -2/+2 | |
2019-06-26 | texture_cache: Corrections, documentation and asserts | Fernando Sahmkow | 1 | -42/+42 | |
2019-06-26 | surface_params: Corrections, asserts and documentation. | Fernando Sahmkow | 2 | -43/+58 | |
2019-06-25 | copy_params: use constexpr for constructor | Fernando Sahmkow | 1 | -3/+4 | |
2019-06-25 | gl_texture_cache: Corrections and fixes | Fernando Sahmkow | 2 | -13/+9 | |
2019-06-25 | gl_resource_manager: Correct MakeStreamCopy | Fernando Sahmkow | 2 | -3/+2 | |
2019-06-25 | texture_cache: Query MemoryManager from the system | Fernando Sahmkow | 5 | -20/+7 | |
2019-06-25 | Implement Time::GetSharedMemoryNativeHandle | David Marcec | 8 | -29/+245 | |
This PR attempts to implement the shared memory provided by GetSharedMemoryNativeHandle. There is still more work to be done however that requires a rehaul of the current time module to handle clock contexts. This PR is mainly to get the basic functionality of the SharedMemory working and allow the use of addition to it whilst things get improved on. Things to note: Memory Barriers are used in the SharedMemory and a better solution would need to be done to implement this. Currently in this PR I’m faking the memory barriers as everything is sync and single threaded. They work by incrementing the counter and just populate the two data slots. On data reading, it will read the last added data. Specific values in the shared memory would need to be updated periodically. This isn't included in this PR since we don't actively do this yet. In a later PR when time is refactored this should be done. Finally, as we don't handle clock contexts. When time is refactored, we will need to update the shared memory for specific contexts. This PR does this already however since the contexts are all identical and not separated. We're just updating the same values for each context which in this case is empty. Tiime:SetStandardUserSystemClockAutomaticCorrectionEnabled, Time:IsStandardUserSystemClockAutomaticCorrectionEnabled are also partially implemented in this PR. The reason the implementation is partial is because once again, a lack of clock contexts. This will be improved on in a future PR. This PR closes issue #2556 | |||||
2019-06-25 | SizedNotificationInfo should be 0x10 bytes, user_uuid is incorrect, this should be the users account id | David Marcec | 1 | -1/+3 | |
2019-06-25 | fixed spelling errors and fixed issue with Pop not returning the SizedNotificationInfo | David Marcec | 1 | -6/+8 | |
2019-06-25 | applets: Pass current process title ID to applets | Zach Hilman | 11 | -41/+59 | |
Avoids using system accessor to get current process in applet code. | |||||
2019-06-25 | general_frontend: Add documentation for parental controls and ecommerce applets | Zach Hilman | 5 | -27/+55 | |
2019-06-25 | web_browser: Only delete temporary directory if it was created | Zach Hilman | 1 | -1/+3 | |
Prevents crashes with ShopN applet occasionally. | |||||
2019-06-25 | web_browser: Take ECommerce applet frontend optionally in constructor | Zach Hilman | 1 | -1/+6 | |
If it is needed but wasn't passed (or passed nullptr), the Shop handling code will alert and throw an error. | |||||
2019-06-25 | frontend: Add base class and default impl for ECommerce applet frontend | Zach Hilman | 2 | -0/+102 | |
2019-06-25 | web_browser: Use function tables for execute and initialize | Zach Hilman | 2 | -7/+285 | |
Allows easy handling of multiple shim types, as they have enough in common to be the same backend but not enough to share init/exec. | |||||
2019-06-25 | web_browser: Correct structures and properly parse TLVs/ShimKind | Zach Hilman | 2 | -61/+168 | |
Much, much more HW-accurate and allows us to easily support all of the different web 'shim' types. | |||||
2019-06-25 | yuzu: Accept default applets for Parental Controls and ECommerce | Zach Hilman | 1 | -5/+7 | |
2019-06-25 | applets: Track ECommerce and Parental Control applet frontends | Zach Hilman | 2 | -7/+29 | |
2019-06-25 | web_browser: Rename OpenPage to OpenPageLocal | Zach Hilman | 4 | -11/+11 | |
This is more representative of what actually occurs, as web does support remote URLs which wouldn't need a romfs callback. This paves for easy future support of this with a call like 'OpenPageRemote' or similar. | |||||
2019-06-25 | frontend: Add base class and default impl of parent controls applet frontend | Zach Hilman | 2 | -1/+52 | |
2019-06-25 | applets: Implement Auth applet backend | Zach Hilman | 2 | -0/+146 | |
This is responsible for parental controls and supports verifying, changing, and registering PIN codes. | |||||
2019-06-25 | core: Keep track of ARPManager and register current application on boot | Zach Hilman | 2 | -0/+76 | |
2019-06-25 | glue: Implement arp:w and arp:r services | Zach Hilman | 3 | -2/+330 | |
These keep track of running process' launch properties and control properties and allows for issuing and reading them by process and title ID. | |||||
2019-06-25 | glue: Add errors for glue/arp services | Zach Hilman | 4 | -2/+65 | |
2019-06-25 | glue: Add scaffolding for bgtc:t and bgtc:sc services | Zach Hilman | 2 | -0/+73 | |
2019-06-25 | arp: Move to glue services | Zach Hilman | 2 | -91/+0 | |
Glue is the name of the sysmodule that contains both arp and bgtc. | |||||
2019-06-25 | glue: Add manager to keep track of application registry | Zach Hilman | 3 | -0/+121 | |
Manages mapping between title IDs and application launch and control properties. | |||||
2019-06-25 | registered_cache: Add getter to determine source slot in content provider union | Zach Hilman | 2 | -0/+17 | |
Used to determine StorageId source for application data. | |||||
2019-06-25 | patch_manager: Add getter for title version | Zach Hilman | 2 | -2/+14 | |
2019-06-24 | texture_cache: Include "core/core.h" | ReinUsesLisp | 1 | -4/+1 | |
2019-06-24 | gl_texture_cache: Explicitly add indirect include | ReinUsesLisp | 1 | -0/+1 | |
2019-06-24 | texture_cache/surface_view: Address feedback | ReinUsesLisp | 1 | -1/+0 | |
2019-06-24 | texture_cache/surface_base: Address feedback | ReinUsesLisp | 2 | -2/+10 | |
2019-06-24 | video_core/surface: Address feedback | ReinUsesLisp | 1 | -2/+2 | |
2019-06-24 | decode/texture: Address feedback | ReinUsesLisp | 1 | -0/+1 | |
2019-06-24 | renderer_opengl/utils: Remove unused includes and unused forward declaration | ReinUsesLisp | 1 | -4/+0 | |
2019-06-24 | gl_texture_cache: Address some feedback | ReinUsesLisp | 1 | -2/+4 | |
2019-06-24 | gl_shader_disk_cache: Address feedback | ReinUsesLisp | 2 | -4/+8 | |
2019-06-24 | gl_shader_decompiler: Address feedback | ReinUsesLisp | 1 | -11/+12 | |
2019-06-24 | shader_bytecode: Include missing <array> | ReinUsesLisp | 1 | -0/+1 | |
2019-06-24 | common/alignment: Address feedback | ReinUsesLisp | 1 | -2/+3 | |
2019-06-24 | Implemented INotificationService | David Marcec | 5 | -1/+127 | |
2019-06-22 | Update reporter.cpp | Thomas May | 1 | -5/+5 | |
2019-06-21 | service/acc: Silence truncation warnings | Lioncash | 1 | -3/+3 | |
The sanitizing function ensures that the returned type is always the correct type. This eliminates warnings without extra casts. | |||||
2019-06-21 | texture_cache: Style and Corrections | Fernando Sahmkow | 7 | -71/+75 | |
2019-06-21 | shader_cache: Correct versioning and size calculation. | Fernando Sahmkow | 2 | -2/+7 | |
2019-06-21 | texture_cache: Eliminate linear textures fallthrough | Fernando Sahmkow | 1 | -4/+0 | |
2019-06-21 | texture_cache: Correct format R16U as sibling | Fernando Sahmkow | 2 | -1/+2 | |
2019-06-21 | texture_cache: Implement texception detection and texture barriers. | Fernando Sahmkow | 2 | -7/+40 | |
2019-06-21 | texture_cache: Corrections to buffers and shadow formats use. | Fernando Sahmkow | 1 | -10/+34 | |
2019-06-21 | texture_cache: Implement Irregular Views in surfaces | Fernando Sahmkow | 2 | -4/+24 | |
2019-06-21 | surface: Correct format S8Z24 | Fernando Sahmkow | 4 | -9/+5 | |
2019-06-21 | texture_cache: Initialize all siblings to invalid pixel format. | Fernando Sahmkow | 1 | -6/+15 | |
2019-06-21 | gl_texture_cache: Use Stream Buffers instead of Persistant for Buffer Copies. | Fernando Sahmkow | 3 | -5/+4 | |
2019-06-21 | gl_texture_cache: Correct Image Blit | Fernando Sahmkow | 1 | -1/+1 | |
2019-06-21 | decoders: correct block calculation | Fernando Sahmkow | 7 | -29/+41 | |
2019-06-21 | texture_cache: Use siblings textures on Rebuild and fix possible error on blitting | Fernando Sahmkow | 2 | -11/+24 | |
2019-06-21 | texture_cache: Remove old rasterizer cache | Fernando Sahmkow | 2 | -1956/+0 | |
2019-06-21 | texture_cache: Implement siblings texture formats. | Fernando Sahmkow | 2 | -12/+31 | |
2019-06-21 | fermi2d: Correct Origin Mode | Fernando Sahmkow | 1 | -5/+10 | |
2019-06-21 | texture_cache: correct texture buffer on surface params | Fernando Sahmkow | 1 | -4/+11 | |
2019-06-21 | texture_cache: eliminate accelerated depth->color/color->depth copies due to driver instability. | Fernando Sahmkow | 4 | -22/+6 | |
2019-06-21 | texture_cache: correct mutex locks | Fernando Sahmkow | 1 | -4/+4 | |
2019-06-21 | shader_ir: Fix image copy rebase issues | Fernando Sahmkow | 1 | -2/+7 | |
2019-06-21 | texture_cache: Don't Image Copy if component types differ | Fernando Sahmkow | 1 | -1/+2 | |
2019-06-21 | texture_cache: move some large methods to cpp files | Fernando Sahmkow | 4 | -139/+135 | |
2019-06-21 | texture_cache: Optimize GetSurface and use references on functions that don't change a surface. | Fernando Sahmkow | 3 | -12/+12 | |
2019-06-21 | texture_cache: Implement Buffer Copy and detect Turing GPUs Image Copies | Fernando Sahmkow | 8 | -12/+148 | |
2019-06-21 | texture_cache uncompress-compress is untopological. | Fernando Sahmkow | 5 | -19/+53 | |
This makes conflicts between non compress and compress textures to be auto recycled. It also limits the amount of mipmaps a texture can have if it goes above it's limit. | |||||
2019-06-21 | texture_cache: Correct copying between compressed and uncompressed formats | Fernando Sahmkow | 3 | -10/+27 | |
2019-06-21 | texture_cache: Only load on recycle with accurate GPU. | Fernando Sahmkow | 1 | -2/+3 | |
Testing so far has proven this to be quite safe as texture memory read added a 2-5ms load to the current cache. | |||||
2019-06-21 | Fix rebase errors | Fernando Sahmkow | 3 | -3/+13 | |
2019-06-21 | texture_cache: Handle uncontinuous surfaces. | Fernando Sahmkow | 4 | -21/+82 | |
2019-06-21 | texture_cache: return null surface on invalid address | Fernando Sahmkow | 1 | -0/+12 | |
2019-06-21 | texture_cache: Add checks for texture buffers. | Fernando Sahmkow | 1 | -2/+16 | |
2019-06-21 | texture_cache: Fermi2D reform and implement View Mirage | Fernando Sahmkow | 11 | -77/+125 | |
This also does some fixes on compressed textures reinterpret and on the Fermi2D engine in general. | |||||
2019-06-21 | gl_shader_decompiler: Implement image binding settings | ReinUsesLisp | 5 | -24/+52 | |
2019-06-21 | shader: Implement bindless images | ReinUsesLisp | 3 | -2/+40 | |
2019-06-21 | shader: Decode SUST and implement backing image functionality | ReinUsesLisp | 9 | -3/+283 | |
2019-06-21 | gl_rasterizer: Track texture buffer usage | ReinUsesLisp | 6 | -74/+119 | |
2019-06-21 | video_core: Make ARB_buffer_storage a required extension | ReinUsesLisp | 5 | -8/+12 | |
2019-06-21 | gl_rasterizer_cache: Use texture buffers to emulate texture buffers | ReinUsesLisp | 5 | -11/+35 | |
2019-06-21 | maxwell_3d: Partially implement texture buffers as 1D textures | ReinUsesLisp | 4 | -10/+24 | |
2019-06-21 | gl_shader_decompiler: Allow 1D textures to be texture buffers | ReinUsesLisp | 1 | -4/+38 | |
2019-06-21 | shader: Implement texture buffers | ReinUsesLisp | 3 | -0/+62 | |
2019-06-21 | texture_cache: loose TryReconstructSurface when accurate GPU is not on. | Fernando Sahmkow | 3 | -4/+20 | |
Also corrects some asserts. | |||||
2019-06-21 | texture_cache: Document the most important methods. | Fernando Sahmkow | 1 | -8/+87 | |
2019-06-21 | texture_cache: Try to Reconstruct Surface on bigger than overlap. | Fernando Sahmkow | 1 | -4/+11 | |
This fixes clouds in SMO Cap Kingdom and lens on Cloud Kingdom. Also moved accurate_gpu setting check to Pick Strategy | |||||
2019-06-21 | texture_cache: Implement Guard mechanism | Fernando Sahmkow | 2 | -1/+12 | |
2019-06-21 | texture_cache: General Fixes | Fernando Sahmkow | 8 | -47/+170 | |
Fixed ASTC mipmaps loading Fixed alignment on openGL upload/download Fixed Block Height Calculation Removed unalign_height | |||||
2019-06-21 | surface_params: Ensure pitch is always written to avoid surface leaks | ReinUsesLisp | 1 | -0/+2 | |
2019-06-21 | gl_framebuffer_cache: Use a hashed struct to cache framebuffers | ReinUsesLisp | 6 | -62/+148 | |
2019-06-21 | texture_cache return invalid buffer on deactivated color_mask | Fernando Sahmkow | 2 | -2/+9 | |
2019-06-21 | engine_upload: Addapt to new Texture Cache | Fernando Sahmkow | 2 | -5/+5 | |
2019-06-21 | surface_params: Optimize CreateForTexture | ReinUsesLisp | 2 | -72/+76 | |
Instead of using Common::AlignUp, use Common::AlignBits to align the texture compression factor. | |||||
2019-06-21 | gl_texture_cache: Make main views be proxy textures instead of a full view. | Fernando Sahmkow | 2 | -11/+25 | |
2019-06-21 | texture_cache: Add ASync Protections | Fernando Sahmkow | 1 | -0/+10 | |
2019-06-21 | Remove Framebuffer reconfiguration and restrict rendertarget protection | Fernando Sahmkow | 4 | -39/+27 | |
2019-06-21 | texture_cache: Implement GPU Dirty Flags | Fernando Sahmkow | 1 | -15/+22 | |
2019-06-21 | texture_cache: Optimize GetMipBlockHeight and GetMipBlockDepth | Fernando Sahmkow | 2 | -13/+50 | |
2019-06-21 | texture_cache: Implement L1_Inner_cache | Fernando Sahmkow | 1 | -13/+30 | |
2019-06-21 | video_core: Use un-shifted block sizes to avoid integer divisions | ReinUsesLisp | 10 | -60/+78 | |
Instead of storing all block width, height and depths in their shifted form: block_width = 1U << block_shift; Store them like they are provided by the emulated hardware (their block_shift form). This way we can avoid doing the costly Common::AlignUp operation to align texture sizes and drop CPU integer divisions with bitwise logic (defined in Common::AlignBits). | |||||
2019-06-21 | texture_cache: Change internal cache from lists to vectors | ReinUsesLisp | 1 | -6/+7 | |
2019-06-21 | Reduce amount of size calculations. | Fernando Sahmkow | 8 | -88/+97 | |
2019-06-21 | texture_cache: Correct premature texceptions | Fernando Sahmkow | 4 | -14/+51 | |
Due to our current infrastructure, it is possible for a mipmap to be set on as a render target before a texception of that mipmap's superset be set afterwards. This is problematic as we rely on texture views to set up texceptions and protecting render targets targets for 3D texture rendering. One simple solution is to configure framebuffers after texture setup but this brings other problems. This solution, forces a reconfiguration of the framebuffers after such event happens. | |||||
2019-06-21 | texture_cache: Implement guest flushing | Fernando Sahmkow | 3 | -10/+29 | |
2019-06-21 | Fixes to mipmap's process and reconstruct process | Fernando Sahmkow | 2 | -3/+3 | |
2019-06-21 | surface_base: Add parenthesis to EmplaceOverview's predicate | ReinUsesLisp | 1 | -3/+2 | |
2019-06-21 | Texture Cache: Implement Blitting and Fermi Copies | Fernando Sahmkow | 7 | -100/+93 | |
2019-06-21 | surface_view: Add constructor for ViewParams | ReinUsesLisp | 3 | -39/+23 | |
2019-06-21 | surface_base: Split BreakDown into layered and non-layered variants | ReinUsesLisp | 1 | -45/+48 | |
2019-06-21 | surface_base: Silence truncation warnings and minor renames and reordering | ReinUsesLisp | 2 | -32/+37 | |
2019-06-21 | copy_params: Use constructor instead of C-like initialization | ReinUsesLisp | 3 | -47/+39 | |
2019-06-21 | Correct Mipmaps View method in Texture Cache | Fernando Sahmkow | 3 | -32/+29 | |
2019-06-21 | Change texture_cache chaching from GPUAddr to CacheAddr | Fernando Sahmkow | 7 | -101/+60 | |
This also reverses the changes to make invalidation and flushing through the GPU address. | |||||
2019-06-21 | Corrections to Structural Matching | Fernando Sahmkow | 2 | -24/+53 | |
The texture will now be reconstructed if the width only matches on GoB alignment. | |||||
2019-06-21 | Implement Texture Cache V2 | Fernando Sahmkow | 6 | -381/+568 | |
2019-06-21 | Correct Surface Base and Views for new Texture Cache | Fernando Sahmkow | 7 | -380/+466 | |
2019-06-21 | Add OGLTextureView | Fernando Sahmkow | 2 | -0/+43 | |
2019-06-21 | Deglobalize Memory Manager on texture cahe and Implement Invalidation and Flushing using GPUVAddr | Fernando Sahmkow | 4 | -1/+20 | |
2019-06-21 | texture_cache: Remove execution context copies from the texture cache | ReinUsesLisp | 7 | -168/+59 | |
This is done to simplify the OpenGL implementation, it is needed for Vulkan. | |||||
2019-06-21 | gl_texture_cache: Implement fermi copies | ReinUsesLisp | 5 | -2/+105 | |
2019-06-21 | texture_cache: Split texture cache into different files | ReinUsesLisp | 12 | -876/+965 | |
2019-06-21 | texture_cache: Move staging buffer into a generic implementation | ReinUsesLisp | 4 | -181/+211 | |
2019-06-21 | texture_cache: Flush 3D textures in the order they are drawn | ReinUsesLisp | 5 | -19/+44 | |
2019-06-21 | gl_texture_cache: Minor changes | ReinUsesLisp | 5 | -140/+185 | |
2019-06-21 | gl_texture_cache: Add copy from multiple overlaps into a single surface | ReinUsesLisp | 3 | -6/+84 | |
2019-06-21 | gl_texture_cache: Attach surface textures instead of views | ReinUsesLisp | 3 | -20/+32 | |
2019-06-21 | gl_texture_cache: Add fast copy path | ReinUsesLisp | 4 | -7/+60 | |
2019-06-21 | gl_texture_cache: Initial implementation | ReinUsesLisp | 9 | -47/+809 | |
2019-06-21 | freezer: Update documentation | Zach Hilman | 1 | -1/+8 | |
2019-06-21 | core: Move Freezer class to tools namespace | Zach Hilman | 4 | -17/+17 | |
2019-06-21 | freezer: Add documentation for methods | Zach Hilman | 2 | -30/+49 | |
2019-06-21 | memory: Add class to manage and enforce memory freezing | Zach Hilman | 4 | -0/+248 | |
2019-06-20 | Revert PR 2590. | Fernando Sahmkow | 1 | -1/+1 | |
Even though it has been proven that IAudioRenderer:SystemEvent is actually an automatic event. The current implementation of such event is all thought to be manual. Thus it's implementation needs to be corrected when doing such change. As it is right now this PR introduced a series of regressions on softlocks on multiple games. Therefore, this pr reverts such change until a correct implementation is made. | |||||
2019-06-20 | Update content_archive.cpp | jonsn0w | 1 | -2/+2 | |
log clutter in debug logs when theres really no need | |||||
2019-06-19 | Change to a more descriptive name | Tobias | 1 | -1/+1 | |
2019-06-19 | yuzu/configure_input: Add missing space in window name | Tobias | 1 | -1/+1 | |
2019-06-19 | Added missing space between two words | Alex Subaric | 1 | -1/+1 | |
Added missing whitespace character between two words in the "Warning Missing Derivation Components" warning message box. | |||||
2019-06-18 | core: Remove unused CiTrace source files | Lioncash | 5 | -399/+0 | |
These source files have been unused for the entire lifecycle of the project. They're a hold-over from Citra and only add to the build time of the project, so they can be removed. There's also likely no way this would ever work in yuzu in its current form without revamping quite a bit of it, given how different the GPU on the Switch is compared to the 3DS. | |||||
2019-06-18 | service/audio/audren_u: Correct event reset type for the system event | Lioncash | 1 | -1/+1 | |
This is actually an auto-reset event in the audio service itself, not a manual one. | |||||
2019-06-17 | Addressed issues | David Marcec | 4 | -9/+14 | |
2019-06-16 | Core_Timing: Make core_timing threadsafe by default. | Fernando Sahmkow | 5 | -60/+25 | |
The old implementation had faulty Threadsafe methods where events could be missing. This implementation unifies unsafe/safe methods and makes core timing thread safe overall. | |||||
2019-06-16 | Signalled accumulated_suspended_tick_changed_event on creation based on RE | David Marcec | 1 | -0/+1 | |
2019-06-16 | Cleanup | David Marcec | 12 | -30/+39 | |
2019-06-16 | Impl'd IsUserAccountSwitchLocked, SetAudioOutVolume, GetAudioOutVolume & Partial impl of GetAccumulatedSuspendedTickChangedEvent | David Marcec | 10 | -11/+93 | |
IPC-100 was changed to InitializeApplicationInfoOld instead of InitializeApplicationInfo. IPC-150 makes an indentical call to IPC-100 however does extra processing. They should not have the same name as it's quite confusing to debug. | |||||
2019-06-13 | file_sys/ips_layer: Remove unnecessary reserve() call | Lioncash | 1 | -1/+0 | |
Given 'replace' is assigned to on the following line, this isn't necessary, given the underlying data is going to be overwritten entirely. | |||||
2019-06-12 | common/hex_util: Reserve std::string memory ahead of time | Lioncash | 1 | -0/+5 | |
Avoids potentially performing multiple reallocations (depending on the size of the input data) by reserving the necessary amount of memory ahead of time. This is trivially doable, so there's no harm in it. | |||||
2019-06-12 | common/hex_util: Combine HexVectorToString() and HexArrayToString() | Lioncash | 11 | -39/+40 | |
These can be generified together by using a concept type to designate them. This also has the benefit of not making copies of potentially very large arrays. | |||||
2019-06-12 | file_sys/card_image: Remove obsolete TODO | Lioncash | 1 | -1/+1 | |
We already support Rev 1+. | |||||
2019-06-12 | kernel/vm_manager: Remove redundant Reset call in destructor | Lioncash | 1 | -3/+1 | |
This is performing more work than would otherwise be necessary during VMManager's destruction. All we actually want to occur in this scenario is for any allocated memory to be freed, which will happen automatically as the VMManager instance goes out of scope. Anything else being done is simply unnecessary work. | |||||
2019-06-12 | gl_device: Fix TestVariableAoffi test | ReinUsesLisp | 1 | -1/+2 | |
This test is intended to be invalid GLSL, but it was being invalid in two points instead of one. The intention is to use a non-immediate parameter in a textureOffset like function. The problem is that this shader was being compiled as a separable shader object and the text was writting to gl_Position without a redeclaration, being invalid GLSL. Address that issue by using a user-defined output attribute. | |||||
2019-06-11 | file_sys/nca_metadata: Update CNMT structures | Lioncash | 1 | -2/+7 | |
Names a few more entries in relevant structures. Information based off SwitchBrew and my own RE. | |||||
2019-06-11 | file_sys/card_image: Deduplicate casts within AddNCAFromPartition() | Lioncash | 1 | -3/+6 | |
Makes for nicer reading. | |||||
2019-06-11 | file_sys/card_image: Make bracing consistent | Lioncash | 1 | -4/+8 | |
Makes for more consistent reading. | |||||
2019-06-11 | file_sys/card_image: Assign collapsed NCA contents directly to ncas member | Lioncash | 1 | -3/+1 | |
Same thing, significantly less noisy. | |||||
2019-06-11 | file_sys/card_image: Deduplicate type cast | Lioncash | 1 | -4/+6 | |
Same thing, less duplication. We can also std::move raw into the PartitionFilesystem constructor. | |||||
2019-06-11 | file_sys/card_image: Get rid of a magic number | Lioncash | 1 | -1/+1 | |
We can just use the size of the array to dehardcode it. | |||||
2019-06-11 | file_sys/card_image: Use std::array deduction guides | Lioncash | 1 | -1/+6 | |
Same thing, less code. | |||||
2019-06-10 | yuzutest: Add minor comments | Zach Hilman | 2 | -8/+9 | |
2019-06-10 | kernel: Differentiate kernel and user processes when picking ID | Zach Hilman | 6 | -10/+29 | |
This allows kernel internal type processes to be assigned IDs in the KIP range while userland processes are assigned in the user range. | |||||
2019-06-10 | nsp: Correct status codes for extracted NSPs | Zach Hilman | 2 | -13/+17 | |
Avoids all extracted NSPs being marked as error file type because they don't have program NCAs. | |||||
2019-06-10 | nsp: Use title ID from NPDM metadata for extracted type NSPs | Zach Hilman | 2 | -1/+22 | |
Avoids 0 being used as title ID for all extracted NSPs. | |||||
2019-06-10 | arm_dynarmic: Check if jit is nullptr when preparing reschedule | Zach Hilman | 1 | -0/+3 | |
Prevents crash with multiprocess loading. | |||||
2019-06-10 | yuzu_tester: Display results in table format | Zach Hilman | 3 | -12/+50 | |
2019-06-10 | yuzutest: Support multiple tests per executable | Zach Hilman | 4 | -33/+41 | |
2019-06-10 | yuzu_tester: Add 'yuzutest' service | Zach Hilman | 2 | -0/+123 | |
2019-06-10 | yuzu_tester: Add SDL2-based EmuWindow that doesn't show the window | Zach Hilman | 2 | -0/+164 | |
2019-06-10 | yuzu_tester: Use config, icon, and main from yuzu-cmd | Zach Hilman | 6 | -0/+624 | |
2019-06-10 | yuzu_tester: Add project subdirectory | Zach Hilman | 2 | -0/+35 | |
2019-06-10 | kernel/process: Make Create()'s name parameter be taken by value | Lioncash | 2 | -2/+2 | |
Makes the interface more flexible in terms of how Create() may be called, while still allowing the parameter itself to be moved into. | |||||
2019-06-10 | kernel/svc: Implement TotalMemoryUsedWithoutMmHeap/TotalMemoryAvailableWithoutMmHeap | Lioncash | 3 | -2/+42 | |
Given we don't currently implement the personal heap yet, the existing memory querying functions are essentially doing what the memory querying types introduced in 6.0.0 do. So, we can build the necessary machinery over the top of those and just use them as part of info types. | |||||
2019-06-10 | kernel/svc: Amend naming for TotalMemoryUsage in svcGetInfo() | Lioncash | 3 | -6/+6 | |
Disambiguates and makes the name a little more consistent with TotalPhysicalMemoryUsed. | |||||
2019-06-10 | kernel/svc: Remove duplicate enum entry in svcGetInfo() | Lioncash | 1 | -2/+1 | |
2019-06-09 | GPUVM: Correct GPU VM virtual address space | Fernando Sahmkow | 1 | -2/+2 | |
2019-06-08 | kepler_compute: Use std::array for cbuf info | ReinUsesLisp | 1 | -2/+3 | |
2019-06-08 | kepler_compute: Fix block_dim_x encoding | ReinUsesLisp | 1 | -1/+1 | |
2019-06-08 | gl_shader_cache: Use static constructors for CachedShader initialization | ReinUsesLisp | 2 | -52/+53 | |
2019-06-08 | gl_rasterizer: Remove unused parameters in descriptor uploads | ReinUsesLisp | 2 | -8/+6 | |
2019-06-08 | video_core/engines: Move ConstBufferInfo out of Maxwell3D | ReinUsesLisp | 6 | -49/+64 | |
2019-06-07 | constants: Extract backup JPEG used by account services | Zach Hilman | 5 | -28/+43 | |
2019-06-07 | shader: Split SSY and PBK stack | ReinUsesLisp | 4 | -27/+78 | |
Hardware testing revealed that SSY and PBK push to a different stack, allowing code like this: SSY label1; PBK label2; SYNC; label1: PBK; label2: EXIT; | |||||
2019-06-07 | kernel_executable: Optimize BLZ decompression | Zach Hilman | 2 | -10/+13 | |
2019-06-07 | cmake: Add missing shader hash file entries | ReinUsesLisp | 1 | -0/+3 | |
2019-06-07 | shader/node: Minor changes | ReinUsesLisp | 1 | -50/+54 | |
Reflect std::shared_ptr nature of Node on initializers and remove constant members in nodes. Add some commentaries. | |||||
2019-06-07 | shader: Move Node declarations out of the shader IR header | ReinUsesLisp | 4 | -493/+518 | |
Analysis passes do not have a good reason to depend on shader_ir.h to work on top of nodes. This splits node-related declarations to their own file and leaves the IR in shader_ir.h | |||||
2019-06-06 | yuzu/configuration: Make all widgets and dialogs aware of language changes | Lioncash | 31 | -58/+326 | |
To prepare for translation support, this makes all of the widgets cognizant of the language change event that occurs whenever installTranslator() is called and automatically retranslates their text where necessary. This is important as calling the backing UI's retranslateUi() is often not enough, particularly in cases where we add our own strings that aren't controlled by it. In that case we need to manually refresh the strings ourselves. | |||||
2019-06-06 | shader: Use shared_ptr to store nodes and move initialization to file | ReinUsesLisp | 35 | -248/+296 | |
Instead of having a vector of unique_ptr stored in a vector and returning star pointers to this, use shared_ptr. While changing initialization code, move it to a separate file when possible. This is a first step to allow code analysis and node generation beyond the ShaderIR class. | |||||
2019-06-05 | service/ns: Add missing override specifiers | Lioncash | 1 | -9/+9 | |
2019-06-05 | yuzu/CMakeLists: Disable implicit QString->QUrl conversions | Lioncash | 1 | -0/+3 | |
Enforces the use of the proper URL resolution functions. e.g. url = some_local_path_string; should actually be: url = QUrl::fromLocalPath(some_local_path_string); etc. This makes it harder to cause bugs when operating with both strings and URLs at the same time. | |||||
2019-06-05 | yuzu/CMakeLists: Disable unsafe overloads of QProcess' start() function | Lioncash | 1 | -0/+3 | |
Other overloads of start() are considerably much safer to use if we ever need this in the future and need to pass arguments to the program, given it contains separate parameters for the program path and the arguments themselves, whereas this unsafe overload contains both as a single string. Given the alternatives are much safer, we can disable this. | |||||
2019-06-05 | yuzu/CMakeLists: Disable implicit type narrowing in connect() calls | Lioncash | 1 | -0/+3 | |
Prevents hard-to-diagnose bugs from potentially occurring and requires any type narrowing to be explicitly performed by our code. | |||||
2019-06-05 | yuzu/configuration: Make function naming consistent | Lioncash | 33 | -213/+234 | |
2019-06-05 | kernel/process: Remove unused boost header include | Lioncash | 1 | -1/+0 | |
Boost headers typically include a lot of other headers, so removing this can prevent a bit of unnecessary compiler churn when building. | |||||
2019-06-05 | game_list: Accept *.kip as a file extension of executables | Zach Hilman | 2 | -3/+2 | |
2019-06-05 | loader: Add recognition for KIP file type | Zach Hilman | 2 | -0/+11 | |
2019-06-05 | loader: Add KIP and INI file parser-specific errors | Zach Hilman | 2 | -1/+9 | |
2019-06-05 | loader: Add AppLoader_KIP for KIP files | Zach Hilman | 3 | -0/+135 | |
2019-06-05 | program_metadata: Add function to load meta from raw parameters | Zach Hilman | 2 | -0/+20 | |
Needed for KIP loading as KIPs do not have an NPDM but do have the essential parts of the data within. | |||||
2019-06-05 | partition_data_manager: Remove KIP processing and use FileSys | Zach Hilman | 1 | -118/+13 | |
Previously, this TU contained the necessary headers to parse KIP/INI but now it should just use the FileSys class. | |||||
2019-06-05 | file_sys: Add classes to parse KIP1 and INI1 files | Zach Hilman | 3 | -0/+330 | |
2019-06-05 | core/core_timing_util: Amend casing of cyclesTo* functions | Lioncash | 3 | -6/+6 | |
Makes the casing consistent with all of our general function naming conventions. | |||||
2019-06-05 | core/core_timing_util: Use std::chrono types for specifying time units | Lioncash | 7 | -36/+43 | |
Makes the interface more type-safe and consistent in terms of return values. | |||||
2019-06-05 | core/core_timing_utils: Simplify overload set | Lioncash | 2 | -49/+2 | |
Removes unused overloads, simplifying the overall interface, deduplicating some code. | |||||
2019-06-04 | shader_bytecode: Mark EXIT as flow instruction | Fernando Sahmkow | 1 | -1/+1 | |
2019-06-03 | input_common/sdl/sdl_impl: Correct logging string in SDLState constructor | Lioncash | 1 | -1/+1 | |
If this path was ever taken, a runtime exception would occur due to the lack of a formatting specifier to insert the error code into the format string. | |||||
2019-06-03 | input_common/sdl/sdl_impl: Move documentation comments to header where applicable | Lioncash | 2 | -7/+6 | |
Places the documentation comments with the rest of SDLState's member function documentation. | |||||
2019-06-03 | input_common/sdl/sdl_impl: Amend names for axes for SDLAnalogPoller | Lioncash | 1 | -13/+13 | |
Adds another underscore to clearly indicate the axis names. | |||||
2019-06-03 | input_common/sdl/sdl_impl: Mark variables const where applicable | Lioncash | 1 | -10/+11 | |
Make it explicit that these aren't modified elsewhere (either through functions by reference, or by other operations). | |||||
2019-06-03 | input_common/sdl/sdl_impl: Mark SDLEventToButtonParamPackage() as static | Lioncash | 1 | -1/+1 | |
Its prototype declared at the top of the translation unit contains the static qualifier, so the function itself should also contain it to make it a proper internally linked function. | |||||
2019-06-03 | input_common/sdl/sdl_impl: Convert reinterpret_cast into a static_cast | Lioncash | 1 | -2/+4 | |
It's valid to static_cast a void pointer back into its proper type. | |||||
2019-06-03 | input_common/sdl/sdl_impl: Use insert_or_assign() where applicable | Lioncash | 1 | -3/+3 | |
Same behavior, but without a potential need to unnecessarily default construct a value. | |||||
2019-06-03 | input_common/sdl/sdl_impl: Simplify SDL_Joystick deleter handling | Lioncash | 1 | -15/+14 | |
The deleter can just be set in the constructor and maintained throughout the lifetime of the object. If a contained pointer is null, then the deleter won't execute, so this is safe to do. We don't need to swap it out with a version of a deleter that does nothing. | |||||
2019-06-03 | input_common/sdl/sdl_impl: Resolve two sign conversion warnings | Lioncash | 1 | -10/+16 | |
Silences the final two warnings in SDL code. | |||||
2019-06-03 | input_common/sdl: Remove unused header includes and forward declarations | Lioncash | 3 | -11/+5 | |
Gets rid of a few unnecessary inclusion dependencies. It also uncovered a few indirect inclusion dependencies being relied upon. | |||||
2019-06-03 | input_common/sdl/sdl_impl: Use nested namespace specifiers where applicable | Lioncash | 1 | -5/+2 | |
2019-06-03 | yuzu/bootmanager: Log out screenshot destination path | Lioncash | 1 | -6/+11 | |
We can make this message more meaningful by indicating the location the screenshot has been saved to. We can also log out whenever a screenshot could not be saved (e.g. due to filesystem permissions or some other reason). | |||||
2019-06-03 | yuzu/bootmanager: Treat the resolution factor as a u32 | Lioncash | 4 | -16/+25 | |
Treating it as a u16 can result in a sign-conversion warning when performing arithmetic with it, as u16 promotes to an int when aritmetic is performed on it, not unsigned int. This also makes the interface more uniform, as the layout interface now operates on u32 across the board. | |||||
2019-06-03 | yuzu/bootmanager: Default EmuThread's destructor in the cpp file | Lioncash | 2 | -1/+4 | |
This class contains non-trivial members, so we should default the destructor's definition within the cpp file. | |||||
2019-06-03 | yuzu/bootmanager: unsigned -> u32 | Lioncash | 2 | -11/+11 | |
Same thing (for platforms we support), less reading. | |||||
2019-06-03 | yuzu/bootmanager: Change false literal to 0 for setSwapInterval() | Lioncash | 1 | -1/+1 | |
This function is defined as taking an int, not a bool. | |||||
2019-06-03 | yuzu/bootmanager: Remove pointer downcast in GRenderWindow's constructor | Lioncash | 2 | -4/+3 | |
We can just pass a pointer to GMainWindow directly and make it a requirement of the interface. This makes the interface a little safer, since this would technically otherwise allow any random QWidget to be the parent of a render window, downcasting it to GMainWindow (which is undefined behavior). | |||||
2019-06-03 | yuzu/bootmanager: Remove unnecessary pointer casts | Lioncash | 1 | -5/+6 | |
We can just invoke these functions by qualifying the object name before the function. | |||||
2019-06-03 | gl_shader_decompiler: Remove guest "position" varying | ReinUsesLisp | 2 | -36/+21 | |
"position" was being written but not read anywhere besides geometry shaders, where it had the same value as gl_Position. This commit replaces "position" with gl_Position, reducing the complexity of our code and the emitted GLSL code. | |||||
2019-05-31 | input_common/sdl/sdl_impl: Silence sign conversion warnings | Lioncash | 1 | -3/+3 | |
Makes the conversions explicit, as opposed to implicit. | |||||
2019-05-31 | common/math_util: Provide a template deduction guide for Common::Rectangle | Lioncash | 1 | -0/+3 | |
Allows for things such as: auto rect = Common::Rectangle{0, 0, 0, 0}; as opposed to being required to explicitly write out the underlying type, such as: auto rect = Common::Rectangle<int>{0, 0, 0, 0}; The only requirement for the deduction is that all constructor arguments be the same type. | |||||
2019-05-31 | game_list_worker: Use QFile over our own IOFile instance or std streams | Lioncash | 1 | -28/+24 | |
Stays consistent in our code with using Qt's provided mechanisms, and also properly handles Unicode paths (which file streams on Windows don't do very well). | |||||
2019-05-31 | game_list_worker: Remove template specializations | Lioncash | 1 | -8/+2 | |
This is equivalent to specifying two separate functions, so we can just do that. | |||||
2019-05-30 | gl_shader_cache: Store a system class and drop global accessors | ReinUsesLisp | 2 | -7/+9 | |
2019-05-30 | gl_shader_cache: Add commentaries explaining the intention in shaders creation | ReinUsesLisp | 1 | -0/+2 | |
2019-05-30 | gl_shader_cache: Flip if condition in GetStageProgram to reduce indentation | ReinUsesLisp | 1 | -25/+26 | |
2019-05-30 | gl_buffer_cache: Remove unused ReserveMemory method | ReinUsesLisp | 2 | -13/+0 | |
2019-05-30 | maxwell_to_gl: Use GL_CLAMP to emulate Clamp wrap mode | ReinUsesLisp | 3 | -7/+4 | |
2019-05-30 | gl_rasterizer: Move alpha testing to the OpenGL pipeline | ReinUsesLisp | 8 | -71/+33 | |
Removes the alpha testing code from each fragment shader invocation. | |||||
2019-05-30 | gl_rasterizer: Use GL_QUADS to emulate quads rendering | ReinUsesLisp | 6 | -132/+5 | |
2019-05-30 | rasterizer_opengl: Remove OpenGL core profile | ReinUsesLisp | 8 | -29/+3 | |
2019-05-30 | main: Remove extraneous comment | Zach Hilman | 1 | -1/+0 | |
2019-05-30 | qt: Silence name collision warnings | ReinUsesLisp | 3 | -15/+15 | |
2019-05-29 | yuzu: Remove unused birthday setting | fearlessTobi | 3 | -170/+44 | |
Fixes #2522. | |||||
2019-05-29 | yuzu/software_keyboard: Remove unnecessary GetStatus() member function | Lioncash | 3 | -10/+1 | |
Like with the profile selection dialog, we can just use the result of QDialog's exec() function to determine whether or not a dialog was accepted. | |||||
2019-05-29 | profile_select: Remove unnecessary GetStatus() member function | Lioncash | 3 | -18/+8 | |
This behavior is already provided by the built-in exec() function. We just need to check the return value of it. | |||||
2019-05-29 | profile_select: Return int instead of u32 for GetIndex() | Lioncash | 3 | -8/+9 | |
Qt uses a signed value to represent indices. We should follow this convention where applicable to avoid unnecessary sign-conversion warnings, as well as making it easier to interoperate with other aspects of Qt. While we're at it, we can also make a sign-conversion explicit. | |||||
2019-05-29 | core/core: Remove unnecessary includes | Lioncash | 3 | -13/+37 | |
The contents of these includes aren't used anywhere in this translation unit. | |||||
2019-05-29 | yuzu_cmd/yuzu: Correct formatting specifier | Lioncash | 1 | -1/+1 | |
Amends the formatting specifier to obey libfmt. Prevents the application from terminating due to a formatting issue in the error case. | |||||
2019-05-29 | core/loader: Remove LoadKernelSystemMode | Lioncash | 5 | -29/+0 | |
This is a hold-over from Citra and doesn't apply to yuzu. | |||||
2019-05-29 | core/telemetry_session: Remove unnecessary web service nulling out in destructor | Lioncash | 1 | -2/+1 | |
This will automatically occur when the backend instance goes out of scope at the end of the destructor's execution. | |||||
2019-05-29 | core/telemetry_session: Remove usages of the global system accessor | Lioncash | 3 | -30/+54 | |
Makes the dependency explicit in the TelemetrySession's interface instead of making it a hidden dependency. This also revealed a hidden issue with the way the telemetry session was being initialized. It was attempting to retrieve the app loader and log out title-specific information. However, this isn't always guaranteed to be possible. During the initialization phase, everything is being constructed. It doesn't mean an actual title has been selected. This is what the Load() function is for. This potentially results in dead code paths involving the app loader. Instead, we explicitly add this information when we know the app loader instance is available. | |||||
2019-05-29 | core/telemetry_session: Explicitly delete copy and move constructors | Lioncash | 1 | -1/+7 | |
NonCopyable is misleading here. It also makes the class non-moveable as well, so we can be explicit about this. | |||||
2019-05-29 | core/telemetry_session: Remove unused include | Lioncash | 1 | -1/+0 | |
2019-05-27 | gl_device: Add commentary to AOFFI unit test source code | ReinUsesLisp | 1 | -0/+1 | |
The intention behind this commit is to hint someone inspecting an apitrace dump to ignore this ill-formed GLSL code. | |||||
2019-05-27 | gl_shader_gen: Always declare extensions after the version declaration | ReinUsesLisp | 2 | -7/+5 | |
This addresses a bug on geometry shaders where code was being written before all #extension declarations were done. Ref to #2523 | |||||
2019-05-27 | ncm: Implement LR OpenAddOnContentLocationResolver (2) | Zach Hilman | 1 | -24/+21 | |
Returns an object of type IAddOnContentLocationResolver for the provided StorageId. | |||||
2019-05-27 | ncm: Implement LR OpenRegisteredLocationResolver (1) | Zach Hilman | 1 | -0/+27 | |
Returns an object of type IRegisteredLocationResolver for the StorageId. | |||||
2019-05-27 | ncm: Implement LR OpenLocationResolver (0) | Zach Hilman | 1 | -0/+50 | |
Returns an object of type ILocationResolver with the provided StorageId. | |||||
2019-05-26 | game_list_worker: Add better error handling to caching | Zach Hilman | 2 | -23/+42 | |
2019-05-26 | yuzu: Clear partial/full game list cache when data is updated | Zach Hilman | 2 | -0/+13 | |
2019-05-26 | game_list: Implement caching for game list | Zach Hilman | 1 | -7/+99 | |
Preserves list of add ons and the icon, which are the two costliest parts of game list population. | |||||
2019-05-26 | ui_settings: Add option to cache game list | Zach Hilman | 2 | -0/+3 | |
2019-05-26 | loader: Move NSO module tracking to AppLoader | Zach Hilman | 22 | -81/+148 | |
Also cleanup of general stuff | |||||
2019-05-26 | vk_device: Let formats array type be deduced | ReinUsesLisp | 1 | -33/+33 | |
2019-05-26 | vk_shader_decompiler: Misc fixes | ReinUsesLisp | 2 | -45/+67 | |
Fix missing OpSelectionMerge instruction. This caused devices loses on most hardware, Intel didn't care. Fix [-1;1] -> [0;1] depth conversions. Conditionally use VK_EXT_scalar_block_layout. This allows us to use non-std140 layouts on UBOs. Update external Vulkan headers. | |||||
2019-05-26 | vk_device: Enable features when available and misc changes | ReinUsesLisp | 2 | -43/+151 | |
Keeps track of native ASTC support, VK_EXT_scalar_block_layout availability and SSBO range. Check for independentBlend and vertexPipelineStorageAndAtomics as a required feature. Always enable it. Use vk::to_string format to log Vulkan enums. Style changes. | |||||
2019-05-26 | emu_window: Pass OnMinimalClientAreaChangeRequest argument by copy | ReinUsesLisp | 5 | -10/+5 | |
There's no performance improvement in passing an unsigned pair by reference. | |||||
2019-05-25 | core_timing_util: Silence sign-comparison warnings | Lioncash | 1 | -4/+4 | |
We can just make the conversion explicit instead of implicit here to silence -Wsign-compare warnings. | |||||
2019-05-25 | loader/nso: Silence sign-comparison warning | Lioncash | 1 | -1/+1 | |
This was previously performing a size_t == int comparison. Silences a -Wsign-compare warning. | |||||
2019-05-25 | yuzu_cmd: Split emu_window OpenGL implementation into its own file | ReinUsesLisp | 6 | -176/+211 | |
2019-05-25 | prepo: Save reports from PlayReport service | Zach Hilman | 1 | -2/+23 | |
Logs a lot of seemingly innocuous telemetry games generate. | |||||
2019-05-25 | fatal: Save report on fatal:u call | Zach Hilman | 1 | -21/+5 | |
Matches offical behavior with creport and replaces old log/text based report system. | |||||
2019-05-25 | service: Save report on unimplemented function call | Zach Hilman | 1 | -0/+3 | |
2019-05-25 | applets/error: Save report on error applet | Zach Hilman | 1 | -5/+14 | |
This matches official behavior with the erpt/eclct/eupld service chain. | |||||
2019-05-25 | applets: Save report on stubbed applet | Zach Hilman | 4 | -15/+49 | |
This also reworks the applet data storage to be peekable. | |||||
2019-05-25 | svc: Save report on call to svcBreak | Zach Hilman | 1 | -1/+7 | |
2019-05-25 | core: Add Reporter class to take/save reports | Zach Hilman | 5 | -1/+416 | |
2019-05-25 | qt: Make UI option for 'Reporting Services' temporary | Zach Hilman | 2 | -0/+24 | |
Reports are unnecessary for normal users and this is to prevent 'power' users from enabling the feature by accident. | |||||
2019-05-25 | settings: Add 'Reporting Services' config option | Zach Hilman | 3 | -10/+13 | |
Full enable/disable for all reports. | |||||
2019-05-25 | arm_interface: Expand backtrace generation | Zach Hilman | 2 | -7/+194 | |
Returns results as a vector of entries for further processing. Logs addresses, offsets, and mangled name. | |||||
2019-05-25 | core: Track load offsets of NSO modules | Zach Hilman | 3 | -0/+18 | |
Needed for backtrace decomposition | |||||
2019-05-25 | configure_hotkeys: Remove unnecessary Settings::Apply() call | Lioncash | 1 | -1/+0 | |
Nothing from the hotkeys dialog relies on this call occurring, and is already called from the dialog that calls applyConfiguration(). | |||||
2019-05-25 | configure_hotkeys: Tidy up key sequence conflict error string | Lioncash | 1 | -2/+2 | |
Avoids mentioning the user and formalizes the error itself. | |||||
2019-05-25 | configure_hotkeys: Change critical error dialog into a warning dialog | Lioncash | 1 | -2/+2 | |
critical() is intended for critical/fatal errors that threaten the overall stability of an application. A user entering a conflicting key sequence is neither of those. | |||||
2019-05-25 | configure_hotkeys: Move conflict detection logic to IsUsedKey() | Lioncash | 2 | -14/+15 | |
We don't need to extract the entire set of hotkeys into a list and then iterate through it. We can traverse the list and early-exit if we're able to. | |||||
2019-05-25 | configure_hotkeys: Remove unused EmitHotkeysChanged() | Lioncash | 3 | -13/+0 | |
1. This is something that should be solely emitted by the hotkey dialog itself 2. This is functionally unused, given there's nothing listening for the signal. | |||||
2019-05-25 | sequence_dialog: Reorganize the constructor | Lioncash | 1 | -4/+8 | |
The previous code was all "smushed" together wasn't really grouped together that well. This spaces things out and separates them by relation to one another, making it easier to visually parse the individual sections of code that make up the constructor. | |||||
2019-05-25 | sequence_dialog: Remove unnecessary horizontal specifier | Lioncash | 1 | -2/+1 | |
QDialogButtonBoxes are horizontal by default. | |||||
2019-05-25 | renderer_opengl/utils: Use a std::string_view with LabelGLObject() | Lioncash | 2 | -10/+10 | |
Uses a std::string_view instead of a std::string, given the pointed to string isn't modified and is only used in a formatting operation. This is nice because a few usages directly supply a string literal to the function, allowing these usages to otherwise not heap allocate, unlike the std::string overloads. While we're at it, we can combine the address formatting into a single formatting call. | |||||
2019-05-25 | yuzu/configuration/configure_graphics: Eliminate type narrowing in a connect call | Lioncash | 1 | -6/+5 | |
A checkbox is able to be tri-state, giving it three possible activity types, so in the connect call here, it would actually be truncating an int into a bool. Instead, we can just listen on the toggled() signal, which passes along a bool, not an int. | |||||
2019-05-25 | yuzu/CMakeLists: Disable implicit QString conversions | Lioncash | 1 | -0/+4 | |
Now that all of our code is compilable with implicit QString conversions, we can enforce it at compile-time by disabling them. | |||||
2019-05-25 | yuzu/applets/software_keyboard: Remove unused assert header | Lioncash | 1 | -1/+0 | |
This isn't actually used anywhere, so it can be removed. | |||||
2019-05-25 | yuzu/applets/software_keyboard: std::move argument in MainWindowFinishedText() | Lioncash | 1 | -1/+1 | |
Given the std::optional can contain an object type that heap allocates, we can use std::move to avoid an unnecessary copy/allocation from occurring. | |||||
2019-05-25 | yuzu/applets/software_keyboard: Resolve sign mismatch comparison | Lioncash | 1 | -1/+1 | |
Qt uses a signed value to represent container sizes, so this was causing a sign mismatch warning. | |||||
2019-05-25 | yuzu/applets/software_keyboard: Specify string conversions explicitly | Lioncash | 2 | -10/+18 | |
Allows the software keyboard applet code to compile with implicit string conversions disabled. | |||||
2019-05-25 | yuzu/applets/error: Specify string conversions explicitly | Lioncash | 1 | -2/+3 | |
Allows the error applet to build successfully with implicit string conversions disabled. | |||||
2019-05-25 | yuzu/main: Specify string conversions where applicable | Lioncash | 1 | -115/+145 | |
2019-05-24 | gl_shader_decompiler: Use an if based cbuf indexing for broken drivers | ReinUsesLisp | 1 | -3/+20 | |
The following code is broken on AMD's proprietary GLSL compiler: ```glsl uint idx = ...; vec4 values = ...; float some_value = values[idx & 3]; ``` It index the wrong components, to fix this the following pessimized code is emitted when that bug is present: ```glsl uint idx = ...; vec4 values = ...; float some_value; if ((idx & 3) == 0) some_value = values.x; if ((idx & 3) == 1) some_value = values.y; if ((idx & 3) == 2) some_value = values.z; if ((idx & 3) == 3) some_value = values.w; ``` | |||||
2019-05-24 | gl_device: Add test to detect broken component indexing | ReinUsesLisp | 2 | -0/+60 | |
Component indexing on AMD's proprietary driver is broken. This commit adds a test to detect when we are on a driver that can't successfully manage component indexing. It dispatches a dummy draw with just one vertex shader that writes to an indexed SSBO from the GPU with data sent through uniforms, it then reads that data from the CPU and compares the expected output. | |||||
2019-05-23 | common/file_util: Remove unnecessary return at end of void StripTailDirSlashes() | Lioncash | 1 | -6/+8 | |
While we're at it, also invert the conditional into a guard clause. | |||||
2019-05-23 | common/file_util: Make GetCurrentDir() return a std::optional | Lioncash | 2 | -3/+4 | |
nullptr was being returned in the error case, which, at a glance may seem perfectly OK... until you realize that std::string has the invariant that it may not be constructed from a null pointer. This means that if this error case was ever hit, then the application would most likely crash from a thrown exception in std::string's constructor. Instead, we can change the function to return an optional value, indicating if a failure occurred. | |||||
2019-05-23 | common/file_util: Remove duplicated documentation comments | Lioncash | 1 | -25/+0 | |
These are already present within the header, so they don't need to be repeated in the cpp file. | |||||
2019-05-23 | common/file_util: Make ReadFileToString and WriteStringToFile consistent | Lioncash | 3 | -7/+7 | |
Makes the parameter ordering consistent, and also makes the filename parameter a std::string. A std::string would be constructed anyways with the previous code, as IOFile's only constructor with a filepath is one taking a std::string. We can also make WriteStringToFile's string parameter utilize a std::string_view for the string, making use of our previous changes to IOFile. | |||||
2019-05-23 | common/file_util: Remove unnecessary c_str() calls | Lioncash | 1 | -2/+2 | |
The file stream open functions have supported std::string overloads since C++11, so we don't need to use c_str() here. Same behavior, less code. | |||||
2019-05-23 | common/file_util: Make IOFile's WriteString take a std::string_view | Lioncash | 1 | -2/+2 | |
We don't need to force the usage of a std::string here, and can instead use a std::string_view, which allows writing out other forms of strings (e.g. C-style strings) without any unnecessary heap allocations. | |||||
2019-05-23 | Fix bitmask logic inversion | Michael Scire | 1 | -2/+1 | |
2019-05-23 | fix introduced clang-format errors | Michael Scire | 1 | -3/+2 | |
2019-05-23 | Address review comments | Michael Scire | 6 | -47/+120 | |
2019-05-23 | clang-format fixes | Michael Scire | 4 | -31/+32 | |
2019-05-23 | Implement IApplicationFunctions::GetDesiredLanguage | Michael Scire | 9 | -403/+1010 | |
2019-05-23 | shader/shader_ir: Make Comment() take a std::string by value | Lioncash | 2 | -3/+3 | |
This allows for forming comment nodes without making unnecessary copies of the std::string instance. e.g. previously: Comment(fmt::format("Base address is c[0x{:x}][0x{:x}]", cbuf->GetIndex(), cbuf_offset)); Would result in a copy of the string being created, as CommentNode() takes a std::string by value (a const ref passed to a value parameter results in a copy). Now, only one instance of the string is ever moved around. (fmt::format returns a std::string, and since it's returned from a function by value, this is a prvalue (which can be treated like an rvalue), so it's moved into Comment's string parameter), we then move it into the CommentNode constructor, which then moves the string into its member variable). | |||||
2019-05-23 | shader/decode/*: Add missing newline to files lacking them | Lioncash | 18 | -18/+18 | |
Keeps the shader code file endings consistent. | |||||
2019-05-23 | shader/decode/*: Eliminate indirect inclusions | Lioncash | 6 | -1/+5 | |
Amends cases where we were using things that were indirectly being satisfied through other headers. This way, if those headers change and eliminate dependencies on other headers in the future, we don't have cascading compilation errors. | |||||
2019-05-23 | service/aoc: Avoid allocating and discarding data | Lioncash | 1 | -8/+8 | |
Previously, the code was accumulating data into a std::vector and then tossing all of it away if a setting was disabled. Instead, we can just check if it's disabled and do no work at all if possible. If it's enabled, then we can append to the vector and allocate. Unlikely to impact usage much, but it is slightly less sloppy with resources. | |||||
2019-05-23 | service/aoc: Remove unnecessary includes | Lioncash | 1 | -2/+0 | |
Removes two header dependencies related to file handling that aren't actually used within the source file. | |||||
2019-05-23 | service/aoc: Pop all passed values where applicable | Lioncash | 1 | -12/+45 | |
A few of the aoc service stubs/implementations weren't fully popping all of the parameters passed to them. This ensures that all parameters are popped and, at minimum, logged out. | |||||
2019-05-22 | shader/decode/memory: Remove left in debug pragma | Lioncash | 1 | -2/+0 | |
2019-05-21 | renderer_opengl/gl_shader_decompiler: Remove redundant name specification in format string | Lioncash | 1 | -1/+1 | |
This accidentally slipped through a rebase. | |||||
2019-05-21 | gl_shader_cache: Fix clang strict standard build issues | ReinUsesLisp | 3 | -9/+13 | |
2019-05-21 | gl_shader_cache: Use shared contexts to build shaders in parallel | ReinUsesLisp | 7 | -56/+112 | |
2019-05-21 | shader/memory: Implement ST (generic memory) | ReinUsesLisp | 2 | -21/+36 | |
2019-05-21 | shader/memory: Implement LD (generic memory) | ReinUsesLisp | 3 | -15/+38 | |
2019-05-21 | yuzu/configuration/config: Make default hotkeys an internally-linked array in the cpp file | Lioncash | 2 | -4/+2 | |
Given the array is a private static array, we can just make it internally linked to hide it from external code. This also allows us to remove an inclusion within the header. | |||||
2019-05-21 | yuzu/configuration/config: Specify string conversions explicitly | Lioncash | 1 | -30/+42 | |
Allows the configuration code to build successfully with implicit string conversions disabled. | |||||
2019-05-20 | shader: Implement S2R Tid{XYZ} and CtaId{XYZ} | ReinUsesLisp | 4 | -15/+69 | |
2019-05-20 | gl_shader_decompiler: Make GetSwizzle constexpr | ReinUsesLisp | 1 | -7/+7 | |
2019-05-20 | yuzu/game_list: Specify string conversions explicitly | Lioncash | 2 | -50/+55 | |
Allows the game list code to compile successfully with implicit string conversions disabled. | |||||
2019-05-20 | yuzu/game_list_worker: Specify string conversions explicitly | Lioncash | 1 | -2/+2 | |
Allows the game list worker code to compile successfully with implicit string conversions disabled. | |||||
2019-05-20 | yuzu/game_list_p: Amend mentions of SMDH in comments | Lioncash | 1 | -3/+3 | |
SMDH is a metadata format used in some executable formats for the Nintendo 3DS. Switch executables don't utilize this metadata format, so this just a holdover from Citra and can be corrected. | |||||
2019-05-20 | yuzu/game_list_p: Specify string conversions explicitly | Lioncash | 1 | -10/+9 | |
Allows the game list item code to build with implicit string conversions disabled. | |||||
2019-05-20 | yuzu/loading_screen: Specify string conversions explicitly | Lioncash | 1 | -9/+9 | |
Allows the loading screen code to compile with implicit string conversions disabled. While we're at it remove unnecessary const usages, and add it to nearby variables where appropriate. | |||||
2019-05-20 | yuzu/bootmanager: Specify string conversions explicitly | Lioncash | 1 | -2/+4 | |
Allows the bootmanager code to compile with implicit string conversions disabled. | |||||
2019-05-20 | yuzu/util: Specify string conversions explicitly | Lioncash | 1 | -8/+10 | |
Allows the util code to build with implicit string conversions disabled. | |||||
2019-05-20 | gl_shader_decompiler: Tidy up minor remaining cases of unnecessary std::string concatenation | Lioncash | 1 | -21/+20 | |
2019-05-20 | gl_shader_decompiler: Replace individual overloads with the fmt-based one | Lioncash | 1 | -28/+16 | |
Gets rid of the need to special-case brace handling depending on the overload used, and makes it consistent across the board with how fmt handles them. Strings with compile-time deducible strings are directly forwarded to std::string's constructor, so we don't need to worry about the performance difference here, as it'll be identical. | |||||
2019-05-20 | gl_shader_decompiler: Utilize fmt overload of AddLine() where applicable | Lioncash | 1 | -136/+152 | |
2019-05-19 | Revert #2466 | Fernando Sahmkow | 1 | -1/+3 | |
This reverts a tested behavior on delay slots not exiting if the exit flag is set. Currently new tests are required in order to ensure this behavior. | |||||
2019-05-19 | gl_shader_decompiler: Add AddLine() overload that forwards to fmt | Lioncash | 1 | -0/+11 | |
In a lot of places throughout the decompiler, string concatenation via operator+ is used quite heavily. This is usually fine, when not heavily used, but when used extensively, can be a problem. operator+ creates an entirely new heap allocated temporary string and given we perform expressions like: std::string thing = a + b + c + d; this ends up with a lot of unnecessary temporary strings being created and discarded, which kind of thrashes the heap more than we need to. Given we utilize fmt in some AddLine calls, we can make this a part of the ShaderWriter's API. We can make an overload that simply acts as a passthrough to fmt. This way, whenever things need to be appended to a string, the operation can be done via a single string formatting operation instead of discarding numerous temporary strings. This also has the benefit of making the strings themselves look nicer and makes it easier to spot errors in them. | |||||
2019-05-19 | yuzu/configuration/configure_web: Specify string conversions explicitly | Lioncash | 1 | -8/+16 | |
Allows the web config code to compile with implicit string conversions disabled. We can also deduplicate the calls to create the pixmap. | |||||
2019-05-19 | yuzu/configuration/configure_system: Specify string conversions explicitly | Lioncash | 1 | -2/+3 | |
Allows the system config code to build successfully with implicit string conversions disabled. | |||||
2019-05-19 | yuzu/configuration/configure_profile_manager: Mark UI string as translatable | Lioncash | 1 | -1/+1 | |
This is a user-facing string, so it should be marked as translatable. | |||||
2019-05-19 | yuzu/configuration/configure_per_general: Specify string conversions explicitly | Lioncash | 1 | -6/+8 | |
Allows the per-game configuration to be successfully built with implicit string conversions disabled. | |||||
2019-05-19 | yuzu/configuration/configure_mouse_advanced: Clean up array accesses | Lioncash | 1 | -19/+22 | |
Deduplicates array accesses and uses a named variable where appropriate. | |||||
2019-05-19 | yuzu/configuration/configure_mouse_advanced: Specify string conversions explicitly | Lioncash | 1 | -11/+23 | |
Allows the advanced mouse configuration code to build with implicit string conversions disabled. | |||||
2019-05-19 | yuzu/configuration/configure_input_player: Clean up array accesses | Lioncash | 1 | -32/+48 | |
Rather than repeatedly index arrays that have quite a large array index, we can just use a named variable instead. | |||||
2019-05-19 | yuzu/configuration/configure_input_player: Specify string conversions explicitly | Lioncash | 1 | -24/+49 | |
Allows the player input configuration code to compile with implicit string conversions disabled. | |||||
2019-05-19 | yuzu/configuration/configure_input: Mark controller type names as translateable | Lioncash | 1 | -5/+8 | |
These are user-facing strings, so they should be localizable. | |||||
2019-05-19 | yuzu/configuration/configure_general: Specify string conversions explicitly | Lioncash | 1 | -1/+2 | |
Allows the general configuration code to successfully compile with implicit string conversions disabled. | |||||
2019-05-19 | yuzu/configuration/configure_gamelist: Specify string conversions explicitly | Lioncash | 1 | -3/+5 | |
Allows the gamelist configuration code to compile with implicit string conversions disabled. | |||||
2019-05-19 | yuzu/configuration/configure_audio: Store power on query into a variable | Lioncash | 1 | -2/+3 | |
Avoids using the system accessor more than necessary, and ensures that both dialog boxes see the same power on state. | |||||
2019-05-19 | yuzu/configuration/configure_audio: Tidy up function cast | Lioncash | 1 | -2/+1 | |
We can just use qOverload here to tidy up the function cast. | |||||
2019-05-19 | yuzu/configuration/configure_audio: Specify string conversions explicitly | Lioncash | 1 | -3/+3 | |
Allows the audio configuration code to build with implicit string conversions disabled. | |||||
2019-05-19 | Dma_pusher: ASSERT on empty command_list | Fernando Sahmkow | 1 | -0/+7 | |
This is a measure to avoid crashes on command list reading as an empty command_list is considered a NOP. | |||||
2019-05-19 | shader/shader_ir: Remove unnecessary inline specifiers | Lioncash | 1 | -2/+2 | |
constexpr internally links by default, so the inline specifier is unnecessary. | |||||
2019-05-19 | shader/shader_ir: Simplify constructors for OperationNode | Lioncash | 1 | -15/+6 | |
Many of these constructors don't even need to be templated. The only ones that need to be templated are the ones that actually make use of the parameter pack. Even then, since std::vector accepts an initializer list, we can supply the parameter pack directly to it instead of creating our own copy of the list, then copying it again into the std::vector. | |||||
2019-05-19 | shader/shader_ir: Remove unnecessary template parameter packs from Operation() overloads where applicable | Lioncash | 1 | -2/+0 | |
These overloads don't actually make use of the parameter pack, so they can be turned into regular non-template function overloads. | |||||
2019-05-19 | shader/shader_ir: Mark tracking functions as const member functions | Lioncash | 2 | -8/+11 | |
These don't actually modify instance state, so they can be marked as const member functions | |||||
2019-05-19 | yuzu/util: Remove unused spinbox.cpp/.h | Lioncash | 3 | -366/+0 | |
This has been left unused since the removal of the vestigial surface viewer. Given it has no uses left, this can be removed as well. | |||||
2019-05-19 | shader/shader_ir: Place implementations of constructor and destructor in cpp file | Lioncash | 2 | -5/+9 | |
Given the class contains quite a lot of non-trivial types, place the constructor and destructor within the cpp file to avoid inlining construction and destruction code everywhere the class is used. | |||||
2019-05-19 | gl_shader_gen: std::move objects where applicable | Lioncash | 1 | -7/+7 | |
Avoids performing copies into the pair being returned. Instead, we can just move the resources into the pair, avoiding the need to make copies of both the std::string and ShaderEntries struct. | |||||
2019-05-19 | gl_shader_disk_cache: in-class initialize virtual file offset of ShaderDiskCacheOpenGL | Lioncash | 2 | -5/+3 | |
Given the offset is assigned a fixed value in the constructor, we can just assign it directly and get rid of the need to write the name of the variable again in the constructor initializer list. | |||||
2019-05-19 | gl_shader_disk_cache: Default ShaderDiskCacheOpenGL's destructor in the cpp file | Lioncash | 2 | -0/+3 | |
Given the disk shader cache contains non-trivial types, we should default it in the cpp file in order to prevent inlining of the complex destruction logic. | |||||
2019-05-19 | gl_shader_disk_cache: Make hash specializations noexcept | Lioncash | 1 | -2/+2 | |
The standard library expects hash specializations that don't throw exceptions. Make this explicit in the type to allow selection of better code paths if possible in implementations. | |||||
2019-05-19 | gl_shader_disk_cache: Remove redundant code string construction in LoadDecompiledEntry() | Lioncash | 1 | -2/+2 | |
We don't need to load the code into a vector and then construct a string over the data. We can just create a string with the necessary size ahead of time, and read the data directly into it, getting rid of an unnecessary heap allocation. | |||||
2019-05-19 | gl_shader_disk_cache: Make variable non-const in decompiled entry case | Lioncash | 1 | -1/+1 | |
std::move does nothing when applied to a const variable. Resources can't be moved if the object is immutable. With this change, we don't end up making several unnecessary heap allocations and copies. | |||||
2019-05-19 | gl_shader_disk_cache: Special-case boolean handling | Lioncash | 2 | -24/+37 | |
Booleans don't have a guaranteed size, but we still want to have them integrate into the disk cache system without needing to actually use a different type. We can do this by supplying non-template overloads for the bool type. Non-template overloads always have precedence during function resolution, so this is safe to provide. This gets rid of the need to smatter ternary conditionals, as well as the need to use u8 types to store the value in. | |||||
2019-05-19 | yuzu/applets/profile_select: Mark header string as translatable | Lioncash | 1 | -2/+2 | |
This is a user-facing string, so it should be marked as translatable. | |||||
2019-05-19 | yuzu/debugger/graphics/graphics_breakpoints: Specify string conversions explicitly | Lioncash | 1 | -1/+1 | |
Allows the graphics breakpoints to compile with implicit string conversions disabled. | |||||
2019-05-19 | yuzu/debugger/profiler: Specify string conversions explicitly | Lioncash | 1 | -2/+2 | |
This allows the microprofile widget to compile with implicit string conversions disabled. | |||||
2019-05-19 | yuzu/debugger/wait_tree: Specify string conversions explicitly | Lioncash | 1 | -14/+17 | |
Allows compiling the wait tree widget with implicit string conversions disabled. | |||||
2019-05-19 | ipc_helpers: Amend floating-point type in Pop<double> specialization | Lioncash | 1 | -1/+1 | |
Currently, this overload isn't used, so this wasn't actually hit in any code, only the float overload is used. | |||||
2019-05-19 | Address review comment | Tobias | 1 | -1/+1 | |
Co-Authored-By: Mat M. <mathew1800@gmail.com> | |||||
2019-05-19 | kernel/svc: Mark GetThreadList() and UnmapProcessCodeMemory() as internally linked | Lioncash | 1 | -4/+4 | |
These are only used from within this translation unit, so they don't need to have external linkage. They were intended to be marked with this anyways to be consistent with the other service functions. | |||||
2019-05-19 | service/am: Add missing return in error case for IStorageAccessor's Read()/Write(). | Lioncash | 1 | -0/+2 | |
Previously this would fall through and return successfully, despite being an out of bounds read or write. | |||||
2019-05-18 | core/kernel/object: Rename ResetType enum members | Lioncash | 19 | -35/+36 | |
Renames the members to more accurately indicate what they signify. "OneShot" and "Sticky" are kind of ambiguous identifiers for the reset types, and can be kind of misleading. Automatic and Manual communicate the kind of reset type in a clearer manner. Either the event is automatically reset, or it isn't and must be manually cleared. The "OneShot" and "Sticky" terminology is just a hold-over from Citra where the kernel had a third type of event reset type known as "Pulse". Given the Switch kernel only has two forms of event reset types, we don't need to keep the old terminology around anymore. | |||||
2019-05-18 | HLE/IPC: HLEContext can memorize the client thread and use it for SleepClientThread | Weiyi Wang | 4 | -9/+10 | |
This reduces the boilerplate that services have to write out the current thread explicitly. Using current thread instead of client thread is also semantically incorrect, and will be a problem when we implement multicore (at which time there will be multiple current threads) | |||||
2019-05-18 | gl_rasterizer: Limit OpenGL point size to a minimum of 1 | ReinUsesLisp | 1 | -1/+3 | |
2019-05-18 | maxwell_to_gl: Add TriangleFan primitive topology | ReinUsesLisp | 1 | -0/+2 | |
2019-05-17 | gl_rasterizer: Pass the right number of array quad vertices count | ReinUsesLisp | 1 | -2/+2 | |
2019-05-17 | qt/configure_graphics: Shadow options at runtime | ReinUsesLisp | 1 | -2/+6 | |
Compatibility profile and the disk shader cache settings shouldn't be changed at runtime. This aims to address that shadowing those options. | |||||
2019-05-17 | yuzu_cmd: Use OpenGL compat when asked in the settings | ReinUsesLisp | 1 | -1/+5 | |
2019-05-17 | yuzu_cmd: Make OpenGL's context current | ReinUsesLisp | 1 | -0/+1 | |
The SDL2 frontend never bound the OpenGL context, resulting on a white screen and no-ops all over the backend. | |||||
2019-05-17 | yuzu/bootmanager: Explicitly enable deprecated OpenGL features on compat | ReinUsesLisp | 1 | -0/+1 | |
Nvidia's proprietary driver creates a real OpenGL compatibility profile without this option, meanwhile Intel (and probably AMD, I haven't tested it) require that QSurfaceFormat::FormatOption::DeprecatedFunctions is explicitly enabled. | |||||
2019-05-14 | maxwell_3d: reduce sevirity of different component formats assert. | Fernando Sahmkow | 1 | -1/+1 | |
This was reduced due to happening on most games and at such constant rate that it affected performance heavily for the end user. In general, we are well aware of the assert and an implementation is already planned. | |||||
2019-05-14 | video_core/engines/engine_upload: Amend constructor initializer list order | Lioncash | 1 | -1/+1 | |
Silences a -Wreorder warning. | |||||
2019-05-14 | video_core/engines/engine_upload: Default destructor in the cpp file | Lioncash | 2 | -1/+3 | |
Avoids inlining destruction logic where applicable, and also makes forward declarations not cause unexpected compilation errors depending on where the State class is used. | |||||
2019-05-14 | video_core/engines/engine_upload: Remove unnecessary const on parameters in function declarations | Lioncash | 1 | -2/+2 | |
These only apply in the definition of the function. They can be omitted from the declaration. | |||||
2019-05-14 | video_core/engines/engine_upload: Remove unnecessary includes | Lioncash | 2 | -2/+2 | |
2019-05-14 | video_core/engines/maxwell3d: Get rid of three magic values in CallMethod() | Lioncash | 1 | -3/+3 | |
We can use the named constant instead of using 32 directly. | |||||
2019-05-14 | video_core/engines/maxwell_3d: Simplify for loops into ranged for loops within InitializeRegisterDefaults() | Lioncash | 1 | -15/+15 | |
Lessens the amount of code that needs to be read, and gets rid of the need to introduce an indexing variable. Instead, we just operate on the objects directly. | |||||
2019-05-14 | video_core/engines/maxwell_3d: Add is_trivially_copyable_v check for Regs | Lioncash | 1 | -0/+2 | |
std::memset is used to clear the entire register structure, which requires that the Regs struct be trivially copyable (otherwise undefined behavior is invoked). This prevents the case where a non-trivial type is potentially added to the struct. | |||||
2019-05-14 | yuzu: Remove explicit types from locks where applicable | Lioncash | 3 | -3/+3 | |
With C++17's deduction guides, the type doesn't need to be explicitly specified within locking primitives anymore. | |||||
2019-05-14 | video_core/gpu_thread: Remove redundant copy constructor for CommandDataContainer | Lioncash | 1 | -6/+0 | |
std::move within a copy constructor (on a data member that isn't mutable) will always result in a copy. Because of that, the behavior of this copy constructor is identical to the one that would be generated automatically by the compiler, so we can remove it. | |||||
2019-05-12 | GPU/MMEInterpreter: Ignore the 'exit' flag when it's executed inside a delay slot. | Sebastian Valle | 1 | -3/+3 | |
It seems instructions marked with the 'exit' flag will not cause an exit when executed within a delay slot. This was hwtested by fincs. | |||||
2019-05-10 | service/set: Correct and simplify behavior related to copying language codes | Lioncash | 1 | -34/+22 | |
This corrects cases where it was possible to write more entries into the write buffer than were requested. Now, we check the size of the buffer before actually writing into them. We were also returning the wrong value for GetAvailableLanguageCodeCount2(). This was previously returning 64, but only 17 should have been returned. 64 entries is the size of the static array used in MakeLanguageCode() within the service binary itself, but isn't the actual total number of language codes present. | |||||
2019-05-10 | video_core/memory_manager: Mark IsBlockContinuous() as a const member function | Lioncash | 2 | -4/+4 | |
Corrects the typo in its name and marks the function as a const member function, given it doesn't actually modify memory manager state. | |||||
2019-05-10 | video_core/memory_manager: Mark the constructor as explicit | Lioncash | 1 | -1/+1 | |
Prevents implicit converting constructions of the memory manager. | |||||
2019-05-10 | video_core/memory_manager: Default the destructor within the cpp file | Lioncash | 2 | -0/+3 | |
Makes the class less surprising when it comes to forward declaring the type, and also prevents inlining the destruction code of the class, given it contains non-trivial types. | |||||
2019-05-10 | video_core/memory_manager: Amend doxygen comments | Lioncash | 1 | -7/+7 | |
Corrects references to non-existent parameters and corrects typos. | |||||
2019-05-10 | video_core/memory_manager: Remove superfluous const from function declarations | Lioncash | 1 | -7/+7 | |
These are able to be omitted from the declaration of functions, since they don't do anything at the type system level. The definitions of the functions can retain the use of const though, since they make the variables immutable in the implementation of the function where they're used. | |||||
2019-05-10 | video_core/renderer_opengl/gl_shader_cache: Correct member initialization order | Lioncash | 1 | -1/+1 | |
Silences a -Wreorder warning. | |||||
2019-05-10 | video_core/shader/decode/texture: Remove unused variable from GetTld4Code() | Lioncash | 1 | -1/+0 | |
2019-05-10 | renderer_vulkan/vk_shader_decompiler: Remove unused variable from DeclareInternalFlags() | Lioncash | 1 | -1/+0 | |
2019-05-10 | video_core/renderer_opengl/gl_shader_decompiler: Remove unused Composite() function | Lioncash | 1 | -11/+0 | |
This isn't used at all, so it can be removed. | |||||
2019-05-10 | video_core/renderer_opengl/gl_rasterizer_cache: Remove unused variable in UploadGLMipmapTexture() | Lioncash | 1 | -1/+0 | |
This variable is unused entirely, so it can be removed. | |||||
2019-05-10 | video_core/gpu_thread: Remove unused local variable | Lioncash | 1 | -1/+1 | |
Instead of retrieving the data from the std::variant instance, we can just check if the variant contains that type of data. This is essentially the same behavior, only it returns a bool indicating whether or not the type in the variant is currently active, instead of actually retrieving the data. | |||||
2019-05-10 | video_core/textures/astc: Remove unused variables | Lioncash | 1 | -6/+2 | |
Silences a few compilation warnings. | |||||
2019-05-09 | CMakeLists: Specify /volatile:iso for MSVC | Lioncash | 1 | -0/+2 | |
By default, MSVC doesn't use standards-compliant volatile semantics. This makes it behave in a standards-compliant manner, making expectations more uniform across compilers. | |||||
2019-05-09 | configure_dialog: Remove the Whats This? button from the dialog | Lioncash | 1 | -0/+4 | |
2019-05-09 | yuzu/hotkeys: Remove unnecessary constructor | Lioncash | 1 | -2/+0 | |
The behavior of the Hotkey constructor is already accomplished via in-class member initializers, so the constructor is superfluous here. | |||||
2019-05-09 | yuzu/main: Move window title updating logic to its own function | Lioncash | 2 | -7/+19 | |
For similar reasons to the previous change, we move this to a single function, so we don't need to duplicate the conversion logic in several places within main.cpp. | |||||
2019-05-09 | yuzu/about_dialog: Specify string conversions explicitly | Lioncash | 1 | -4/+4 | |
Specifies the conversions explicitly to avoid implicit conversions from const char* to QString. This makes it easier to disable implicit QString conversions in the future. In this case, the implicit conversion was technically wrong as well. The implicit conversion treats the input strings as ASCII characters. This would result in an incorrect conversion being performed in the rare case a branch name was created with a non-ASCII Unicode character, likely resulting in junk being displayed. | |||||
2019-05-09 | yuzu/compatdb: Remove unnecessary qualifiers | Lioncash | 1 | -3/+3 | |
Keeps the code consistent in regards to how the buttons are referred to. | |||||
2019-05-09 | configuration/config: Move config loading and saving to functions based off groups | Lioncash | 2 | -315/+573 | |
Over time our config values have grown quite numerous in size. Unfortunately it also makes the single functions we have for loading and saving values more error prone. For example, we were loading the core settings twice when they only should have been loaded once. In another section, a variable was shadowing another variable used to load settings from a completely different section. Finally, in one other case, there was an extraneous endGroup() call used that didn't need to be done. This was essentially dead code and also a bug waiting to happen. This separates the section loading code into its own separate functions. This keeps variables only visible to the code that actually needs it, and makes it much easier to visually see the end of each individual configuration group. It also makes it much easier to visually catch bugs during code review. While we're at it, this also uses QStringLiteral instead of raw string literals, which both avoids constructing a lot of QString instances, but also makes it much easier to disable implicit ASCII to QString and vice-versa in the future via setting QT_NO_CAST_FROM_ASCII and QT_NO_CAST_TO_ASCII as compilation flags. | |||||
2019-05-07 | src/CMakeLists: Add /Zc:externConstexpr to the MSVC build flags | Lioncash | 1 | -8/+10 | |
The C++ standard allows constexpr variables declared with the extern keyword to have external linkage. Previously MSVC wasn't abiding by this. This just makes the compiler more standards compliant during builds. Given we currently don't make use of anything that would break by this, this is safe to enable. | |||||
2019-05-07 | src/CMakeLists: Vertically order compilation flags | Lioncash | 1 | -9/+19 | |
Makes it much nicer to visually scan the options. This also starts the flag descriptions from the same column for the same reason. | |||||
2019-05-07 | core/memory: Remove unused FlushMode enum | Lioncash | 1 | -9/+0 | |
Recent changes to memory-related code resulted in this being unused, so we can remove it. | |||||
2019-05-07 | Correct possible error on Rasterizer Caches | Fernando Sahmkow | 1 | -1/+2 | |
There was a weird bug that could happen if the object died directly and the cache address wasn't stored. | |||||
2019-05-04 | core/telemetry_session: Only create the backend when we really need it | zhupengfei | 2 | -9/+9 | |
The backend is not used until we decide to submit the testcase/telemetry, and creating it early prevents users from updating the credentials properly while the games are running. | |||||
2019-05-04 | shader/decode/texture: Remove unused variable | Lioncash | 1 | -1/+0 | |
This isn't used anywhere, so we can get rid of it. | |||||
2019-05-04 | CMakeLists: Explicitly specify -Wall for the non-MSVC case | Lioncash | 1 | -1/+4 | |
Ensures that -Wall is always active as a compilation flag. | |||||
2019-05-04 | gl_rasterizer: Silence unused variable warning | Lioncash | 1 | -2/+2 | |
Makes use of src, so it's not considered unused. | |||||
2019-05-04 | common/zstd_compression: Remove #pragma once directive from source file | Lioncash | 1 | -2/+0 | |
Introduced in 72477731ed20c56a4d6f18a22f43224fab667cef. This is only necessary within header files. | |||||
2019-05-04 | core/frontend/emu_window: Make GraphicsContext's destructor virtual | Lioncash | 2 | -0/+4 | |
This class is used in a polymorphic context, so destruction of the context will lead to undefined behavior if the destructor isn't virtual. | |||||
2019-05-03 | shader_ir/other: Implement IPA.IDX | ReinUsesLisp | 2 | -5/+9 | |
2019-05-03 | gl_shader_decompiler: Skip physical unused attributes | ReinUsesLisp | 1 | -18/+27 | |
2019-05-03 | shader_ir/memory: Assert on non-32 bits ALD.PHYS | ReinUsesLisp | 1 | -0/+3 | |
2019-05-03 | shader: Add physical attributes commentaries | ReinUsesLisp | 4 | -4/+8 | |
2019-05-03 | gl_shader_decompiler: Implement GLSL physical attributes | ReinUsesLisp | 2 | -66/+101 | |
2019-05-03 | shader_ir/memory: Implement physical input attributes | ReinUsesLisp | 4 | -6/+32 | |
2019-05-03 | gl_shader_decompiler: Abstract generic attribute operations | ReinUsesLisp | 1 | -29/+26 | |
2019-05-03 | gl_shader_decompiler: Declare all possible varyings on physical attribute usage | ReinUsesLisp | 4 | -27/+88 | |
2019-05-03 | shader: Remove unused AbufNode Ipa mode | ReinUsesLisp | 6 | -35/+14 | |
2019-05-03 | shader_ir/memory: Emit AL2P IR | ReinUsesLisp | 2 | -0/+22 | |
2019-05-03 | shader_bytecode: Add AL2P decoding | ReinUsesLisp | 1 | -2/+15 | |
2019-05-01 | Refactors and name corrections. | Fernando Sahmkow | 6 | -35/+35 | |
2019-05-01 | service/audren_u: Handle variadic command buffers in GetWorkBufferSize() | Lioncash | 2 | -17/+93 | |
Also introduced in REV5 was a variable-size audio command buffer. This also affects how the size of the work buffer should be determined, so we can add handling for this as well. Thankfully, no other alterations were made to how the work buffer size is calculated in 7.0.0-8.0.0. There were indeed changes made to to how some of the actual audio commands are generated though (particularly in REV7), however they don't apply here. | |||||
2019-05-01 | service/audren_u: Handle version 2 of performance frame info in GetWorkBufferSize() | Lioncash | 2 | -6/+13 | |
Introduced in REV5. This is trivial to add support for, now that everything isn't a mess of random magic constant values. All this is, is a change in data type sizes as far as this function cares. | |||||
2019-05-01 | service/audren_u: Clean up work buffer calculations | Lioncash | 1 | -49/+214 | |
"Unmagics" quite a few magic constants within this code, making it much easier to understand. Particularly given this factors out specific sections into their own self-contained lambda functions. | |||||
2019-05-01 | gl_shader_disk_cache: Skip stored shader variants instead of asserting | ReinUsesLisp | 1 | -1/+4 | |
Instead of asserting on already stored shader variants, silently skip them. This shouldn't be happening but when a shader is invalidated and it is not stored in the shader cache, this assert would hit and save that shader anyways when the asserts are disabled. | |||||
2019-05-01 | Fix Layered ASTC Textures | Fernando Sahmkow | 1 | -1/+3 | |
By adding the missing layer offset in ASTC compression. | |||||
2019-05-01 | loader/nso: Remove left-in debug pragma | Lioncash | 1 | -2/+0 | |
Unintentionally introduced in 552d5071fa171165e4054392d8bb6bf2ecc924e2 | |||||
2019-04-29 | kernel/svc: Make svcCreateThread/svcStartThread/svcSleepThread/svcExitThread calls show up in the debug log | Lioncash | 1 | -4/+4 | |
These are actually quite important indicators of thread lifetimes, so they should be going into the debug log, rather than being treated as misc info and delegated to the trace log. | |||||
2019-04-29 | kernel/svc: Reorganize svcSetThreadCoreMask() | Lioncash | 1 | -32/+39 | |
Makes the code much nicer to follow in terms of behavior and control flow. It also fixes a few bugs in the implementation. Notably, the thread's owner process shouldn't be accessed in order to retrieve the core mask or ideal core. This should be done through the current running process. The only reason this bug wasn't encountered yet is because we currently only support running one process, and thus every owner process will be the current process. We also weren't checking against the process' CPU core mask to see if an allowed core is specified or not. With this out of the way, it'll be less noisy to implement proper handling of the affinity flags internally within the kernel thread instances. | |||||
2019-04-29 | kernel/thread: Update thread processor ID flags | Lioncash | 2 | -7/+16 | |
Adds the missing flags to the enum and documents them. | |||||
2019-04-28 | service/audctl: Update documentation comments to be relative to 8.0.0 | Lioncash | 1 | -2/+2 | |
The state of these service calls are still the same in version 8.0.0. | |||||
2019-04-26 | shader_ir: Move Sampler index entry in operand< to sort declarations | ReinUsesLisp | 1 | -2/+2 | |
2019-04-26 | shader_ir: Add missing entry to Sampler operand< comparison | ReinUsesLisp | 1 | -2/+3 | |
2019-04-26 | shader_ir/texture: Fix sampler const buffer key shift | ReinUsesLisp | 1 | -1/+1 | |
2019-04-25 | mii_manager: Fix incorrect loop condition in mii UUID generation code | Zach Hilman | 3 | -2/+3 | |
2019-04-25 | profile_select: Port Service::Account::UUID to Common::UUID | Zach Hilman | 9 | -29/+27 | |
2019-04-25 | mii: Implement Delete and Destroy file | Zach Hilman | 4 | -13/+122 | |
2019-04-25 | mii: Implement IsUpdated command (IPC 0) | Zach Hilman | 3 | -9/+34 | |
2019-04-25 | mii_manager: Cleanup and optimization | Zach Hilman | 5 | -39/+55 | |
2019-04-25 | mii: Implement IDatabaseService commands using MiiManager | Zach Hilman | 2 | -15/+244 | |
Since the MiiManager was designed around the IPC interface, this is quite easy. Only functions that were clearly defined were implemented. | |||||
2019-04-25 | mii: Add MiiManager class to manage Mii database | Zach Hilman | 2 | -0/+622 | |
Provides serialization/deserialization to the database in system save files, accessors for database state and proper handling of both major Mii formats (MiiInfo and MiiStoreData) | |||||
2019-04-25 | common: Extract UUID to its own class | Zach Hilman | 6 | -78/+108 | |
Since the Mii database uses UUIDs very similar to the Accounts database, it makes no sense to not share code between them. | |||||
2019-04-23 | Re added new lines at the end of files | FreddyFunk | 2 | -2/+2 | |
2019-04-23 | gl_shader_disk_cache: Compress precompiled shader cache file with Zstandard | unknown | 1 | -6/+10 | |
2019-04-23 | gl_shader_disk_cache: Use VectorVfsFile for the virtual precompiled shader cache file | unknown | 3 | -101/+168 | |
2019-04-23 | gl_shader_disk_cache: Remove per shader compression | unknown | 2 | -45/+11 | |
2019-04-23 | Fixes and Corrections to DMA Engine | Fernando Sahmkow | 2 | -37/+57 | |
2019-04-23 | Add Swizzle Parameters to the DMA engine | Fernando Sahmkow | 2 | -2/+27 | |
2019-04-23 | Add Documentation Headers to all the GPU Engines | Fernando Sahmkow | 5 | -0/+29 | |
2019-04-23 | Corrections and styling | Fernando Sahmkow | 5 | -6/+9 | |
2019-04-23 | Implement Maxwell3D Data Upload | Fernando Sahmkow | 2 | -3/+32 | |
2019-04-23 | Introduce skeleton of the GPU Compute Engine. | Fernando Sahmkow | 3 | -8/+202 | |
2019-04-23 | Revamp Kepler Memory to use a subegine to manage uploads | Fernando Sahmkow | 6 | -93/+134 | |
2019-04-21 | Rasterizer Cache: Use a temporal storage for Surfaces loading/flushing. | Fernando Sahmkow | 4 | -18/+30 | |
This PR should heavily reduce memory usage since temporal buffers are no longer stored per Surface but instead managed by the Rasterizer Cache. | |||||
2019-04-21 | Corrections Half Float operations on const buffers and implement saturation. | Fernando Sahmkow | 2 | -15/+16 | |
2019-04-20 | Allow picking a Compatibility Profile for OpenGL. | Fernando Sahmkow | 7 | -1/+21 | |
This option allows picking the compatibility profile since a lot of bugs are fixed in it. We devs will use this option to easierly debug current problems in our Core implementation.:wq | |||||
2019-04-20 | Apply Position Y Direction | Fernando Sahmkow | 1 | -0/+3 | |
2019-04-20 | RasterizerCache Redesign: Flush | Fernando Sahmkow | 6 | -17/+26 | |
flushing is now responsability of children caches instead of the cache object. This change will allow the specific cache to pass extra parameters on flushing and will allow more flexibility. | |||||
2019-04-20 | make ReadBlockunsafe and WriteBlockunsafe, ignore invalid pages. | Fernando Sahmkow | 1 | -4/+12 | |
2019-04-19 | gl_state: Fix samplers memory corruption | ReinUsesLisp | 1 | -3/+5 | |
It was possible for "samplers" to be read without being written. This addresses that. | |||||
2019-04-19 | kernel/svc: Name supervisor call 0x36 | Lioncash | 1 | -1/+1 | |
This call was added to the SVC handlers in the 8.0.0 kernel, so we can finally give it a name. | |||||
2019-04-18 | service/audctl: Implement GetTargetVolumeMin() and GetTargetVolumeMax() | Lioncash | 2 | -2/+32 | |
These two service functions are literally hardcoded to always return these values without any other error checking. | |||||
2019-04-18 | video_core: Silent -Wswitch warnings | ReinUsesLisp | 10 | -77/+106 | |
2019-04-17 | web_browser: Make OpenPage non-const | Zach Hilman | 13 | -25/+30 | |
2019-04-17 | main: Add GMainWindow hooks for Error display | Zach Hilman | 4 | -3/+11 | |
2019-04-17 | main: Switch to AppletManager for frontend | Zach Hilman | 1 | -3/+9 | |
2019-04-17 | qt: Add dialog implementation of Error applet | Zach Hilman | 3 | -0/+94 | |
2019-04-17 | general_backend: Move StubApplet and add backend PhotoViewer | Zach Hilman | 2 | -1/+102 | |
2019-04-17 | general_frontend: Add frontend scaffold for PhotoViewer applet | Zach Hilman | 2 | -0/+55 | |
2019-04-17 | frontend: Add frontend receiver for Error applet | Zach Hilman | 3 | -2/+79 | |
2019-04-17 | applets: Add Error applet | Zach Hilman | 3 | -24/+224 | |
Responsible for displaying error codes and messages | |||||
2019-04-17 | applets: Port current applets to take frontend in constructor | Zach Hilman | 6 | -14/+16 | |
As opposed to using Core::System::GetInstance() | |||||
2019-04-17 | web_browser: Make OpenPage const | Zach Hilman | 4 | -7/+7 | |
2019-04-17 | core: Remove specific applets in favor of AppletManager | Zach Hilman | 2 | -47/+32 | |
2019-04-17 | am: Delegate applet creation to AppletManager | Zach Hilman | 1 | -24/+3 | |
2019-04-17 | applets: Add AppletManager class to control lifetime | Zach Hilman | 2 | -0/+137 | |
2019-04-17 | kernel/thread: Unify wait synchronization types | Lioncash | 7 | -45/+38 | |
This is a holdover from Citra, where the 3DS has both WaitSynchronization1 and WaitSynchronizationN. The switch only has one form of wait synchronizing (literally WaitSynchonization). This allows us to throw out code that doesn't apply at all to the Switch kernel. Because of this unnecessary dichotomy within the wait synchronization utilities, we were also neglecting to properly handle waiting on multiple objects. While we're at it, we can also scrub out any lingering references to WaitSynchronization1/WaitSynchronizationN in comments, and change them to WaitSynchronization (or remove them if the mention no longer applies). | |||||
2019-04-17 | kernel/svc: Migrate svcCancelSynchronization behavior to a thread function | Lioncash | 3 | -7/+17 | |
The actual behavior of this function is slightly more complex than what we're currently doing within the supervisor call. To avoid dumping most of this behavior in the supervisor call itself, we can migrate this to another function. | |||||
2019-04-17 | kernel/wait_object: Make GetHighestPriorityReadyThread() a const member function | Lioncash | 2 | -2/+2 | |
This doesn't actually modify internal state of a wait object, so it can be const qualified. | |||||
2019-04-17 | yuzu/bootmanager: Replace unnnecessary constructor initializer list member of GGLContext | Lioncash | 1 | -2/+2 | |
The default constructor will always run, even when not specified, so this is redundant. However, the context member can indeed be initialized in the constructor initializer list. | |||||
2019-04-17 | yuzu/bootmanager: Remove unnecessary includes | Lioncash | 1 | -1/+0 | |
This include isn't used anymore so it can be removed. | |||||
2019-04-17 | yuzu/bootmanager: Resolve constructor initializer list warnings | Lioncash | 1 | -2/+1 | |
Resolves -Wreorder warnings. These will automatically be initialized to nullptr anyways, so these were redundant. | |||||
2019-04-17 | CMakeLists: Ensure we specify Unicode as the codepage on Windows | Lioncash | 2 | -4/+9 | |
Previously we were building with MBCS, which is pretty undesirable. We want the application to be Unicode-aware in general. Currently, we make the command line variant of yuzu use ANSI variants of the non-standard getopt functions that we link in for Windows, given we only have an ANSI option-set. We should really replace getopt with a library that we make all build types of yuzu link in, but this will have to do for the time being. | |||||
2019-04-17 | kernel/vm_manager: Remove usages of global system accessors | Lioncash | 3 | -7/+11 | |
Makes the dependency on the system instance explicit within VMManager's interface. | |||||
2019-04-17 | Implement IsBlockContinous | Fernando Sahmkow | 2 | -2/+13 | |
This detects when a GPU Memory Block is not continous within host cpu memory. | |||||
2019-04-16 | Apply Const correctness to SwizzleKepler and replace u32 for size_t on iterators. | Fernando Sahmkow | 2 | -9/+12 | |
2019-04-16 | Use ReadBlockUnsafe for fetyching DMA CommandLists | Fernando Sahmkow | 2 | -4/+2 | |
2019-04-16 | Document unsafe versions and add BlockCopyUnsafe | Fernando Sahmkow | 3 | -16/+45 | |
2019-04-16 | Use ReadBlockUnsafe for Shader Cache | Fernando Sahmkow | 1 | -5/+7 | |
2019-04-16 | Use ReadBlockUnsafe on TIC and TSC reading | Fernando Sahmkow | 2 | -2/+4 | |
Use ReadBlockUnsafe on TIC and TSC reading as memory is never flushed from host GPU there. | |||||
2019-04-16 | GPU MemoryManager: Implement ReadBlockUnsafe and WriteBlockUnsafe | Fernando Sahmkow | 2 | -0/+34 | |
2019-04-16 | Use WriteBlock and ReadBlock. | Fernando Sahmkow | 1 | -10/+6 | |
2019-04-16 | Implement Block Linear copies in Kepler Memory. | Fernando Sahmkow | 3 | -5/+38 | |
2019-04-16 | vk_shader_decompiler: Add missing operations | ReinUsesLisp | 1 | -0/+7 | |
2019-04-16 | shader_ir/decode: Fix half float pre-operations and remove MetaHalfArithmetic | ReinUsesLisp | 9 | -85/+72 | |
Operations done before the main half float operation (like HAdd) were managing a packed value instead of the unpacked one. Adding an unpacked operation allows us to drop the per-operand MetaHalfArithmetic entry, simplifying the code overall. | |||||
2019-04-16 | gl_shader_decompiler: Fix MrgH0 decompilation | ReinUsesLisp | 1 | -2/+2 | |
GLSL decompilation for HMergeH0 was wrong. This addresses that issue. | |||||
2019-04-16 | shader_ir/decode: Implement half float saturation | ReinUsesLisp | 5 | -8/+31 | |
2019-04-16 | shader_ir/decode: Reduce severity of unimplemented half-float FTZ | ReinUsesLisp | 3 | -3/+9 | |
2019-04-16 | renderer_opengl: Implement half float NaN comparisons | ReinUsesLisp | 3 | -36/+59 | |
2019-04-16 | shader_ir: Avoid using static on heap-allocated objects | ReinUsesLisp | 1 | -5/+4 | |
Using static here might be faster at runtime, but it adds a heap allocation called before main. | |||||
2019-04-16 | Do some corrections in conversion shader instructions. | Fernando Sahmkow | 2 | -23/+73 | |
Corrects encodings for I2F, F2F, I2I and F2I Implements Immediate variants of all four conversion types. Add assertions to unimplemented stuffs. | |||||
2019-04-15 | CMakeLists: Define QT_USE_QSTRINGBUILDER for the Qt target | Lioncash | 2 | -1/+7 | |
This is a compile definition introduced in Qt 4.8 for reducing the total potential number of strings created when performing string concatenation. This allows for less memory churn. This can be read about here: https://blog.qt.io/blog/2011/06/13/string-concatenation-with-qstringbuilder/ For a change that isn't source-compatible, we only had one occurrence that actually need to have its type clarified, which is pretty good, as far as transitioning goes. | |||||
2019-04-15 | svc: Specify handle value in thread's name | Lioncash | 2 | -2/+10 | |
Allows the handle to be seen alongside the entry point. | |||||
2019-04-15 | Correct Kepler Memory on Linear Pushes. | Fernando Sahmkow | 2 | -16/+48 | |
2019-04-15 | Support compressed formats on linear textures. | Fernando Sahmkow | 1 | -2/+5 | |
2019-04-15 | common/{lz4_compression, zstd_compression}: Add missing header guards | Lioncash | 2 | -0/+4 | |
These two files were missing the #pragma once directive. | |||||
2019-04-15 | Correct Pitch in Fermi2D | Fernando Sahmkow | 1 | -4/+1 | |
2019-04-15 | kernel/thread: Remove BoostPriority() | Lioncash | 2 | -11/+0 | |
This is a holdover from Citra that currently remains unused, so it can be removed from the Thread interface. | |||||
2019-04-14 | kernel/thread: Remove unused guest_handle member variable | Lioncash | 3 | -16/+7 | |
This member variable is entirely unused. It was only set but never actually utilized. Given that, we can remove it to get rid of noise in the thread interface. | |||||
2019-04-14 | gl_shader_decompiler: Use variable AOFFI on supported hardware | ReinUsesLisp | 10 | -71/+102 | |
2019-04-14 | shader_ir: Implement STG, keep track of global memory usage and flush | ReinUsesLisp | 11 | -89/+186 | |
2019-04-13 | kernel/svc: Implement svcUnmapProcessCodeMemory | Lioncash | 3 | -1/+143 | |
Essentially performs the inverse of svcMapProcessCodeMemory. This unmaps the aliasing region first, then restores the general traits of the aliased memory. What this entails, is: - Restoring Read/Write permissions to the VMA. - Restoring its memory state to reflect it as a general heap memory region. - Clearing the memory attributes on the region. | |||||
2019-04-13 | kernel/svc: Implement svcMapProcessCodeMemory | Lioncash | 4 | -1/+131 | |
This is utilized for mapping code modules into memory. Notably, the ldr service would call this in order to map objects into memory. | |||||
2019-04-12 | Fix Clang Format | FreddyFunk | 2 | -5/+10 | |
2019-04-12 | common/swap: Improve codegen of the default swap fallbacks | Lioncash | 1 | -3/+7 | |
Uses arithmetic that can be identified more trivially by compilers for optimizations. e.g. Rather than shifting the halves of the value and then swapping and combining them, we can swap them in place. e.g. for the original swap32 code on x86-64, clang 8.0 would generate: mov ecx, edi rol cx, 8 shl ecx, 16 shr edi, 16 rol di, 8 movzx eax, di or eax, ecx ret while GCC 8.3 would generate the ideal: mov eax, edi bswap eax ret now both generate the same optimal output. MSVC used to generate the following with the old code: mov eax, ecx rol cx, 8 shr eax, 16 rol ax, 8 movzx ecx, cx movzx eax, ax shl ecx, 16 or eax, ecx ret 0 Now MSVC also generates a similar, but equally optimal result as clang/GCC: bswap ecx mov eax, ecx ret 0 ==== In the swap64 case, for the original code, clang 8.0 would generate: mov eax, edi bswap eax shl rax, 32 shr rdi, 32 bswap edi or rax, rdi ret (almost there, but still missing the mark) while, again, GCC 8.3 would generate the more ideal: mov rax, rdi bswap rax ret now clang also generates the optimal sequence for this fallback as well. This is a case where MSVC unfortunately falls short, despite the new code, this one still generates a doozy of an output. mov r8, rcx mov r9, rcx mov rax, 71776119061217280 mov rdx, r8 and r9, rax and edx, 65280 mov rax, rcx shr rax, 16 or r9, rax mov rax, rcx shr r9, 16 mov rcx, 280375465082880 and rax, rcx mov rcx, 1095216660480 or r9, rax mov rax, r8 and rax, rcx shr r9, 16 or r9, rax mov rcx, r8 mov rax, r8 shr r9, 8 shl rax, 16 and ecx, 16711680 or rdx, rax mov eax, -16777216 and rax, r8 shl rdx, 16 or rdx, rcx shl rdx, 16 or rax, rdx shl rax, 8 or rax, r9 ret 0 which is pretty unfortunate. | |||||
2019-04-12 | core/core: Move process execution start to System's Load() | Lioncash | 20 | -107/+144 | |
This gives us significantly more control over where in the initialization process we start execution of the main process. Previously we were running the main process before the CPU or GPU threads were initialized (not good). This amends execution to start after all of our threads are properly set up. | |||||
2019-04-12 | core/process: Remove unideal page table setting from LoadFromMetadata() | Lioncash | 1 | -5/+0 | |
Initially required due to the split codepath with how the initial main process instance was initialized. We used to initialize the process like: Init() { main_process = Process::Create(...); kernel.MakeCurrentProcess(main_process.get()); } Load() { const auto load_result = loader.Load(*kernel.GetCurrentProcess()); if (load_result != Loader::ResultStatus::Success) { // Handle error here. } ... } which presented a problem. Setting a created process as the main process would set the page table for that process as the main page table. This is fine... until we get to the part that the page table can have its size changed in the Load() function via NPDM metadata, which can dictate either a 32-bit, 36-bit, or 39-bit usable address space. Now that we have full control over the process' creation in load, we can simply set the initial process as the main process after all the loading is done, reflecting the potential page table changes without any special-casing behavior. We can also remove the cache flushing within LoadModule(), as execution wouldn't have even begun yet during all usages of this function, now that we have the initialization order cleaned up. | |||||
2019-04-12 | core/core: Move main process creation into Load() | Lioncash | 1 | -4/+3 | |
Now that we have dependencies on the initialization order, we can move the creation of the main process to a more sensible area: where we actually load in the executable data. This allows localizing the creation and loading of the process in one location, making the initialization of the process much nicer to trace. | |||||
2019-04-12 | video_core/gpu: Create threads separately from initialization | Lioncash | 10 | -25/+51 | |
Like with CPU emulation, we generally don't want to fire off the threads immediately after the relevant classes are initialized, we want to do this after all necessary data is done loading first. This splits the thread creation into its own interface member function to allow controlling when these threads in particular get created. | |||||
2019-04-12 | core/cpu_core_manager: Create threads separately from initialization. | Lioncash | 11 | -39/+58 | |
Our initialization process is a little wonky than one would expect when it comes to code flow. We initialize the CPU last, as opposed to hardware, where the CPU obviously needs to be first, otherwise nothing else would work, and we have code that adds checks to get around this. For example, in the page table setting code, we check to see if the system is turned on before we even notify the CPU instances of a page table switch. This results in dead code (at the moment), because the only time a page table switch will occur is when the system is *not* running, preventing the emulated CPU instances from being notified of a page table switch in a convenient manner (technically the code path could be taken, but we don't emulate the process creation svc handlers yet). This moves the threads creation into its own member function of the core manager and restores a little order (and predictability) to our initialization process. Previously, in the multi-threaded cases, we'd kick off several threads before even the main kernel process was created and ready to execute (gross!). Now the initialization process is like so: Initialization: 1. Timers 2. CPU 3. Kernel 4. Filesystem stuff (kind of gross, but can be amended trivially) 5. Applet stuff (ditto in terms of being kind of gross) 6. Main process (will be moved into the loading step in a following change) 7. Telemetry (this should be initialized last in the future). 8. Services (4 and 5 should ideally be alongside this). 9. GDB (gross. Uses namespace scope state. Needs to be refactored into a class or booted altogether). 10. Renderer 11. GPU (will also have its threads created in a separate step in a following change). Which... isn't *ideal* per-se, however getting rid of the wonky intertwining of CPU state initialization out of this mix gets rid of most of the footguns when it comes to our initialization process. | |||||
2019-04-12 | common/swap: Mark byte swapping free functions with [[nodiscard]] and noexcept | Lioncash | 1 | -11/+11 | |
Allows the compiler to inform when the result of a swap function is being ignored (which is 100% a bug in all usage scenarios). We also mark them noexcept to allow other functions using them to be able to be marked as noexcept and play nicely with things that potentially inspect "nothrowability". | |||||
2019-04-12 | common/swap: Simplify swap function ifdefs | Lioncash | 1 | -48/+15 | |
Including every OS' own built-in byte swapping functions is kind of undesirable, since it adds yet another build path to ensure compilation succeeds on. Given we only support clang, GCC, and MSVC for the time being, we can utilize their built-in functions directly instead of going through the OS's API functions. This shrinks the overall code down to just if (msvc) use msvc's functions else if (clang or gcc) use clang/gcc's builtins else use the slow path | |||||
2019-04-12 | common/swap: Remove 32-bit ARM path | Lioncash | 1 | -13/+0 | |
We don't plan to support host 32-bit ARM execution environments, so this is essentially dead code. | |||||
2019-04-12 | common/scope_exit: Replace std::move with std::forward in ScopeExit() | Lioncash | 1 | -1/+1 | |
The template type here is actually a forwarding reference, not an rvalue reference in this case, so it's more appropriate to use std::forward to preserve the value category of the type being moved. | |||||
2019-04-11 | kernel: Make handle type declarations constexpr | Lioncash | 10 | -10/+10 | |
Some objects declare their handle type as const, while others declare it as constexpr. This makes the const ones constexpr for consistency, and prevent unexpected compilation errors if these happen to be attempted to be used within a constexpr context. | |||||
2019-04-11 | ui_settings: Rename game directory variables | FreddyFunk | 5 | -20/+20 | |
2019-04-11 | gl_rasterizer_cache: Relax restrictions on FastCopySurface and FastLayeredCopySurface | Fernando Sahmkow | 1 | -4/+10 | |
2019-04-11 | service: Update service function tables | Lioncash | 27 | -57/+262 | |
Updates function tables based off information from SwitchBrew. | |||||
2019-04-11 | gl_shader_manager: Move code to source file and minor clean up | ReinUsesLisp | 2 | -34/+61 | |
2019-04-10 | gl_rasterizer: Apply just the needed state on Clear | ReinUsesLisp | 1 | -4/+4 | |
2019-04-10 | ldr: Mark IsValidNROHash() as a const member function | Lioncash | 1 | -5/+4 | |
This doesn't modify instance state, so it can be made const. | |||||
2019-04-10 | ldr: Amend parameters for LoadNro/UnloadNro LoadNrr/UnloadNrr | Lioncash | 1 | -60/+81 | |
The initial two words indicate a process ID. Also UnloadNro only specifies one address, not two. | |||||
2019-04-10 | gl_device: Implement interface and add uniform offset alignment | ReinUsesLisp | 5 | -13/+70 | |
2019-04-10 | vk_shader_decompiler: Implement flow primitives | ReinUsesLisp | 1 | -5/+82 | |
2019-04-10 | vk_shader_decompiler: Implement most common texture primitives | ReinUsesLisp | 1 | -8/+65 | |
2019-04-10 | vk_shader_decompiler: Implement texture decompilation helper functions | ReinUsesLisp | 1 | -0/+32 | |
2019-04-10 | vk_shader_decompiler: Implement Assign and LogicalAssign | ReinUsesLisp | 1 | -2/+64 | |
2019-04-10 | vk_shader_decompiler: Implement non-OperationCode visits | ReinUsesLisp | 1 | -7/+129 | |
2019-04-10 | vk_shader_decompiler: Implement OperationCode decompilation interface | ReinUsesLisp | 1 | -1/+411 | |
2019-04-10 | vk_shader_decompiler: Implement Visit | ReinUsesLisp | 1 | -1/+50 | |
2019-04-10 | vk_shader_decompiler: Implement labels tree and flow | ReinUsesLisp | 1 | -0/+71 | |
2019-04-10 | vk_shader_decompiler: Implement declarations | ReinUsesLisp | 1 | -3/+457 | |
2019-04-10 | vk_shader_decompiler: Declare and stub interface for a SPIR-V decompiler | ReinUsesLisp | 3 | -0/+127 | |
2019-04-10 | video_core: Add sirit as optional dependency with Vulkan | ReinUsesLisp | 1 | -1/+4 | |
sirit is a runtime assembler for SPIR-V | |||||
2019-04-10 | fsp_srv: Remove unnecessary parameter popping in IDirectory's Read() | Lioncash | 1 | -4/+1 | |
IDirectory's Read() function doesn't take any input parameters. It only uses the output parameters that we already provide. | |||||
2019-04-10 | fsp_srv: Log out option values in IFile's Read and Write functions | Lioncash | 1 | -4/+6 | |
These indicate options that alter how a read/write is performed. Currently we don't need to handle these, as the only one that seems to be used is for writes, but all the custom options ever seem to do is immediate flushing, which we already do by default. | |||||
2019-04-10 | kernel/server_session: Remove obsolete TODOs | Lioncash | 1 | -7/+2 | |
These are holdovers from Citra. | |||||
2019-04-10 | configure_hotkeys: Pass the dialog as a parent to SequenceDialog() | Lioncash | 1 | -1/+1 | |
Without passing in a parent, this can result in focus being stolen from the dialog in certain cases. Example: On Windows, if the logging window is left open, the logging Window will potentially get focus over the hotkey dialog itself, since it brings all open windows for the application into view. By specifying a parent, we only bring windows for the parent into view (of which there are none, aside from the hotkey dialog). | |||||
2019-04-10 | configure_hotkeys: Avoid dialog memory leak within Configure() | Lioncash | 1 | -3/+3 | |
Without a parent, this dialog won't have its memory freed when it happens to get destroyed. | |||||
2019-04-10 | Remove bounding in LD_C | Fernando Sahmkow | 1 | -2/+1 | |
2019-04-10 | configure_hotkeys: Mark member variables as const where applicable in Configure() | Lioncash | 1 | -7/+7 | |
2019-04-10 | configure_hotkeys: Make comparison check a little more self-documenting | Lioncash | 1 | -1/+2 | |
This is checking if an index is valid or not and returning early if it isn't. | |||||
2019-04-10 | configure_dialog: Amend constructor initializer list order | Lioncash | 1 | -1/+1 | |
Avoids a -Wreorder compiler warning. | |||||
2019-04-10 | configure_hotkey: Remove unnecessary include | Lioncash | 1 | -1/+0 | |
Avoids dumping all of the core settings machinery into whatever files include this header. Nothing inside the header itself actually made use of anything in settings.h anyways. | |||||
2019-04-10 | configure_hotkey: Make IsUsedKey() a const member function | Lioncash | 2 | -2/+2 | |
This doesn't actually modify instance state of the dialog, so this can be made const. | |||||
2019-04-09 | Correct Fermi Copy on Linear Textures. | Fernando Sahmkow | 1 | -0/+4 | |
2019-04-09 | kernel/process: Set page table when page table resizes occur. | Lioncash | 1 | -0/+2 | |
We need to ensure dynarmic gets a valid pointer if the page table is resized (the relevant pointers would be invalidated in this scenario). In this scenario, the page table can be resized depending on what kind of address space is specified within the NPDM metadata (if it's present). | |||||
2019-04-09 | Implement Texture Format ZF32_X24S8. | Fernando Sahmkow | 1 | -0/+2 | |
2019-04-09 | Correct depth compare with color formats for R32F | Fernando Sahmkow | 1 | -2/+17 | |
2019-04-09 | yuzu/loading_screen: Resolve runtime Qt string formatting warnings | Lioncash | 1 | -1/+6 | |
In our error console, when loading a game, the strings: QString::arg: Argument missing: "Loading...", 0 QString::arg: Argument missing: "Launching...", 0 would occasionally pop up when the loading screen was running. This was due to the strings being assumed to have formatting indicators in them, however only two out of the four strings actually have them. This only applies the arguments to the strings that have formatting specifiers provided, which avoids these warnings from occurring. | |||||
2019-04-09 | added a toggle to force 30fps mode | zarroboogs | 5 | -6/+23 | |
2019-04-08 | gl_backend: Align Pixel Storage | Fernando Sahmkow | 2 | -4/+12 | |
This commit makes sure GL reads on the correct pack size for the respective texture buffer. | |||||
2019-04-08 | Correct LOP_IMN encoding | Fernando Sahmkow | 1 | -1/+1 | |
2019-04-08 | Correct XMAD mode, psl and high_b on different encodings. | Fernando Sahmkow | 2 | -9/+33 | |
2019-04-08 | Adapt Bindless to work with AOFFI | Fernando Sahmkow | 1 | -7/+18 | |
2019-04-08 | Move ConstBufferAccessor to Maxwell3d, correct mistakes and clang format. | Fernando Sahmkow | 9 | -44/+25 | |
2019-04-08 | Fix bad rebase | Fernando Sahmkow | 1 | -2/+1 | |
2019-04-08 | Fix TMML | Fernando Sahmkow | 1 | -5/+7 | |
2019-04-08 | Simplify ConstBufferAccessor | Fernando Sahmkow | 5 | -53/+22 | |
2019-04-08 | Refactor GetTextureCode and GetTexCode to use an optional instead of optional parameters | Fernando Sahmkow | 2 | -34/+33 | |
2019-04-08 | Implement TXQ_B | Fernando Sahmkow | 2 | -2/+10 | |
2019-04-08 | Implement TMML_B | Fernando Sahmkow | 1 | -5/+10 | |
2019-04-08 | Corrections to TEX_B | Fernando Sahmkow | 2 | -4/+37 | |
2019-04-08 | Fixes to Const Buffer Accessor and Formatting | Fernando Sahmkow | 3 | -10/+10 | |
2019-04-08 | Implement Bindless Handling on SetupTexture | Fernando Sahmkow | 4 | -18/+34 | |
2019-04-08 | Unify both sampler types. | Fernando Sahmkow | 4 | -22/+48 | |
2019-04-08 | Implement Bindless Samplers and TEX_B in the IR. | Fernando Sahmkow | 4 | -16/+77 | |
2019-04-08 | Implement Const Buffer Accessor | Fernando Sahmkow | 5 | -2/+65 | |
2019-04-08 | kernel/svc: Deglobalize the supervisor call handlers | Lioncash | 8 | -364/+413 | |
Adjusts the interface of the wrappers to take a system reference, which allows accessing a system instance without using the global accessors. This also allows getting rid of all global accessors within the supervisor call handling code. While this does make the wrappers themselves slightly more noisy, this will be further cleaned up in a follow-up. This eliminates the global system accessors in the current code while preserving the existing interface. | |||||
2019-04-07 | Permit a Null Shader in case of a bad host_ptr. | Fernando Sahmkow | 2 | -0/+22 | |
2019-04-07 | core/memory: Remove unused enum constants | Lioncash | 1 | -10/+0 | |
These are holdovers from Citra and can be removed. | |||||
2019-04-07 | core/memory: Remove GetCurrentPageTable() | Lioncash | 2 | -6/+1 | |
Now that nothing actually touches the internal page table aside from the memory subsystem itself, we can remove the accessor to it. | |||||
2019-04-07 | arm/arm_dynarmic: Remove unnecessary current_page_table member | Lioncash | 2 | -8/+0 | |
Given the page table will always be guaranteed to be that of whatever the current process is, we no longer need to keep this around. | |||||
2019-04-07 | kernel: Handle page table switching within MakeCurrentProcess() | Lioncash | 4 | -6/+3 | |
Centralizes the page table switching to one spot, rather than making calling code deal with it everywhere. | |||||
2019-04-06 | kernel/server_session: Return a std::pair from CreateSessionPair() | Lioncash | 4 | -11/+8 | |
Keeps the return type consistent with the function name. While we're at it, we can also reduce the amount of boilerplate involved with handling these by using structured bindings. | |||||
2019-04-06 | kernel/server_port: Return a std::pair from CreatePortPair() | Lioncash | 2 | -7/+7 | |
Returns the same type that the function name describes. | |||||
2019-04-06 | maxwell_3d: Reduce severity of ProcessSyncPoint | ReinUsesLisp | 1 | -2/+2 | |
2019-04-06 | video_core/textures/convert: Replace include with a forward declaration | Lioncash | 2 | -1/+5 | |
Avoids dragging in a direct dependency in a header. | |||||
2019-04-06 | video_core/texures/texture: Remove unnecessary includes | Lioncash | 6 | -2/+5 | |
Nothing in this header relies on common_funcs or the memory manager. This gets rid of reliance on indirect inclusions in the OpenGL caches. | |||||
2019-04-06 | yuzu/debugger: Remove graphics surface viewer | Lioncash | 5 | -622/+0 | |
This doesn't actually work anymore, and given how long it's been left in that state, it's unlikely anyone actually seriously used it. Generally it's preferable to use RenderDoc or Nsight to view surfaces. | |||||
2019-04-06 | memory_manager: Improved implementation of read/write/copy block. | bunnei | 3 | -12/+84 | |
- Fixes graphical issues with Chocobo's Mystery Dungeon EVERY BUDDY! - Fixes a crash with Mario Tennis Aces | |||||
2019-04-06 | video_core/macro_interpreter: Remove assertion within FetchParameter() | Lioncash | 1 | -2/+1 | |
We can just use .at(), which essentially does the same thing, but with less code. | |||||
2019-04-06 | video_core/macro_interpreter: Simplify GetRegister() | Lioncash | 1 | -11/+6 | |
Given we already ensure nothing can set the zeroth register in SetRegister(), we don't need to check if the index is zero and special case it. We can just access the register normally, since it's already going to be zero. We can also replace the assertion with .at() to perform the equivalent behavior inline as part of the API. | |||||
2019-04-06 | video_core/memory_manager: Make Read() a const qualified member function | Lioncash | 2 | -6/+6 | |
Given this doesn't actually alter internal state, this can be made a const member function. | |||||
2019-04-06 | video_core/memory_manager: Make ReadBlock() a const qualifier member function | Lioncash | 2 | -2/+2 | |
Now, since we have a const qualified variant of GetPointer(), we can put it to use in ReadBlock() to retrieve the source pointer that is passed into memcpy. Now block reading may be done from a const context. | |||||
2019-04-06 | video_core/memory_manager: Add a const qualified variant of GetPointer() | Lioncash | 2 | -2/+17 | |
Allows retrieving read-only pointers from a const context externally. | |||||
2019-04-06 | video_core/memory_manager: Make FindFreeRegion() a const member function | Lioncash | 2 | -10/+11 | |
This doesn't modify internal state, so it can be made a const member function. | |||||
2019-04-06 | video_core/memory_manager: Make GpuToCpuAddress() a const member function | Lioncash | 2 | -3/+3 | |
This doesn't modify any internal state, so it can be made a const member function to allow its use in const contexts. | |||||
2019-04-06 | yuzu/debugger/graphics_surface: Display error messages for file I/O errors | Lioncash | 1 | -7/+25 | |
2019-04-06 | yuzu/debugger/graphics_surface: Tidy up SaveSurface | Lioncash | 1 | -15/+14 | |
- Use QStringLiteral where applicable. - Use const where applicable - Remove unnecessary precondition check (we already assert the pixbuf being non null) | |||||
2019-04-06 | yuzu/debugger/graphics_surface: Clean up connection overload deduction | Lioncash | 1 | -12/+10 | |
We can utilize qOverload with the signal connections to make the function deducing a little less ugly. | |||||
2019-04-06 | Implement SyncPoint Register in the GPU. | Fernando Sahmkow | 2 | -1/+27 | |
2019-04-06 | yuzu/debugger/graphics_surface: Fill in missing surface format listings | Lioncash | 1 | -43/+84 | |
Fills in the missing surface types that were marked as unknown. The order corresponds with the TextureFormat enum within video_core/texture.h. We also don't need to all of these strings as translatable (only the first string, as it's an English word). | |||||
2019-04-06 | video_core/gpu_thread: Silence truncation warning in ThreadManager's constructor | Lioncash | 1 | -1/+1 | |
Since c5d41fd812d7eb1a04f36b76c08fe971cee0868c callback parameters were changed to use an s64 to represent late cycles instead of an int, so this was causing a truncation warning to occur here. Changing it to s64 is sufficient to silence the warning. | |||||
2019-04-06 | video_core/engines: Make memory manager members private | Lioncash | 9 | -13/+14 | |
These aren't used externally by anything, so they can be made private data members. | |||||
2019-04-06 | video_core/engines: Remove unnecessary inclusions where applicable | Lioncash | 10 | -9/+25 | |
Replaces header inclusions with forward declarations where applicable and also removes unused headers within the cpp file. This reduces a few more dependencies on core/memory.h | |||||
2019-04-06 | renderer_opengl/utils: Skip empty binds | ReinUsesLisp | 1 | -0/+3 | |
2019-04-06 | gl_rasterizer: Use ARB_multi_bind to update SSBOs | ReinUsesLisp | 2 | -9/+9 | |
2019-04-06 | gl_rasterizer: Use ARB_multi_bind to update UBOs across stages | ReinUsesLisp | 4 | -22/+58 | |
2019-04-05 | hle/result: Remove unnecessary bitfield entry for ResultCode | Lioncash | 1 | -4/+0 | |
This is a hold over from the 3DS error codes in Citra. | |||||
2019-04-05 | file_sys/program_metadata: Remove obsolete TODOs | Lioncash | 2 | -15/+14 | |
BitField has been trivially copyable since e99a14862841841d74be8d0ea9426c2d23546b5e, so we can eliminate these TODO comments and use ReadObject() directly instead of memcpying the data. | |||||
2019-04-05 | common/multi_level_queue: Silence truncation warning in iterator operator++ | Lioncash | 1 | -1/+1 | |
2019-04-05 | common/bit_util: Make CountLeading/CountTrailing functions have the same return types | Lioncash | 1 | -8/+8 | |
Makes the return type consistently uniform (like the intrinsics we're wrapping). This also conveniently silences a truncation warning within the kernel multi_level_queue. | |||||
2019-04-05 | file_sys/nca_metadata: Remove unnecessary comparison operators for TitleType | Lioncash | 2 | -11/+0 | |
enum class elements from the same enum can already be compared against one another without the need for explicitly defined comparison operators. | |||||
2019-04-05 | file_sys/fsmitm_romfsbuild: Utilize a string_view in romfs_calc_path_hash() | Lioncash | 1 | -1/+3 | |
The given string instance doesn't need to be copied entirely, we can just use a view instead. | |||||
2019-04-05 | service/fsp_srv: Don't pass SaveDataDescriptor instances by value. | Lioncash | 4 | -6/+6 | |
Passing around a 64 byte data struct by value is kind of wasteful, instead pass a reference to the struct. | |||||
2019-04-05 | service/fsp_srv: Remove unnecessary unknown member in OpenSaveDataFileSystem | Lioncash | 1 | -7/+8 | |
The unknown member here is actually padding due to being passed as a struct. We can do the same, and remove the need to pop a padding word. | |||||
2019-04-05 | service/fsp_srv: Update SaveDataInfo and SaveDataDescriptor structs | Lioncash | 3 | -4/+15 | |
I realized that I updated the documentation on SwitchBrew a while ago, but never actually updated the structs within yuzu. | |||||
2019-04-05 | filesystem: Use a std::string_view in OpenFile() | Lioncash | 1 | -5/+8 | |
Rather than make a full copy of the path, we can just use a string view and truncate the viewed portion of the string instead of creating a totally new truncated string. | |||||
2019-04-05 | gl_shader_decompiler: Rename GenerateTemporal() to GenerateTemporary() | Lioncash | 1 | -12/+12 | |
Temporal generally indicates a relation to time, but this is just creating a temporary, so this isn't really an accurate name for what the function is actually doing. | |||||
2019-04-05 | gl_shader_decompiler: Fix TXQ types | ReinUsesLisp | 1 | -2/+3 | |
TXQ returns integer types. Shaders usually do: R0 = TXQ(); // => int R0 = static_cast<float>(R0); If we don't treat it as an integer, it will cast a binary float value as float - resulting in a corrupted number. | |||||
2019-04-04 | hle/service: Resolve unused variable warnings | Lioncash | 8 | -62/+58 | |
In several places, we have request parsers where there's nothing to really parse, simply because the HLE function in question operates on buffers. In these cases we can just remove these instances altogether. In the other cases, we can retrieve the relevant members from the parser and at least log them out, giving them some use. | |||||
2019-04-04 | core: Add missing override specifiers where applicable | Lioncash | 13 | -23/+9 | |
Applies the override specifier where applicable. In the case of destructors that are defaulted in their definition, they can simply be removed. This also removes the unnecessary inclusions being done in audin_u and audrec_u, given their close proximity. | |||||
2019-04-04 | video_core/renderer_opengl: Remove unnecessary includes | Lioncash | 13 | -24/+4 | |
Quite a few unused includes have built up over time, particularly on core/memory.h. Removing these includes means the source files including those files will no longer need to be rebuilt if they're changed, making compilation slightly faster in this scenario. | |||||
2019-04-04 | yuzu/main: Remove unnecessary includes | Lioncash | 1 | -5/+8 | |
While we're at it, don't use <QtGui> and <QtWidgets> and instead include exactly which headers we actually need. | |||||
2019-04-04 | yuzu/main: Use QStringLiteral where applicable within OnTransferableShaderCacheOpenFile() | Lioncash | 1 | -2/+2 | |
Allows these strings to have no allocation cost when used at runtime. | |||||
2019-04-04 | yuzu/main: Tidy up the error dialog string in OnTransferableShaderCacheOpenFile() | Lioncash | 1 | -3/+2 | |
Rather than scream that the file doesn't exist, we can clearly state what specifically doesn't exist, to avoid ambiguity, and make it easier to understand for non-primary English speakers/readers. | |||||
2019-04-04 | yuzu/main: Remove unnecessary string concatenation in OnTransferableShaderCacheOpenFile() | Lioncash | 1 | -1/+1 | |
We can just make the trailing portion of the string part of the formatting, getting rid of the need to make another temporary string. | |||||
2019-04-04 | yuzu/main: Make open_target a QString | Lioncash | 1 | -4/+2 | |
Simplifies the amount of string conversions necessary. We also don't need to log out what occurs here. | |||||
2019-04-04 | yuzu/main: Use static variant of QFile's exists() | Lioncash | 1 | -1/+1 | |
There's no need to construct a QFile instance just to check for its existence. | |||||
2019-04-04 | common/lz4_compression: Remove #pragma once directive from the cpp file | Lioncash | 1 | -2/+0 | |
Introduced within 798d76f4c7018174e58702fb06a042dc8c84f0be, this only really has an effect within header files. Silences a -Wpragma-once-outside-header warning with clang. | |||||
2019-04-04 | file_sys/control_metadata: Amend naming of members | Lioncash | 2 | -12/+24 | |
Quite a bit of these were out of sync with Switchbrew (and in some cases entirely wrong). While we're at it, also expand the section of named members. A segment within the control metadata is used to specify maximum values for the user, device, and cache storage max sizes and journal sizes. These appear to be generally used by the am service (e.g. in CreateCacheStorage, etc). | |||||
2019-04-04 | kernel/svc: Properly sanitize mutex address in WaitProcessWideKeyAtomic | Lioncash | 1 | -0/+14 | |
We need to be checking whether or not the given address is within the kernel address space or if the given address isn't word-aligned and bail in these scenarios instead of trashing any kernel state. | |||||
2019-04-04 | gl_state: Rework to enable individual applies | ReinUsesLisp | 3 | -339/+324 | |
2019-04-03 | service/am: Correct behavior of CreateTransferMemoryStorage() | Lioncash | 1 | -6/+6 | |
For whatever reason, shared memory was being used here instead of transfer memory, which (quite clearly) will not work based off the name of the function. This corrects this wonky usage of shared memory. | |||||
2019-04-03 | kernel/transfer_memory: Add accessors to data and sizes | Lioncash | 2 | -11/+31 | |
Also amend erroneous use of size_t. We should be using u64 here. | |||||
2019-04-03 | shader_ir/memory: Reduce severity of LD_L cache management and log it | ReinUsesLisp | 2 | -2/+9 | |
2019-04-03 | shader_ir/memory: Reduce severity of ST_L cache management and log it | ReinUsesLisp | 2 | -3/+11 | |
2019-04-03 | gl_shader_decompiler: Return early when an operation is invalid | ReinUsesLisp | 1 | -1/+6 | |
2019-04-03 | yuzu/applets/software_keyboard: Use QDialogButtonBox standard buttons instead of custom buttons | Lioncash | 1 | -7/+7 | |
Like the previous change, this allows Qt to handle proper translations of the UI buttons, rather than us needing to handle it. | |||||
2019-04-03 | yuzu/applets/profile_select: Use QDialogButtonBox standard buttons instead of custom buttons | Lioncash | 1 | -4/+1 | |
Makes for shorter code, while also not requiring the buttons to be directly translated, they'll be handled by Qt itself. | |||||
2019-04-03 | kernel/server_session: Provide a GetName() override | Lioncash | 1 | -0/+4 | |
Given server sessions can be given a name, we should allow retrieving it instead of using the default implementation of GetName(), which would just return "[UNKNOWN KERNEL OBJECT]". | |||||
2019-04-03 | kernel/object: Remove unused handle type entry | Lioncash | 2 | -2/+0 | |
The AddressArbiter type isn't actually used, given the arbiter itself isn't a direct kernel object (or object that implements the wait object facilities). Given this, we can remove the enum entry entirely. | |||||
2019-04-03 | yuzu/debugger/profiler: Remove unnecessary includes | Lioncash | 2 | -4/+6 | |
Moves includes into the cpp file where necessary. This way, microprofile-related stuff isn't dumped into other UI-related code when the dialog header gets included. | |||||
2019-04-02 | gl_sampler_cache: Port sampler cache to OpenGL | ReinUsesLisp | 5 | -123/+82 | |
2019-04-02 | video_core: Abstract vk_sampler_cache into a templated class | ReinUsesLisp | 5 | -58/+101 | |
2019-04-02 | kernel/svc: Implement svcGetThreadList | Lioncash | 4 | -1/+70 | |
Similarly like svcGetProcessList, this retrieves the list of threads from the current process. In the kernel itself, a process instance maintains a list of threads, which are used within this function. Threads are registered to a process' thread list at thread initialization, and unregistered from the list upon thread destruction (if said thread has a non-null owning process). We assert on the debug event case, as we currently don't implement kernel debug objects. | |||||
2019-04-02 | kernel/svc: Implement svcGetProcessList | Lioncash | 4 | -1/+53 | |
This service function simply copies out a specified number of kernel process IDs, while simultaneously reporting the total number of processes. | |||||
2019-04-02 | process: Fix up compilation | ReinUsesLisp | 1 | -1/+1 | |
2019-04-02 | gpu_thread: Improve synchronization by using CoreTiming. | bunnei | 3 | -51/+65 | |
2019-04-02 | kernel/thread: Make AllWaitObjectsReady() a const qualified member function | Lioncash | 2 | -2/+2 | |
Now that ShouldWait() is a const qualified member function, this one can be made const qualified as well, since it can handle passing a const qualified this pointer to ShouldWait(). | |||||
2019-04-02 | kernel/wait_object: Make ShouldWait() take thread members by pointer-to-const | Lioncash | 11 | -11/+11 | |
Given this is intended as a querying function, it doesn't make sense to allow the implementer to modify the state of the given thread. | |||||
2019-04-01 | kernel/thread: Avoid sign conversion within GetCommandBufferAddress() | Lioncash | 1 | -2/+2 | |
Previously this was performing a u64 + int sign conversion. When dealing with addresses, we should generally be keeping the arithmetic in the same signedness type. This also gets rid of the static lifetime of the constant, as there's no need to make a trivial type like this potentially live for the entire duration of the program. | |||||
2019-04-01 | kernel/thread: Make parameter of GetWaitObjectIndex() const qualified | Lioncash | 2 | -3/+3 | |
The pointed to member is never actually modified, so it can be made const. | |||||
2019-04-01 | kernel/resource_limit: Remove the name member from resource limits | Lioncash | 3 | -14/+6 | |
This doesn't really provide any benefit to the resource limit interface. There's no way for callers to any of the service functions for resource limits to provide a custom name, so all created instances of resource limits other than the system resource limit would have a name of "Unknown". The system resource limit itself is already trivially identifiable from its limit values, so there's no real need to take up space in the object to identify one object meaningfully out of N total objects. | |||||
2019-04-01 | general: Use deducation guides for std::lock_guard and std::unique_lock | Lioncash | 23 | -75/+77 | |
Since C++17, the introduction of deduction guides for locking facilities means that we no longer need to hardcode the mutex type into the locks themselves, making it easier to switch mutex types, should it ever be necessary in the future. | |||||
2019-03-31 | gl_shader_decompiler: Hide local definitions inside an anonymous namespace | ReinUsesLisp | 1 | -6/+8 | |
2019-03-31 | shader_ir/decode: Silent implicit sign conversion warning | Mat M | 1 | -2/+2 | |
Co-Authored-By: ReinUsesLisp <reinuseslisp@airmail.cc> | |||||
2019-03-30 | kernel/scheduler: Remove unused parameter to AddThread() | Lioncash | 3 | -4/+4 | |
This was made unused in b404fcdf1443b91ac9994c05ad1fe039fcd9675e, but the parameter itself wasn't removed. | |||||
2019-03-30 | kernel/scheduler: Use deduction guides on mutex locks | Lioncash | 1 | -8/+8 | |
Since C++17, we no longer need to explicitly specify the type of the mutex within the lock_guard. The type system can now deduce these with deduction guides. | |||||
2019-03-30 | service/fatal: Mark local variables as const where applicable | Lioncash | 1 | -6/+6 | |
2019-03-30 | service/fatal: Remove unnecessary semicolon | Lioncash | 1 | -1/+1 | |
Resolves a -Wextra-semi warning. | |||||
2019-03-30 | service/fatal: Name FatalInfo structure members | Lioncash | 1 | -31/+44 | |
Based off RE, most of these structure members are register values, which makes, sense given this service is used to convey fatal errors. One member indicates the program entry point address, one is a set of bit flags used to determine which registers to print, and one member indicates the architecture type. The only member that still isn't determined is the final member within the data structure. | |||||
2019-03-30 | gl_shader_decompiler: Add AOFFI backing implementation | ReinUsesLisp | 1 | -38/+85 | |
2019-03-30 | shader_ir/decode: Implement AOFFI for TEX and TLD4 | ReinUsesLisp | 2 | -27/+94 | |
2019-03-30 | shader_ir: Implement immediate register tracking | ReinUsesLisp | 2 | -1/+19 | |
2019-03-29 | kernel/shared_memory: Remove unused core/memory.h include | Lioncash | 1 | -1/+0 | |
Nothing from this header is used, so we can remove this include, getting rid of a dependency on it. | |||||
2019-03-29 | kernel/shared_memory: Sanitize supplied size when unmapping | Lioncash | 3 | -4/+18 | |
The kernel makes sure that the given size to unmap is always the same size as the entire region managed by the shared memory instance, otherwise it returns an error code signifying an invalid size. This is similarly done for transfer memory (which we already check for). | |||||
2019-03-29 | common/thread: Remove unused functions | Lioncash | 2 | -41/+0 | |
Many of these functions are carried over from Dolphin (where they aren't used anymore). Given these have no use (and we really shouldn't be screwing around with OS-specific thread scheduler handling from the emulator, these can be removed. The function for setting the thread name is left, however, since it can have debugging utility usages. | |||||
2019-03-29 | common/zstd_compression: simplify decompression interface | unknown | 3 | -13/+11 | |
2019-03-29 | gl_shader_disk_cache: Fixup clang format | unknown | 1 | -2/+3 | |
2019-03-29 | gl_shader_disk_cache: Use Zstandard for compression | unknown | 1 | -6/+6 | |
2019-03-29 | common/zstd_compression: Add Zstandard wrapper | unknown | 3 | -0/+98 | |
2019-03-29 | common: Link libzstd_static | unknown | 1 | -1/+1 | |
2019-03-29 | Addressed feedback | unknown | 1 | -1/+0 | |
2019-03-29 | core: Do not link LZ4 to core. Use common/data_compression for nso segment decompression instead. | unknown | 1 | -0/+1 | |
2019-03-29 | gl_shader_disk_cache: Use LZ4HC with compression level 9 instead of compression level 12 for less compression time | unknown | 1 | -3/+3 | |
2019-03-29 | Addressed feedback | unknown | 7 | -91/+145 | |
2019-03-29 | core: Do not link LZ4 to core. Use common/data_compression for nso segment decompression instead. | unknown | 2 | -11/+8 | |
2019-03-29 | gl_shader_disk_cache: Use better compression for transferable and precompiled shader disk chache files | unknown | 3 | -10/+26 | |
2019-03-29 | data_compression: Move LZ4 compression from video_core/gl_shader_disk_cache to common/data_compression | unknown | 5 | -39/+75 | |
2019-03-29 | core/yuzu: Remove enable_nfc setting | fearlessTobi | 7 | -28/+1 | |
This was initially added to prevent problems from stubbed/not implemented NFC services, but as we never encountered such and as it's only used in a deprecated function anyway, I guess we can just remove it to prevent more clutter of the settings. | |||||
2019-03-29 | vk_swapchain: Implement a swapchain manager | ReinUsesLisp | 3 | -1/+305 | |
2019-03-29 | kernel/process: Report total physical memory used to svcGetInfo | Lioncash | 3 | -4/+11 | |
Reports the (mostly) correct size through svcGetInfo now for queries to total used physical memory. This still doesn't correctly handle memory allocated via svcMapPhysicalMemory, however, we don't currently handle that case anyways. | |||||
2019-03-29 | kernel/process: Store the total size of the code memory loaded | Lioncash | 2 | -0/+5 | |
This will be necessary to properly report the used memory size in svcGetInfo. | |||||
2019-03-28 | kernel/process: Store the main thread stack size to a data member | Lioncash | 2 | -4/+7 | |
This will be necessary in order to properly report memory usage within svcGetInfo. | |||||
2019-03-28 | kernel/process: Make Run's stack size parameter a u64 | Lioncash | 2 | -2/+2 | |
This will make operating with the process-related SVC commands much nicer in the future (the parameter representing the stack size in svcStartProcess is a 64-bit value). | |||||
2019-03-28 | kernel/process: Ensure that given stack size is always page-aligned | Lioncash | 1 | -0/+4 | |
The kernel always makes sure that the given stack size is aligned to page boundaries. | |||||
2019-03-28 | gl_shader_manager: Remove unnecessary gl_shader_manager inclusion | Lioncash | 1 | -2/+0 | |
This isn't used at all in the OpenGL shader cache, so we can remove it's include here, meaning one less file needs to be recompiled if any changes ever occur within that header. core/memory.h is also not used within this file at all, so we can remove it as well. | |||||
2019-03-28 | gl_shader_manager: Move using statement into the cpp file | Lioncash | 2 | -4/+4 | |
Avoids introducing Maxwell3D into the namespace for everything that includes the header. | |||||
2019-03-28 | gl_shader_manager: Remove reliance on global accessor within MaxwellUniformData::SetFromRegs() | Lioncash | 3 | -9/+9 | |
We can just pass in the Maxwell3D instance instead of going through the system class to get at it. This also lets us simplify the interface a little bit. Since we pass in the Maxwell3D context now, we only really need to pass the shader stage index value in. | |||||
2019-03-28 | patch_manager: Dump NSO name with build ID | Zach Hilman | 4 | -9/+11 | |
2019-03-27 | Fixes and corrections on formatting. | Fernando Sahmkow | 5 | -41/+30 | |
2019-03-27 | Fixes to multilevelqueue's iterator. | Fernando Sahmkow | 1 | -1/+5 | |
2019-03-27 | Use MultiLevelQueue instead of old ThreadQueueList | Fernando Sahmkow | 3 | -31/+34 | |
2019-03-27 | Add MultiLevelQueue Tests | Fernando Sahmkow | 2 | -0/+56 | |
2019-03-27 | Implement intrinsics CountTrailingZeroes and test it. | Fernando Sahmkow | 3 | -12/+76 | |
2019-03-27 | Implement a MultiLevelQueue | Fernando Sahmkow | 3 | -0/+349 | |
2019-03-27 | gl_shader_manager: Amend Doxygen string for MaxwellUniformData | Lioncash | 1 | -3/+3 | |
Previously only one line of the whole comment was in proper Doxygen formatting. | |||||
2019-03-27 | gpu_thread: Remove unused dma_pusher class member variable from ThreadManager | Lioncash | 2 | -5/+2 | |
The pusher instance is only ever used in the constructor of the ThreadManager for creating the thread that the ThreadManager instance contains. Aside from that, the member is unused, so it can be removed. | |||||
2019-03-27 | gl_rasterizer: Remove unused reference member variable from RasterizerOpenGL | Lioncash | 3 | -9/+5 | |
This member variable is no longer being used, so it can be removed, removing a dependency on EmuWindow from the rasterizer's interface" | |||||
2019-03-27 | video_core: Amend constructor initializer list order where applicable | Lioncash | 6 | -14/+14 | |
Specifies the members in the same order that initialization would take place in. This also silences -Wreorder warnings. | |||||
2019-03-27 | video_core: Add missing override specifiers | Lioncash | 3 | -4/+4 | |
Ensures that the signatures will always match with the base class. Also silences a few compilation warnings. | |||||
2019-03-27 | video_core/gpu: Amend typo in GPU member variable name | Lioncash | 2 | -7/+8 | |
smaphore -> semaphore | |||||
2019-03-27 | game_list: Register content with ContentProvider | Zach Hilman | 8 | -91/+102 | |
2019-03-27 | core: Port current uses of RegisteredCache to ContentProvider | Zach Hilman | 8 | -27/+32 | |
2019-03-27 | core: Store system-wide ContentProvider for the emulator | Zach Hilman | 2 | -0/+40 | |
2019-03-27 | file_sys: Create ContentProvider interface and default implementations | Zach Hilman | 2 | -152/+279 | |
2019-03-26 | service/am: Implement EnterFatalSection and LeaveFatalSection | Lioncash | 2 | -2/+29 | |
These functions act in tandem similar to how a lock or mutex require a balanced lock()/unlock() sequence. EnterFatalSection simply increments a counter for how many times it has been called, while LeaveFatalSection ensures that a previous call to EnterFatalSection has occured. If a previous call has occurred (the counter is not zero), then the counter gets decremented as one would expect. If a previous call has not occurred (the counter is zero), then an error code is returned. | |||||
2019-03-26 | service/am: Sort ISelfController's member functions according to table order | Lioncash | 2 | -36/+36 | |
Makes the declaration order of the handling functions consistent with the handler table itself. | |||||
2019-03-25 | bootmanager: Bypass input focus issues | ReinUsesLisp | 4 | -55/+78 | |
2019-03-25 | bootmanager: Bypass resizing issue | ReinUsesLisp | 1 | -7/+12 | |
2019-03-25 | bootmanager: Delete container to avoid crash on game restarting | ReinUsesLisp | 2 | -14/+10 | |
While we are at it, remove nullptr checks for deletion, since the C++ standard defines that delete does it by its own | |||||
2019-03-24 | core/cheat_engine: Make MemoryReadImpl and MemoryWriteImpl internally linked | Lioncash | 1 | -0/+2 | |
These don't need to be visible outside of the translation unit, so they can be enclosed within an anonymous namespace. | |||||
2019-03-24 | core/core_timing: Make callback parameters consistent | Lioncash | 7 | -12/+12 | |
In some cases, our callbacks were using s64 as a parameter, and in other cases, they were using an int, which is inconsistent. To make all callbacks consistent, we can just use an s64 as the type for late cycles, given it gets rid of the need to cast internally. While we're at it, also resolve some signed/unsigned conversions that were occurring related to the callback registration. | |||||
2019-03-24 | kernel/kernel: Remove unnecessary forward declaration | Lioncash | 1 | -3/+0 | |
This is no longer necessary, as ResultVal isn't used anywhere in the header. | |||||
2019-03-24 | kernel/process: Remove unused AddressMapping struct | Lioncash | 1 | -8/+0 | |
Another leftover from citra that's now no longer necessary. | |||||
2019-03-24 | kernel/vm_manager: Handle shrinking of the heap size within SetHeapSize() | Lioncash | 2 | -24/+46 | |
One behavior that we weren't handling properly in our heap allocation process was the ability for the heap to be shrunk down in size if a larger size was previously requested. This adds the basic behavior to do so and also gets rid of HeapFree, as it's no longer necessary now that we have allocations and deallocations going through the same API function. While we're at it, fully document the behavior that this function performs. | |||||
2019-03-24 | kernel/vm_manager: Rename HeapAllocate to SetHeapSize | Lioncash | 3 | -4/+3 | |
Makes it more obvious that this function is intending to stand in for the actual supervisor call itself, and not acting as a general heap allocation function. Also the following change will merge the freeing behavior of HeapFree into this function, so leaving it as HeapAllocate would be misleading. | |||||
2019-03-24 | kernel/vm_manager: Handle case of identical calls to HeapAllocate | Lioncash | 1 | -0/+5 | |
In cases where HeapAllocate is called with the same size of the current heap, we can simply do nothing and return successfully. This avoids doing work where we otherwise don't have to. This is also what the kernel itself does in this scenario. | |||||
2019-03-24 | kernel/vm_manager: Remove unused class variables | Lioncash | 1 | -3/+0 | |
Over time these have fallen out of use due to refactoring, so these can be removed. | |||||
2019-03-24 | kernel/vm_manager: Remove unnecessary heap_used data member | Lioncash | 3 | -13/+2 | |
This isn't required anymore, as all the kernel ever queries is the size of the current heap, not the total usage of it. | |||||
2019-03-24 | kernel/vm_manager: Tidy up heap allocation code | Lioncash | 3 | -27/+37 | |
Another holdover from citra that can be tossed out is the notion of the heap needing to be allocated in different addresses. On the switch, the base address of the heap will always be managed by the memory allocator in the kernel, so this doesn't need to be specified in the function's interface itself. The heap on the switch is always allocated with read/write permissions, so we don't need to add specifying the memory permissions as part of the heap allocation itself either. This also corrects the error code returned from within the function. If the size of the heap is larger than the entire heap region, then the kernel will report an out of memory condition. | |||||
2019-03-22 | kernel/codeset: Make CodeSet's memory data member a regular std::vector | Lioncash | 5 | -7/+8 | |
The use of a shared_ptr is an implementation detail of the VMManager itself when mapping memory. Because of that, we shouldn't require all users of the CodeSet to have to allocate the shared_ptr ahead of time. It's intended that CodeSet simply pass in the required direct data, and that the memory manager takes care of it from that point on. This means we just do the shared pointer allocation in a single place, when loading modules, as opposed to in each loader. | |||||
2019-03-22 | loader/nso: Place translation unit specific functions into an anonymous namespace | Lioncash | 1 | -20/+21 | |
Makes it impossible to indirectly violate the ODR in some other translation unit due to these existing. | |||||
2019-03-22 | file_sys/cheat_engine: Silence truncation and sign-conversion warnings | Lioncash | 2 | -5/+6 | |
2019-03-22 | file_sys/cheat_engine: Remove use of global system accessors | Lioncash | 6 | -43/+51 | |
Instead, pass in the core timing instance and make the dependency explicit in the interface. | |||||
2019-03-22 | loader/nso: Clean up use of magic constants | Lioncash | 1 | -4/+6 | |
Now that the NSO header has the proper size, we can just use sizeof on it instead of having magic constants. | |||||
2019-03-22 | file_sys/patch_manager: Deduplicate NSO header | Lioncash | 3 | -64/+65 | |
This source file was utilizing its own version of the NSO header. Instead of keeping this around, we can have the patch manager also use the version of the header that we have defined in loader/nso.h | |||||
2019-03-22 | loader/nso: Fix definition of the NSO header struct | Lioncash | 1 | -3/+15 | |
The total struct itself is 0x100 (256) bytes in size, so we should be providing that amount of data. Without the data, this can result in omitted data from the final loaded NSO file. | |||||
2019-03-22 | file_sys/patch_manager: Remove two magic values | Lioncash | 1 | -2/+5 | |
These correspond to the NSOBuildHeader. | |||||
2019-03-22 | video_core: Implement API agnostic view based texture cache | ReinUsesLisp | 3 | -0/+974 | |
Implements an API agnostic texture view based texture cache. Classes defined here are intended to be inherited by the API implementation and used in API-specific code. This implementation exposes protected virtual functions to be called from the implementer. Before executing any surface copies methods (defined in API-specific code) it tries to detect if the overlapping surface is a superset and if it is, it creates a view. Views are references of a subset of a surface, it can be a superset view (the same as referencing the whole texture). Current code manages 1D, 1D array, 2D, 2D array, cube maps and cube map arrays with layer and mipmap level views. Texture 3D slices views are not implemented. If the view attempt fails, the fast path is invoked with the overlapping textures (defined in the implementer). If that one fails (returning nullptr) it will flush and reload the texture. | |||||
2019-03-22 | Revert "Devirtualize Register/Unregister and use a wrapper instead." | bunnei | 3 | -8/+12 | |
- Fixes graphical issues from transitions in Super Mario Odyssey. | |||||
2019-03-21 | service/am: Add function table for IDebugFunctions | Lioncash | 1 | -1/+15 | |
We already have the service related stuff set up for this, however, it's missing the function table. | |||||
2019-03-21 | kernel/vm_manager: Rename CodeStatic/CodeMutable to Code and CodeData respectively | Lioncash | 4 | -22/+20 | |
Makes it more evident that one is for actual code and one is for actual data. Mutable and static are less than ideal terms here, because read-only data is technically not mutable, but we were mapping it with that label. | |||||
2019-03-21 | kernel/vm_manager: Amend flag values for CodeMutable | Lioncash | 1 | -1/+1 | |
This should actually be using the data flags, rather than the code flags. | |||||
2019-03-21 | core/memory: Remove unnecessary includes | Lioncash | 1 | -3/+0 | |
In 93da8e0abfcdcc6e3cb5488a0db12373429f1377, the page table construct was moved to the common library (which utilized these inclusions). Since the move, nothing requires these headers to be included within the memory header. | |||||
2019-03-21 | common/bit_util: Fix bad merge duplicating the copy constructor | Lioncash | 1 | -2/+0 | |
Introduced as a result of #2090, we already define the copy constructor further down below, so this isn't needed. | |||||
2019-03-21 | memory_manager: Cleanup FindFreeRegion. | bunnei | 2 | -12/+6 | |
2019-03-21 | memory_manager: Use Common::AlignUp in public interface as needed. | bunnei | 1 | -11/+22 | |
2019-03-21 | common/uint128: Add missing header guard | Lioncash | 1 | -0/+2 | |
2019-03-21 | common/uint128: Add missing top-file source text | Lioncash | 2 | -0/+7 | |
2019-03-21 | memory_manager: Bug fixes and further cleanup. | bunnei | 2 | -73/+72 | |
2019-03-21 | memory: Check that core is powered on before attempting to use GPU. | bunnei | 1 | -1/+1 | |
- GPU will be released on shutdown, before pages are unmapped. - On subsequent runs, current_page_table will be not nullptr, but GPU might not be valid yet. | |||||
2019-03-21 | maxwell_dma: Check for valid source in destination before copy. | bunnei | 1 | -0/+10 | |
- Avoid a crash in Octopath Traveler. | |||||
2019-03-21 | memory_manager: Add protections for invalid GPU addresses. | bunnei | 2 | -22/+43 | |
- Avoid a crash in Xenoblade Chronicles 2. | |||||
2019-03-21 | gl_rasterizer_cache: Check that backing memory is valid before creating a surface. | bunnei | 2 | -15/+12 | |
- Fixes a crash in Puyo Puyo Tetris. | |||||
2019-03-21 | gpu: Rewrite virtual memory manager using PageTable. | bunnei | 13 | -212/+481 | |
2019-03-21 | gpu: Move GPUVAddr definition to common_types. | bunnei | 17 | -39/+31 | |
2019-03-21 | common/CMakeLists: Amend boost dependency | Lioncash | 1 | -1/+1 | |
When #2247 was created, thread_queue_list.h was the only user of boost-related code, however #2252 moved the page table struct into common, which makes use of Boost.ICL, so we need to add the dependency to the common library's link interface again. | |||||
2019-03-20 | kernel/process: Make MapSegment lambda reference parameter const | Lioncash | 1 | -1/+1 | |
The segment itself isn't actually modified. | |||||
2019-03-20 | kernel: Move CodeSet structure to its own source files | Lioncash | 8 | -44/+110 | |
Given this is utilized by the loaders, this allows avoiding inclusion of the kernel process definitions where avoidable. This also keeps the loading format for all executable data separate from the kernel objects. | |||||
2019-03-20 | Fix crash caused by 2238. | Fernando Sahmkow | 1 | -1/+2 | |
2019-03-20 | Fix small bug that kept a thread as a condvar thread after being signalled. | Fernando Sahmkow | 2 | -6/+8 | |
2019-03-20 | loader: Remove Linker class | Lioncash | 3 | -185/+0 | |
Given the class is now currently unused, it can be removed. | |||||
2019-03-20 | loader: Remove Linker inheritance from NRO and NSO loaders | Lioncash | 2 | -4/+4 | |
Neither the NRO or NSO loaders actually make use of the functions or members provided by the Linker interface, so we can just remove the inheritance altogether. | |||||
2019-03-20 | Add CondVar Thread State. | Fernando Sahmkow | 5 | -4/+10 | |
2019-03-20 | Small fixes to address_arbiter to better match the IDB. | Fernando Sahmkow | 2 | -5/+5 | |
2019-03-19 | Fix getopt on systems where char is unsigned by default | xperia64 | 1 | -2/+2 | |
2019-03-19 | file_sys/content_archive: Amend name of Data_Unknown5 enum entry | Lioncash | 2 | -2/+15 | |
While we're at it, give each entry some documentation. | |||||
2019-03-18 | input_common/sdl: Correct return values within implementations of GetPollers() | Lioncash | 2 | -2/+6 | |
In both cases, we weren't actually returning anything, which is undefined behavior. | |||||
2019-03-18 | input_common/sdl: Use a type alias to shorten declaration of GetPollers | Lioncash | 3 | -11/+9 | |
Just makes the definitions a little bit more tidy. | |||||
2019-03-18 | fsp_srv: Unstub SetCurrentProcess | Lioncash | 2 | -1/+5 | |
This just acts as a basic setter for a given PID value and performs no further checking, so we can just store the passed in value. | |||||
2019-03-18 | service/am: Add basic implementation of ChangeMainAppletMasterVolume | Lioncash | 2 | -1/+29 | |
All this does is supply a new volume level and a fade time in nanoseconds for the volume transition to occur within. | |||||
2019-03-18 | service/am: Unstub SetTransparentVolumeRate() | Lioncash | 2 | -1/+17 | |
Like the other volume setter, this mainly just sets a data member within the service, nothing too special. | |||||
2019-03-18 | service/am: Unstub SetExpectedMasterVolume() | Lioncash | 2 | -11/+27 | |
This function passes in the desired main applet and library applet volume levels. We can then just pass those values back within the relevant volume getter functions, allowing us to unstub those as well. The initial values for the library and main applet volumes differ. The main applet volume is 0.25 by default, while the library applet volume is initialized to 1.0 by default in the services themselves. | |||||
2019-03-17 | CMakeLists: Move off of modifying CMAKE_*-related flags | Lioncash | 1 | -20/+12 | |
Modifying CMAKE_* related flags directly applies those changes to every single CMake target. This includes even the targets we have in the externals directory. So, if we ever increased our warning levels, or enabled particular ones, or enabled any other compilation setting, then this would apply to externals as well, which is often not desirable. This makes our compilation flag setup less error prone by only applying our settings to our targets and leaving the externals alone entirely. This also means we don't end up clobbering any provided flags on the command line either, allowing users to specifically use the flags they want. | |||||
2019-03-17 | input_common/sdl_impl: Make lambda capture more specific in SDLState constructor | Lioncash | 1 | -1/+1 | |
We don't need to universally capture by reference. We specifically just need to capture the this pointer. | |||||
2019-03-17 | input_common/sdl_impl: Remove unnecessary std::chrono::duration construction | Lioncash | 1 | -1/+1 | |
Specifying the time unit itself is sufficient here. | |||||
2019-03-17 | input_common/sdl_impl: Remove unused variable in SDLState constructor | Lioncash | 1 | -1/+0 | |
2019-03-17 | CMakeLists: Move compilation flags into the src directory | Lioncash | 1 | -0/+69 | |
We generally shouldn't be hijacking CMAKE_CXX_FLAGS, etc as a means to append flags to the targets, since this adds the compilation flags to everything, including our externals, which can result in weird issues and makes the build hierarchy fragile. Instead, we want to just apply these compilation flags to our targets, and let those managing external libraries to properly specify their compilation flags. This also results in us not getting as many warnings, as we don't raise the warning level on every external target. | |||||
2019-03-17 | core: Move PageTable struct into Common. | bunnei | 16 | -171/+215 | |
2019-03-17 | gl_rasterizer: Skip zero addr/sized regions on flush/invalidate. | bunnei | 1 | -0/+6 | |
2019-03-16 | ipc_helpers: Allow pushing and popping floating-point values | Lioncash | 1 | -0/+30 | |
Certain values that are passed through the IPC buffer are actually floating point values, not solely integral values. | |||||
2019-03-16 | common/thread_queue_list: Remove unnecessary dependency on boost | Lioncash | 2 | -4/+4 | |
We really don't need to pull in several headers of boost related machinery just to perform the erase-remove idiom (particularly with C++20 around the corner, which adds universal container std::erase and std::erase_if, which we can just use instead). With this, we don't need to link in anything boost-related into common. | |||||
2019-03-16 | kernel/thread: Actually remove the definition of ExitCurrentThread() | Lioncash | 1 | -6/+0 | |
This was intended to be removed in 51d7f6bffcc0498a47abc7de27bf0906fc523dae, but I guess I forgot to actually save the file like a dingus. | |||||
2019-03-16 | memory: Simplify rasterizer cache operations. | bunnei | 3 | -68/+22 | |
2019-03-16 | video_core: Refactor to use MemoryManager interface for all memory access. | bunnei | 20 | -189/+196 | |
# Conflicts: # src/video_core/engines/kepler_memory.cpp # src/video_core/engines/maxwell_3d.cpp # src/video_core/morton.cpp # src/video_core/morton.h # src/video_core/renderer_opengl/gl_global_cache.cpp # src/video_core/renderer_opengl/gl_global_cache.h # src/video_core/renderer_opengl/gl_rasterizer_cache.cpp | |||||
2019-03-16 | kernel/thread: Move thread exiting logic from ExitCurrentThread to svcExitThread | Lioncash | 2 | -8/+7 | |
Puts the operation on global state in the same places as the rest of the svc calls. | |||||
2019-03-16 | kernel/thread: Migrate WaitCurrentThread_Sleep into the Thread interface | Lioncash | 4 | -25/+24 | |
Rather than make a global accessor for this sort of thing. We can make it a part of the thread interface itself. This allows getting rid of a hidden global accessor in the kernel code. | |||||
2019-03-16 | kernel/thread: Expand documentation of nominal_priority and current_priority | Lioncash | 2 | -3/+11 | |
Aims to disambiguate why each priority instance exists a little bit. While we're at it, also add an explanatory comment to UpdatePriority(). | |||||
2019-03-16 | kernel/thread: Make bracing consistent within UpdatePriority() | Lioncash | 1 | -2/+4 | |
2019-03-16 | kernel/thread: Amend condition within UpdatePriority() | Lioncash | 1 | -3/+3 | |
This condition was checking against the nominal thread priority, whereas the kernel itself checks against the current priority instead. We were also assigning the nominal priority, when we should be assigning current_priority, which takes priority inheritance into account. This can lead to the incorrect priority being assigned to a thread. Given we recursively update the relevant threads, we don't need to go through the whole mutex waiter list. This matches what the kernel does as well (only accessing the first entry within the waiting list). | |||||
2019-03-16 | kernel/thread: Maintain priority ordering of added mutex waiting threads | Lioncash | 1 | -14/+24 | |
The kernel keeps the internal waiting list ordered by priority. This is trivial to do with std::find_if followed by an insertion. | |||||
2019-03-16 | yuzu: Make hotkeys configurable via the GUI | Adityarup Laha | 23 | -208/+426 | |
* Adds a new Hotkeys tab in the Controls group. * Double-click a Hotkey to rebind it. | |||||
2019-03-15 | gdbstub: Fix some bugs in IsMemoryBreak() and ServeBreak. Add workaround to let watchpoints break into GDB. (#4651) | Dimitri A | 3 | -4/+5 | |
* gdbstub: fix IsMemoryBreak() returning false while connected to client As a result, the only existing codepath for a memory watchpoint hit to break into GDB (InterpeterMainLoop, GDB_BP_CHECK, ARMul_State::RecordBreak) is finally taken, which exposes incorrect logic* in both RecordBreak and ServeBreak. * a blank BreakpointAddress structure is passed, which sets r15 (PC) to NULL * gdbstub: DynCom: default-initialize two members/vars used in conditionals * gdbstub: DynCom: don't record memory watchpoint hits via RecordBreak() For now, instead check for GDBStub::IsMemoryBreak() in InterpreterMainLoop and ServeBreak. Fixes PC being set to a stale/unhit breakpoint address (often zero) when a memory watchpoint (rwatch, watch, awatch) is handled in ServeBreak() and generates a GDB trap. Reasons for removing a call to RecordBreak() for memory watchpoints: * The``breakpoint_data`` we pass is typed Execute or None. It describes the predicted next code breakpoint hit relative to PC; * GDBStub::IsMemoryBreak() returns true if a recent Read/Write operation hit a watchpoint. It doesn't specify which in return, nor does it trace it anywhere. Thus, the only data we could give RecordBreak() is a placeholder BreakpointAddress at offset NULL and type Access. I found the idea silly, compared to simply relying on GDBStub::IsMemoryBreak(). There is currently no measure in the code that remembers the addresses (and types) of any watchpoints that were hit by an instruction, in order to send them to GDB as "extended stop information." I'm considering an implementation for this. * gdbstub: Change an ASSERT to DEBUG_ASSERT I have never seen the (Reg[15] == last_bkpt.address) assert fail in practice, even after several weeks of (locally) developping various branches around GDB. Only leave it inside Debug builds. | |||||
2019-03-15 | frontend: qt: fix a freeze where if you click on entry in the game list too fast, citra will hang | liushuyu | 1 | -3/+1 | |
2019-03-15 | gpu: Use host address for caching instead of guest address. | bunnei | 26 | -294/+394 | |
2019-03-15 | core/hle/kernel/mutex: Remove usages of global system accessors | Lioncash | 1 | -11/+15 | |
Removes the use of global system accessors, and instead uses the explicit interface provided. | |||||
2019-03-15 | core/hle/kernel: Make Mutex a per-process class. | Lioncash | 5 | -18/+47 | |
Makes it an instantiable class like it is in the actual kernel. This will also allow removing reliance on global accessors in a following change, now that we can encapsulate a reference to the system instance in the class. | |||||
2019-03-13 | video_core/morton: Use enum to describe MortonCopyPixels128 mode | ReinUsesLisp | 3 | -7/+10 | |
2019-03-13 | video_core/morton: Remove unused parameter in MortonSwizzle | ReinUsesLisp | 3 | -8/+7 | |
2019-03-13 | video_core/morton: Remove clang-format off when it's not needed | ReinUsesLisp | 1 | -133/+129 | |