Commit message (Collapse) | Author | Files | Lines | ||
---|---|---|---|---|---|
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-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-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-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-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 | 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-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 | 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 | |
2019-03-13 | video_core/morton: Remove unused functions | ReinUsesLisp | 1 | -39/+0 | |
2019-03-13 | core/hle/kernel/svc: Implement svcUnmapTransferMemory | Lioncash | 1 | -1/+48 | |
Similarly, like svcMapTransferMemory, we can also implement svcUnmapTransferMemory fairly trivially as well. | |||||
2019-03-13 | core/hle/kernel/svc: Implement svcMapTransferMemory | Lioncash | 1 | -1/+57 | |
Now that transfer memory handling is separated from shared memory, we can implement svcMapTransferMemory pretty trivially. | |||||
2019-03-13 | core/hle/kernel: Split transfer memory handling out into its own class | Lioncash | 6 | -4/+177 | |
Within the kernel, shared memory and transfer memory facilities exist as completely different kernel objects. They also have different validity checking as well. Therefore, we shouldn't be treating the two as the same kind of memory. They also differ in terms of their behavioral aspect as well. Shared memory is intended for sharing memory between processes, while transfer memory is intended to be for transferring memory to other processes. This breaks out the handling for transfer memory into its own class and treats it as its own kernel object. This is also important when we consider resource limits as well. Particularly because transfer memory is limited by the resource limit value set for it. While we currently don't handle resource limit testing against objects yet (but we do allow setting them), this will make implementing that behavior much easier in the future, as we don't need to distinguish between shared memory and transfer memory allocations in the same place. | |||||
2019-03-13 | video_core/texture: Fix up sampler lod bias | ReinUsesLisp | 1 | -1/+1 | |
2019-03-13 | vk_sampler_cache: Use operator== instead of memcmp | Mat M | 1 | -1/+1 | |
Co-Authored-By: ReinUsesLisp <reinuseslisp@airmail.cc> | |||||
2019-03-13 | vk_sampler_cache: Implement a sampler cache | ReinUsesLisp | 4 | -1/+140 | |
2019-03-13 | kernel/process: Remove use of global system accessors | Lioncash | 2 | -8/+9 | |
Now that we pass in a reference to the system instance, we can utilize it to eliminate the global accessors in Process-related code. | |||||
2019-03-12 | video_core/texture: Add a raw representation of TSCEntry | ReinUsesLisp | 1 | -24/+29 | |
2019-03-11 | renderer_opengl/gl_global_cache: Replace indexing for assignment with insert_or_assign | Lioncash | 2 | -3/+3 | |
The previous code had some minor issues with it, really not a big deal, but amending it is basically 'free', so I figured, "why not?". With the standard container maps, when: map[key] = thing; is done, this can cause potentially undesirable behavior in certain scenarios. In particular, if there's no value associated with the key, then the map constructs a default initialized instance of the value type. In this case, since it's a std::shared_ptr (as a type alias) that is the value type, this will construct a std::shared_pointer, and then assign over it (with objects that are quite large, or actively heap allocate this can be extremely undesirable). We also make the function take the region by value, as we can avoid a copy (and by extension with std::shared_ptr, a copy causes an atomic reference count increment), in certain scenarios when ownership isn't a concern (i.e. when ReserveGlobalRegion is called with an rvalue reference, then no copy at all occurs). So, it's more-or-less a "free" gain without many downsides. | |||||
2019-03-11 | renderer_opengl/gl_global_cache: Append missing override specifiers | Lioncash | 1 | -2/+2 | |
Two of the functions here are overridden functions, so we can append these specifiers to make it explicit. | |||||
2019-03-11 | set_sys: Move constants to anonymous namespace | Zach Hilman | 1 | -1/+1 | |
2019-03-11 | kernel/server_port: Make data members private | Lioncash | 4 | -14/+36 | |
With this, all kernel objects finally have all of their data members behind an interface, making it nicer to reason about interactions with other code (as external code no longer has the freedom to totally alter internals and potentially messing up invariants). | |||||
2019-03-11 | hwopus: Leverage multistream API for decoding regular Opus packets | Lioncash | 1 | -34/+48 | |
After doing a little more reading up on the Opus codec, it turns out that the multistream API that is part of libopus can handle regular packets. Regular packets are just a degenerate case of multistream Opus packets, and all that's necessary is to pass the number of streams as 1 and provide a basic channel mapping, then everything works fine for that case. This allows us to get rid of the need to use both APIs in the future when implementing multistream variants in a follow-up PR, greatly simplifying the code that needs to be written. | |||||
2019-03-11 | gl_rasterizer: Use system instance passed from argument | ReinUsesLisp | 2 | -29/+31 | |
2019-03-11 | set_sys: Use official nintendo version string | Zach Hilman | 4 | -19/+25 | |
2019-03-11 | system_version: Correct sizes on VectorVfsFile construction | Zach Hilman | 1 | -4/+4 | |
2019-03-11 | set_sys: Use correct error codes in GetFirmwareVersion* | Zach Hilman | 1 | -21/+41 | |
2019-03-10 | core/hle/result: Remove now-unnecessary manually defined copy assignment operator | Lioncash | 1 | -5/+0 | |
Previously this was required, as BitField wasn't trivially copyable. BitField has since been made trivially copyable, so now this isn't required anymore. | |||||
2019-03-10 | core/hle/result: Amend error in comment description for ResultCode | Lioncash | 1 | -1/+1 | |
Gets rid of another holdover from Citra, and describes the OS on the Switch instead. | |||||
2019-03-10 | core/hle/result: Remove now-unused constructor for ResultCode | Lioncash | 1 | -10/+0 | |
Now that the final stray ErrorDescription member was relocated, we can finally remove it and its relevant constructor in the ResultCode union. | |||||
2019-03-10 | core/hle/result: Relocate IPC error code to ipc_helpers | Lioncash | 3 | -3/+4 | |
Relocates the error code to where it's most related, similar to how all the other error codes are. Previously we were including a non-generic error in the main result code header. | |||||
2019-03-10 | service/service: Remove unncessary calls to c_str() | Lioncash | 1 | -4/+3 | |
These can just be passed regularly, now that we use fmt instead of our old logging system. While we're at it, make the parameters to MakeFunctionString std::string_views. | |||||
2019-03-10 | set_sys: Implement GetFirmwareVersion(2) for libnx hosversion | Zach Hilman | 6 | -3/+128 | |
Uses the synthesized system archive 9 (SystemVersion) and reports v5.1.0-0.0 | |||||
2019-03-10 | audio_core/cubeb_sink: Convert _MSC_VER ifdefs to _WIN32 | Lioncash | 2 | -4/+4 | |
This behavior also needs to be visible for MinGW builds as well. | |||||
2019-03-09 | clang fix | Hexagon12 | 1 | -1/+2 | |
2019-03-09 | Log 2 new setting values | Hexagon12 | 1 | -0/+2 | |
2019-03-09 | gl_rasterizer: Encapsulate sampler queries into methods | ReinUsesLisp | 3 | -64/+72 | |
2019-03-09 | yuzu_cmd/config: Replace C casts with static_cast | ReinUsesLisp | 1 | -4/+5 | |
2019-03-09 | yuzu_cmd/config: Silent implicit cast warning | ReinUsesLisp | 1 | -1/+1 | |
2019-03-09 | gl_rasterizer: Minor logger changes | ReinUsesLisp | 1 | -19/+13 | |
2019-03-08 | dma_pusher: Store command_list_header by copy | ReinUsesLisp | 1 | -1/+1 | |
Instead of holding a reference that will get invalidated by dma_pushbuffer.pop(), hold it as a copy. This doesn't have any performance cost since CommandListHeader is 8 bytes long. | |||||
2019-03-08 | kernel/hle_ipc: Convert std::shared_ptr IPC header instances to std::optional | Lioncash | 4 | -47/+47 | |
There's no real need to use a shared lifetime here, since we don't actually expose them to anything else. This is also kind of an unnecessary use of the heap given the objects themselves are so small; small enough, in fact that changing over to optionals actually reduces the overall size of the HLERequestContext struct (818 bytes to 808 bytes). | |||||
2019-03-08 | kernel: Make the address arbiter instance per-process | Lioncash | 8 | -28/+35 | |
Now that we have the address arbiter extracted to its own class, we can fix an innaccuracy with the kernel. Said inaccuracy being that there isn't only one address arbiter. Each process instance contains its own AddressArbiter instance in the actual kernel. This fixes that and gets rid of another long-standing issue that could arise when attempting to create more than one process. | |||||
2019-03-08 | kernel/svc: Move address arbiter signaling behind a unified API function | Lioncash | 3 | -22/+26 | |
Similar to how WaitForAddress was isolated to its own function, we can also move the necessary conditional checking into the address arbiter class itself, allowing us to hide the implementation details of it from public use. | |||||
2019-03-08 | kernel/svc: Move address arbiter waiting behind a unified API function | Lioncash | 3 | -19/+24 | |
Rather than let the service call itself work out which function is the proper one to call, we can make that a behavior of the arbiter itself, so we don't need to directly expose those implementation details. | |||||
2019-03-07 | common/bit_field: Make BitField trivially copyable | Lioncash | 1 | -9/+7 | |
This makes the class much more flexible and doesn't make performing copies with classes that contain a bitfield member a pain. Given BitField instances are only intended to be used within unions, the fact the full storage value would be copied isn't a big concern (only sizeof(union_type) would be copied anyways). While we're at it, provide defaulted move constructors for consistency. | |||||
2019-03-07 | video_core/gpu_thread: Remove unimplemented WaitForIdle function prototype | Lioncash | 1 | -3/+0 | |
This function didn't have a definition, so we can remove it to prevent accidentally attempting to use it. | |||||
2019-03-07 | video_core/gpu_thread: Amend constructor initializer list order | Lioncash | 1 | -2/+2 | |
Moves the data members to satisfy the order they're declared as in the constructor initializer list. Silences a -Wreorder warning. | |||||
2019-03-07 | video_core/gpu: Make GPU's destructor virtual | Lioncash | 3 | -3/+3 | |
Because of the recent separation of GPU functionality into sync/async variants, we need to mark the destructor virtual to provide proper destruction behavior, given we use the base class within the System class. Prior to this, it was undefined behavior whether or not the destructor in the derived classes would ever execute. | |||||
2019-03-07 | citra_qt: Settings (configuration) rework | zhupengfei | 2 | -203/+250 | |
2019-03-07 | service/audio/hwopus: Move decoder state to its own class | Lioncash | 1 | -50/+85 | |
Moves the non-multistream specific state to its own class. This will be necessary to support the multistream variants of opus decoding. | |||||
2019-03-07 | service/audio/hwopus: Provide a name for the second word of OpusPacketHeader | Lioncash | 1 | -2/+4 | |
This indicates the entropy coder's final range. | |||||
2019-03-07 | service/audio/hwopus: Move Opus packet header out of the IHardwareOpusDecoderManager | Lioncash | 1 | -17/+17 | |
This will be utilized by more than just that class in the future. This also renames it from OpusHeader to OpusPacketHeader to be more specific about what kind of header it is. | |||||
2019-03-07 | service/audio/hwopus: Enclose internals in an anonymous namespace | Lioncash | 1 | -2/+3 | |
Makes it impossible to violate the ODR, as well as providing a place for future changes. | |||||
2019-03-07 | service/audio/audout_u: Only actually stop the audio stream in StopAudioOut if the stream is playing | Lioncash | 1 | -1/+3 | |
The service itself only does further actions if the stream is playing. If the stream is already stopped, then it just exits successfully. | |||||
2019-03-07 | gpu_thread: Fix deadlock with threading idle state check. | bunnei | 2 | -7/+11 | |
2019-03-07 | gpu_thread: (HACK) Ignore flush on FlushAndInvalidateRegion. | bunnei | 1 | -3/+1 | |
2019-03-07 | gpu: Always flush. | bunnei | 2 | -13/+6 | |
2019-03-07 | gpu: Refactor a/synchronous implementations into their own classes. | bunnei | 8 | -65/+162 | |
2019-03-07 | gpu: Move command processing to another thread. | bunnei | 9 | -15/+358 | |
2019-03-07 | bootmanager: Ensure that we have a context for shader loading. | bunnei | 1 | -4/+6 | |
2019-03-07 | gpu: Refactor command and swap buffers interface for asynch. | bunnei | 5 | -17/+26 | |
2019-03-07 | gpu: Refactor to take RendererBase instead of RasterizerInterface. | bunnei | 3 | -18/+23 | |
2019-03-07 | settings: Add new graphics setting for use_asynchronous_gpu_emulation. | bunnei | 7 | -0/+24 | |
2019-03-07 | core: Set is_powered_on before GPU is initialized. | bunnei | 1 | -1/+3 | |
2019-03-06 | yuzu: add a hotkey to switch between undocked and docked mode | fearlessTobi | 1 | -0/+8 | |
2019-03-06 | hle/service/audio/audout_u: Correct lack of return in failure case of AppendAudioOutBufferImpl() | Lioncash | 1 | -0/+1 | |
Previously we were overwriting the error case with a success code further down (which is definitely not what we should be doing here). | |||||
2019-03-06 | yuzu/debugger/wait_tree: Remove use of global CurrentProcess accessor | Lioncash | 2 | -5/+6 | |
We already have the thread instance that was created under the current process, so we can just pass the handle table of it along to retrieve the owner of the mutex. | |||||
2019-03-06 | video_core/engines: Remove unnecessary includes | Lioncash | 10 | -11/+11 | |
Removes a few unnecessary dependencies on core-related machinery, such as the core.h and memory.h, which reduces the amount of rebuilding necessary if those files change. This also uncovered some indirect dependencies within other source files. This also fixes those. | |||||
2019-03-06 | kernel/server_session: Make data members private | Lioncash | 5 | -32/+73 | |
Makes it much nicer to locally reason about server session behavior, as part of its functionality isn't placed around other classes. | |||||
2019-03-06 | kernel/client_session: Make data members private | Lioncash | 1 | -4/+5 | |
These can be made private, as they aren't accessed in contexts that require them to be public. | |||||
2019-03-05 | hle/service/audio: Extract audio error codes to a header | Lioncash | 4 | -10/+21 | |
Places all error codes in an easily includable header. This also corrects the unsupported error code (I accidentally used the hex value when I meant to use the decimal one). | |||||
2019-03-05 | kernel/address_arbiter: Pass in system instance to constructor | Lioncash | 6 | -26/+45 | |
Allows getting rid of reliance on the global accessor functions and instead operating on the provided system instance. | |||||
2019-03-05 | kernel/address_arbiter: Minor tidying up | Lioncash | 1 | -18/+18 | |
- Invert conditions into guard clases where applicable. - Mark std::vector parameter of WakeThreads as const | |||||
2019-03-05 | kernel/address_arbiter: Convert the address arbiter into a class | Lioncash | 5 | -82/+135 | |
Places all of the functions for address arbiter operation into a class. This will be necessary for future deglobalizing efforts related to both the memory and system itself. | |||||
2019-03-05 | video_core/surface: Remove obsolete TODO in PixelFormatFromRenderTargetFormat() | Lioncash | 1 | -2/+0 | |
This isn't needed anymore, according to Hexagon | |||||
2019-03-05 | vm_manager: Remove cheat-specific ranges from VMManager | Zach Hilman | 10 | -77/+56 | |
2019-03-05 | kernel/thread: Remove obsolete TODO in Create() | Lioncash | 1 | -2/+0 | |
This is a TODO carried over from Citra that doesn't apply here. | |||||
2019-03-05 | core/hle/ipc: Remove unnecessary includes | Lioncash | 6 | -8/+12 | |
Removes a few inclusion dependencies from the headers or replaces existing ones with ones that don't indirectly include the required headers. This allows removing an inclusion of core/memory.h, meaning that if the memory header is ever changed in the future, it won't result in rebuilding the entirety of the HLE services (as the IPC headers are used quite ubiquitously throughout the HLE service implementations). | |||||
2019-03-05 | core: Add support for registering and controlling ownership of CheatEngine | Zach Hilman | 2 | -0/+13 | |
2019-03-05 | cheat_engine: Add parser and interpreter for game cheats | Zach Hilman | 3 | -0/+715 | |
2019-03-05 | loader/nso: Set main code region in VMManager | Zach Hilman | 3 | -2/+21 | |
For rom directories (and by extension, XCI/NSP/NAX/NCA) this is for the NSO with name 'main', for regular NSOs, this is the NSO. | |||||
2019-03-05 | vm_manager: Add support for storing and getting main code region | Zach Hilman | 2 | -0/+28 | |
Used as root for one region of cheats, set by loader | |||||
2019-03-05 | patch_manager: Display cheats in game list add-ons | Zach Hilman | 1 | -0/+2 | |
2019-03-05 | patch_manager: Add support for loading cheats lists | Zach Hilman | 2 | -0/+56 | |
Uses load/<title_id>/<mod_name>/cheats as root dir, file name is all upper or lower hex first 8 bytes build ID. | |||||
2019-03-05 | controllers/npad: Add accessor for current press state | Zach Hilman | 1 | -0/+1 | |
Allows frontend/features to access pressed buttons conveniently as possible | |||||
2019-03-05 | web_browser: Add shortcut to Enter key to exit applet | Zach Hilman | 2 | -0/+7 | |
Addresses issues where a user in fullscreen could not exit some web applets without leaving fullscreen. | |||||
2019-03-04 | vm_manager: Use range helpers in HeapAlloc() and HeapFree() | Lioncash | 1 | -4/+2 | |
Significantly tidies up two guard conditionals. | |||||
2019-03-04 | vm_manager: Provide address range checking functions for other memory regions | Lioncash | 2 | -4/+35 | |
Makes the interface uniform when it comes to checking various memory regions. | |||||
2019-03-04 | kernel/scheduler: Pass in system instance in constructor | Lioncash | 5 | -17/+23 | |
Avoids directly relying on the global system instance and instead makes an arbitrary system instance an explicit dependency on construction. This also allows removing dependencies on some global accessor functions as well. | |||||
2019-03-04 | kernel/shared_memory: Get rid of the use of global accessor functions within Create() | Lioncash | 1 | -3/+2 | |
Given we already pass in a reference to the kernel that the shared memory instance is created under, we can just use that to check the current process, rather than using the global accessor functions. This allows removing direct dependency on the system instance entirely. | |||||
2019-03-04 | svc: Migrate address range checking functions to VMManager | Lioncash | 3 | -23/+30 | |
Provides a bit of a more proper interface for these functions. | |||||
2019-03-04 | core/core: Remove the global telemetry accessor function | Lioncash | 1 | -4/+0 | |
With all usages converted off of it, this function can be removed. | |||||
2019-03-04 | yuzu: Remove usage of the global telemetry accessor | Lioncash | 2 | -3/+3 | |
In these cases the system object is nearby, and in the other, the long-form of accessing the telemetry instance is already used, so we can get rid of the use of the global accessor. | |||||
2019-03-04 | yuzu-cmd/yuzu: Replace direct usage of the global system telemetry accessor in main() | Lioncash | 1 | -1/+1 | |
We already have the system instance around, so we can use that instead of the accessor. | |||||
2019-03-04 | core/core: Replace direct usage of the global system telemetry accessor from Shutdown() | Lioncash | 1 | -7/+7 | |
The telemetry instance is actually a member of the class itself, so we can access it directly instead of going through the global accessor. | |||||
2019-03-04 | video_core/renderer_opengl: Replace direct usage of global system object accessors | Lioncash | 2 | -11/+17 | |
We already pass a reference to the system object to the constructor of the renderer, so we can just use that instead of using the global accessor functions. | |||||
2019-03-04 | maxwell_to_vk: Initial implementation | ReinUsesLisp | 4 | -3/+553 | |
2019-03-02 | web_service: Remove unnecessary inclusions | Lioncash | 2 | -3/+0 | |
Reduces the potential amount of rebuilding necessary if any headers change. In particular, we were including a header from the core library when we don't even link the core library to the web_service library, so this also gets rid of an indirect dependency. | |||||
2019-03-02 | logging/backend: Make time_origin a class variable instead of a local static | Lioncash | 1 | -2/+1 | |
Moves local global state into the Impl class itself and initializes it at the creation of the instance instead of in the function. This makes it nicer for weakly-ordered architectures, given the CreateEntry() class won't need to have atomic loads executed for each individual call to the CreateEntry class. | |||||
2019-03-02 | logging/backend: Move CreateEntry into the Impl class | Lioncash | 2 | -29/+26 | |
This function is only ever used within this source file and makes it easier to remove static state in the following change. | |||||
2019-03-02 | fixup! Joystick: Allow for background events; Add deadzone to SDLAnalog | B3n30 | 1 | -6/+17 | |
2019-03-02 | input/sdl: lock map mutex after SDL call | Weiyi Wang | 1 | -11/+17 | |
Any SDL invocation can call the even callback on the same thread, which can call GetSDLJoystickBySDLID and eventually cause double lock on joystick_map_mutex. To avoid this, lock guard should be placed as closer as possible to the object accessing code, so that any SDL invocation is with the mutex unlocked | |||||
2019-03-02 | Input: Remove global variables from SDL Input | James Rowe | 9 | -809/+206 | |
Changes the interface as well to remove any unique methods that frontends needed to call such as StartJoystickEventHandler by conditionally starting the polling thread only if the frontend hasn't started it already. Additionally, moves all global state into a single SDLState class in order to guarantee that the destructors are called in the proper order | |||||
2019-03-02 | Input: Copy current SDL.h/cpp files to impl | James Rowe | 2 | -0/+680 | |
This should make reviewing much easier as you can then see what changed happened between the old file and the new one | |||||
2019-03-02 | citra_qt/main: make SPEED_LIMIT_STEP static constexpr | fearlessTobi | 1 | -1/+4 | |
MSVC does not seem to like using constexpr values in a lambda that were declared outside of it. Previously on MSVC build the hotkeys to inc-/decrease the speed limit were not working correctly because in the lambda the SPEED_LIMIT_STEP had garbage values. After googling around a bit I found: https://github.com/codeplaysoftware/computecpp-sdk/issues/95 which seems to be a similar issue. Trying the suggested fix to make the variable static constexpr also fixes the bug here. | |||||
2019-03-02 | Memory: don't lock hle mutex in memory read/write | Weiyi Wang | 1 | -6/+0 | |
The comment already invalidates itself: neither MMIO nor rasterizer cache belongsHLE kernel state. This mutex has a too large scope if MMIO or cache is included, which is prone to dead lock when multiple thread acquires these resource at the same time. If necessary, each MMIO component or rasterizer should have their own lock. | |||||
2019-03-02 | vk_buffer_cache: Fix clang-format | ReinUsesLisp | 1 | -3/+3 | |
2019-03-02 | fuck git for ruining my day, I will learn but I will not forgive | bunnei | 1 | -1/+1 | |
2019-03-01 | vk_buffer_cache: Implement a buffer cache | ReinUsesLisp | 3 | -0/+205 | |
This buffer cache is just like OpenGL's buffer cache with some minor style changes. It uses VKStreamBuffer. | |||||
2019-03-01 | service/audio/audren_u: Implement OpenAudioRendererAuto | Lioncash | 2 | -7/+20 | |
This currently has the same behavior as the regular OpenAudioRenderer API function, so we can just move the code within OpenAudioRenderer to an internal function that both service functions call. | |||||
2019-03-01 | service/audio: Provide an implementation of ExecuteAudioRendererRendering | Lioncash | 1 | -1/+12 | |
This service function appears to do nothing noteworthy on the switch. All it does at the moment is either return an error code or abort the system. Given we obviously don't want to kill the system, we just opt for always returning the error code. | |||||
2019-02-28 | gl_rasterizer: Remove texture unbinding after dispatching a draw call | ReinUsesLisp | 1 | -12/+0 | |
Unbinding was required when OpenGL delete operations didn't unbind a resource if it was bound. This is no longer needed and can be removed. | |||||
2019-02-28 | gl_state: Fixup multibind bug | ReinUsesLisp | 1 | -2/+2 | |
2019-02-28 | Devirtualize Register/Unregister and use a wrapper instead. | Fernando Sahmkow | 3 | -12/+8 | |
2019-02-28 | Corrections and redesign. | Fernando Sahmkow | 2 | -51/+51 | |
2019-02-28 | Fix linux compile error. | Fernando Sahmkow | 1 | -1/+1 | |
2019-02-28 | Remove NotifyFrameBuffer as we are doing a texception pass every drawcall. | Fernando Sahmkow | 2 | -25/+0 | |
2019-02-28 | Remove certain optimizations that caused texception to fail in certain scenarios. | Fernando Sahmkow | 3 | -24/+1 | |
2019-02-28 | Bug fixes and formatting | Fernando Sahmkow | 2 | -3/+4 | |
2019-02-28 | rasterizer_cache_gl: Implement Texception Pass | Fernando Sahmkow | 3 | -0/+51 | |
2019-02-28 | rasterizer_cache_gl: Implement Partial Reinterpretation of Surfaces. | Fernando Sahmkow | 2 | -0/+100 | |
2019-02-28 | rasterizer_cache: mark reinterpreted surfaces and add ability to reload marked surfaces on next use. | Fernando Sahmkow | 2 | -0/+78 | |
2019-02-28 | rasterizer_cache_gl: Notify on framebuffer change | Fernando Sahmkow | 2 | -4/+23 | |
2019-02-28 | rasterizer_cache: Expose FlushObject to Child classes and allow redefining of Register and Unregister | Fernando Sahmkow | 1 | -11/+11 | |
2019-02-27 | Speed up memory page mapping (#2141) | Annomatg | 1 | -6/+11 | |
- Memory::MapPages total samplecount was reduced from 4.6% to 1.06%. - From main menu into the game from 1.03% to 0.35% | |||||
2019-02-27 | audio_core/cubeb_sink: Ensure COM is initialized on Windows prior to calling cubeb_init | Lioncash | 2 | -0/+19 | |
cubeb now requires that COM explicitly be initialized on the thread prior to calling cubeb_init. | |||||
2019-02-27 | gl_rasterizer_cache: Create texture views for array discrepancies | ReinUsesLisp | 3 | -32/+42 | |
When a texture is sampled in a shader with a different array mode than the cached state, create a texture view and bind that to the shader instead. | |||||
2019-02-27 | service/hid: Amend forward declaration of ServiceManager | Lioncash | 1 | -1/+1 | |
The SM namespace is within the Service namespace, so this was forward declaring a type that didn't exist. | |||||
2019-02-27 | yuzu/compatdb: Remove unused lambda capture | Lioncash | 1 | -1/+1 | |
Silences a compiler warning with clang. | |||||
2019-02-27 | vk_memory_manager: Reorder constructor initializer list in terms of member declaration order | Lioncash | 1 | -1/+1 | |
Reorders members in the order that they would actually be initialized in. Silences a -Wreorder warning. | |||||
2019-02-27 | gl_rasterizer: Reorder constructor initializer list in terms of member declaration order | Lioncash | 1 | -2/+2 | |
Orders the members in the order they would actually be initialized in. Silences a -Wreorder warning. | |||||
2019-02-27 | gl_shader_disk_cache: Remove #pragma once from cpp file | Lioncash | 1 | -2/+0 | |
This is only necessary in headers. Silences a warning with clang. | |||||
2019-02-27 | core/frontend/emu_window: Make ClipToTouchScreen a const member function | Lioncash | 2 | -2/+2 | |
This member function doesn't modify instance state, so it can have the const specifier applied to it. | |||||
2019-02-27 | audio_core/audio_renderer: Name previously unknown parameters of AudioRendererParameter | Lioncash | 2 | -19/+21 | |
Provides names for previously unknown entries (aside from the two u8 that appear to be padding bytes, and a single word that also appears to be reserved or padding). This will be useful in subsequent changes when unstubbing behavior related to the audio renderer services. | |||||
2019-02-27 | common/math_util: Move contents into the Common namespace | Lioncash | 18 | -40/+40 | |
These types are within the common library, so they should be within the Common namespace. | |||||
2019-02-27 | common/vector_math: Move Vec[x] types into the Common namespace | Lioncash | 6 | -38/+38 | |
These types are within the common library, so they should be using the Common namespace. | |||||
2019-02-27 | common/quaternion: Move Quaternion into the Common namespace | Lioncash | 2 | -6/+6 | |
Quaternion is within the common library, so it should be using the Common namespace. | |||||
2019-02-27 | service/vi: Unstub GetDisplayService | Lioncash | 5 | -11/+49 | |
This function is also supposed to check its given policy type with the permission of the service itself. This implements the necessary machinery to unstub these functions. Policy::User seems to just be basic access (which is probably why vi:u is restricted to that policy), while the other policy seems to be for extended abilities regarding which displays can be managed and queried, so this is assumed to be for a background compositor (which I've named, appropriately, Policy::Compositor). | |||||
2019-02-27 | core/ipc_helper: Allow popping all signed value types with RequestParser | Lioncash | 1 | -0/+15 | |
There's no real reason this shouldn't be allowed, given some values sent via a request can be signed. This also makes it less annoying to work with popping enum values, given an enum class with no type specifier will work out of the box now. It's also kind of an oversight to allow popping s64 values, but nothing else. | |||||
2019-02-27 | gl_rasterizer_cache: Move format conversion to its own file | ReinUsesLisp | 7 | -136/+175 | |
2019-02-27 | decoders: Minor style changes | ReinUsesLisp | 2 | -14/+8 | |
2019-02-26 | service/vi: Remove use of a module class | Lioncash | 8 | -46/+99 | |
This didn't really provide much benefit here, especially since the subsequent change requires that the behavior for each service's GetDisplayService differs in a minor detail. This also arguably makes the services nicer to read, since it gets rid of an indirection in the class hierarchy. | |||||
2019-02-26 | renderer_opengl: Update pixel format tracking | ReinUsesLisp | 1 | -0/+1 | |
2019-02-26 | maxwell_3d: Use std::bitset to manage dirty flags | ReinUsesLisp | 4 | -52/+51 | |
2019-02-26 | vk_stream_buffer: Remove copy code path | ReinUsesLisp | 2 | -53/+18 | |
2019-02-26 | shader/decode: Remove extras from MetaTexture | ReinUsesLisp | 4 | -40/+65 | |
2019-02-26 | shader/decode: Split memory and texture instructions decoding | ReinUsesLisp | 7 | -501/+538 | |
2019-02-25 | kernel/handle_table: Make local variables as const where applicable | Lioncash | 1 | -4/+5 | |
Makes immutable state explicit. | |||||
2019-02-25 | kernel/handle_table: Allow process capabilities to limit the handle table size | Lioncash | 6 | -10/+54 | |
The kernel allows restricting the total size of the handle table through the process capability descriptors. Until now, this functionality wasn't hooked up. With this, the process handle tables become properly restricted. In the case of metadata-less executables, the handle table will assume the maximum size is requested, preserving the behavior that existed before these changes. | |||||
2019-02-25 | kernel/handle-table: In-class initialize data members | Lioncash | 2 | -3/+2 | |
Directly initializes members where applicable. | |||||
2019-02-25 | kernel/handle_table: Resolve truncation warnings | Lioncash | 1 | -2/+2 | |
Avoids implicit truncation warnings from u32 -> u16 (the truncation is desirable behavior here). | |||||
2019-02-25 | audio_core/cubeb_sink: Initialize CubebSinkStream's last_frame data member | Lioncash | 1 | -1/+1 | |
Ensures that all member variables are initialized in a deterministic manner across the board. | |||||
2019-02-25 | audio_core/cubeb_sink: Add override specifier to destructor | Lioncash | 1 | -1/+1 | |
CubebSinkStream inherits from a base class with a virtual destructor, so override can be appended to CubebSinkStream's destructor. | |||||
2019-02-25 | audio_core/cubeb_sink: Resolve variable shadowing warnings in SamplesInQueue | Lioncash | 1 | -2/+2 | |
The name of the parameter was shadowing the member variable of the same name. Instead, alter the name of the parameter to prevent said shadowing. | |||||
2019-02-25 | audio_core/codec: Resolve truncation warnings within DecodeADPCM | Lioncash | 1 | -2/+2 | |
The assignments here were performing an implicit truncation from int to s16. Make it explicit that this is desired behavior. | |||||
2019-02-25 | shader/track: Resolve variable shadowing warnings | Lioncash | 1 | -5/+5 | |
2019-02-25 | service/vi: Update IManagerDisplayService's function table | Lioncash | 1 | -0/+1 | |
Amends it to add the 7.0.0+ CreateStrayLayer function. | |||||
2019-02-25 | file_sys/vfs_vector: Fix ignored offset on Write | Frederic L | 1 | -1/+1 | |
2019-02-24 | Remove GCC version checks | tgsm | 1 | -3/+3 | |
Citra can't be compiled using GCC <7 because of required C++17 support, so these version checks don't need to exist anymore. | |||||
2019-02-24 | vk_stream_buffer: Implement a stream buffer | ReinUsesLisp | 3 | -1/+200 | |
This manages two kinds of streaming buffers: one for unified memory models and one for dedicated GPUs. The first one skips the copy from the staging buffer to the real buffer, since it creates an unified buffer. This implementation waits for all fences to finish their operation before "invalidating". This is suboptimal since it should allocate another buffer or start searching from the beginning. There is room for improvement here. This could also handle AMD's "pinned" memory (a heap with 256 MiB) that seems to be designed for buffer streaming. | |||||
2019-02-24 | vk_resource_manager: Minor VKFenceWatch changes | ReinUsesLisp | 2 | -7/+7 | |
2019-02-24 | vk_memory_manager: Fixup commit interval allocation | ReinUsesLisp | 1 | -2/+1 | |
VKMemoryCommitImpl was using as the end of its interval "begin + end". That ended up wasting memory. | |||||
2019-02-24 | gl_rasterizer_cache: Fixup parameter order in layered swizzle | ReinUsesLisp | 1 | -1/+1 | |
2019-02-22 | vk_scheduler: Implement a scheduler | ReinUsesLisp | 3 | -1/+132 | |
The scheduler abstracts command buffer and fence management with an interface that's able to do OpenGL-like operations on Vulkan command buffers. It returns by value a command buffer and fence that have to be used for subsequent operations until Flush or Finish is executed, after that the current execution context (the pair of command buffers and fences) gets invalidated a new one must be fetched. Thankfully validation layers will quickly detect if this is skipped throwing an error due to modifications to a sent command buffer. | |||||
2019-02-22 | service/nvflinger: Store BufferQueue instances as regular data members | Lioncash | 7 | -36/+39 | |
The NVFlinger service is already passed into services that need to guarantee its lifetime, so the BufferQueue instances will already live as long as they're needed. Making them std::shared_ptr instances in this case is unnecessary. | |||||
2019-02-21 | service/vi/vi_layer: Convert Layer struct into a class | Lioncash | 6 | -10/+43 | |
Like the previous changes made to the Display struct, this prepares the Layer struct for changes to its interface. Given Layer will be given more invariants in the future, we convert it into a class to better signify that. | |||||
2019-02-21 | service/nvflinger: Move display specifics over to vi_display | Lioncash | 4 | -35/+141 | |
With the display and layer structures relocated to the vi service, we can begin giving these a proper interface before beginning to properly support the display types. This converts the display struct into a class and provides it with the necessary functions to preserve behavior within the NVFlinger class. | |||||
2019-02-21 | Fixes Unicode Key File Directories (#2120) | Jungy | 1 | -1/+2 | |
* Fixes Unicode Key File Directories Adds code so that when loading a file it converts to UTF16 first, to ensure the files can be opened. Code borrowed from FileUtil::Exists. * Update src/core/crypto/key_manager.cpp Co-Authored-By: Jungorend <Jungorend@users.noreply.github.com> * Update src/core/crypto/key_manager.cpp Co-Authored-By: Jungorend <Jungorend@users.noreply.github.com> * Using FileUtil instead to be cleaner. * Update src/core/crypto/key_manager.cpp Co-Authored-By: Jungorend <Jungorend@users.noreply.github.com> | |||||
2019-02-20 | service/nvflinger: Relocate definitions of Layer and Display to the vi service | Lioncash | 7 | -57/+123 | |
These are more closely related to the vi service as opposed to the intermediary nvflinger. This also places them in their relevant subfolder, as future changes to these will likely result in subclassing to represent various displays and services, as they're done within the service itself on hardware. The reasoning for prefixing the display and layer source files is to avoid potential clashing if two files with the same name are compiled (e.g. if 'display.cpp/.h' or 'layer.cpp/.h' is added to another service at any point), which MSVC will actually warn against. This prevents that case from occurring. This also presently coverts the std::array introduced within f45c25aabacc70861723a7ca1096a677bd987487 back to a std::vector to allow the forward declaration of the Display type. Forward declaring a type within a std::vector is allowed since the introduction of N4510 (http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/n4510.html) by Zhihao Yuan. | |||||
2019-02-19 | video_core/dma_pusher: Simplyfy Step() logic. | Markus Wick | 2 | -81/+77 | |
As fetching command list headers and and the list of command headers is a fixed 1:1 relation now, they can be implemented within a single call. This cleans up the Step() logic quite a bit. | |||||
2019-02-19 | video_core/dma_pusher: The full list of headers at once. | Markus Wick | 2 | -48/+58 | |
Fetching every u32 from memory leads to a big overhead. So let's fetch all of them as a block if possible. This reduces the Memory::* calls by the dma_pusher by a factor of 10. | |||||
2019-02-19 | vk_memory_manager: Implement memory manager | ReinUsesLisp | 3 | -0/+342 | |
A memory manager object handles the memory allocations for a device. It allocates chunks of Vulkan memory objects and then suballocates. | |||||
2019-02-16 | Corrections, documenting and fixes. | Fernando Sahmkow | 4 | -13/+14 | |
2019-02-16 | audio_core/buffer: Make const and non-const getter for samples consistent | Lioncash | 2 | -2/+2 | |
This way proper const/non-const selection can occur. | |||||
2019-02-16 | address_arbiter: Use nested namespaces where applicable | Lioncash | 2 | -8/+4 | |
A fairly trivial change. Other sections of the codebase use nested namespaces instead of separate namespaces here. This one must have just been overlooked. | |||||
2019-02-16 | video_core: Remove usages of System::GetInstance() within the engines | Lioncash | 9 | -23/+49 | |
Avoids the use of the global accessor in favor of explicitly making the system a dependency within the interface. | |||||
2019-02-16 | Use u128 on Clock Cycles calculation. | Fernando Sahmkow | 5 | -27/+32 | |
2019-02-16 | Implement 128 bits Unsigned Integer Multiplication and Division. | Fernando Sahmkow | 3 | -0/+50 | |
2019-02-16 | Correct CNTPCT to use Clock Cycles instead of Cpu Cycles. | Fernando Sahmkow | 3 | -2/+13 | |
2019-02-16 | core_timing: Convert core timing into a class | Lioncash | 53 | -412/+548 | |
Gets rid of the largest set of mutable global state within the core. This also paves a way for eliminating usages of GetInstance() on the System class as a follow-up. Note that no behavioral changes have been made, and this simply extracts the functionality into a class. This also has the benefit of making dependencies on the core timing functionality explicit within the relevant interfaces. | |||||
2019-02-15 | Adressed review comments | B3n30 | 2 | -7/+9 | |
2019-02-15 | threadsafe_queue: Add WaitIfEmpty and use it in logging | B3n30 | 3 | -14/+26 | |
2019-02-15 | renderer_opengl: respect the sRGB colorspace for the screenshot feature | fearlessTobi | 1 | -1/+2 | |
Previously, we were completely ignoring for screenshots whether the game uses RGB or sRGB. This resulted in screenshot colors that looked off for some titles. | |||||
2019-02-15 | gl_state: Synchronize gl_state even when state is disabled | ReinUsesLisp | 1 | -83/+61 | |
There are some potential edge cases where gl_state may fail to track the state if a related state changes while the toggle is disabled or it didn't change. This addresses that. | |||||
2019-02-14 | vk_resource_manager: Implement a command buffer pool with VKFencedPool | ReinUsesLisp | 2 | -1/+59 | |
2019-02-14 | vk_resource_manager: Add VKFencedPool interface | ReinUsesLisp | 2 | -0/+83 | |
Handles a pool of resources protected by fences. Manages resource overflow allocating more resources. This class is intended to be used through inheritance. | |||||
2019-02-14 | vk_resource_manager: Implement VKResourceManager and fence allocator | ReinUsesLisp | 2 | -0/+85 | |
CommitFence iterates a pool of fences until one is found. If all fences are being used at the same time, allocate more. | |||||
2019-02-14 | vk_resource_manager: Implement VKFenceWatch | ReinUsesLisp | 2 | -0/+68 | |
A fence watch is used to keep track of the usage of a fence and protect a resource or set of resources without having to inherit from their handlers. | |||||
2019-02-14 | vk_resource_manager: Implement VKFence | ReinUsesLisp | 2 | -0/+131 | |
Fences take ownership of objects, protecting them from GPU-side or driver-side concurrent access. They must be commited from the resource manager. Their usage flow is: commit the fence from the resource manager, protect resources with it and use them, send the fence to an execution queue and Wait for it if needed and then call Release. Used resources will automatically be signaled when they are free to be reused. | |||||
2019-02-14 | vk_resource_manager: Add VKResource interface | ReinUsesLisp | 3 | -1/+43 | |
VKResource is an interface that gets signaled by a fence when it is free to be reused. | |||||
2019-02-14 | shader_decompiler: Improve Accuracy of Attribute Interpolation. | Fernando Sahmkow | 6 | -38/+74 | |
2019-02-13 | rasterizer_cache_gl: Only do fast layered copy on the same format. As | Fernando Sahmkow | 1 | -1/+5 | |
glCopyImageSubData does not support different formats. | |||||
2019-02-13 | Make bitfield assignment operator public | fearlessTobi | 1 | -6/+2 | |
This change needs to be made to get the code compiling again. It was suggested after a conversation with Lioncash. The conversation can be seen here: https://user-images.githubusercontent.com/20753089/45064197-b6107800-b0b2-11e8-9db8-f696299fb86a.PNG | |||||
2019-02-13 | threadsafe_queue: Use std::size_t for representing size | Lioncash | 1 | -7/+6 | |
Makes it consistent with the regular standard containers in terms of size representation. This also gets rid of dependence on our own type aliases, removing the need for an include. | |||||
2019-02-13 | threadsafe_queue: Remove NeedSize template parameter | Lioncash | 2 | -15/+13 | |
The necessity of this parameter is dubious at best, and in 2019 probably offers completely negligible savings as opposed to just leaving this enabled. This removes it and simplifies the overall interface. | |||||
2019-02-13 | core_timing: Make EmptyTimedCallback a local variable | Lioncash | 1 | -3/+3 | |
Given this is only used in one place, it can be moved closest to its usage site. | |||||
2019-02-13 | vk_device: Abstract device handling into a class | ReinUsesLisp | 3 | -1/+351 | |
VKDevice contains all the data required to manage and initialize a physical device. Its intention is to be passed across Vulkan objects to query device-specific data (for example the logical device and the dispatch loader). | |||||
2019-02-13 | renderer_opengl: Remove reference to global system instance | Lioncash | 1 | -3/+3 | |
We already store a reference to the system instance that the renderer is created with, so we don't need to refer to the system instance via Core::System::GetInstance() | |||||
2019-02-12 | gl_rasterizer_cache: Remove unnecessary newline | Lioncash | 1 | -2/+0 | |
2019-02-12 | gl_rasterizer_cache: Get rid of variable shadowing | Lioncash | 1 | -6/+14 | |
Avoids shadowing the members of the struct itself, which results in a -Wshadow warning. | |||||
2019-02-12 | renderer_vulkan: Add declarations file | ReinUsesLisp | 2 | -0/+52 | |
This file is intended to be included instead of vulkan/vulkan.hpp. It includes declarations of unique handlers using a dynamic dispatcher instead of a static one (which would require linking to a Vulkan library). | |||||
2019-02-12 | logging: Add Vulkan backend logging class type | ReinUsesLisp | 2 | -0/+2 | |
2019-02-12 | gl_shader_decompiler: Re-implement TLDS lod | ReinUsesLisp | 2 | -22/+35 | |
2019-02-12 | core_timing: Rename CoreTiming namespace to Core::Timing | Lioncash | 35 | -174/+172 | |
Places all of the timing-related functionality under the existing Core namespace to keep things consistent, rather than having the timing utilities sitting in its own completely separate namespace. | |||||
2019-02-11 | Corrected F2I None mode to RoundEven. | Fernando Sahmkow | 2 | -4/+4 | |
2019-02-11 | Fix incorrect value for CC bit in IADD | Fernando Sahmkow | 1 | -2/+2 | |
2019-02-10 | kepler_compute: Fixup assert and rename engines | ReinUsesLisp | 6 | -52/+59 | |
When I originally added the compute assert I used the wrong documentation. This addresses that. The dispatch register was tested with homebrew against hardware and is triggered by some games (e.g. Super Mario Odyssey). What exactly is missing to get a valid program bound by this engine requires more investigation. | |||||
2019-02-09 | Implement BGRA8 framebuffer format | greggameplayer | 3 | -0/+4 | |
2019-02-09 | Implement linear textures (#2089) | Fernando Sahmkow | 2 | -5/+39 | |
2019-02-08 | gl_rasterizer_cache: Fixup texture view parameters | ReinUsesLisp | 1 | -2/+2 | |
These parameters were declared as constants and passed to glTextureView but then they were removed on a rabase. This addresses that mistake. | |||||
2019-02-08 | nvdisp_disp0: change drawing message log level from Warning to Trace | Tobias | 1 | -3/+3 | |
This is a leftover from the early yuzu days. We shouldn't log every time when we are drawing by default, so let's change the log level to Trace. | |||||
2019-02-08 | Use QString instead of std::string where applicable | unknown | 1 | -17/+11 | |
2019-02-08 | Use constexpr char array instead of string where applicable | Mat M | 1 | -1/+1 | |
Co-Authored-By: FreddyFunk <frederic.laing.development@gmail.com> | |||||
2019-02-08 | frontend: Open transferable shader cache for a selected game in the gamelist | unknown | 4 | -0/+50 | |
2019-02-07 | shader_ir: Remove F4 prefix to texture operations | ReinUsesLisp | 3 | -26/+25 | |
This was originally included because texture operations returned a vec4. These operations now return a single float and the F4 prefix doesn't mean anything. | |||||
2019-02-07 | shader_ir: Clean texture management code | ReinUsesLisp | 3 | -133/+104 | |
Previous code relied on GLSL parameter order (something that's always ill-formed on an IR design). This approach passes spatial coordiantes through operation nodes and array and depth compare values in the the texture metadata. It still contains an "extra" vector containing generic nodes for bias and component index (for example) which is still a bit ill-formed but it should be better than the previous approach. | |||||
2019-02-07 | gl_rasterizer_cache: Mark surface copy destinations as modified. | bunnei | 2 | -4/+18 | |
2019-02-07 | gl_rasterizer: Implement a more accurate fermi 2D copy. | bunnei | 7 | -68/+188 | |
- This is a blit, use the blit registers. | |||||
2019-02-07 | cmake: Fix title bar issue | ReinUsesLisp | 1 | -1/+14 | |
2019-02-07 | gl_shader_disk_cache: Check LZ4 size limit | Frederic L | 1 | -0/+4 | |
Co-Authored-By: ReinUsesLisp <reinuseslisp@airmail.cc> | |||||
2019-02-07 | gl_shader_disk_cache: Consider compressed size zero as an error | Frederic L | 1 | -2/+2 | |
Co-Authored-By: ReinUsesLisp <reinuseslisp@airmail.cc> | |||||
2019-02-07 | cmake: Use CMAKE_COMMAND instead of "cmake" | Frederic L | 1 | -1/+1 | |
Co-Authored-By: ReinUsesLisp <reinuseslisp@airmail.cc> | |||||
2019-02-07 | gl_shader_disk_cache: Use unordered containers | ReinUsesLisp | 4 | -56/+64 | |
2019-02-07 | gl_shader_cache: Fixup GLSL unique identifiers | ReinUsesLisp | 2 | -3/+3 | |
2019-02-07 | loading_screen: Unchunk progress bar | ReinUsesLisp | 1 | -1/+3 | |
2019-02-07 | gl_shader_cache: Link loading screen with disk shader cache load | ReinUsesLisp | 10 | -12/+62 | |
2019-02-07 | gl_shader_cache: Set GL_PROGRAM_SEPARABLE to dumped shaders | ReinUsesLisp | 1 | -0/+1 | |
i965 (and probably all mesa drivers) require GL_PROGRAM_SEPARABLE when using glProgramBinary. This is probably required by the standard but it's ignored by permisive proprietary drivers. | |||||
2019-02-07 | gl_shader_disk_cache: Pass core system as argument and guard against games without title ids | ReinUsesLisp | 11 | -18/+58 | |
2019-02-07 | gl_shader_disk_cache: Guard reads and writes against failure | ReinUsesLisp | 2 | -216/+339 | |
2019-02-07 | gl_shader_disk_cache: Address miscellaneous feedback | ReinUsesLisp | 5 | -43/+57 | |
2019-02-07 | gl_shader_disk_cache: Pass return values returning instead of by parameters | ReinUsesLisp | 3 | -39/+37 | |
2019-02-07 | gl_shader_disk_cache: Compress program binaries using LZ4 | ReinUsesLisp | 1 | -7/+28 | |
2019-02-07 | gl_shader_disk_cache: Compress GLSL code using LZ4 | ReinUsesLisp | 2 | -6/+57 | |
2019-02-07 | gl_shader_disk_cache: Save GLSL and entries into the precompiled file | ReinUsesLisp | 9 | -135/+234 | |
2019-02-07 | settings: Hide shader cache behind a setting | ReinUsesLisp | 8 | -0/+42 | |
2019-02-07 | gl_shader_disk_cache: Invalidate shader cache changes with CMake hash | ReinUsesLisp | 4 | -46/+72 | |
2019-02-07 | gl_shader_cache: Refactor to support disk shader cache | ReinUsesLisp | 2 | -121/+388 | |
2019-02-07 | gl_shader_disk_cache: Add transferable cache invalidation | ReinUsesLisp | 2 | -0/+8 | |
2019-02-07 | gl_shader_disk_cache: Add precompiled load | ReinUsesLisp | 2 | -0/+45 | |
2019-02-07 | gl_shader_disk_cache: Add precompiled save | ReinUsesLisp | 2 | -0/+57 | |
2019-02-07 | gl_shader_disk_cache: Add transferable load | ReinUsesLisp | 2 | -0/+56 | |
2019-02-07 | gl_shader_disk_cache: Add transferable stores | ReinUsesLisp | 2 | -0/+194 | |
2019-02-07 | gl_shader_disk_cache: Add ShaderDiskCacheOpenGL class and helpers | ReinUsesLisp | 2 | -0/+76 | |
2019-02-07 | gl_shader_disk_cache: Add file and move BaseBindings declaration | ReinUsesLisp | 4 | -10/+58 | |
2019-02-07 | gl_shader_decompiler: Remove name entries | ReinUsesLisp | 2 | -28/+10 | |
2019-02-07 | gl_shader_util: Add parameter to handle retrievable programs | ReinUsesLisp | 3 | -6/+10 | |
2019-02-07 | rasterizer_interface: Add disk cache entry for the rasterizer | ReinUsesLisp | 6 | -0/+17 | |
2019-02-07 | file_util: Add shader directory | ReinUsesLisp | 3 | -0/+3 | |
2019-02-07 | shader_decode: Implement LDG and basic cbuf tracking | ReinUsesLisp | 1 | -0/+33 | |
2019-02-06 | gdbstub: only let Execute breakpoints write/restore BKPT opcodes into target memory | Dimitri ALBORA | 1 | -4/+10 | |
2019-02-06 | remove all occurance of specifying endianness inside BitField | Weiyi Wang | 6 | -96/+96 | |
This commit it automatically generated by command in zsh: sed -i -- 's/BitField<\(.*\)_le>/BitField<\1>/g' **/*(D.) BitField is now aware to endianness and default to little endian. It expects a value representation type without storage specification for its template parameter. | |||||
2019-02-06 | common/bitfield: make it endianness-aware | Weiyi Wang | 3 | -3/+100 | |
2019-02-06 | common/swap: remove default value for swap type internal storage | Weiyi Wang | 1 | -1/+1 | |
This is compromise for swap type being used in union. A union has deleted default constructor if it has at least one variant member with non-trivial default constructor, and no variant member of T has a default member initializer. In the use case of Bitfield, all variant members will be the swap type on endianness mismatch, which would all have non-trivial default constructor if default value is specified, and non of them can have member initializer | |||||
2019-02-06 | common/swap: use template and tag for LE/BE specification | Weiyi Wang | 1 | -39/+91 | |
The tag can be useful for other type-generic templates like BitFields to forward the endianness specification | |||||
2019-02-06 | common/swap: add swap template for enum | Weiyi Wang | 1 | -0/+52 | |
2019-02-06 | QT: Fix the loading screen 'H' switch logo to not glitch out | James Rowe | 1 | -1/+4 | |
2019-02-06 | service/nvflinger,service/vi: Handle failure cases with exposed API | Lioncash | 4 | -47/+133 | |
Converts many of the Find* functions to return a std::optional<T> as opposed to returning the raw return values directly. This allows removing a few assertions and handles error cases like the service itself does. | |||||
2019-02-05 | Fix crash when no files are selected | xperia64 | 1 | -6/+6 | |
2019-02-05 | Add file extension to screenshot filename if not provided | xperia64 | 1 | -3/+7 | |
2019-02-05 | service/nvflinger: Mark FindVsyncEvent() as a const member function | Lioncash | 2 | -2/+2 | |
This member function doesn't actually modify instance state, so it can be marked as a const member function. | |||||
2019-02-05 | service/nvflinger: Rename GetVsyncEvent() to FindVsyncEvent() | Lioncash | 3 | -3/+3 | |
This was missed within #2075. Renames the member function to make it consistent with the rest of the Find* functions. | |||||
2019-02-05 | video_core/texture: Fix BitField size for depth_minus_one | ReinUsesLisp | 1 | -1/+1 | |
2019-02-04 | Update src/video_core/engines/shader_bytecode.h | Mat M | 1 | -1/+1 | |
Co-Authored-By: FernandoS27 <fsahmkow27@gmail.com> | |||||
2019-02-03 | Fix TXQ not using the component mask. | Fernando Sahmkow | 2 | -6/+13 | |
2019-02-03 | shader_ir/memory: Add ST_L 64 and 128 bits stores | ReinUsesLisp | 1 | -3/+11 | |
2019-02-03 | shader/track: Search inside of conditional nodes | ReinUsesLisp | 1 | -0/+11 | |
Some games search conditionally use global memory instructions. This allows the heuristic to search inside conditional nodes for the source constant buffer. | |||||
2019-02-03 | shader_ir: Rename BasicBlock to NodeBlock | ReinUsesLisp | 30 | -122/+120 | |
It's not always used as a basic block. Rename it for consistency. | |||||
2019-02-03 | shader_ir: Pass decoded nodes as a whole instead of per basic blocks | ReinUsesLisp | 27 | -57/+62 | |
Some games call LDG at the top of a basic block, making the tracking heuristic to fail. This commit lets the heuristic the decoded nodes as a whole instead of per basic blocks. This may lead to some false positives but allows it the heuristic to track cases it previously couldn't. | |||||
2019-02-03 | video_core: Assert on invalid GPU to CPU address queries | ReinUsesLisp | 8 | -47/+67 | |
2019-02-03 | maxwell_3d: Allow sampler handles with TSC id zero | ReinUsesLisp | 1 | -10/+6 | |
2019-02-03 | maxwell_3d: Allow texture handles with TIC id zero | ReinUsesLisp | 3 | -21/+7 | |
Also remove "enabled" field from Tegra::Texture::FullTextureInfo because it would become unused. | |||||
2019-02-03 | memory_manager: Check for reserved page status | ReinUsesLisp | 1 | -1/+2 | |
2019-02-03 | shader_ir/memory: Add LD_L 128 bits loads | ReinUsesLisp | 1 | -7/+19 | |
2019-02-03 | shader_bytecode: Rename BytesN enums to BitsN | ReinUsesLisp | 2 | -7/+7 | |
2019-02-03 | shader_ir/memory: Add LD_L 64 bits loads | ReinUsesLisp | 1 | -6/+17 | |
2019-02-01 | rasterizer_interface: Remove unused AccelerateFill operation | ReinUsesLisp | 3 | -11/+0 | |
2019-02-01 | video_core: Remove unused Fill surface type | ReinUsesLisp | 2 | -6/+1 | |
2019-02-01 | kernel: Remove the Timer class | Lioncash | 9 | -259/+0 | |
A holdover from citra, the Horizon kernel on the switch has no prominent kernel object that functions as a timer. At least not to the degree of sophistication that this class provided. As such, this can be removed entirely. This class also wasn't used at all in any meaningful way within the core, so this was just code sitting around doing nothing. This also allows removing a few things from the main KernelCore class that allows it to use slightly less resources overall (though very minor and not anything really noticeable). | |||||
2019-01-30 | gl_rasterizer_cache: Fixup test clause | ReinUsesLisp | 1 | -6/+5 | |
2019-01-30 | gl_rasterizer_cache: Guard clause swizzle testing | Mat M | 1 | -1/+3 | |
Co-Authored-By: ReinUsesLisp <reinuseslisp@airmail.cc> | |||||
2019-01-30 | gl_state: Remove texture target tracking | ReinUsesLisp | 2 | -5/+0 | |
2019-01-30 | gl_rasterizer_cache: Move swizzling to textures instead of state | ReinUsesLisp | 6 | -28/+35 | |
2019-01-30 | gl_state: Use DSA and multi bind to update texture bindings | ReinUsesLisp | 1 | -8/+22 | |
2019-01-30 | gl_rasterizer: Use DSA for textures | ReinUsesLisp | 5 | -185/+105 | |
2019-01-30 | kernel/wait_object: Devirtualize functions related to manipulating the thread list directly | Lioncash | 1 | -3/+3 | |
No inheritors of the WaitObject class actually make use of their own implementations of these functions, so they can be made non-virtual. It's also kind of sketchy to allow overriding how the threads get added to the list anyways, given the kernel itself on the actual hardware doesn't seem to customize based off this. | |||||
2019-01-30 | kernel/timer: Remove unnecessary WakeupAllWaitingThreads() override | Lioncash | 2 | -6/+0 | |
This implementation just calls the base class variant of the function, so this isn't necessary. | |||||
2019-01-30 | kernel/readable_event: Remove unnecessary WakeupAllWaitingThreads() override | Lioncash | 2 | -6/+0 | |
This just calls the base variant of the function, so it can be removed. | |||||
2019-01-30 | video_core/dma_pusher: Silence C4828 warnings | Lioncash | 1 | -1/+1 | |
This was previously causing: warning C4828: The file contains a character starting at offset 0xa33 that is illegal in the current source character set (codepage 65001). warnings on Windows when compiling yuzu. | |||||
2019-01-30 | hwopus: Implement DecodeInterleaved | Lioncash | 1 | -4/+35 | |
This functions almost identically to DecodeInterleavedWithPerfOld, however this function also has the ability to reset the decoder context. This is documented as a potentially desirable thing in the libopus manual in some circumstances as it says for the OPUS_RESET_STATE ctl: "This should be called when switching streams in order to prevent the back to back decoding from giving different result from one at a time decoding." | |||||
2019-01-30 | service/nvflinger: Make FindBufferQueueId() a const member function | Lioncash | 2 | -2/+26 | |
This member function doesn't actually modify instance state, so it can be const-qualified. | |||||
2019-01-30 | service/nvflinger: Rename Get prefix on function to Find | Lioncash | 3 | -23/+23 | |
This more accurately describes what the function is actually attempting to do (it's not a simple trivial getter). | |||||
2019-01-30 | shader_ir: Unify constant buffer offset values | ReinUsesLisp | 17 | -25/+36 | |
Constant buffer values on the shader IR were using different offsets if the access direct or indirect. cbuf34 has a non-multiplied offset while cbuf36 does. On shader decoding this commit multiplies it by four on cbuf34 queries. | |||||
2019-01-30 | hwopus: Deduplicate the decoding code within DecodeInterleavedOld and DecodeInterleavedWithPerfOld | Lioncash | 1 | -19/+14 | |
Keeps the logic in one spot for use by both functions. | |||||
2019-01-30 | hwopus: Replace std::optional<std::reference_wrapper<u64>> with u64* | Lioncash | 1 | -9/+6 | |
This doesn't really offer anything over the use of a direct pointer, so we can just use that instead. | |||||
2019-01-30 | hwopus: Mark local variables as const where applicable | Lioncash | 1 | -8/+16 | |
Makes non-mutable state more explicit. | |||||
2019-01-30 | hwopus: Fill in the rest of the unknown service function names | Lioncash | 1 | -9/+11 | |
Filled in via information provided by SwitchBrew. | |||||
2019-01-30 | service/ns: Update function tables | Lioncash | 1 | -14/+20 | |
Updates function tables based off information provided by SwitchBrew | |||||
2019-01-30 | service/ncm: Update function tables | Lioncash | 1 | -4/+4 | |
Updates function tables based off information provided by SwitchBrew | |||||
2019-01-30 | service/audio: Update function tables | Lioncash | 4 | -8/+23 | |
Updates function tables based off information provided by SwitchBrew. | |||||
2019-01-30 | service/am/applet_ae: Update function tables | Lioncash | 1 | -1/+2 | |
Updates function tables based off information provided by SwitchBrew. | |||||
2019-01-30 | service/fsp-srv: Update function tables | Lioncash | 2 | -17/+25 | |
Updates function tables based off information provided by SwitchBrew. | |||||
2019-01-30 | service/btm: Update function tables | Lioncash | 1 | -55/+97 | |
Updates function tables based off information provided by SwitchBrew | |||||
2019-01-30 | service/btdrv: Update function tables | Lioncash | 1 | -46/+101 | |
Updates function tables based off information provided by SwitchBrew. | |||||
2019-01-30 | gl_shader_cache: Use explicit bindings | ReinUsesLisp | 7 | -249/+194 | |
2019-01-30 | gl_rasterizer: Implement global memory management | ReinUsesLisp | 6 | -4/+140 | |
2019-01-30 | shader_decode: Implement LDG and basic cbuf tracking | ReinUsesLisp | 7 | -10/+240 | |
2019-01-30 | video_core/GPU Implemented the GPU PFIFO puller semaphore operations. (#1908) | Kevin | 2 | -12/+242 | |
* Implemented the puller semaphore operations. * Nit: Fix 2 style issues * Nit: Add Break to default case. * Fix style. * Update for comments. Added ReferenceCount method * Forgot to remove GpuSmaphoreAddress union. * Fix the clang-format issues. * More clang formatting. * two more white spaces for the Clang formatting. * Move puller members into the regs union * Updated to use Memory::WriteBlock instead of Memory::Write* * Fix clang style issues * White space clang error * Removing unused funcitons and other pr comment * Removing unused funcitons and other pr comment * More union magic for setting regs value. * union magic refcnt as well * Remove local var * Set up the regs and regs_assert_positions up properly * Fix clang error | |||||
2019-01-30 | gl_shader_cache: Fix texture view for cubemaps as cubemap arrays | ReinUsesLisp | 4 | -3/+28 | |
Cubemaps are considered layered and to create a texture view the texture mustn't be a layered texture, resulting in cubemaps being bound as cubemap arrays. To fix this issue this commit introduces an extra surface parameter called "is_array" and uses this to query for texture view creation. Now that texture views for cubemaps are actually being created, this also fixes the number of layers created for the texture view (since they have to be 6 to create a texture view of cubemaps). | |||||
2019-01-30 | gl_rasterizer: Workaround invalid zeta clears | ReinUsesLisp | 2 | -14/+19 | |
Some games (like Xenoblade Chronicles 2) clear both depth and stencil buffers while there's a depth-only texture attached (e.g. D16 Unorm). This commit reads the zeta format of the bound surface on ConfigureFramebuffers and returns if depth and/or stencil attachments were set. This is ignored on DrawArrays but on Clear it's used to just clear those attachments, bypassing an OpenGL error. | |||||
2019-01-30 | service/psc: Update function tables | Lioncash | 1 | -8/+9 | |
Updates the function tables based off information on SwitchBrew. Gets rid of a swath of unknown names. | |||||
2019-01-30 | nvflinger: Add the Null display | Lioncash | 1 | -1/+2 | |
In addition to the default, external, EDID, and internal displays, there's also a null display provided as well, which as the name suggests, does nothing but discard all commands given to it. This is provided for completeness. | |||||
2019-01-30 | nvflinger: Change log message in OpenDisplay to be a debug log instead of a warning | Lioncash | 1 | -1/+1 | |
Opening a display isn't really a thing to warn about. It's an expected thing, so this can be a debug log. This also alters the string to indicate the display name better. Opening "Default" display reads a little nicer compared to Opening display Default. | |||||
2019-01-30 | nvflinger: Remove unnecessary header inclusions | Lioncash | 1 | -2/+0 | |
2019-01-30 | nvflinger: Mark locals const where applicable | Lioncash | 1 | -11/+11 | |
Makes non-mutable state more explicit. | |||||
2019-01-30 | nvflinger: Use a std::array for the available displays instead of std::vector | Lioncash | 2 | -7/+7 | |
The built-in set of displays is fixed, so we can utilize an array instead of a vector here. | |||||
2019-01-30 | hle/ipc_helpers: Fix clang-format warnings | Lioncash | 1 | -1/+0 | |
2019-01-29 | hle/ipc_helpers: Allow pushing signed values | Lioncash | 1 | -0/+22 | |
This is kind of a large hole in the API, given we allow popping signed values. This fixes that. | |||||
2019-01-28 | service/pm: Implement SetMaintenanceBoot() | Lioncash | 1 | -1/+10 | |
This quite literally functions as a basic setter. No other error checking or anything (since there's nothing to really check against). With this, it completes the pm:bm interface in terms of functionality. | |||||
2019-01-28 | service/pm: Tidy up functionality related to SystemBootMode | Lioncash | 2 | -2/+9 | |
Just minor tidying of interfaces. | |||||
2019-01-28 | service/vi: Remove stubbed notifier from SetLayerVisibility | Lioncash | 1 | -2/+3 | |
This appears to be a vestigial API function that's only kept around for compatibility's sake, given the function only returns a success error code and exits. Since that's the case, we can remove the stubbed notification from the log, since doing nothing is technically the correct behavior in this case. | |||||
2019-01-28 | shader/shader_ir: Amend three comment typos | Lioncash | 1 | -3/+3 | |
Given we're in the area, these are three trivial typos that can be corrected. | |||||
2019-01-28 | shader/shader_ir: Amend constructor initializer ordering for AbufNode | Lioncash | 1 | -2/+2 | |
Orders the class members in the same order that they would actually be initialized in. Gets rid of two compiler warnings. | |||||
2019-01-28 | shader/decode: Avoid a pessimizing std::move within DecodeRange() | Lioncash | 1 | -1/+1 | |
std::moveing a local variable in a return statement has the potential to prevent copy elision from occurring, so this can just be converted into a regular return. | |||||
2019-01-27 | kernel/svc: Log out uncaught C++ exceptions from svcBreak | Lioncash | 1 | -0/+4 | |
Looking into the implementation of the C++ standard facilities that seem to be within all modules, it appears that they use 7 as a break reason to indicate an uncaught C++ exception. This was primarily found via the third last function called within Horizon's equivalent of libcxxabi's demangling_terminate_handler(), which passes the value 0x80000007 to svcBreak. | |||||
2019-01-26 | dsp_interface: fix sound being played while volume is 0 | fearlessTobi | 1 | -1/+1 | |
According to documentation, if the argument of std::exp is zero, one is returned. However we want the return value to be also zero in this case so no audio is played. | |||||
2019-01-26 | Use QPixmap/QIcon for background color selection button | xperia64 | 2 | -7/+15 | |
2019-01-26 | video_core: Silent implicit conversion warning | ReinUsesLisp | 1 | -3/+4 | |
2019-01-24 | frontend: Refactor ScopeAcquireWindowContext out of renderer_opengl. | bunnei | 7 | -36/+54 | |
2019-01-22 | citra_qt: Log settings on launch | zhupengfei | 5 | -0/+35 | |
2019-01-22 | maxwell_3d: Set rt_separate_frag_data to 1 by default | ReinUsesLisp | 2 | -4/+6 | |
Commercial games assume that this value is 1 but they never set it. On the other hand nouveau manually sets this register. On ConfigureFramebuffers we were asserting for what we are actually implementing (according to envytools). | |||||
2019-01-22 | QT: Hide GLWidget immediately after showing. | James Rowe | 1 | -0/+2 | |
With the loading screen merged, we don't want to actually show at this point, but it still needs to be shown to actually create the context. Turns out you can just show and hide it immediately and it'll work. | |||||
2019-01-22 | SDL Frontend: Add shared context support | James Rowe | 2 | -1/+38 | |
2019-01-22 | QT Frontend: Migrate to QOpenGLWindow | James Rowe | 4 | -30/+113 | |
2019-01-21 | Change const char* to const char[] | James Rowe | 1 | -4/+4 | |
2019-01-21 | Fix mingw compile error and warnings | James Rowe | 2 | -6/+6 | |
2019-01-21 | Add fade out effect to the loading screen | James Rowe | 4 | -94/+158 | |
2019-01-21 | Set Minimum Size to the same as renderwindow | James Rowe | 1 | -0/+1 | |
2019-01-21 | Remove blue box around loading screen | James Rowe | 1 | -1/+0 | |
2019-01-21 | Change the background color of Stage Complete to yuzu blue | James Rowe | 1 | -1/+1 | |
2019-01-21 | Rename step 1 and step 2 to be a little more descriptive | James Rowe | 2 | -8/+8 | |
2019-01-21 | Prevent estimated time from flashing after slow shader compilation starts | James Rowe | 1 | -1/+1 | |
2019-01-21 | Move progress bar style into constexpr strings | James Rowe | 1 | -28/+32 | |
2019-01-20 | Hide progress bar on Prepare step | James Rowe | 1 | -7/+8 | |
2019-01-20 | QT: Upgrade the Loading Bar to look much better | James Rowe | 4 | -11/+201 | |
2019-01-20 | Add a workaround if QMovie isn't available | James Rowe | 2 | -1/+20 | |
2019-01-20 | QT Frontend: Add a Loading screen with progressbar | James Rowe | 8 | -10/+239 | |
With shader caches on the horizon, one requirement is to provide visible feedback for the progress. The shader cache reportedly takes several minutes to load for large caches that were invalidated, and as such we should provide a loading screen with progress. Adds a loading screen widget that will be shown until the first frame of the game is swapped. This was chosen in case shader caches are not being used, several games still take more than a few seconds to launch and could benefit from a loading screen. | |||||
2019-01-18 | file_sys/directory: Remove unused DirectoryBackend class | Lioncash | 1 | -23/+0 | |
This isn't used at all, so we can just get rid of it. | |||||
2019-01-18 | gl_rasterizer: Silent unsafe mix warning | ReinUsesLisp | 1 | -1/+1 | |
2019-01-17 | yuzu/configuration/configure_input_player: Forward declare types where applicable | Lioncash | 2 | -2/+7 | |
Allows removing the inclusion of the main input common header from the UI config header. | |||||
2019-01-17 | yuzu/configuration/configure_touchscreen_advanced: Remove unnecessary header inclusions | Lioncash | 1 | -2/+0 | |
2019-01-17 | yuzu/configuration/configure_per_general: Remove unused header inclusions | Lioncash | 2 | -4/+3 | |
2019-01-17 | yuzu/configuration/configure_debug: Remove unused header inclusions | Lioncash | 1 | -1/+0 | |
2019-01-17 | yuzu/configuration/configure_system: Remove unused header inclusions | Lioncash | 1 | -8/+4 | |
2019-01-17 | yuzu/configuration/configure_web: Remove an unused lambda capture | Lioncash | 1 | -5/+4 | |
'this' isn't actually used within the lambda, since what we need from the class is already assigned within the capture section of the lambda. | |||||
2019-01-17 | yuzu/configuration/configure_web: Use an ellipsis with 'Verifying' text | Lioncash | 1 | -1/+1 | |
It's a common UI pattern to use an ellipsis to indicate an ongoing action, rather than just specifying the word by itself. | |||||
2019-01-17 | core/frontend/applets/web_browser: Include missing headers | Lioncash | 1 | -2/+8 | |
Gets rid of a few indirect inclusions. | |||||
2019-01-17 | core/frontend/applets/web_browser: Make OpenPage() non-const | Lioncash | 7 | -20/+25 | |
This is a function that definitely doesn't always have a non-modifying behavior across all implementations, so this should be made non-const. This gets rid of the need to mark data members as mutable to work around the fact mutating data members needs to occur. | |||||
2019-01-17 | yuzu/web_browser: std::move std::function instances in OpenPage() | Lioncash | 1 | -2/+2 | |
Avoids the need to potentially reallocate the contained callbacks. | |||||
2019-01-17 | yuzu/web_browser: Make slot functions private | Lioncash | 1 | -2/+1 | |
These currently aren't used by anything other than the QtWebBrowser class itself, and can be made private. | |||||
2019-01-16 | shader_ir: Fixup clang build | ReinUsesLisp | 1 | -4/+6 | |
2019-01-15 | loader: Propagate NCA logo section to ReadBanner and ReadLogo | Zach Hilman | 9 | -0/+61 | |
2019-01-15 | content_archive: Add getter for logo section of NCA | Zach Hilman | 2 | -0/+16 | |
2019-01-15 | gl_shader_decompiler: replace std::get<> with std::get_if<> for macOS compatibility | ReinUsesLisp | 1 | -44/+58 | |
2019-01-15 | gl_shader_decompiler: Inline textureGather component | ReinUsesLisp | 1 | -15/+16 | |
2019-01-15 | shader_decode: Fixup XMAD | ReinUsesLisp | 1 | -1/+1 | |
2019-01-15 | shader_ir: Pass to decoder functions basic block's code | ReinUsesLisp | 27 | -82/+83 | |
2019-01-15 | shader_decode: Improve zero flag implementation | ReinUsesLisp | 15 | -75/+79 | |
2019-01-15 | shader_ir: Remove composite primitives and use temporals instead | ReinUsesLisp | 4 | -241/+224 | |
2019-01-15 | gl_shader_decompiler: Fixup AssignCompositeHalf | ReinUsesLisp | 1 | -1/+1 | |
2019-01-15 | shader_decode: Use proper primitive names | ReinUsesLisp | 4 | -25/+21 | |
2019-01-15 | shader_decode: Use BitfieldExtract instead of shift + and | ReinUsesLisp | 8 | -48/+37 | |
2019-01-15 | shader_ir: Remove Ipa primitive | ReinUsesLisp | 3 | -13/+2 | |
2019-01-15 | gl_shader_decompiler: Use rasterizer's UBO size limit | ReinUsesLisp | 1 | -1/+3 | |
2019-01-15 | gl_shader_gen: Fixup code formatting | ReinUsesLisp | 2 | -18/+22 | |
2019-01-15 | video_core: Rename glsl_decompiler to gl_shader_decompiler | ReinUsesLisp | 7 | -7/+7 | |
2019-01-15 | shader_ir: Remove RZ and use Register::ZeroIndex instead | ReinUsesLisp | 3 | -12/+16 | |
2019-01-15 | shader_decode: Implement TEXS.F16 | ReinUsesLisp | 3 | -15/+57 | |
2019-01-15 | shader_decode: Fixup R2P | ReinUsesLisp | 1 | -2/+3 | |
2019-01-15 | glsl_decompiler: Fixup TLDS | ReinUsesLisp | 1 | -1/+0 | |
2019-01-15 | glsl_decompiler: Fixup geometry shaders | ReinUsesLisp | 2 | -15/+17 | |
2019-01-15 | shader_decode: Fixup WriteLogicOperation zero comparison | ReinUsesLisp | 1 | -1/+1 | |
2019-01-15 | glsl_decompiler: Fixup permissive member function declarations | ReinUsesLisp | 1 | -133/+133 | |
2019-01-15 | shader_decode: Fixup PSET | ReinUsesLisp | 1 | -2/+3 | |
2019-01-15 | shader_decode: Fixup clang-format | ReinUsesLisp | 2 | -2/+4 | |
2019-01-15 | video_core: Implement IR based geometry shaders | ReinUsesLisp | 4 | -10/+102 | |
2019-01-15 | shader_decode: Implement VMAD and VSETP | ReinUsesLisp | 5 | -2/+129 | |
2019-01-15 | shader_decode: Implement HSET2 | ReinUsesLisp | 3 | -1/+50 | |
2019-01-15 | shader_decode: Rework HSETP2 | ReinUsesLisp | 4 | -47/+57 | |
2019-01-15 | shader_decode: Implement R2P | ReinUsesLisp | 1 | -1/+28 | |
2019-01-15 | shader_decode: Implement CSETP | ReinUsesLisp | 1 | -14/+37 | |
2019-01-15 | shader_decode: Implement PSET | ReinUsesLisp | 1 | -1/+16 | |
2019-01-15 | shader_decode: Implement HFMA2 | ReinUsesLisp | 4 | -5/+60 | |
2019-01-15 | glsl_decompiler: Remove HNegate inlining | ReinUsesLisp | 1 | -10/+0 | |
2019-01-15 | shader_decode: Implement POPC | ReinUsesLisp | 4 | -1/+22 | |
2019-01-15 | shader_decode: Implement TLDS (untested) | ReinUsesLisp | 3 | -10/+92 | |
2019-01-15 | shader_decode: Update TLD4 reflecting #1862 changes | ReinUsesLisp | 2 | -52/+52 | |
2019-01-15 | shader_ir: Fixup TEX and TEXS and partially fix TLD4 decompiling | ReinUsesLisp | 3 | -60/+72 | |
2019-01-15 | shader_decode: Fixup FSET | ReinUsesLisp | 1 | -2/+2 | |
2019-01-15 | shader_decode: Implement IADD32I | ReinUsesLisp | 1 | -0/+11 | |
2019-01-15 | shader_decode: Fixup clang-format | ReinUsesLisp | 1 | -1/+1 | |
2019-01-15 | video_core: Return safe values after an assert hits | ReinUsesLisp | 8 | -8/+19 | |
2019-01-15 | shader_decode: Implement FFMA | ReinUsesLisp | 1 | -1/+36 | |
2019-01-15 | video_core: Address feedback | ReinUsesLisp | 4 | -13/+16 | |
2019-01-15 | shader_ir: Fixup file inclusions and clang-format | ReinUsesLisp | 3 | -2/+2 | |
2019-01-15 | shader_ir: Move comment node string | Mat M | 1 | -2/+2 | |
Co-Authored-By: ReinUsesLisp <reinuseslisp@airmail.cc> | |||||
2019-01-15 | shader_ir: Address feedback to avoid UB in bit casting | ReinUsesLisp | 1 | -2/+4 | |
2019-01-15 | shader_decode: Fixup clang-format | ReinUsesLisp | 2 | -3/+2 | |
2019-01-15 | shader_decode: Implement LEA | ReinUsesLisp | 1 | -0/+55 | |
2019-01-15 | shader_decode: Implement IADD3 | ReinUsesLisp | 1 | -0/+61 | |
2019-01-15 | shader_decode: Implement LOP3 | ReinUsesLisp | 2 | -0/+62 | |
2019-01-15 | shader_decode: Implement ST_L | ReinUsesLisp | 1 | -0/+17 | |
2019-01-15 | shader_decode: Implement LD_L | ReinUsesLisp | 1 | -0/+18 | |
2019-01-15 | shader_decode: Implement HSETP2 | ReinUsesLisp | 1 | -1/+37 | |
2019-01-15 | shader_decode: Implement HADD2 and HMUL2 | ReinUsesLisp | 1 | -1/+48 | |
2019-01-15 | shader_decode: Implement HADD2_IMM and HMUL2_IMM | ReinUsesLisp | 1 | -1/+28 | |
2019-01-15 | shader_decode: Implement MOV_SYS | ReinUsesLisp | 1 | -0/+27 | |
2019-01-15 | shader_decode: Implement IMNMX | ReinUsesLisp | 1 | -0/+16 | |
2019-01-15 | shader_decode: Implement F2F_C | ReinUsesLisp | 1 | -2/+10 | |
2019-01-15 | shader_decode: Implement I2I | ReinUsesLisp | 1 | -0/+26 | |
2019-01-15 | shader_decode: Implement BRA internal flag | ReinUsesLisp | 1 | -4/+8 | |
2019-01-15 | shader_decode: Implement ISCADD | ReinUsesLisp | 1 | -0/+15 | |
2019-01-15 | shader_decode: Implement XMAD | ReinUsesLisp | 1 | -1/+85 | |
2019-01-15 | shader_decode: Implement PBK and BRK | ReinUsesLisp | 1 | -1/+22 | |
2019-01-15 | shader_decode: Implement LOP | ReinUsesLisp | 1 | -0/+15 | |
2019-01-15 | shader_decode: Implement SEL | ReinUsesLisp | 1 | -0/+8 | |
2019-01-15 | shader_decode: Implement IADD | ReinUsesLisp | 1 | -1/+28 | |
2019-01-15 | shader_decode: Implement ISETP | ReinUsesLisp | 1 | -1/+30 | |
2019-01-15 | shader_decode: Implement BFI | ReinUsesLisp | 1 | -1/+22 | |
2019-01-15 | shader_decode: Implement ISET | ReinUsesLisp | 1 | -1/+27 | |
2019-01-15 | shader_decode: Implement LD_C | ReinUsesLisp | 1 | -0/+31 | |
2019-01-15 | shader_decode: Implement SHL | ReinUsesLisp | 1 | -0/+8 | |
2019-01-15 | shader_decode: Implement SHR | ReinUsesLisp | 1 | -1/+26 | |
2019-01-15 | shader_decode: Implement LOP32I | ReinUsesLisp | 2 | -1/+72 | |
2019-01-15 | shader_decode: Implement BFE | ReinUsesLisp | 1 | -1/+25 | |
2019-01-15 | shader_decode: Implement FSET | ReinUsesLisp | 1 | -1/+36 | |
2019-01-15 | shader_decode: Implement F2I | ReinUsesLisp | 1 | -0/+37 | |
2019-01-15 | shader_decode: Implement I2F | ReinUsesLisp | 1 | -0/+23 | |
2019-01-15 | shader_decode: Implement F2F | ReinUsesLisp | 1 | -1/+37 | |
2019-01-15 | shader_decode: Stub DEPBAR | ReinUsesLisp | 1 | -0/+4 | |
2019-01-15 | shader_decode: Implement SSY and SYNC | ReinUsesLisp | 1 | -0/+19 | |
2019-01-15 | shader_decode: Implement PSETP | ReinUsesLisp | 1 | -1/+21 | |
2019-01-15 | shader_decode: Implement TMML | ReinUsesLisp | 1 | -3/+45 | |
2019-01-15 | shader_decode: Implement TEX and TXQ | ReinUsesLisp | 2 | -0/+223 | |
2019-01-15 | shader_decode: Implement TEXS (F32) | ReinUsesLisp | 2 | -0/+217 | |
2019-01-15 | shader_decode: Implement FSETP | ReinUsesLisp | 1 | -1/+33 | |
2019-01-15 | shader_decode: Partially implement BRA | ReinUsesLisp | 1 | -0/+12 | |
2019-01-15 | shader_decode: Implement IPA | ReinUsesLisp | 1 | -0/+12 | |
2019-01-15 | shader_decode: Implement EXIT | ReinUsesLisp | 1 | -1/+32 | |
2019-01-15 | shader_decode: Implement ST_A | ReinUsesLisp | 1 | -0/+30 | |
2019-01-15 | shader_decode: Implement LD_A | ReinUsesLisp | 1 | -1/+39 | |
2019-01-15 | shader_decode: Implement FADD32I | ReinUsesLisp | 1 | -0/+12 | |
2019-01-15 | shader_decode: Implement FMUL32_IMM | ReinUsesLisp | 1 | -0/+10 | |
2019-01-15 | shader_decode: Implement MOV32_IMM | ReinUsesLisp | 1 | -1/+9 | |
2019-01-15 | shader_decode: Stub RRO_C, RRO_R and RRO_IMM | ReinUsesLisp | 1 | -0/+9 | |
2019-01-15 | shader_decode: Implement FMNMX_C, FMNMX_R and FMNMX_IMM | ReinUsesLisp | 1 | -0/+18 | |
2019-01-15 | shader_decode: Implement MUFU | ReinUsesLisp | 1 | -0/+29 | |
2019-01-15 | shader_decode: Implement FADD_C, FADD_R and FADD_IMM | ReinUsesLisp | 1 | -0/+15 | |
2019-01-15 | shader_decode: Implement FMUL_C, FMUL_R and FMUL_IMM | ReinUsesLisp | 1 | -0/+42 | |
2019-01-15 | shader_decode: Implement MOV_C and MOV_R | ReinUsesLisp | 1 | -1/+23 | |
2019-01-15 | video_core: Replace gl_shader_decompiler | ReinUsesLisp | 8 | -4185/+57 | |
2019-01-15 | glsl_decompiler: Implementation | ReinUsesLisp | 3 | -0/+1483 | |
2019-01-15 | shader_ir: Add condition code helper | ReinUsesLisp | 2 | -0/+13 | |
2019-01-15 | shader_ir: Add predicate combiner helper | ReinUsesLisp | 2 | -0/+15 | |
2019-01-15 | shader_ir: Add comparison helpers | ReinUsesLisp | 2 | -0/+106 | |
2019-01-15 | shader_ir: Add half float helpers | ReinUsesLisp | 2 | -0/+44 | |
2019-01-15 | shader_ir: Add integer helpers | ReinUsesLisp | 2 | -0/+40 | |
2019-01-15 | shader_ir: Add float helpers | ReinUsesLisp | 2 | -0/+24 | |
2019-01-15 | shader_ir: Add setters | ReinUsesLisp | 2 | -0/+24 | |
2019-01-15 | shader_ir: Add local memory getters | ReinUsesLisp | 2 | -0/+7 | |
2019-01-15 | shader_ir: Add internal flag getters | ReinUsesLisp | 2 | -0/+10 | |
2019-01-15 | shader_ir: Add attribute getters | ReinUsesLisp | 2 | -0/+26 | |
2019-01-15 | shader_ir: Add constant buffer getters | ReinUsesLisp | 2 | -0/+25 | |
2019-01-15 | shader_ir: Add register getter | ReinUsesLisp | 2 | -0/+9 | |
2019-01-15 | shader_ir: Add immediate node constructors | ReinUsesLisp | 2 | -1/+34 | |
2019-01-15 | shader_ir: Initial implementation | ReinUsesLisp | 30 | -0/+1573 | |
2019-01-15 | shader_bytecode: Fixup encoding | ReinUsesLisp | 1 | -1/+1 | |
2019-01-15 | shader_header: Make local memory size getter constant | ReinUsesLisp | 1 | -1/+1 | |
2019-01-14 | audio_core: remove unnecessary spaces on comments | Otávio Pace | 1 | -2/+2 | |
2019-01-09 | gl_rasterizer: Workaround Intel VAO DSA bug | ReinUsesLisp | 3 | -7/+16 | |
There is a bug on Intel's blob driver where it fails to properly build a vertex array object if it's not bound even after creating it with glCreateVertexArrays. This workaround binds it after creating it to bypass the issue. | |||||
2019-01-08 | gl_global_cache: Add dummy global cache manager | ReinUsesLisp | 5 | -3/+96 | |
2019-01-08 | settings: Fix comment structure | Zach Hilman | 2 | -5/+7 | |
2019-01-08 | settings: Use std::chrono::seconds instead of s64 for RTC | Zach Hilman | 6 | -17/+21 | |
2019-01-08 | time: Use custom RTC settings if applicable for game | Zach Hilman | 2 | -8/+12 | |
2019-01-08 | core: Set custom RTC differential on game boot | Zach Hilman | 1 | -0/+7 | |
2019-01-08 | qt: Provide UI to edit custom RTC settings | Zach Hilman | 2 | -28/+66 | |
2019-01-08 | settings: Add custom RTC settings | Zach Hilman | 4 | -4/+30 | |
Stored as signed seconds since epoch. | |||||
2019-01-07 | gl_rasterizer: Skip framebuffer configuration if rendertargets have not been changed | ReinUsesLisp | 2 | -1/+31 | |
2019-01-07 | gl_rasterizer_cache: Use dirty flags for the depth buffer | ReinUsesLisp | 4 | -3/+23 | |
2019-01-07 | gl_rasterizer_cache: Use dirty flags for color buffers | ReinUsesLisp | 4 | -4/+24 | |
2019-01-07 | gl_shader_cache: Use dirty flags for shaders | ReinUsesLisp | 5 | -2/+23 | |
2019-01-06 | gl_stream_buffer: Use DSA for buffer management | ReinUsesLisp | 3 | -17/+14 | |
2019-01-06 | gl_rasterizer: Use DSA for vertex array objects | ReinUsesLisp | 6 | -79/+53 | |
2019-01-06 | gl_state: Drop uniform buffer state tracking | ReinUsesLisp | 3 | -10/+0 | |
2019-01-05 | gl_rasterizer_cache: Use GL_STREAM_COPY for PBOs | ReinUsesLisp | 1 | -1/+1 | |
Since the data is doing the path CPU -> GPU -> GPU copy is the most approximate hint. Using GL_STREAM_DRAW generated a performance warning on Nvidia's stack. Changing this hint removed the warning. | |||||
2019-01-05 | service/vi: Correct scaling mode conversions | Lioncash | 1 | -15/+13 | |
These values are not equivalent, based off RE. The internal value is put into a lookup table with the following values: [3, 0, 1, 2, 4] So the values absolutely do not map 1:1 like the comment was indicating. | |||||
2019-01-05 | service/vi: Factor out scaling mode conversions from the IPC function itself | Lioncash | 1 | -17/+21 | |
Avoids entangling the IPC buffer appending with the actual operation of converting the scaling values over. This also inserts the proper error handling for invalid scaling values. | |||||
2019-01-05 | service/vi: Unstub IApplicationDisplayService' SetLayerScalingMode() | Lioncash | 1 | -21/+38 | |
This appears to only check if the scaling mode can actually be handled, rather than actually setting the scaling mode for the layer. This implements the same error handling performed on the passed in values. | |||||
2019-01-05 | service/vi: Correct reported dimensions from IApplicationDisplayService's GetDisplayResolution() | Lioncash | 1 | -12/+8 | |
Within the actual service, it makes no distinguishing between docked and undocked modes. This will always return the constants values reporting 1280x720 as the dimensions. | |||||
2019-01-04 | qt: Move profile manager to own UI tab | Zach Hilman | 9 | -427/+565 | |
2019-01-04 | Removed pulse event type | David Marcec | 4 | -9/+0 | |
Pulse is considered a hack and nothing should be using it. We should completely remove it | |||||
2019-01-04 | Return no application area when games try to open an application area | David Marcec | 1 | -4/+4 | |
This will prompt CreateApplicationArea | |||||
2019-01-04 | Proper no message handling for AM::PopMessage | David Marcec | 1 | -1/+10 | |
When we have no messages, we should be returning an error code. | |||||
2019-01-03 | Fixed botw deadlock(and possibly 30 fps games rendering too fast? needs testing to confirm) | David Marcec | 1 | -1/+1 | |
Upon investigating the issue with #1878, I found that games are the ones who handle the vsync event resetting and not us. | |||||
2019-01-03 | service/vi: Implement SetDisplayEnabled() | Lioncash | 1 | -1/+10 | |
This IPC command is simply a stub inside the actual service itself, and just returns a successful error code regardless of input. This is likely only retained in the service interface to not break older code that relied upon it succeeding in some way. | |||||
2019-01-03 | service/vi: Log more information where applicable | Lioncash | 1 | -63/+74 | |
In many cases, we didn't bother to log out any of the popped data members. This logs them out to the console within the logging call to provide more contextual information. | |||||
2019-01-03 | service/vi: Implement OpenDefaultDisplay in terms of OpenDisplay | Lioncash | 1 | -4/+17 | |
Internally within the vi services, this is essentially all that OpenDefaultDisplay does, so it's trivial to just do the same, and forward the default display string into the function. | |||||
2019-01-02 | service/vi: Correct initial width and height values | Lioncash | 1 | -2/+2 | |
Based off RE, it appears that almost all display types seem to use 1920x1080 except for a few (null display, edid display). | |||||
2019-01-02 | service/vi: Document unknown DisplayInfo struct members | Lioncash | 1 | -2/+13 | |
It appears that the two members indicate whether a display has a bounded number of layers (and if set, the second member indicates the total number of layers). | |||||
2019-01-01 | yuzu/configure_general: Silence truncation warnings in loadConfiguration() | Lioncash | 1 | -2/+2 | |
The QPixmap API expects an unsigned int. | |||||
2019-01-01 | yuzu/config: Silence truncation warnings | Lioncash | 1 | -1/+1 | |
2019-01-01 | core/kernel: Remove unnecessary inclusions | Lioncash | 16 | -16/+22 | |
Gets rid of a few unnecessary header dependencies in some source files. | |||||
2018-12-31 | kernel/svc: Correct misleading error message within CreateThread() | Lioncash | 1 | -2/+3 | |
This is a bounds check to ensure that the thread priority is within the valid range of 0-64. If it exceeds 64, that doesn't necessarily mean that an actual priority of 64 was expected (it actually means whoever called the function screwed up their math). Instead clarify the message to indicate the allowed range of thread priorities. | |||||
2018-12-31 | kernel/svc: Sanitize core number and thread priorities in CreateThread() | Lioncash | 1 | -6/+17 | |
Now that we handle the kernel capability descriptors we can correct CreateThread to properly check against the core and priority masks like the actual kernel does. | |||||
2018-12-31 | kernel/process: Rename GetAllowedProcessorMask() and GetAllowedThreadPriorityMask() | Lioncash | 2 | -11/+11 | |
Makes them consistent with their kernel capability counterparts. | |||||
2018-12-31 | kernel/svc: Simplify thread core ID sanitizing in CreateThread | Lioncash | 1 | -7/+1 | |
Rather than use a switch here, this can be collapsed into a simple range check, which is a little easier on the eyes. | |||||
2018-12-31 | arm_interface: Make include path relative for arm_interface.h | Lioncash | 1 | -1/+1 | |
Makes it consistent with the rest of the includes. | |||||
2018-12-31 | arm_interface: Make LogBacktrace() a const member function | Lioncash | 2 | -2/+2 | |
This function doesn't modify instance state, so it can be made const. | |||||
2018-12-31 | arm_interface: Mark variables as const where applicable in LogBacktrace() | Lioncash | 1 | -3/+4 | |
Two of these variables have fixed values, so we can make that immediately obvious from the get-go. | |||||
2018-12-31 | arm_interface: Remove unnecessary semicolon | Lioncash | 1 | -1/+1 | |
Namespaces don't require the use of a semicolon. Silences a -Wextra-semi warning. | |||||
2018-12-30 | gl_rasterizer_cache: Texture view if shader samples array but OGL is not | ReinUsesLisp | 3 | -14/+74 | |
When a shader samples a texture array but that texture in OpenGL is created without layers, use a texture view to increase the texture hierarchy. For example, instead of binding a GL_TEXTURE_2D bind a GL_TEXTURE_2D_ARRAY view. | |||||
2018-12-30 | service/time: Minor cleanup to GetClockSnapshot() | Lioncash | 1 | -7/+9 | |
Moves some variables closer to their actual usage sites. | |||||
2018-12-30 | service/time: Fill in some structures and remove padding where not necessary | Lioncash | 2 | -7/+9 | |
2018-12-29 | Moved log backtrace to arm_interface.cpp. Added printing of error code to fatal | David Marcec | 4 | -18/+36 | |
2018-12-29 | travis: Use correct package for linux Qt5WebEngine | Zach Hilman | 3 | -4/+3 | |
2018-12-29 | web_browser: Add bounds checking to applet interface | Zach Hilman | 10 | -146/+160 | |
2018-12-28 | gpu: Remove PixelFormat G8R8U and G8R8S, as they do not seem to exist. | bunnei | 4 | -79/+46 | |
- Fixes UI rendering issues in The Legend of Zelda: Breath of the Wild. | |||||
2018-12-28 | main: Add main window integrations for QtWebBrowserApplet | Zach Hilman | 3 | -0/+168 | |
2018-12-28 | qt: Implement Qt frontend to web browser | Zach Hilman | 2 | -0/+154 | |
Using a custom reimplementation of QWebEngineView and an injector script. | |||||
2018-12-28 | core: Add getter and setter for WebBrowserApplet frontend | Zach Hilman | 4 | -2/+22 | |
2018-12-28 | frontend: Add frontend responder for web browser | Zach Hilman | 2 | -0/+52 | |
2018-12-28 | applets: Implement LibAppletOff (Web) applet | Zach Hilman | 4 | -0/+234 | |
2018-12-28 | loader: Add accessor for Manual RomFS | Zach Hilman | 5 | -0/+30 | |
2018-12-28 | hid: Make Hid service accessible and add GetPressState | Zach Hilman | 4 | -459/+540 | |
2018-12-28 | romfs: Add SingleDiscard extraction type | Zach Hilman | 2 | -2/+6 | |
Needed for manual RomFS extraction, as Full generates an extra directory and Truncated generates variable results. | |||||
2018-12-28 | am: Add size parameter to am:IStorage logging | Zach Hilman | 1 | -4/+4 | |
2018-12-28 | audio_core: Convert LOG_CRITICAL + UNREACHABLE over to UNIMPLEMENTED/UNIMPLEMENTED_MSG | Lioncash | 3 | -10/+6 | |
These two macros being used in tandem were used prior to the introduction of UNIMPLEMENTED and UNIMPLEMENTED_MSG. This provides equivalent behavior, just with less typing/reading involved. | |||||
2018-12-28 | kernel/process: Start the main thread using the specified ideal core | Lioncash | 1 | -2/+2 | |
This matches kernel behavior in that processes are started using their specified ideal core, rather than always starting on core 0. | |||||
2018-12-28 | kernel: Rename 'default' CPU core to 'ideal' core | Lioncash | 5 | -23/+23 | |
This makes the naming more closely match its meaning. It's just a preferred core, not a required default core. This also makes the usages of this term consistent across the thread and process implementations. | |||||
2018-12-28 | kernel/thread: Move process thread initialization into process.cpp | Lioncash | 3 | -36/+30 | |
This function isn't a general purpose function that should be exposed to everything, given it's specific to initializing the main thread for a Process instance. Given that, it's a tad bit more sensible to place this within process.cpp, which keeps it visible only to the code that actually needs it. | |||||
2018-12-28 | file_sys/program_metadata: Print out more descriptive address space descriptions | Lioncash | 1 | -3/+7 | |
Provides extra information that makes it easier to tell if an executable being run is using a 36-bit address space or a 39-bit address space. While we don't support AArch32 executables yet, this also puts in distinguishing information for the 32-bit address space types as well. | |||||
2018-12-28 | Qt/Configure: Use sidebar to divide tabs into smaller groups | spycrab | 3 | -59/+124 | |
2018-12-28 | kernel/process: Remove most allocation functions from Process' interface | Lioncash | 4 | -49/+35 | |
In all cases that these functions are needed, the VMManager can just be retrieved and used instead of providing the same functions in Process' interface. This also makes it a little nicer dependency-wise, since it gets rid of cases where the VMManager interface was being used, and then switched over to using the interface for a Process instance. Instead, it makes all accesses uniform and uses the VMManager instance for all necessary tasks. All the basic memory mapping functions did was forward to the Process' VMManager instance anyways. | |||||
2018-12-27 | Add missing uintBitsToFloat to SetRegisterToHalfFloat | Rodolfo Bogado | 1 | -2/+2 | |
2018-12-27 | am: Implement GetSaveDataSize and ExtendSaveData | Zach Hilman | 6 | -8/+53 | |
These functions come in a pair and are needed by Smash Ultimate, Minecraft, and Skyrim, amongst others. | |||||
2018-12-27 | filesystem: Populate save data sizes from control data | Zach Hilman | 2 | -0/+53 | |
2018-12-27 | savedata_factory: Partially implement IVFC save sizes using files | Zach Hilman | 2 | -0/+38 | |
This stores a file in the save directory called '.yuzu_save_size' which stores the two save sizes (normal area and journaled area) sequentially as u64s. | |||||
2018-12-27 | loader: Add accessor for game control data | Zach Hilman | 5 | -9/+14 | |
2018-12-27 | control_metadata: Update NACP fields with latest Switchbrew data | Zach Hilman | 2 | -6/+29 | |
2018-12-27 | control_metadata: Use value member instead of unique_ptr to store struct | Zach Hilman | 2 | -10/+13 | |
Serves no actual purpose in this instance besides making NACP's copy assignment deleted, which is not intended behavior. | |||||
2018-12-27 | vfs: Add reinterpret_casts to WriteArray and Object | Zach Hilman | 1 | -2/+2 | |
Allows these functions to compile when T is not u8. | |||||
2018-12-27 | kernel/vm_manager: Reset region attributes when unmapping a VMA | Lioncash | 1 | -0/+1 | |
Like the other members related to memory regions, the attributes need to be reset back to their defaults as well. | |||||
2018-12-26 | configure_per_general: Mark UI strings as translatable in the constructor | Lioncash | 1 | -2/+2 | |
These are user-facing strings, so they should be translatable. | |||||
2018-12-26 | configure_input_simple: Make input profile array constexpr | Lioncash | 1 | -12/+7 | |
Calling tr() from a file-scope array isn't advisable, since it can be executed before the Qt libraries are even fully initialized, which can lead to crashes. Instead, the translatable strings should be annotated, and the tr() function should be called at the string's usage site. | |||||
2018-12-26 | renderer_opengl: Correct forward declaration of FramebufferLayout | Lioncash | 1 | -1/+1 | |
This is actually a struct, not a class, which can lead to compilation warnings. | |||||
2018-12-26 | Apply CC test to the final value to be stored in the register | Rodolfo Bogado | 1 | -9/+12 | |
2018-12-26 | Fixed shader linking error due to TLDS (#1934) | David | 1 | -1/+1 | |
* Fixed shader linking error due to TLDS coord should be coords * Fix remaining coords | |||||
2018-12-26 | npad: Remove code to invert input in horizontal mode. | bunnei | 1 | -46/+0 | |
- This was incorrect, the game appears to handle this for us. - Fixes horizontal mode with Puyo Puyo Tetris and Super Mario Odyssey. | |||||
2018-12-26 | shader_bytecode: Fixup TEXS.F16 encoding | ReinUsesLisp | 1 | -1/+1 | |
2018-12-25 | qt: Use ProfileSelectionDialog when selecting user for save data | Zach Hilman | 1 | -22/+16 | |
This allows us to present a much nicer UI to the user over a simple combo box and is made easy with the modular nature of the profile-selection applet frontend. | |||||
2018-12-25 | qt: Add setting to prompt for user on game boot | Zach Hilman | 6 | -0/+32 | |
Using the QtProfileSelectorDialog, this implementation is trivial. This mimics the real switch behavior of asking which user on every game boot, but it is default disabled as that might get inconvenient. | |||||
2018-12-22 | Includde saturation in the evaluation of the control code | Rodolfo Bogado | 1 | -3/+4 | |
2018-12-22 | Handle RZ cases evaluating the expression instead of the register value. | Rodolfo Bogado | 1 | -14/+22 | |
2018-12-22 | complete emulation of ZeroFlag | Rodolfo Bogado | 1 | -100/+97 | |
2018-12-21 | common/quaternion: Ensure that w is always initialized | Lioncash | 1 | -1/+1 | |
Previously xyz was always being zero initialized due to its constructor, but w wasn't. Ensures that we always have a deterministic initial state. | |||||
2018-12-21 | hid: Fix SetNpadJoyHoldType and improve logging. | bunnei | 1 | -44/+163 | |
2018-12-21 | kernel/process: Hook up the process capability parser to the process itself | Lioncash | 7 | -122/+44 | |
While we're at it, we can also toss out the leftover capability parsing from Citra. | |||||
2018-12-21 | kernel/process_capability: Handle debug capability flags | Lioncash | 2 | -1/+18 | |
2018-12-21 | kernel/process_capability: Handle handle table capability flags | Lioncash | 2 | -1/+11 | |
This just specifies the handle table size. There's also a section of reserved bits that are checked against. | |||||
2018-12-21 | kernel/process_capability: Handle kernel version capability flags | Lioncash | 2 | -1/+18 | |
2018-12-21 | kernel/process_capability: Handle program capability flags | Lioncash | 3 | -2/+29 | |
2018-12-21 | kernel/process_capability: Handle interrupt capability flags | Lioncash | 1 | -1/+21 | |
Similar to the service capability flags, however, we currently don't emulate the GIC, so this currently handles all interrupts as being valid for the time being. | |||||
2018-12-21 | kernel/process_capability: Handle syscall capability flags | Lioncash | 2 | -1/+29 | |
2018-12-21 | kernel/process_capability: Handle the priority mask and core mask flags | Lioncash | 2 | -1/+40 | |
Handles the priority mask and core mask flags to allow building up the masks to determine the usable thread priorities and cores for a kernel process instance. | |||||
2018-12-21 | kernel/process: Introduce process capability parsing skeleton | Lioncash | 5 | -3/+468 | |
We've had the old kernel capability parser from Citra, however, this is unused code and doesn't actually map to how the kernel on the Switch does it. This introduces the basic functional skeleton for parsing process capabilities. | |||||
2018-12-21 | common: Add basic bit manipulation utility function to Common | Lioncash | 2 | -0/+62 | |
2018-12-19 | kernel/svc: Handle thread handles within GetProcessId | Lioncash | 1 | -10/+23 | |
If a thread handle is passed to svcGetProcessId, the kernel attempts to access the process ID via the thread's instance's owning process. Technically, this function should also be handling the kernel debug objects as well, however we currently don't handle those kernel objects yet, so I've left a note via a comment about it to remind myself when implementing it in the future. | |||||
2018-12-19 | svc: Implement svcSetMemoryAttribute | Lioncash | 1 | -5/+46 | |
With all the basic backing functionality implemented, we can now unstub svcSetMemoryAttribute. | |||||
2018-12-19 | vm_manager: Add member function for setting memory attributes across an address range | Lioncash | 2 | -0/+41 | |
This puts the backing functionality for svcSetMemoryAttribute in place, which will be utilized in a following change. | |||||
2018-12-19 | vm_manager: Add member function for checking a memory range adheres to certain attributes, permissions and states | Lioncash | 2 | -0/+100 | |
2018-12-19 | kernel/kernel: Use correct initial PID for userland Process instances | Lioncash | 2 | -4/+14 | |
Starts the process ID counter off at 81, which is what the kernel itself checks against internally when creating processes. It's actually supposed to panic if the PID is less than 81 for a userland process. | |||||
2018-12-19 | kernel/svc: Correct output parameter for svcGetThreadId | Lioncash | 1 | -1/+1 | |
The service call uses a 64-bit value, just like svcGetProcessId. This amends the function signature accordingly. | |||||
2018-12-19 | kernel/thread: Make thread_id a 64-bit value | Lioncash | 4 | -7/+7 | |
The kernel uses a 64-bit value for the thread ID, so we shouldn't be using a 32-bit value. | |||||
2018-12-19 | kernel/svc: Correct output parameter for svcGetProcessId | Lioncash | 2 | -2/+10 | |
svcGetProcessId's out parameter is a pointer to a 64-bit value, not a 32-bit one. | |||||
2018-12-19 | kernel/process: Make process_id a 64-bit value | Lioncash | 3 | -6/+6 | |
In the actual kernel, this is a 64-bit value, so we shouldn't be using a 32-bit type to handle it. | |||||
2018-12-19 | Device handle should not be a random id, instead it's the current npad id | David Marcec | 1 | -2/+2 | |
Found during hardware testing | |||||
2018-12-19 | Moved backtrace to ArmInterface | David Marcec | 8 | -47/+20 | |
2018-12-19 | hopefully fix clang format issue | David Marcec | 1 | -0/+1 | |
2018-12-19 | Fixed uninitialized memory due to missing returns in canary | David Marcec | 14 | -3/+33 | |
Functions which are suppose to crash on non canary builds usually don't return anything which lead to uninitialized memory being used. | |||||
2018-12-19 | service/sm: Improve debug log for RegisterService | Lioncash | 1 | -4/+5 | |
Now it also indicates the name and max session count. This also gives a name to the unknown bool. This indicates if the created port is supposed to be using light handles or regular handles internally. This is passed to the respective svcCreatePort parameter internally. | |||||
2018-12-18 | yuzu, video_core: Screenshot functionality | zhupengfei | 15 | -43/+228 | |
Allows capturing screenshot at the current internal resolution (native for software renderer), but a setting is available to capture it in other resolutions. The screenshot is saved to a single PNG in the current layout. | |||||
2018-12-18 | Texture format fixes: Flag RGBA16UI as GL_RGBA_INTEGER format, and interpret R16U as Z16 when depth_compare is enabled. | heapo | 1 | -1/+11 | |
2018-12-18 | kernel/thread: Set default fpcr | MerryMage | 1 | -0/+3 | |
2018-12-18 | arm_dynarmic: Set CNTFRQ value | MerryMage | 1 | -0/+1 | |
2018-12-18 | shader_bytecode: Fixup half float's operator B encoding | ReinUsesLisp | 1 | -1/+1 | |
2018-12-18 | service/am: Unstub GetAppletResourceUserId | Lioncash | 1 | -2/+5 | |
This is supposed to return the current process' ID. (0 indicates an invalid ID for both process IDs and ARU IDs). | |||||
2018-12-17 | Implement postfactor multiplication/division for fmul instructions | heapo | 2 | -5/+21 | |
2018-12-17 | Fix arrayed shadow sampler array slice/depth comparison ordering, as well as invalid GLSL LOD selection. | heapo | 1 | -16/+14 | |
2018-12-16 | vm_manager: Rename meminfo_state to state | Lioncash | 2 | -10/+9 | |
This is shorter and more concise. This also removes the now-innaccurate comment, as it's not returned wholesale to svcQueryMemory anymore. | |||||
2018-12-16 | vm_manager: Add backing functionality for memory attributes | Lioncash | 2 | -1/+85 | |
Adds the barebones enumeration constants and functions in place to handle memory attributes, while also essentially leaving the attribute itself non-functional. | |||||
2018-12-15 | nvhost_gpu: Skip empty GPU command lists. | bunnei | 1 | -0/+4 | |
2018-12-13 | audio_core: Make g_sink_details internally linked | Lioncash | 7 | -36/+58 | |
We can hide the direct array from external view and instead provide functions to retrieve the necessary info. This has the benefit of completely hiding the makeup of the SinkDetails structure from the rest of the code. Given that this makes the array hidden, we can also make the array constexpr by altering the members slightly. This gets rid of several static constructor calls related to std::vector and std::function. Now we don't have heap allocations here that need to occur before the program can even enter main(). It also has the benefit of saving a little bit of heap space, but this doesn't matter too much, since the savings in that regard are pretty tiny. | |||||
2018-12-13 | Fix Service object leak on emulation stop | Jens Schmer | 2 | -10/+12 | |
Services created with the ServiceFramework base class install themselves as HleHandlers with an owning shared_ptr in the ServerPort ServiceFrameworkBase::port member variable, creating a cyclic ownership between ServiceFrameworkBase and the ServerPort, preventing deletion of the service objects. Fix that by removing the ServiceFrameworkBase::port member because that was only used to detect multiple attempts at installing a port. Instead store a flag if the port was already installed to achieve the same functionality. | |||||
2018-12-12 | svc: Enable svcQueryProcessMemory | Lioncash | 2 | -1/+6 | |
svcQueryProcessMemory is trivial to implement, given all the behavior necessary for it is present, it just needs a handler for it. | |||||
2018-12-12 | svc: Write out the complete MemoryInfo structure in QueryProcessMemory | Lioncash | 1 | -0/+3 | |
In the previous change, the memory writing was moved into the service function itself, however it still had a problem, in that the entire MemoryInfo structure wasn't being written out, only the first 32 bytes of it were being written out. We still need to write out the trailing two reference count members and zero out the padding bits. Not doing this can result in wrong behavior in userland code in the following scenario: MemoryInfo info; // Put on the stack, not quaranteed to be zeroed out. svcQueryMemory(&info, ...); if (info.device_refcount == ...) // Whoops, uninitialized read. This can also cause the wrong thing to happen if the user code uses std::memcmp to compare the struct, with another one (questionable, but allowed), as the padding bits are not guaranteed to be a deterministic value. Note that the kernel itself also fully zeroes out the structure before writing it out including the padding bits. | |||||
2018-12-12 | svc: Handle memory writing explicitly within QueryProcessMemory | Lioncash | 2 | -26/+22 | |
Moves the memory writes directly into QueryProcessMemory instead of letting the wrapper function do it. It would be inaccurate to allow the handler to do it because there's cases where memory shouldn't even be written to. For example, if the given process handle is invalid. HOWEVER, if the memory writing is within the wrapper, then we have no control over if these memory writes occur, meaning in an error case, 68 bytes of memory randomly get trashed with zeroes, 64 of those being written to wherever the memory info address points to, and the remaining 4 being written wherever the page info address points to. One solution in this case would be to just conditionally check within the handler itself, but this is kind of smelly, given the handler shouldn't be performing conditional behavior itself, it's a behavior of the managed function. In other words, if you remove the handler from the equation entirely, does the function still retain its proper behavior? In this case, no. Now, we don't potentially trash memory from this function if an invalid query is performed. | |||||
2018-12-12 | vm_manager: Correct ordering of last two struct members of MemoryInfo | Lioncash | 1 | -2/+2 | |
These should be swapped. | |||||
2018-12-12 | svc_wrap: Correct register index for a wrapper specialization | Lioncash | 1 | -1/+1 | |
This would result in svcSetMemoryAttribute getting the wrong value for its third parameter. This is currently fine, given the service function is stubbed, however this will be unstubbed in a future change, so this needs to change. | |||||
2018-12-12 | vm_manager: Amend the returned values for invalid memory queries in QueryMemory() | Lioncash | 2 | -4/+7 | |
The kernel returns a memory info instance with the base address set to the end of the address space, and the size of said block as 0 - address_space_end, it doesn't set both of said members to zero. | |||||
2018-12-12 | vm_manager: Migrate memory querying to the VMManager interface | Lioncash | 4 | -18/+33 | |
Gets rid of the need to directly access the managed VMAs outside of the memory manager itself just for querying memory. | |||||
2018-12-12 | vm_manager: Migrate MemoryInfo and PageInfo to vm_manager.h | Lioncash | 3 | -17/+16 | |
Gets the two structures out of an unrelated header and places them with the rest of the memory management code. This also corrects the structures. PageInfo appears to only contain a 32-bit flags member, and the extra padding word in MemoryInfo isn't necessary. | |||||
2018-12-12 | vm_manager: Amend MemoryState enum members | Lioncash | 5 | -28/+111 | |
Amends the MemoryState enum to use the same values like the actual kernel does. Also provides the necessary operators to operate on them. This will be necessary in the future for implementing svcSetMemoryAttribute, as memory block state is checked before applying the attribute. | |||||
2018-12-12 | Fix Process object leak on emulation stop | Jens Schmer | 3 | -13/+12 | |
The Process object kept itself alive indefinitely because its handle_table contains a SharedMemory object which owns a reference to the same Process object, creating a circular ownership scenario. Break that up by storing only a non-owning pointer in the SharedMemory object. | |||||
2018-12-11 | patch_manager: Prevent use of a dangling pointer within PatchRomFS | Lioncash | 1 | -4/+3 | |
fmt::format() returns a std::string instance by value, so calling .c_str() on it here is equivalent to doing: auto* ptr = std::string{}.c_str(); The data being pointed to isn't guaranteed to actually be valid anymore after that expression ends. Instead, we can just take the string as is, and provide the necessary formatting parameters. | |||||
2018-12-11 | gl_shader_cache: Dehardcode constant in CalculateProgramSize() | Lioncash | 1 | -2/+2 | |
This constant is related to the size of the instruction. | |||||
2018-12-11 | gl_shader_cache: Resolve truncation compiler warning | Lioncash | 1 | -1/+1 | |
The previous code would cause a warning, as it was truncating size_t (64-bit) to a u32 (32-bit) implicitly. | |||||
2018-12-10 | fsp_srv: Implement IStorage::GetSize | Zach Hilman | 1 | -2/+15 | |
Takes no input and returns the size as a u64. Needed by Katamari Damacy Reroll to boot. | |||||
2018-12-10 | gl_shader_decompiler: IPA FrontFacing: the right value when is the front face is 0xFFFFFFFF. | Marcos Vitali | 1 | -1/+1 | |
2018-12-10 | service/fsp_srv: Correct returned value in GetGlobalAccessLogMode() | Lioncash | 1 | -1/+10 | |
Based off RE, the backing code only ever seems to use 0-2 as the range of values 1 being a generic log enable, with 2 indicating logging should go to the SD card. These are used as a set of flags internally. Given we only care about receiving the log in general, we can just always signify that we want logging in general. | |||||
2018-12-10 | applets: Correct usage of SignalStateChanged event | Zach Hilman | 3 | -6/+4 | |
This was causing some games (most notably Pokemon Quest) to softlock due to an event being fired when not supposed to. This also removes a hack wherein we were firing the state changed event when the game retrieves it, which is incorrect. | |||||
2018-12-09 | Implemented a shader unique identifier. | Fernando Sahmkow | 4 | -0/+57 | |
2018-12-09 | Add more info into textures' object labels | FernandoS27 | 2 | -2/+57 | |
2018-12-08 | web_service: move telemetry condition from TelemetrySession constructor to destructor | fearlessTobi | 1 | -8/+4 | |
Fixes an issue where Testcases couldn't be sent when Telemetry was disabled, because both things are tied closely together in the backend. | |||||
2018-12-08 | file_sys/save_data_factory: Update SaveDataSpaceId enum | Lioncash | 1 | -1/+3 | |
Amends it with missing values deduced from RE (ProperSystem being from SwitchBrew for naming) (SdCardUser wasn't that difficult to discern given it's used alongside SdCardSystem when creating the save data indexer, based off the usage of the string "saveDataIxrDbSd" nearby). | |||||
2018-12-07 | gl_shader_decompiler: TLDS/TLD4/TLD4S Reworked reflecting the source registers, bugs fixed and modularize. | Marcos Vitali | 1 | -106/+134 | |
2018-12-07 | Backport review comment from citra-emu/citra#4418 | Tobias | 1 | -2/+2 | |
Original reason: As Windows multi-byte character codec is unspecified while we always assume std::string uses UTF-8 in our code base, this can output gibberish when the string contains non-ASCII characters. ::OutputDebugStringW combined with Common::UTF8ToUTF16W is preferred here. | |||||
2018-12-07 | savedata_factory: Add support for CacheStorage | Zach Hilman | 1 | -0/+2 | |
2018-12-07 | savedata_factory: Delete TemporaryStorage on startup | Zach Hilman | 1 | -1/+5 | |
Mimics hardware behavior. | |||||
2018-12-06 | memory: Convert ASSERT into a DEBUG_ASSERT within GetPointerFromVMA() | Lioncash | 1 | -1/+1 | |
Given memory should always be expected to be valid during normal execution, this should be a debug assertion, rather than a check in regular builds. | |||||
2018-12-06 | vm_manager: Make vma_map private | Lioncash | 5 | -28/+41 | |
This was only ever public so that code could check whether or not a handle was valid or not. Instead of exposing the object directly and allowing external code to potentially mess with the map contents, we just provide a member function that allows checking whether or not a handle is valid. This makes all member variables of the VMManager class private except for the page table. | |||||
2018-12-06 | Avoid (expensive) audio interpolation when sample rates already match | heapo | 2 | -4/+8 | |
2018-12-06 | system_archive: Implement open source NgWord2 | Zach Hilman | 3 | -1/+41 | |
2018-12-06 | hle/service: Replace log + UNIMPLEMENTED with UNIMPLEMENTED_MSG | Lioncash | 1 | -2/+1 | |
Combines the two into one, shortening the amount of code here. | |||||
2018-12-06 | hle/service: Remove unnecessary using declarations | Lioncash | 1 | -5/+1 | |
Only one usage of the specified objects made use of the lack of namespacing. Given the low usage, we can just remove these. | |||||
2018-12-06 | hle/service, hle/sm: Compress usages of MakeResult() | Lioncash | 2 | -3/+3 | |
These auto-deduce the result based off its arguments, so there's no need to do that work for the compiler, plus, the function return value itself already indicates what we're returning. | |||||
2018-12-06 | hle/service, hle/sm: Use structured bindings where applicable | Lioncash | 2 | -9/+3 | |
Gets rid of the need to keep the variables separate from their actual initialization spots. | |||||
2018-12-06 | yuzu/wait_tree: Pass QString by value and std::move in the initializer list for WaitTreeText | Lioncash | 2 | -2/+2 | |
Just a trivial modernization that potentially avoids copying strings in certain scenarios. | |||||
2018-12-05 | yuzu/game_list_worker: Don't retrieve the file type twice in AddFstEntriesToGameList() | Lioncash | 1 | -5/+9 | |
Similarly, here we can avoid doing unnecessary work twice by retrieving the file type only once and comparing it against relevant operands, avoiding potential unnecessary object construction/destruction. | |||||
2018-12-05 | yuzu/game_list_worker: Don't retrieve file type and file type strings twice in MakeGameListEntry() | Lioncash | 1 | -4/+6 | |
While GetFileType() is indeed a getter function, that doesn't mean it's a trivial function, given some case require reading from the data or constructing other objects in the background. Instead, only do necessary work once. | |||||
2018-12-05 | loaders: Make GetFileType() a const qualified member function | Lioncash | 10 | -10/+10 | |
No implementations actually modify instance state (and it would be questionable to do that in the first place given the name), so we can make this a const member function. | |||||
2018-12-05 | Call shrink_to_fit after page-table vector resizing to cause crt to actually lower vector capacity. For 36-bit titles saves 800MB of commit. | heapo | 1 | -0/+8 | |
2018-12-05 | kernel/process: Set ideal core from metadata | Lioncash | 1 | -0/+1 | |
A very trivial change. If metadata is available, the process should use it to retrieve the desired core for the process to run on. | |||||
2018-12-05 | configure_input_simple: Properly signal docked mode change | Zach Hilman | 3 | -33/+31 | |
2018-12-05 | configure_input: Add ConfigureInputSimple as default input UI config | Zach Hilman | 8 | -1/+293 | |
Greatly simplifies the current input UI, while still allowing power users to tweak advanced settings. Adds 'input profiles', which are easy autoconfigurations to make getting started easy and fast. Also has a custom option which brings up the current, full UI. | |||||
2018-12-05 | configure_input: Convert into QDialog | Zach Hilman | 3 | -7/+47 | |
2018-12-05 | configure: Use ConfigureInputSimple for Input tab | Zach Hilman | 1 | -26/+26 | |
2018-12-05 | ui_settings: Add UI setting for input profile index | Zach Hilman | 2 | -0/+5 | |
2018-12-05 | configuration/config: Use an intermediary variable for accessing players | Lioncash | 1 | -43/+38 | |
Avoids typing the same long accessor just to retrieve player attributes. | |||||
2018-12-05 | ng_word: Deduplicate use of a constant value | Lioncash | 1 | -1/+1 | |
We've already given the constant to the vector itself, so we don't need to re-hardcode it in the array. | |||||
2018-12-05 | system_archive: Use a regular function pointer instead of std::function for file-scope system archive array | Lioncash | 1 | -3/+2 | |
This allows the array to be constexpr. std::function is also allowed to allocate memory, which makes its constructor non-trivial, we definitely don't want to have all of these execute at runtime, taking up time before the application can actually load. | |||||
2018-12-05 | service/ldr: Deduplicate instruction cache clearing code in LoadNro() | Lioncash | 1 | -8/+2 | |
We don't need to specify all of the ARM interfaces explicitly. | |||||
2018-12-05 | service/ldr: Amend layout of the NRO header | Lioncash | 1 | -3/+3 | |
The first word is just a padding byte, it's not an actual entry instruction. Also renames the rest of the entries according to SwitchBrew. | |||||
2018-12-05 | gl_shader_decompiler: Implement TEXS.F16 | ReinUsesLisp | 2 | -13/+51 | |
2018-12-05 | service/ldr: Corrent padding within the NRR header layout | Lioncash | 1 | -1/+2 | |
The padding after the magic signature value should be 12 bytes rather than 28 bytes. The other 16 should be placed after the title ID pattern. | |||||
2018-12-05 | gl_shader_decompiler: Fixup inverted if | ReinUsesLisp | 1 | -6/+5 | |
2018-12-05 | svc: Avoid incorrect fast yield condition | Zach Hilman | 1 | -6/+1 | |
2018-12-05 | kernel/svc: Correct behavior of svcResetSignal() | Lioncash | 1 | -4/+11 | |
While partially correct, this service call allows the retrieved event to be null, as it also uses the same handle to check if it was referring to a Process instance. The previous two changes put the necessary machinery in place to allow for this, so we can simply call those member functions here and be done with it. | |||||
2018-12-05 | kernel/process: Make Process a WaitObject | Lioncash | 3 | -6/+68 | |
Process instances can be waited upon for state changes. This is also utilized by svcResetSignal, which will be modified in an upcoming change. This simply puts all of the WaitObject related machinery in place. | |||||
2018-12-05 | kernel/readable_event: Add member function for enforcing a strict reset contract | Lioncash | 2 | -1/+22 | |
svcResetSignal relies on the event instance to have already been signaled before attempting to reset it. If this isn't the case, then an error code has to be returned. | |||||
2018-12-05 | Improve msvc codegen for hot-path array LUTs | heapo | 1 | -275/+277 | |
In some constexpr functions, msvc is building the LUT at runtime (pushing each element onto the stack) out of an abundance of caution. Moving the arrays into be file-scoped constexpr's avoids this and turns the functions into simple look-ups as intended. | |||||
2018-12-05 | yuzu/game_list_worker: Move std::string construction after the termination check in callbacks | Lioncash | 1 | -7/+7 | |
Avoids potentially allocating a std::string instance when it isn't needed. | |||||
2018-12-04 | kernel/svc: Remove unused header inclusion | Lioncash | 1 | -1/+0 | |
2018-12-04 | kernel/svc: Implement svcSignalEvent() | Lioncash | 1 | -1/+16 | |
This function simply does a handle table lookup for a writable event instance identified by the given handle value. If a writable event cannot be found for the given handle, then an invalid handle error is returned. If a writable event is found, then it simply signals the event, as one would expect. | |||||
2018-12-04 | kernel/svc: Implement svcCreateEvent() | Lioncash | 2 | -1/+42 | |
svcCreateEvent operates by creating both a readable and writable event and then attempts to add both to the current process' handle table. If adding either of the events to the handle table fails, then the relevant error from the handle table is returned. If adding the readable event after the writable event to the table fails, then the writable event is removed from the handle table and the relevant error from the handle table is returned. Note that since we do not currently test resource limits, we don't check the resource limit table yet. | |||||
2018-12-04 | qt: Add Properties menu to game list right-click | Zach Hilman | 9 | -22/+54 | |
2018-12-04 | Rewrited TEX/TEXS (TEX Scalar). (#1826) | Marcos | 1 | -259/+177 | |
* Rewrited TEX/TEXS (TEX Scalar). * Style fixes. * Styles issues. | |||||
2018-12-04 | debugger: Set paused thread color | Luke Street | 1 | -1/+2 | |
2018-12-04 | kernel/object: Amend handle types to distinguish between readable and writable events | Lioncash | 6 | -11/+20 | |
Two kernel object should absolutely never have the same handle ID type. This can cause incorrect behavior when it comes to retrieving object types from the handle table. In this case it allows converting a WritableEvent into a ReadableEvent and vice-versa, which is undefined behavior, since the object types are not the same. This also corrects ClearEvent() to check both kernel types like the kernel itself does. | |||||
2018-12-04 | kernel/handle_table: Amend reference to CTR-OS in Create() | Lioncash | 1 | -2/+3 | |
Another hold-over from Citra. | |||||
2018-12-04 | kernel/svc: Implement the resource limit svcGetInfo option | Lioncash | 4 | -9/+34 | |
Allows a process to register the resource limit as part of its handle table. | |||||
2018-12-04 | svc: Implement SetThreadActivity (thread suspension) | Luke Street | 5 | -6/+76 | |
2018-12-04 | Removed unused file. | Subv | 1 | -142/+0 | |
This is a leftover from #1792 | |||||
2018-12-04 | GPU: Don't try to route PFIFO methods (0-0x40) to the other engines. | Subv | 1 | -0/+6 | |
2018-12-04 | [Kernel::CreateThread] Match format specifiers to LOG_TRACE's arguments | V.Kalyuzhny | 1 | -1/+1 | |
2018-12-04 | scheduler: Avoid manual Reschedule call | Zach Hilman | 2 | -11/+11 | |
This will automatically occur anyway when PrepareReschedule is called | |||||
2018-12-03 | scheduler: Only work steal higher priority threads from other cores | Zach Hilman | 3 | -35/+24 | |
2018-12-03 | applets: Correct event ResetTypes from OneShot to Sticky | Zach Hilman | 5 | -14/+6 | |
Fixes bugs relating to signalling in software keyboard. | |||||
2018-12-03 | qt: Implement GUI dialog frontend for ProfileSelector | Zach Hilman | 6 | -0/+269 | |
Presents profiles in a list, similar to switch. | |||||
2018-12-03 | am: Use ProfileSelect applet | Zach Hilman | 1 | -0/+4 | |
2018-12-03 | applets: Implement ProfileSelect applet | Zach Hilman | 2 | -0/+130 | |
Allows the player to select an emulated profile. | |||||
2018-12-03 | qt: Register to use Qt ProfileSelector instead of default | Zach Hilman | 1 | -0/+2 | |
2018-12-03 | core: Add getter/setter for ProfileSelector in System | Zach Hilman | 2 | -0/+16 | |
2018-12-03 | frontend: Add frontend applet for ProfileSelect | Zach Hilman | 3 | -0/+48 | |
Responsible for selecting a profile and firing callback upon completion. | |||||
2018-12-03 | software_keyboard: Signal state changed event upon construction | Zach Hilman | 1 | -1/+6 | |
Previously, ILibraryAppletAccessor would signal upon creation of any applet, but this is incorrect. A flag inside of the applet code determines whether or not creation should signal state change and swkbd happens to be one of these applets. | |||||
2018-12-03 | qt: Add UI to display game properties and disable add-ons | Zach Hilman | 4 | -0/+501 | |
2018-12-03 | loader: Add support for reading the name of game's developer | Zach Hilman | 5 | -0/+26 | |
2018-12-03 | aoc_u: Obey disabled add-ons list when listing DLC | Zach Hilman | 1 | -0/+12 | |
2018-12-03 | patch_manager: Obey disabled add-ons list when patching game | Zach Hilman | 2 | -11/+50 | |
2018-12-03 | core: Make GetGameFileFromPath function externally accessible | Zach Hilman | 2 | -3/+9 | |
2018-12-03 | config: Store and load disabled add-ons list | Zach Hilman | 3 | -0/+55 | |
2018-12-03 | settings: Store list of disabled add-ons per title ID | Zach Hilman | 1 | -0/+5 | |
2018-12-03 | game_list: Remove a reference of a reference | Frederic Laing | 1 | -2/+2 | |
2018-12-03 | Moved backtrace to ArmInterface | David Marcec | 6 | -14/+39 | |
Added to both dynarmic and unicorn | |||||
2018-12-03 | Print backtrace on svcBreak | David Marcec | 3 | -0/+24 | |
When we get an svcBreak we get a backtrace now | |||||
2018-12-03 | loader/nso: Remove dependency on the System class | Lioncash | 3 | -8/+11 | |
Similar to the NRO changes, we can also pass the process explicitly as a parameter from Load instead of indirecting through the System class. | |||||
2018-12-03 | loader/nro: Make the static LoadNro function internally linked | Lioncash | 2 | -7/+5 | |
This simply acts as a forwarding function for the Load() function, so this doesn't need to be directly exposed. | |||||
2018-12-03 | file_sys/directory: Amend path buffer size for directory entries | Lioncash | 1 | -2/+2 | |
The path buffer is actually 0x301 (769) characters in length, with the extra character being intended for the null-terminator. | |||||
2018-12-03 | loader/nro: Remove dependency on the System class | Lioncash | 2 | -10/+13 | |
Load() is already given the process instance as a parameter, so instead of coupling the class to the System class, we can just forward that parameter to LoadNro() | |||||
2018-12-02 | service/usb: Update function table | Lioncash | 1 | -1/+1 | |
Updates the function table for IClientEpSession based off information provided by SwitchBrew. | |||||
2018-12-02 | service/erpt: Update function table | Lioncash | 1 | -5/+7 | |
Updates the function table according to information provided by SwitchBrew. | |||||
2018-12-02 | yuzu/configuration: Make slots private where applicable | Lioncash | 5 | -7/+2 | |
These slots are only ever attached to event handling mechanisms within the class itself, they're never used externally. Because of this, we can make the functions private. This also removes redundant usages of the private access specifier. | |||||
2018-12-02 | yuzu/configuration: Add missing override specifiers to configuration-related classes | Lioncash | 7 | -7/+7 | |
Resolves trivial compiler warnings. | |||||
2018-12-02 | yuzu/configuration/configure_input: Default destructor in the cpp file | Lioncash | 2 | -0/+3 | |
The previous code could potentially be a compilation issue waiting to occur, given we forward declare the type for a std::unique_ptr. If the complete definition of the forward declared type isn't visible in a translation unit that the class is used in, then it would fail to compile. Defaulting the destructor in a cpp file ensures the std::unique_ptr's destructor is only invoked where its complete type is known. | |||||
2018-12-02 | Fixed crash with SetNpadMode | David Marcec | 1 | -2/+3 | |
fixed crash due to handheld | |||||
2018-12-02 | svc: Use the current process' handle table for retrieving the process instance to act upon | Lioncash | 1 | -1/+2 | |
The kernel uses the handle table of the current process to retrieve the process that should be used to retrieve certain information. To someone not familiar with the kernel, this might raise the question of "Ok, sounds nice, but doesn't this make it impossible to retrieve information about the current process?". No, it doesn't, because HandleTable instances in the kernel have the notion of a "pseudo-handle", where certain values allow the kernel to lookup objects outside of a given handle table. Currently, there's only a pseudo-handle for the current process (0xFFFF8001) and a pseudo-handle for the current thread (0xFFFF8000), so to retrieve the current process, one would just pass 0xFFFF8001 into svcGetInfo. The lookup itself in the handle table would be something like: template <typename T> T* Lookup(Handle handle) { if (handle == PSEUDO_HANDLE_CURRENT_PROCESS) { return CurrentProcess(); } if (handle == PSUEDO_HANDLE_CURRENT_THREAD) { return CurrentThread(); } return static_cast<T*>(&objects[handle]); } which, as is shown, allows accessing the current process or current thread, even if those two objects aren't actually within the HandleTable instance. | |||||
2018-12-02 | svc: Reorganize svcGetInfo, handle more error cases for existing implemented info categories | Lioncash | 1 | -50/+99 | |
Our implementation of svcGetInfo was slightly incorrect in that we weren't doing proper error checking everywhere. Instead, reorganize it to be similar to how the kernel seems to do it. | |||||
2018-12-02 | svc: Avoid performance-degrading unnecessary reschedule | Zach Hilman | 2 | -8/+6 | |
2018-12-02 | service/audio/audout_u: Amend constructor initialization list order | Lioncash | 1 | -2/+2 | |
Orders the constructor initializer list the same way the members of the class are declared. Prevents -Wreorder warnings | |||||
2018-12-02 | file_sys/registered_cache: Eliminate variable shadowing | Lioncash | 1 | -27/+26 | |
Also inverts if statements where applicable to allow unindenting code a little bit. | |||||
2018-12-02 | filesystem: De-globalize registered_cache_union | Lioncash | 8 | -40/+26 | |
We can just return a new instance of this when it's requested. This only ever holds pointers to the existing registed caches, so it's not a large object. Plus, this also gets rid of the need to keep around a separate member function just to properly clear out the union. Gets rid of one of five globals in the filesystem code. | |||||
2018-12-02 | yuzu/game_list_worker: Deduplicate game list entry creation | Lioncash | 1 | -47/+33 | |
Avoids duplicating the same code twice verbatim. | |||||
2018-12-02 | yuzu/game_list_worker: Tidy up string handling in FillControlMap() | Lioncash | 1 | -6/+7 | |
We don't need to call out to our own file handling functions when we're going to construct a QFileInfo instance right after it. We also don't need to convert to a std::string again just to compare the file extension. | |||||
2018-12-02 | crypto/key_manager: Remove unused variable in GetTicketblob() | Lioncash | 1 | -1/+0 | |
2018-12-01 | Fix debug build | Lioncash | 2 | -5/+3 | |
A non-existent parameter was left in some formatting calls (the logging macro for which only does anything meaningful on debug builds) | |||||
2018-12-01 | file_sys: Override missing mutating functions to be stubbed out for ReadOnlyVfsDirectory by default | Lioncash | 2 | -0/+25 | |
Ensures that read only indeed means read only. | |||||
2018-12-01 | service/fsp_srv: Implement CleanDirectoryRecursively | Lioncash | 5 | -5/+72 | |
This is the same behavior-wise as DeleteDirectoryRecursively, with the only difference being that it doesn't delete the top level directory in the hierarchy, so given: root_dir/ - some_dir/ - File.txt - OtherFile.txt The end result is just: root_dir/ | |||||
2018-11-30 | remove border from GameList | Bartosz Kaszubowski | 1 | -0/+1 | |
2018-11-30 | Services/VI: Dereferencing an uninitialized std::optional is undefined behavior. | Subv | 1 | -0/+2 | |
Assert that it is not empty before using it in the DequeueBuffer wait callback. | |||||
2018-11-30 | service/set: Convert GetLanguageCode over to using PushEnum() | Lioncash | 1 | -1/+1 | |
This code was around prior to the introduction of PushEnum, so convert it over so we don't need to cast here. | |||||
2018-11-30 | service/set: Implement MakeLanguageCode | Lioncash | 2 | -1/+19 | |
This function simply converts a given index into a language code. | |||||
2018-11-30 | configure_input: Amend clang-format discrepancies | Lioncash | 1 | -1/+1 | |
2018-11-30 | gl_rasterizer_cache: Update AccurateCopySurface to flush complete source surface. | bunnei | 1 | -1/+4 | |
- Fixes issues with Breath of the Wild with use_accurate_gpu_emulation setting. | |||||
2018-11-29 | gl_rasterizer: Enable clip distances when set in register and in shader | ReinUsesLisp | 5 | -13/+37 | |
2018-11-29 | gl_rasterizer: Implement a framebuffer cache | ReinUsesLisp | 2 | -40/+82 | |
2018-11-29 | gl_shader_manager: Update pipeline when programs have changed | ReinUsesLisp | 1 | -4/+17 | |
2018-11-29 | hle_ipc: Refactor SleepClientThread to avoid ReadableEvent | Zach Hilman | 9 | -14/+14 | |
2018-11-29 | kernel/event: Reference ReadableEvent from WritableEvent | Zach Hilman | 32 | -317/+175 | |
2018-11-29 | core: Port all current usages of Event to Readable/WritableEvent | Zach Hilman | 29 | -164/+287 | |
2018-11-29 | hle_ipc: Use event pair for SleepClientThread | Zach Hilman | 2 | -19/+22 | |
2018-11-29 | kernel: Add named event table | Zach Hilman | 2 | -0/+30 | |
Used to store ReadableEvents of all events on the system. | |||||
2018-11-29 | kernel: Divide Event into ReadableEvent and WritableEvent | Zach Hilman | 6 | -61/+210 | |
More hardware accurate. On the actual system, there is a differentiation between the signaler and signalee, they form a client/server relationship much like ServerPort and ClientPort. | |||||
2018-11-29 | kernel/object: Add descriptions to ResetTypes | Zach Hilman | 1 | -3/+3 | |
2018-11-29 | gl_rasterizer_cache: Remove BlitSurface and replace with more accurate copy. | bunnei | 1 | -144/+1 | |
- BlitSurface with different texture targets is inherently broken. - When target is the same, we can just use FastCopySurface. - Fixes rendering issues with Breath of the Wild. | |||||
2018-11-29 | gl_shader_decompiler: Remove texture temporal in TLD4 | ReinUsesLisp | 1 | -3/+1 | |
2018-11-29 | gl_shader_decompiler: Flip negated if else statement | ReinUsesLisp | 1 | -3/+3 | |
2018-11-29 | gl_shader_decompiler: Use GLSL scope on instructions unrelated to textures | ReinUsesLisp | 1 | -35/+10 | |
2018-11-29 | gl_shader_decompiler: Move texture code generation into lambdas | ReinUsesLisp | 1 | -97/+78 | |
2018-11-29 | gl_shader_decompiler: Clean up texture instructions | ReinUsesLisp | 1 | -87/+56 | |
2018-11-29 | gl_shader_decompiler: Scope GLSL variables with a scoped object | ReinUsesLisp | 1 | -32/+72 | |
2018-11-29 | gl_rasterizer: Signal UNIMPLEMENTED when rt_separate_frag_data is not zero | ReinUsesLisp | 1 | -1/+1 | |
2018-11-29 | gl_rasterizer_cache: Use brackets for two-line single-expresion blocks | ReinUsesLisp | 1 | -1/+2 | |
2018-11-29 | gl_rasterizer: Remove unused struct declarations | ReinUsesLisp | 1 | -14/+0 | |
2018-11-29 | gl_rasterizer: Remove extension booleans | ReinUsesLisp | 4 | -16/+4 | |
2018-11-28 | npad: Use NPadIdToIndex to prevent invalid array access | Zach Hilman | 1 | -2/+2 | |
2018-11-28 | dma_pushbuffer: Optimize to avoid loop and copy on Push. | bunnei | 3 | -13/+23 | |
2018-11-28 | gpu: Move command list profiling to DmaPusher::DispatchCalls. | bunnei | 2 | -5/+5 | |
2018-11-27 | npad: Fix copy/paste error with LED position assignments | Zach Hilman | 1 | -3/+3 | |
2018-11-27 | yuzu/configure_input_player: Use std::size_t to represent the player index instead of u8 | Lioncash | 2 | -3/+3 | |
Prevents compiler warnings related to truncation when invoking the dialog. It's also extremely suspect to use a u8 value here instead of a more general type to begin with. | |||||
2018-11-27 | yuzu/configure_input: Make CallConfigureDialog a non-member template function | Lioncash | 3 | -21/+20 | |
This doesn't depend on any part of the private interface, so it can be made a non-member internal function. | |||||
2018-11-27 | file_sys/registered_cache: Remove unused <map> include | Lioncash | 1 | -1/+0 | |
2018-11-27 | file_sys/registered_cache: Use regular const references instead of std::shared_ptr for InstallEntry() | Lioncash | 3 | -32/+31 | |
These parameters don't need to utilize a shared lifecycle directly in the interface. Instead, the caller should provide a regular reference for the function to use. This also allows the type system to flag attempts to pass nullptr and makes it more generic, since it can now be used in contexts where a shared_ptr isn't being used (in other words, we don't constrain the usage of the interface to a particular mode of memory management). | |||||
2018-11-27 | gl_shader_decompiler: Fixup clip distance index | ReinUsesLisp | 1 | -1/+1 | |
2018-11-27 | control_metadata: Correct typo in language name (Portugese -> Portuguese) | Lioncash | 1 | -7/+17 | |
While we're at it, organize the array linearly, since clang formats the array elements quite wide length-wise with the addition of the missing 'u'. Technically also fixes patch lookup and icon lookup with Portuguese, though I doubt anyone has actually run into this issue. | |||||
2018-11-27 | yuzu/configure_input_player: Use a lambda expression instead of std::bind | Lioncash | 1 | -1/+1 | |
std::bind is the pre-C++11 way of doing this. | |||||
2018-11-27 | yuzu/configure_input_player: Amend constructor initializer list order | Lioncash | 1 | -4/+3 | |
Orders the elements the way they would actually be initialized in. Resolves compiler warnings with gcc and clang | |||||
2018-11-27 | yuzu/configure_input: Remove unused function MoveGridElement | Lioncash | 1 | -7/+0 | |
2018-11-27 | yuzu/configure_input*: Move data members after function declarations | Lioncash | 2 | -41/+42 | |
The common pattern is to put the data members after the function interface where applicable. | |||||
2018-11-27 | yuzu/configure_input: Remove unnecessary includes | Lioncash | 3 | -17/+3 | |
2018-11-27 | gl_rasterizer: Fixup for #1723. | Markus Wick | 1 | -1/+1 | |
On invalidating the streaming buffer, we need to reupload all vertex buffers. But we don't need to reconfigure the vertex format. This was a (silly) misstake in #1723. Thanks at Rodrigo for discovering the issue. Fun fact, as configuring the vertex format also invalidate the vertex buffer, this misstake had no affect on the behavior. | |||||
2018-11-27 | gpu: Rewrite GPU command list processing with DmaPusher class. | bunnei | 18 | -108/+353 | |
- More accurate impl., fixes Undertale (among other games). | |||||
2018-11-27 | remove viewport_transform_enabled as it seems to be inactive when valid transforms are used. | Rodolfo Bogado | 1 | -12/+5 | |
2018-11-27 | svc: Implement svcSetResourceLimitLimitValue() | Lioncash | 1 | -1/+36 | |
The opposite of the getter functions, this function sets the limit value for a particular ResourceLimit resource category, with the restriction that the new limit value must be equal to or greater than the current resource value. If this is violated, then ERR_INVALID_STATE is returned. e.g. Assume: current[Events] = 10; limit[Events] = 20; a call to this service function lowering the limit value to 10 would be fine, however, attempting to lower it to 9 in this case would cause an invalid state error. | |||||
2018-11-27 | svc: Implement svcGetResourceLimitCurrentValue() | Lioncash | 1 | -16/+49 | |
This kernel service function is essentially the exact same as svcGetResourceLimitLimitValue(), with the only difference being that it retrieves the current value for a given resource category using the provided resource limit handle, rather than retrieving the limiting value of that resource limit instance. Given these are exactly the same and only differ on returned values, we can extract the existing code for svcGetResourceLimitLimitValue() to handle both values. | |||||
2018-11-27 | morton: Fixup compiler warning | ReinUsesLisp | 1 | -1/+2 | |
2018-11-27 | svc: Implement svcGetResourceLimitLimitValue() | Lioncash | 2 | -2/+33 | |
This kernel service function retrieves the maximum allowable value for a provided resource category for a given resource limit instance. Given we already have the functionality added to the resource limit instance itself, it's sufficient to just hook it up. The error scenarios for this are: 1. If an invalid resource category type is provided, then ERR_INVALID_ENUM is returned. 2. If an invalid handle is provided, then ERR_INVALID_HANDLE is returned (bad thing goes in, bad thing goes out, as one would expect). If neither of the above error cases occur, then the out parameter is provided with the maximum limit value for the given category and success is returned. | |||||
2018-11-27 | svc: Implement svcCreateResourceLimit() | Lioncash | 2 | -1/+27 | |
This function simply creates a ResourceLimit instance and attempts to create a handle for it within the current process' handle table. If the kernal fails to either create the ResourceLimit instance or create a handle for the ResourceLimit instance, it returns a failure code (OUT_OF_RESOURCE, and HANDLE_TABLE_FULL respectively). Finally, it exits by providing the output parameter with the handle value for the ResourceLimit instance and returning that it was successful. Note: We do not return OUT_OF_RESOURCE because, if yuzu runs out of available memory, then new will currently throw. We *could* allocate the kernel instance with std::nothrow, however this would be inconsistent with how all other kernel objects are currently allocated. | |||||
2018-11-27 | Added comment on Main memory size for more clarity | David Marcec | 1 | -0/+1 | |
2018-11-27 | Made svcSetHeapSize and svcCreateSharedMemory more readable | David Marcec | 1 | -4/+4 | |
2018-11-27 | Reworked svcs slightly, improved error messages in AM and fsp_srv | David Marcec | 3 | -20/+30 | |
2018-11-27 | gdbstub: Silence value truncation warning within FpuWrite() | Lioncash | 1 | -1/+1 | |
Previously this would cause an implicit truncation warning about assigning a u64 value to a u32 value without an explicit cast. | |||||
2018-11-27 | Implement depth clamp | Rodolfo Bogado | 5 | -10/+58 | |
2018-11-27 | Add support for Clip Distance enabled register | Rodolfo Bogado | 3 | -3/+26 | |
2018-11-27 | GPU States: Implement Polygon Offset. This is used in SMO all the time. (#1784) | Marcos | 5 | -5/+107 | |
* GPU States: Implement Polygon Offset. This is used in SMO all the time. * Clang Format fixes. * Initialize polygon_offset in the constructor. | |||||
2018-11-26 | profile_manager: Save and load ProfileData from disk | Zach Hilman | 3 | -17/+19 | |
The ProfileData is a 0x80-sized structure that stores various pieces of miscellaneous data for the account. | |||||
2018-11-26 | Implemented Tile Width Spacing | FernandoS27 | 8 | -36/+55 | |
2018-11-26 | Fixed hwopus compile error | David Marcec | 1 | -1/+1 | |
2018-11-26 | Improved error messages in AM, HwOpus and NvMap | David Marcec | 3 | -26/+39 | |
2018-11-26 | Improved error messages for SVCs | David Marcec | 1 | -76/+170 | |
2018-11-26 | Changed logging to be "Log before execution", Added more error logging, all services should now log on some level | David Marcec | 51 | -374/+726 | |
2018-11-25 | svc: Return ERR_INVALID_ENUM_VALUE from svcGetInfo | Luke Street | 1 | -1/+2 | |
2018-11-25 | Limit the amount of viewports tested for state changes only to the usable ones | Rodolfo Bogado | 1 | -2/+10 | |
2018-11-25 | gl_shader_decompiler: Implement S2R's Y_DIRECTION | ReinUsesLisp | 5 | -16/+26 | |
2018-11-25 | morton: Style changes | ReinUsesLisp | 1 | -12/+12 | |
2018-11-25 | video_core: Move morton functions to their own file | ReinUsesLisp | 6 | -345/+391 | |
2018-11-24 | Fix Texture Overlapping | FernandoS27 | 1 | -43/+70 | |
2018-11-24 | Implemented BRA CC conditional and FSET CC Setting | FernandoS27 | 1 | -4/+14 | |
2018-11-24 | Add support for viewport_transfom_enable register | Rodolfo Bogado | 2 | -6/+22 | |
2018-11-24 | service/sm: Take std::string by const reference in UnregisterService | Lioncash | 2 | -2/+2 | |
Avoids the need to create a copy of the std::string instance (potentially allocating). The only reason RegisterService takes its argument by value is because it's std::moved internally. | |||||
2018-11-24 | nvdrv: Implement/stub DumpGraphicsMemoryInfo and GetStatus. | bunnei | 2 | -2/+18 | |
- Used by Undertale. | |||||
2018-11-24 | Add support for clear_flags register | Rodolfo Bogado | 5 | -28/+95 | |
2018-11-24 | Fix TEXS Instruction encodings | FernandoS27 | 1 | -22/+48 | |
2018-11-24 | Fix one encoding in TEX Instruction | FernandoS27 | 1 | -3/+3 | |
2018-11-24 | Corrected inputs indexing in TEX instruction | FernandoS27 | 1 | -66/+85 | |
2018-11-23 | memory_manager: Do not allow 0 to be a valid GPUVAddr. | bunnei | 2 | -1/+9 | |
- Fixes a bug with Undertale using 0 for a render target. | |||||
2018-11-23 | Added predicate comparison LessEqualWithNan (#1736) | Hexagon12 | 2 | -5/+13 | |
* Added predicate comparison LessEqualWithNan * oops * Clang fix | |||||
2018-11-23 | gl_shader_decompiler: Implement clip distances | ReinUsesLisp | 3 | -21/+58 | |
2018-11-23 | file_sys: Implement system archive synthesizer for NgWord (806) | Zach Hilman | 5 | -6/+61 | |
2018-11-22 | am: Return StubApplet instead of nullptr when AppletId not found | Zach Hilman | 3 | -11/+11 | |
2018-11-22 | gl_shader_decompiler: Add a message for unimplemented cc generation | ReinUsesLisp | 1 | -23/+46 | |
2018-11-22 | correct clang-format | greggameplayer | 1 | -1/+1 | |
2018-11-22 | debug_pad: Avoid loading input for nonexistent buttons (Home and Screenshot) | Zach Hilman | 1 | -2/+3 | |
Prevents memory exceptions when the debug pad is enabled. | |||||
2018-11-22 | core: Relocate CPU core management to its own class | Lioncash | 4 | -97/+225 | |
Keeps the CPU-specific behavior from being spread throughout the main System class. This will also act as the home to contain member functions that perform operations on all cores. The reason for this being that the following pattern is sort of prevalent throughout sections of the codebase: If clearing the instruction cache for all 4 cores is necessary: Core::System::GetInstance().ArmInterface(0).ClearInstructionCache(); Core::System::GetInstance().ArmInterface(1).ClearInstructionCache(); Core::System::GetInstance().ArmInterface(2).ClearInstructionCache(); Core::System::GetInstance().ArmInterface(3).ClearInstructionCache(); This is kind of... well, silly to copy around whenever it's needed. especially when it can be reduced down to a single line. This change also puts the basics in place to begin "ungrafting" all of the forwarding member functions from the System class that are used to access CPU state or invoke CPU-specific behavior. As such, this change itself makes no changes to the direct external interface of System. This will be covered by another changeset. | |||||
2018-11-22 | macro_interpreter: Implement AddWithCarry and SubtractWithBorrow. | bunnei | 2 | -8/+25 | |
- Used by Undertale. | |||||
2018-11-22 | audout_u: Add support for multiple IAudioOut streams. | bunnei | 2 | -9/+22 | |
- Used by Undertale. | |||||
2018-11-22 | maxwell_3d: Implement alternate blend equations. | bunnei | 2 | -0/+12 | |
- Used by Undertale. | |||||
2018-11-22 | common/thread: Drop Hungarian notation on SetCurrentThreadName's parameter | Lioncash | 1 | -7/+7 | |
This is inconsistent with our coding style. | |||||
2018-11-22 | scheduler: Add explanations for YieldWith and WithoutLoadBalancing | Zach Hilman | 6 | -79/+141 | |
2018-11-22 | common/thread: Make Barrier's 'count' member non-const | Lioncash | 1 | -1/+1 | |
While admirable as a means to ensure immutability, this has the unfortunate downside of making the class non-movable. std::move cannot actually perform a move operation if the provided operand has const data members (std::move acts as an operation to "slide" resources out of an object instance). Given Barrier contains move-only types such as std::mutex, this can lead to confusing error messages if an object ever contained a Barrier instance and said object was attempted to be moved. | |||||
2018-11-22 | common/thread: Initialize class member variables where applicable | Lioncash | 1 | -6/+4 | |
Simplifies the constructor interfaces for Barrier and Event classes. | |||||
2018-11-22 | common/thread: Group non-member functions together | Lioncash | 1 | -3/+2 | |
Keeps the non-member interface in one spot instead of split into two places, making it nicer to locate functions. | |||||
2018-11-22 | common/thread: Remove SleepCurrentThread() | Lioncash | 2 | -12/+0 | |
This is also unused and superceded by standard functionality. The standard library provides std::this_thread::sleep_for(), which provides a much more flexible interface, as different time units can be used with it. | |||||
2018-11-22 | common/thread: Remove unused CurrentThreadId() | Lioncash | 2 | -12/+0 | |
This is an old function that's no longer necessary. C++11 introduced proper threading support to the language and a thread ID can be retrieved via std::this_thread::get_id() if it's ever needed. | |||||
2018-11-22 | common: Remove bit_set.h | Lioncash | 2 | -245/+0 | |
This is an analog of BitSet from Dolphin that was introduced to allow iterating over a set of bits. Given it's currently unused, and given that std::bitset exists, we can remove this. If it's ever needed in the future it can be brought back. | |||||
2018-11-22 | applets: Add StubApplet | Zach Hilman | 3 | -0/+98 | |
This will log all data it receives, log all calls to its methods and push dummy data into both channels on execution. | |||||
2018-11-22 | gl_shader_decompiler: Rename internal flag strings | ReinUsesLisp | 1 | -15/+20 | |
2018-11-22 | gl_shader_decompiler: Rename control codes to condition codes | ReinUsesLisp | 2 | -67/+50 | |
2018-11-22 | Automatically disable joycons docked | greggameplayer | 1 | -0/+4 | |
when docked mode is enable | |||||
2018-11-22 | gl_shader_decompiler: Fix register overwriting on texture calls | ReinUsesLisp | 1 | -60/+78 | |
2018-11-22 | kernel/handle_table: Move private static functions into the cpp file | Lioncash | 2 | -7/+9 | |
These don't depend on class state, and are effectively implementation details, so they can go into the cpp file . | |||||
2018-11-22 | kernel/handle_table: Restrict handle table size to 1024 entries | Lioncash | 1 | -5/+2 | |
The previous handle table size is a holdover from Citra. The actual handle table construct on Horizon only allows for a maximum of 1024 entries. | |||||
2018-11-22 | kernel/handle_table: Default destructor in the cpp file | Lioncash | 2 | -0/+3 | |
We don't need to potentially inline the teardown logic of all of the handle instances. | |||||
2018-11-21 | Properly Implemented TXQ Instruction | FernandoS27 | 1 | -2/+12 | |
2018-11-21 | gl_shader_decompiler: Implement BFI_IMM_R | ReinUsesLisp | 2 | -0/+23 | |
2018-11-21 | nvhost_ctrl_gpu: Implement IoctlGetGpuTime. | bunnei | 2 | -0/+19 | |
- Used by Undertale. | |||||
2018-11-21 | Removed pre 4.3 ARB extensions | FernandoS27 | 7 | -48/+13 | |
2018-11-21 | Update OpenGL's backend version from 3.3 to 4.3 | FernandoS27 | 3 | -4/+4 | |
2018-11-21 | Use default values for unknown framebuffer pixel format | FernandoS27 | 2 | -0/+8 | |
2018-11-21 | common: Remove dependency on xbyak | Lioncash | 3 | -274/+0 | |
Xbyak is currently entirely unused. Rather than carting it along, remove it and get rid of a dependency. If it's ever needed in the future, then it can be re-added (and likely be more up to date at that point in time). | |||||
2018-11-21 | gl_shader_decompiler: Implement R2P_IMM | ReinUsesLisp | 2 | -0/+42 | |
2018-11-21 | common/math_util: Simplify std::make_signed usages to std::make_signed_t | Lioncash | 1 | -2/+2 | |
Gets rid of the need to use typename to access the ::type alias. | |||||
2018-11-21 | common/math_util: Make Rectangle's constructors constexpr | Lioncash | 1 | -2/+2 | |
Allows objects that contain rectangle instances to be constexpr constructible as well. | |||||
2018-11-21 | common/math_util: Remove unnecessary static from PI | Lioncash | 1 | -1/+1 | |
const/constexpr variables have internal linkage by default. | |||||
2018-11-21 | common/math_util: Remove unused IntervalsIntersect() function | Lioncash | 1 | -6/+0 | |
This hasn't been used since the project started, so we may as well get rid of it to keep it from bit rotting. | |||||
2018-11-21 | gl_shader_decompiler: Remove UNREACHABLE when setting RZ | ReinUsesLisp | 1 | -2/+1 | |
2018-11-21 | gl_shader_decompiler: Use UNIMPLEMENTED instead of LOG+UNREACHABLE when applicable | ReinUsesLisp | 1 | -371/+258 | |
2018-11-21 | maxwell_3d: Initialize rasterizer color mask registers as enabled. | bunnei | 1 | -0/+9 | |
- Fixes rendering regression with Sonic Mania. | |||||
2018-11-21 | am: Correct build failure | Lioncash | 1 | -2/+2 | |
The interface for shared memory was changed, but another commit was merged that relied on the (previously public) internals of SharedMemory. This amends that discrepancy. | |||||
2018-11-21 | patch_manager: Show LayeredExeFS patch in add-ons column | Zach Hilman | 2 | -4/+15 | |
The decision was made to name them LayeredExeFS instead of just LayeredFS to differentiate from normal RomFS-based mods. The name may be long/unweildy, but conveys the meaning well. | |||||
2018-11-21 | file_sys/card_image: Provide named members for the GamecardInfo struct | Lioncash | 1 | -1/+12 | |
Fills out the struct according to information provided by SwitchBrew | |||||
2018-11-21 | common/assert: Add UNIMPLEMENTED_IF and UNIMPLEMENTED_IF_MSG for conditional assertions | Lioncash | 1 | -0/+3 | |
Currently, there's no way to specify if an assertion should conditionally occur due to unimplemented behavior. This is useful when something is only partially implemented (e.g. due to ongoing RE work). In particular, this would be useful within the graphics code. The rationale behind this is it allows a dev to disable unimplemented feature assertions (which can occur in an unrelated work area), while still enabling regular assertions, which act as behavior guards for conditions or states which must not occur. Previously, the only way a dev could temporarily disable asserts, was to disable the regular assertion macros, which has the downside of also disabling, well, the regular assertions which hold more sanitizing value, as opposed to unimplemented feature assertions. | |||||
2018-11-20 | common/assert: Make the UNIMPLEMENTED macro properly assert | Lioncash | 1 | -1/+1 | |
Currently, this was only performing a logging call, which doesn't actually invoke any assertion behavior. This is unlike UNIMPLEMENTED_MSG, which *does* assert. This makes the expected behavior uniform across both macros. | |||||
2018-11-20 | patch_manager: Apply LayeredExeFS patches | Zach Hilman | 1 | -0/+25 | |
This will scan the <mod>/exefs dir for all files and then layer those on top of the game's exefs and use this as the new exefs. This allows for overriding of the compressed NSOs or adding new files. This does use the same dir as IPS/IPSwitch patch, but since the loader will not look for those they are ignored. | |||||
2018-11-20 | settings: Add option to dump ExeFS of games upon launch | Zach Hilman | 7 | -0/+27 | |
When enabled, all exefs(es) will be copied to yuzu/dump/<title_id>/exefs. | |||||
2018-11-20 | kernel/process: Move <random> include to the cpp file | Lioncash | 2 | -1/+1 | |
<random> isn't necesary directly within the header and can be placed in the cpp file where its needed. Avoids propagating random generation utilities via a header file. | |||||
2018-11-20 | shader_cache: Only lock covered instructions. | Markus Wick | 4 | -8/+24 | |
2018-11-20 | am/applets: Make the applet data broker part of the applet itself. | Lioncash | 5 | -31/+36 | |
The accessor should be doing just that, accessing, rather than retaining the lifetime of the data broker as well. | |||||
2018-11-20 | am/applets: Replace includes with forward declarations where applicable | Lioncash | 2 | -2/+9 | |
Also resolve places where includes should have been provided, but weren't. | |||||
2018-11-20 | am/applets: Relocate comments above the relevant data member in AppletDataBroker | Lioncash | 1 | -11/+18 | |
Avoids wonky wrapping and makes it nicer to read. | |||||
2018-11-20 | yuzu/applets/software_keyboard: Override accept() and reject() instead of providing own differently named member functions | Lioncash | 2 | -8/+8 | |
Uses Qt's built-in interface instead of rolling our own separate one on top of it. This also fixes a bug in reject() where we were calling accept() instead of reject(). | |||||
2018-11-20 | yuzu/applets/software_keyboard: std::move std::function instances where applicable | Lioncash | 1 | -2/+2 | |
std::function instances can potentially allocate. std::moveing them prevents an avoidable allocation in that case. | |||||
2018-11-20 | yuzu/applets/software_keyboard: Make slots private functions | Lioncash | 1 | -2/+1 | |
These aren't required to be public. | |||||
2018-11-20 | Implemented Fast Layered Copy | FernandoS27 | 2 | -2/+30 | |
2018-11-20 | kernel/resource_limit: Clean up interface | Lioncash | 6 | -190/+81 | |
Cleans out the citra/3DS-specific implementation details that don't apply to the Switch. Sets the stage for implementing ResourceLimit instances properly. While we're at it, remove the erroneous checks within CreateThread() and SetThreadPriority(). While these are indeed checked in some capacity, they are not checked via a ResourceLimit instance. In the process of moving out Citra-specifics, this also replaces the system ResourceLimit instance's values with ones from the Switch. | |||||
2018-11-20 | lm: Implement SetDestination by doing nothing | Lioncash | 1 | -1/+12 | |
This service function was likely intended to be a way to redirect where the output of a log went. e.g. Firing a log over a network, dumping over a tunneling session, etc. Given we always want to see the log and not change its output. It's one of the lucky service functions where the easiest implementation is to just do nothing at all and return success. | |||||
2018-11-19 | software_keyboard: Fix erroneous extra PushNormalData | Zach Hilman | 1 | -3/+2 | |
2018-11-19 | software_keyboard: Return correct result code on user cancel operation | Zach Hilman | 3 | -5/+1 | |
2018-11-19 | applet: Add AppletDataBroker to manage HLE to AM service interaction | Zach Hilman | 5 | -104/+194 | |
This cleans up most of the callbacks and such in the Applets::Applet interface, while also properly implementing all four data channels. | |||||
2018-11-19 | software_keyboard: Use correct offset for inital text string | Zach Hilman | 1 | -1/+2 | |
2018-11-19 | kernel/shared_memory: Make Map() and Unmap() take the target process by reference rather than as a pointer | Lioncash | 3 | -12/+12 | |
Both member functions assume the passed in target process will not be null. Instead of making this assumption implicit, we can change the functions to be references and enforce this at the type-system level. | |||||
2018-11-19 | kernel/shared_memory: Add a const qualified member function overload for GetPointer() | Lioncash | 2 | -1/+12 | |
Given this doesn't mutate instance state, we can provide a const-qualified variant as well. | |||||
2018-11-19 | kernel/shared_memory: Use 64-bit types for offset and size in CreateForApplet | Lioncash | 2 | -2/+2 | |
Keeps the interface consistent with the regular Create() function. | |||||
2018-11-19 | kernel/shared_memory: Make GetPointer() take a std::size_t instead of a u32 | Lioncash | 2 | -2/+2 | |
Makes the interface nicer to use in terms of 64-bit code, as it makes it less likely for one to get truncation warnings (and also makes sense in the context of the rest of the interface where 64-bit types are used for sizes and offsets | |||||
2018-11-19 | kernel/shared_memory: Make data members private | Lioncash | 1 | -12/+17 | |
Rather than allow unfettered access to the class internals, we hide all members by default and create and API that other code can operate against. | |||||
2018-11-19 | ldr: Clean up error codes | Lioncash | 1 | -29/+12 | |
The separate enum isn't particularly necessary here, and the values can just be directly put into the ResultCode instances, given the names are also self-documenting here. | |||||
2018-11-19 | svc: Implement yield types 0 and -1 | Zach Hilman | 6 | -2/+130 | |
2018-11-19 | filesystem: Clear registered union paths on factory creation | Zach Hilman | 2 | -0/+6 | |
2018-11-19 | configure_input: Use Joycons Docked instead of Connected as label | Zach Hilman | 1 | -1/+1 | |
2018-11-19 | configure_input_player: Set minimum width on controls | Zach Hilman | 2 | -23/+30 | |
2018-11-19 | configure_input: Properly update UI components on removal of player | Zach Hilman | 1 | -0/+2 | |
2018-11-19 | configure_input: Make None a controller option instead of checkbox | Zach Hilman | 11 | -152/+148 | |
2018-11-19 | hid: Use player-defined controller type as PREFERRED_CONTROLLER | Zach Hilman | 16 | -296/+234 | |
2018-11-19 | qt: Move controller button config to separate dialog | Zach Hilman | 4 | -0/+1767 | |
Handles button configuration for all controller layouts and debug pads. Configurable at construction. | |||||
2018-11-19 | qt: Add UI to configure touchscreen parameters | Zach Hilman | 4 | -0/+281 | |
This allows adjusting the finger, diameter, and angle of the emulated touchscreen. It also provides a warning to the user about what changing these parameters can do. | |||||
2018-11-19 | qt: Add UI to configure mouse buttons | Zach Hilman | 4 | -0/+542 | |
Supports setting the five mouse buttons to any valid controller button/keyboard key (Left, Right, Middle, Foward, Back) | |||||
2018-11-19 | configure_input: Add support for multiplayer and controller types | Zach Hilman | 3 | -998/+525 | |
This moves the actual button configuration to a separate dialog and only has the enabled and type controls in the tab. | |||||
2018-11-19 | hid/npad: Update NPad to use player controller bindings and type | Zach Hilman | 2 | -55/+108 | |
2018-11-19 | hid/touchscreen: Update Touchscreen to use advanced parameters | Zach Hilman | 1 | -6/+6 | |
Including finger ID, diamater x/y, and angle. Additionally, checks if the touchscreen is enabled. | |||||
2018-11-19 | hid: Add controller bindings for Mouse controller | Zach Hilman | 2 | -4/+30 | |
2018-11-19 | hid: Add keyboard bindings for Keyboard controller | Zach Hilman | 2 | -2/+24 | |
2018-11-19 | hid: Add controller bindings for DebugPad controller | Zach Hilman | 2 | -21/+43 | |
Used by developers to test games, not present on retail systems. Some games are known to respond to DebugPad input though, for example Kirby Star Allies. | |||||
2018-11-19 | yuzu/config: Add (de-)serialization for multiplayer | Zach Hilman | 2 | -21/+331 | |
Defaults to full keyboard for keyboard -- It did not seem to be necessary to make the keyboard configurable (besides enabled/disabled). | |||||
2018-11-19 | yuzu_cmd/config: Add config deserialization for multiplayer | Zach Hilman | 1 | -37/+254 | |
2018-11-19 | settings: Add settings for multiple players and controllers | Zach Hilman | 1 | -3/+48 | |
Uses the PlayerInput struct to represent all of the data that constitutes a player. | |||||
2018-11-19 | settings: Add Native type for keyboard | Zach Hilman | 1 | -0/+210 | |
2018-11-19 | settings: Add Native type for mouse buttons | Zach Hilman | 2 | -0/+34 | |
2018-11-19 | Added missing start/end touch attributes to touchscreen | David Marcec | 2 | -1/+18 | |
2018-11-19 | Added debugpad skeleton | David Marcec | 2 | -2/+55 | |
2018-11-19 | Added controller helper funcs | David Marcec | 2 | -0/+35 | |
2018-11-19 | Changed polling rate of hid and Right joycon rotation | David Marcec | 1 | -2/+2 | |
2018-11-19 | Left joycon rotation button remapping | David Marcec | 2 | -7/+21 | |
2018-11-19 | Added automatic npad switch based on supported stylesets | David Marcec | 2 | -4/+124 | |
2018-11-19 | Added multi-input support and controller assignment at any port | David Marcec | 2 | -122/+181 | |
2018-11-19 | Removed hard coded values for width and height | David Marcec | 1 | -2/+4 | |
2018-11-19 | software_keyboard: Check for UTF-8 config flag | Zach Hilman | 2 | -9/+23 | |
2018-11-19 | Eliminated unnessessary memory allocation and copy (#1702) | Frederic L | 3 | -9/+20 | |
2018-11-19 | Correctly sets default system language for yuzu-CLI (#1727) | Schplee | 1 | -0/+2 | |
* Correctly sets default system language for yuzu-CLI A user reported that yuzu_cmd runs games in Japanese rather than the correct default of English (like yuzu-qt does correctly), this change fixes that. * fix clang issue deleted whitespace | |||||
2018-11-19 | gl_rasterizer: Remove default clip distance | ReinUsesLisp | 1 | -2/+0 | |
2018-11-18 | svc: ResetSignal is not stubbed | Tobias | 1 | -1/+1 | |
https://user-images.githubusercontent.com/20753089/48677874-b8e01c80-eb7b-11e8-8043-b99faa29022c.PNG | |||||
2018-11-18 | software_keyboard: Add max and current length display to dialog | Zach Hilman | 2 | -1/+11 | |
2018-11-18 | software_keyboard: Push all data over all channels on dialog completion | Zach Hilman | 1 | -18/+26 | |
2018-11-18 | applet: Use std::queue instead of std::vector for storage stack | Zach Hilman | 5 | -18/+44 | |
2018-11-18 | applet: Add operation completed callback | Zach Hilman | 8 | -9/+34 | |
2018-11-18 | software_keyboard: Push buffer size to offset 0x4 in output data | Zach Hilman | 4 | -18/+39 | |
2018-11-18 | software_keyboard: Make GetText asynchronous | Zach Hilman | 9 | -29/+64 | |
a | |||||
2018-11-18 | am: Allow applets to push multiple and different channels of data | Zach Hilman | 10 | -64/+62 | |
2018-11-18 | am: Implement ILibraryAppletAccessor IsCompleted and GetResult | Zach Hilman | 2 | -4/+9 | |
2018-11-18 | am: Implement text check software keyboard mode | Zach Hilman | 6 | -14/+120 | |
Allows the game to verify and send a message to the frontend. | |||||
2018-11-18 | am: Deglobalize software keyboard applet | Zach Hilman | 17 | -100/+180 | |
2018-11-18 | qt/main: Register Qt Software Keyboard frontend with AM | Zach Hilman | 3 | -0/+6 | |
Allows using Qt provider over default. | |||||
2018-11-18 | am: Construct and use proper applets with ILibraryAppletAccessor | Zach Hilman | 1 | -1/+26 | |
Allows use of software keyboard applet and future applets to be easily added by adding enum ID and a switch case. | |||||
2018-11-18 | qt/applets: Provide Qt frontend implementation of software keyboard | Zach Hilman | 3 | -0/+171 | |
Implements all of the features of the keyboard, including length, default text, character validation, and UTF-16 character support. | |||||
2018-11-18 | am/applets: Add connector between frontend and AM applet classes | Zach Hilman | 3 | -0/+130 | |
Provides a middleman between the Frontend provider class and the expected AM::Applets::Applet class needed by ILibraryAppletAccessor | |||||
2018-11-18 | frontend/applets: Add frontend software keyboard provider and default | Zach Hilman | 3 | -0/+63 | |
Default implementation will return "yuzu" for any string. GUI clients (or CLI) can implement the Frontend::SoftwareKeyboardApplet class and register an instance to provide functionality. | |||||
2018-11-18 | am/applets: Add Applet superclass to describe a generic applet | Zach Hilman | 3 | -0/+77 | |
Adds an Initialize and Execute methods which are used by the ILibraryAppletAccessor to start and control the applet. | |||||
2018-11-18 | am: Unstub ILibraryAppletAccessor::Start | Zach Hilman | 1 | -5/+17 | |
Now starts the applet provided in constructor. | |||||
2018-11-18 | am: Implement PopInteractiveOutData and PushInteractiveInData | Zach Hilman | 1 | -14/+24 | |
Used by software keyboard applet for data transfer. | |||||
2018-11-18 | am: Convert storage stack to vector | Zach Hilman | 1 | -27/+59 | |
std::stack was no longer suitable for non-trivial operations | |||||
2018-11-18 | am: Move AM::IStorage to header | Zach Hilman | 1 | -0/+16 | |
Needs to be accessible by applet files. | |||||
2018-11-18 | am: Move IStorageAccessor to header and update backing buffer | Zach Hilman | 2 | -64/+62 | |
Writes to an AM::IStorage object through an IStorageAccessor will now be preserved once the accessor is destroyed. | |||||
2018-11-18 | am: Implement CreateTransferMemoryStorage | Zach Hilman | 2 | -0/+26 | |
Creates an AM::IStorage object with the contents of the transfer memory located at the handle provided. | |||||
2018-11-18 | string_util: Implement buffer to UTF-16 string helper function | Zach Hilman | 2 | -0/+17 | |
Needed as most all software keyboard functions use fixed-length UTF16 string buffers. | |||||
2018-11-18 | svc: Implement svcCreateTransferMemory | Zach Hilman | 1 | -3/+33 | |
Seems to be used and created identically to SharedMemory, so just reuse that. | |||||
2018-11-18 | drop support for non separate alpha as it seems to cause issues in some games | Rodolfo Bogado | 3 | -61/+35 | |
2018-11-18 | ldr_ro: Add error check for memory allocation failure | Zach Hilman | 4 | -13/+27 | |
2018-11-17 | fix sampler configuration, thanks to Marcos for his investigation | Rodolfo Bogado | 3 | -19/+57 | |
2018-11-17 | small type fix | Rodolfo Bogado | 1 | -6/+6 | |
2018-11-17 | small fix for alphaToOne bit location | Rodolfo Bogado | 1 | -2/+2 | |
2018-11-17 | fix for gcc compilation | Rodolfo Bogado | 1 | -60/+61 | |
2018-11-17 | add AlphaToCoverage and AlphaToOne | Rodolfo Bogado | 5 | -1/+39 | |
2018-11-17 | add support for fragment_color_clamp | Rodolfo Bogado | 5 | -1/+24 | |
2018-11-17 | add missing MirrorOnceBorder support where supported | Rodolfo Bogado | 1 | -0/+6 | |
2018-11-17 | set border color not depending on the wrap mode | Rodolfo Bogado | 1 | -9/+9 | |
only enable color mask for the first framebuffer id independent blending is disabled | |||||
2018-11-17 | set default value for point size register | Rodolfo Bogado | 2 | -5/+4 | |
2018-11-17 | fix viewport and scissor behavior | Rodolfo Bogado | 6 | -64/+89 | |
2018-11-17 | vi: Implement TransactParcel for Disconnect and DetachBuffer | Zach Hilman | 1 | -0/+22 | |
Used by homebrew on exit. According to switchbrew, returns an empty response parcel with one zero in it. | |||||
2018-11-17 | Stubbed am:EnableApplicationCrashReport | MysticExile | 2 | -10/+18 | |
2018-11-17 | gl_rasterizer: Skip VB upload if the state is clean. | Markus Wick | 9 | -6/+60 | |
2018-11-17 | hwopus: DecodeInterleavedWithPerformance: Fix ordering of output parameters. | bunnei | 1 | -1/+1 | |
- Fixes audio issues with Pokemon: Let's Go Pikachu & Eevee. | |||||
2018-11-17 | Implemented CalculateStandardUserSystemClockDifferenceByUser | David Marcec | 3 | -1/+18 | |
Seems pokemon calls this sometimes and it caused "random crashes" | |||||
2018-11-17 | textures/decoders: Replace magic numbers | Frederic Laing | 1 | -37/+33 | |
2018-11-16 | kernel/errors: Clean up error codes | Lioncash | 2 | -62/+32 | |
Similar to PR 1706, which cleans up the error codes for the filesystem code, but done for the kernel error codes. This removes the ErrCodes namespace and specifies the errors directly. This also fixes up any straggling lines of code that weren't using the named error codes where applicable. | |||||
2018-11-16 | Common/Bitfield: store value as unsigned type | Weiyi Wang | 1 | -9/+10 | |
Storing signed type causes the following behaviour: extractValue can do overflow/negative left shift. Now it only relies on two implementation-defined behaviours (which are almost always defined as we want): unsigned->signed conversion and signed right shift | |||||
2018-11-16 | Added various bluetooth based cmds for palma | David Marcec | 2 | -1/+145 | |
It seems palma is done through bluetooth, we need this for pokemon go however more research needs to be done when we actually get palma working. This is presumably used for transfering data between the controller and the console, it does not seem for actual input as far as I know. | |||||
2018-11-16 | Added SetIsPalmaAllConnectable, SetPalmaBoostMode | David Marcec | 1 | -2/+14 | |
Currently unclear what these do yet, will be researched at a later time when we want to implement palma. | |||||
2018-11-16 | Fixed switching operation modes when not running a game | David Marcec | 1 | -0/+3 | |
The service manager seems to be a nullptr before a game boots | |||||
2018-11-16 | Report resolution scaling support for vi and am | David Marcec | 3 | -60/+76 | |
Specifying an internal resolution in yuzu now will report the scaled changes to vi and am. | |||||
2018-11-16 | file_sys/errors: Remove currently unused filesystem error codes | Lioncash | 1 | -10/+0 | |
Rather than keeping around unused values, we can just introduce them as needed. | |||||
2018-11-16 | file_sys/errors: Get rid of the ErrCodes namespace | Lioncash | 1 | -17/+5 | |
There's no real point to keeping the separate enum around, especially given the name of the error code itself is supposed to document what the value actually represents. | |||||
2018-11-16 | file_sys/errors: Extract FS-related error codes to file_sys/errors.h | Lioncash | 4 | -14/+19 | |
Keeps filesystem-related error codes in one spot. | |||||
2018-11-16 | Fixed priority switching edge case for handheld (#1675) | David | 1 | -12/+46 | |
* Fixed priority switching edge case for handheld We accidently used controller index instead of npad id * Moved NPadIdToIndex | |||||
2018-11-16 | fsp_srv: Add support for using open source archive if not found in NAND | Zach Hilman | 1 | -0/+10 | |
2018-11-16 | file_sys: Add framework for synthesizing open source archives | Zach Hilman | 3 | -0/+109 | |
2018-11-16 | vfs_vector: Add VFS backend for std::array | Zach Hilman | 1 | -0/+52 | |
Allows using constexpr/static const data with VFS. | |||||
2018-11-16 | csrng: Use random integer distribution instead of raw engine | Zach Hilman | 1 | -1/+2 | |
Prevents returning the same value every single call. | |||||
2018-11-15 | textures/decoders: Minor cleanup | Frederic Laing | 1 | -16/+16 | |
2018-11-15 | gl_rasterizer_chache: Minor cleanup | Frederic Laing | 1 | -3/+3 | |
2018-11-15 | ldr_ro: Implement UnloadNro (command 1) | Zach Hilman | 1 | -22/+85 | |
Includes actual unmapping and address error checking. | |||||
2018-11-15 | ldr_ro: Fully Implement LoadNro (command 0) | Zach Hilman | 1 | -11/+110 | |
Includes NRO and BSS error checking, maximum loaded NRO check, NRR hash check, and proper remapping of BSS data. | |||||
2018-11-15 | ldr_ro: Implement UnloadNrr (command 3) | Zach Hilman | 1 | -2/+84 | |
Includes initialization check, proper address check, alignment check, and actual unloading of a loaded NRR. | |||||
2018-11-15 | ldr_ro: Fully implement LoadNrr (command 2) | Zach Hilman | 1 | -0/+112 | |
Includes parameter error checking, hash enforcement, initialization check, and max NRR load check. | |||||
2018-11-15 | process: Make MirrorMemory take state to map new memory as | Zach Hilman | 2 | -3/+7 | |
Credits to Subv | |||||
2018-11-15 | pl_u: Resize buffers in shared font data getter to what game requests | Zach Hilman | 1 | -0/+8 | |
Fixes unmapped spam in SMP and buffer size errors in some other games | |||||
2018-11-14 | service/acc: Correct error case within TrySelectUserWithoutInteraction() | Lioncash | 1 | -2/+4 | |
empty() in this case will always return false, since the returned container is a std::array. Instead, check if all given users are invalid before returning the error code. | |||||
2018-11-14 | profile_manager: Replace iterative loop with a ranged-for loop in ParseUserSaveFile() | Lioncash | 1 | -4/+5 | |
2018-11-14 | profile_manager: Move UUID Format function definitions into the cpp file | Lioncash | 2 | -11/+18 | |
Avoids relying on fmt always being indirectly included. | |||||
2018-11-14 | yuzu/configure_system: Mark the entropy mask string as nontranslatable | Lioncash | 1 | -1/+1 | |
There's no need for translators to concern themselves with the validation mask used by the entry field. | |||||
2018-11-14 | nfp: Correct erroneous sizeof expression within GetTagInfo() | Lioncash | 1 | -1/+1 | |
The previous expression would copy sizeof(size_t) amount of bytes (8 on a 64-bit platform) rather than the full 10 bytes comprising the uuid member. Given the source and destination types are the same, we can just use an assignment here instead. | |||||
2018-11-14 | service/audren_u: Forward RequestUpdateAuto through the same function as RequestUpdate | Lioncash | 1 | -3/+3 | |
Based off RE, they both currently go through the same codepath with no difference in behavior. | |||||
2018-11-14 | hid/npad: Add missing break in switch statement within Controller_NPad::OnUpdate() | Lioncash | 1 | -0/+1 | |
2018-11-14 | service: Mark MakeFunctionString with the [[maybe_unused]] attribute. | Lioncash | 1 | -2/+2 | |
When yuzu is compiled in release mode this function is unused, however, when compiled in debug mode, it's used within a LOG_TRACE statement. This prevents erroneous compilation warnings about an unused function (that isn't actually totally unused). | |||||
2018-11-14 | kernel/thread: Deduplicate scheduler switching code | Lioncash | 2 | -37/+13 | |
The code in both places was the same verbatim, so we can extract it to a function to deduplicate the logic. | |||||
2018-11-14 | string_util: Remove ArrayToString() | Lioncash | 2 | -21/+0 | |
An old function from Dolphin. This is also unused, and pretty inflexible when it comes to printing out different data types (for example, one might not want to print out an array of u8s but a different type instead. Given we use fmt, there's no need to keep this implementation of the function around. | |||||
2018-11-14 | string_util: Remove TryParse() | Lioncash | 2 | -54/+3 | |
This is an unused hold-over from Dolphin that was primarily used to parse values out of the .ini files. Given we already have libraries that do this for us, we don't need to keep this around. | |||||
2018-11-13 | qt: Move Open yuzu Folder action from Help to File | Zach Hilman | 1 | -1/+2 | |
2018-11-13 | video_core/renderer_base: Remove GL include from the renderer base class files | Lioncash | 1 | -1/+0 | |
Keeps the base class source files implementation-agnostic. | |||||
2018-11-13 | string_util: Remove ThousandSeparate() | Lioncash | 1 | -14/+0 | |
This is currently unused and doesn't really provide much value to keep around either. | |||||
2018-11-13 | hle/audren_u: Implement Get/SetRenderingTimeLimit | Lioncash | 1 | -2/+23 | |
These appear to be a basic getter and setter pair, so these are fairly trivial to implement and get out of the way. | |||||
2018-11-13 | audio_core/audio_renderer: Fix typo in AuxInfo member name | Lioncash | 1 | -1/+1 | |
2018-11-13 | vm_manager: Unstub GetTotalHeapUsage() | Lioncash | 1 | -2/+1 | |
Now that we've moved all of the heap-related stuff to the VMManager class, we can unstub this function, as the necessary members are visible now. | |||||
2018-11-13 | kernel/process: Migrate heap-related memory management out of the process class and into the vm manager | Lioncash | 4 | -84/+97 | |
Avoids a breach of responsibilities in the interface and keeps the direct code for memory management within the VMManager class. | |||||
2018-11-13 | svc: Use proper random entropy generation algorithm | Zach Hilman | 6 | -8/+33 | |
2018-11-13 | GDBStub improvements: | Hedges | 1 | -37/+86 | |
- Add FPU support - Fix access to TLS Fix clang-format. | |||||
2018-11-13 | yuzu: Add hotkey for Amiibo loading | fearlessTobi | 1 | -1/+9 | |
2018-11-13 | gl_rasterizer: Minor cleanup | Frederic L | 1 | -4/+2 | |
Minor code cleanup from unaddressed feedback in #1654 | |||||
2018-11-13 | gl_state: Amend compilation warnings | Lioncash | 2 | -3/+4 | |
Makes float -> integral conversions explicit via casts and also silences a sign conversion warning. | |||||
2018-11-13 | svc: Return random seed for svcGetInfo RandomEntropy | Zach Hilman | 2 | -4/+8 | |
2018-11-13 | Implement ASTC_2D_10X8 & ASTC_2D_10X8_SRGB (#1666) | greggameplayer | 4 | -71/+101 | |
* Implement ASTC_2D_10X8 & ASTC_2D_10X8_SRGB ( needed by Mario+Rabbids Kingdom Battle ) * Small placement correction | |||||
2018-11-12 | yuzu: Add a missing "!" to fix the stuck-in-fullscreen bug | Tobias | 1 | -1/+1 | |
2018-11-12 | settings: Add config option to set RNG seed | Zach Hilman | 6 | -100/+171 | |
2018-11-12 | csrng: Use std::mt19937 engine for random number generation | Zach Hilman | 2 | -2/+11 | |
2018-11-11 | Use core extensions when available to set max anisotropic filtering level | Rodolfo Bogado | 1 | -2/+7 | |
2018-11-11 | Improve state management by splitting some of the states id separated function to avoid a full apply overhead | Rodolfo Bogado | 6 | -39/+40 | |
2018-11-11 | Try to fix problems with stencil test in some games, relax translation to opengl enums to avoid crashing and only generate logs of the errors. | Rodolfo Bogado | 4 | -37/+61 | |
2018-11-11 | set sampler max lod, min lod, lod bias and max anisotropy | Rodolfo Bogado | 3 | -13/+33 | |
2018-11-11 | Improved GPU Caches lookup Speed | FernandoS27 | 1 | -18/+17 | |
2018-11-10 | Added maybe_unused | David Marcec | 2 | -2/+7 | |
2018-11-10 | Added ToPosixTime & ToPosixTimeWithMyRule | David Marcec | 1 | -2/+41 | |
Added instead of using a seperate PR to prevent conflicts | |||||
2018-11-10 | gl_shader_decompiler: Guard out of bound geometry shader input reads | ReinUsesLisp | 4 | -15/+24 | |
Geometry shaders follow a pattern that results in out of bound reads. This pattern is: - VSETP to predicate - Use that predicate to conditionally set a register a big number - Use the register to access geometry shaders At the time of writing this commit I don't know what's the intent of this number. Some drivers argue about these out of bound reads. To avoid this issue, input reads are guarded limiting reads to the highest posible vertex input of the current topology (e.g. points to 1 and triangles to 3). | |||||
2018-11-10 | Added consts and static | David Marcec | 1 | -6/+6 | |
2018-11-09 | Implement GetClockSnapshot | David Marcec | 3 | -21/+88 | |
Needed by megaman 11 | |||||
2018-11-08 | gl_rasterizer_cache: Remove unnecessary memory allocation and copy in CopySurface | Frederic Laing | 1 | -10/+7 | |
2018-11-08 | gl_rasterizer: Fix compiler warnings | Frederic Laing | 1 | -2/+2 | |
2018-11-08 | rasterizer_cache: Remove reliance on the System singleton | Lioncash | 9 | -10/+25 | |
Rather than have a transparent dependency, we can make it explicit in the interface. This also gets rid of the need to put the core include in a header. | |||||
2018-11-08 | rasterizer_cache: Add missing virtual destructor to RasterizerCacheObject | Lioncash | 3 | -0/+10 | |
Ensures that destruction will always do the right thing in any context. | |||||
2018-11-08 | gl_resource_manager: Amend clang-format discrepancies | Lioncash | 1 | -4/+2 | |
Fixes the buildbot. | |||||
2018-11-08 | svcBreak now dumps information from the debug buffer passed (#1646) | David | 1 | -0/+28 | |
* svcBreak now dumps information from the debug buffer passed info1 and info2 seem to somtimes hold an address to a buffer, this is usually 4 bytes or the size of the int and contains an error code. There's other circumstances where it can be something different so we hexdump these to examine them at a later date. * Addressed comments | |||||
2018-11-08 | Correct issue where texturelod could not be applied to 2darrayshadow | FernandoS27 | 1 | -1/+5 | |
2018-11-08 | Renamed CheckIfOperationChanged to OnDockedModeChanged | David Marcec | 2 | -21/+23 | |
2018-11-07 | Implement 3 coordinate array in TEXS instruction | FernandoS27 | 1 | -6/+6 | |
2018-11-07 | Updated npad styles on holdtype switches | David Marcec | 1 | -0/+2 | |
Fixes input for megaman | |||||
2018-11-07 | Fixups | David Marcec | 3 | -12/+17 | |
2018-11-07 | Ability to switch between docked and undocked mode in-game | David Marcec | 7 | -36/+163 | |
Started implementation of the AM message queue mainly used in state getters. Added the ability to switch docked mode whilst in game without stopping emulation. Also removed some things which shouldn't be labelled as stubs as they're implemented correctly | |||||
2018-11-07 | fixed spelling error | David Marcec | 1 | -1/+1 | |
2018-11-07 | Added missing log | David Marcec | 1 | -0/+1 | |
2018-11-07 | Implement acc:TrySelectUserWithoutInteraction | David Marcec | 5 | -3/+25 | |
Needed for Shantae - Half-Genie Hero - Ultimate Edition! | |||||
2018-11-06 | gl_rasterizer: Skip VAO binding if the state is clean. | Markus Wick | 3 | -2/+21 | |
2018-11-06 | gl_rasterizer: Split VAO and VB setup functions. | Markus Wick | 2 | -5/+16 | |
2018-11-06 | gl_rasterizer_cache: Add profiles for Copy and Blit. | Markus Wick | 1 | -2/+6 | |
They were missed, and Copy is very high in profile here. It doesn't block the GPU, but it stalls the driver thread. So with our bad GL instructions, this might block quite a while. | |||||
2018-11-06 | gl_resource_manager: Profile creation and deletion. | Markus Wick | 1 | -0/+42 | |
2018-11-06 | gl_stream_buffer: Profile orphaning of stream buffer. | Markus Wick | 1 | -0/+5 | |
This serialize to the driver thread and so it may block for a while. So if it is in the benchmark, we get noticed if it happens too often. | |||||
2018-11-06 | microprofile: Drop ReleaseActiveBuffer scope. | Markus Wick | 1 | -4/+0 | |
This was created with the unfinished resampling PR in mind. As the resampling is now on the audio thread, we don't need to care about this here any more. | |||||
2018-11-06 | configure_system: Fix compiler warning | Frederic Laing | 2 | -3/+3 | |
2018-11-06 | yuzu/main: Fix compiler warning | Frederic Laing | 1 | -1/+2 | |
2018-11-06 | gl_resource_manager: Split implementations in .cpp file. | Markus Wick | 5 | -114/+167 | |
Those implementations are quite costly, so there is no need to inline them to the caller. Ressource deletion is often a performance bug, so in this way, we support to add breakpoints to them. | |||||
2018-11-06 | Implement SetMemoryPermission | Frederic Laing | 1 | -3/+39 | |
2018-11-05 | Add support to color mask to avoid issues in blending caused by wrong values in the alpha channel in some render targets. | Rodolfo Bogado | 5 | -25/+79 | |
2018-11-05 | Implement multi-target viewports and blending | Rodolfo Bogado | 6 | -128/+259 | |
2018-11-04 | Fix quickstart link | Dharmin K Shah | 1 | -1/+1 | |
2018-11-04 | Fix typo in BufferTransformFlags | Frederic Laing | 1 | -2/+2 | |
2018-11-04 | game_list: Only reload game list after relevant settings changed | Zach Hilman | 5 | -1/+28 | |
Prevents unnecessary reloads on every configuration operation. | |||||
2018-11-04 | sm: Implement RegisterService and UnregisterService | Zach Hilman | 2 | -2/+55 | |
These are needed by Edizon to boot. They are used to see if a user is using SX OS, as SX OS registers a custom service called 'tx' and attempting to register a service of the same name lets the application know if it is present. | |||||
2018-11-03 | qt: Add help option to open yuzu folder | Zach Hilman | 3 | -0/+13 | |
Opens a new file manager window at the UserDir. | |||||
2018-11-03 | Stubbed SetMemoryPermission | Frederic Laing | 2 | -1/+12 | |
2018-11-02 | correct syntax | greggameplayer | 1 | -4/+3 | |
2018-11-02 | Fixed incorrect hwopus assert | David Marcec | 1 | -1/+1 | |
2018-11-02 | Fixed HID crash when launching more than 1 game & signaled syleset change event | David Marcec | 2 | -0/+5 | |
This should fix crashes when launching multiple games in yuzu | |||||
2018-11-02 | game_list: Make add-ons column optional | Zach Hilman | 6 | -119/+166 | |
As the add-ons column takes the most processing time out of any (as it needs to search registration for updates/dlc, patch control NCAs, search for mods, etc.), an option was added to disable it. This does not affect the application of add-ons. In large game collections, this decreases game list refresh time by as much as 70%. | |||||
2018-11-02 | filesystem: Cache RegisteredCacheUnion instead of constructing on demand | Zach Hilman | 2 | -4/+11 | |
Prevents unnecessary re-reads of the metadata and unnecessary temporary objects. | |||||
2018-11-02 | file_sys: Use common KeyManager in NCA container types | Zach Hilman | 6 | -7/+18 | |
Creates a single KeyManager for the entire container and then passes it into the NCA constructor, eliminating several unnecessary KeyManager reads. | |||||
2018-11-02 | content_archive: Add optional KeyManager parameter to constructor | Zach Hilman | 2 | -3/+5 | |
Allows resuing a common KeyManager when a large amount of NCAs are handled by the same class. Should the parameter not be provided, a new KeyManager will be constructed, as was the default behavior prior to this. | |||||
2018-11-02 | Fix ASTC Decompressor to support depth parameter | FernandoS27 | 7 | -65/+131 | |
2018-11-01 | memory_manager: Do not MapBufferEx over already in use memory. | bunnei | 2 | -31/+52 | |
- This fixes rendering when changing areas in Super Mario Odyssey. | |||||
2018-11-01 | Fix ASTC formats | FernandoS27 | 4 | -12/+21 | |
2018-11-01 | Implemented ASTC 5x5 | FernandoS27 | 1 | -1/+5 | |
2018-11-01 | Implement Cube Arrays | FernandoS27 | 4 | -0/+20 | |
2018-11-01 | maxwell_3d: Restructure macro upload to use a single macro code memory. | bunnei | 4 | -27/+55 | |
- Fixes an issue where macros could be skipped. - Fixes rendering of distant objects in Super Mario Odyssey. | |||||
2018-10-31 | configure_system: Contrain profile usernames to 32 characters | Lioncash | 5 | -25/+113 | |
Previously, we would let a user enter an unbounded name and then silently truncate away characters that went over the 32-character limit. This is kind of bad from the UX point of view, because we're essentially not doing what the user intended in certain scenarios. Instead, we clamp it to 32 characters and make that visually apparent in the dialog box to provide a name for a user. | |||||
2018-10-31 | Implement SurfaceTarget Texture2DArray | greggameplayer | 1 | -0/+1 | |
( needed by Mario+Rabbids Kingdom Battle ) | |||||
2018-10-31 | Improve OpenGL state handling | Rodolfo Bogado | 3 | -105/+158 | |
2018-10-30 | service/usb: Update IPdSession's function table | Lioncash | 1 | -3/+3 | |
Updated based off information on SwitchBrew. | |||||
2018-10-30 | video_core: Move surface declarations out of gl_rasterizer_cache | ReinUsesLisp | 6 | -898/+954 | |
2018-10-30 | Assert Control Codes Generation | FernandoS27 | 2 | -1/+103 | |
2018-10-30 | general: Remove unused boost inclusions where applicable | Lioncash | 3 | -4/+0 | |
Cleans up unused includes and trims off some dependencies on externals. | |||||
2018-10-30 | global: Use std::optional instead of boost::optional (#1578) | Frederic L | 49 | -266/+274 | |
* get rid of boost::optional * Remove optional references * Use std::reference_wrapper for optional references * Fix clang format * Fix clang format part 2 * Adressed feedback * Fix clang format and MacOS build | |||||
2018-10-30 | hle_ipc: Add member function for querying the existence of a domain header | Lioncash | 3 | -3/+6 | |
Gets rid of the need to call the getter and then check for null. | |||||
2018-10-30 | hle_ipc: Make GetDomainMessageHeader return a regular pointer | Lioncash | 2 | -3/+3 | |
Nothing requires the shared owner ship here, so we can just return a plain pointer. | |||||
2018-10-29 | ns: Implement command 400: GetApplicationControlData | Zach Hilman | 4 | -17/+75 | |
Returns the raw NACP bytes and the raw icon bytes into a title-provided buffer. Pulls from Registration Cache for control data, returning all zeros should it not exist. | |||||
2018-10-29 | patch_manager: Add support for dumping decompressed NSOs | Zach Hilman | 2 | -1/+14 | |
When enabled in settings, PatchNSO will dump the unmodified NSO that it was passed to a file named <build id>.nso in the dump root for the current title ID. | |||||
2018-10-29 | settings: Add setting to control NSO dumping | Zach Hilman | 6 | -1/+28 | |
Also adds UI option in Debug > Dump section, with the idea later things to be dumped (i.e. other game data or textures, etc) will use the same group box. | |||||
2018-10-29 | bis_factory: Add getter for mod dump root for a title ID | Zach Hilman | 4 | -6/+33 | |
Equates to yuzu_dir/dump/<title id>/ | |||||
2018-10-29 | fsp_srv: Implement ISaveDataInfoReader | Zach Hilman | 1 | -0/+144 | |
An object to read SaveDataInfo objects, which describe a unique save on the system. This implementation iterates through all the directories in the save data space and uses the paths to reconstruct the metadata. | |||||
2018-10-29 | fsp_srv: Implement command 61: OpenSaveDataInfoReaderBySaveDataSpaceId | Zach Hilman | 2 | -1/+13 | |
Needed by Checkpoint. Returns an object that can iterate through all savedata on the system. | |||||
2018-10-29 | savedata_factory: Expose accessors for SaveDataSpace | Zach Hilman | 4 | -14/+32 | |
2018-10-29 | loader/nro: Call RegisterRomFS from Load | Zach Hilman | 1 | -0/+5 | |
Allows NRO homebrew to use the RomFS in the ASET section. | |||||
2018-10-29 | control_metadata: Add GetRawBytes function to NACP | Zach Hilman | 2 | -0/+7 | |
Returns the raw bytes of the NACP file. Needed for GetApplicationControlData which returns the raw, unprocessed NACP to the game. | |||||
2018-10-29 | time_stretch: Switch to values of Citra | fearlessTobi | 1 | -3/+3 | |
2018-10-29 | video_core: Move OpenGL specific utils to its renderer | ReinUsesLisp | 6 | -30/+61 | |
2018-10-29 | renderer_opengl: Correct bpp value for ASTC_2D_8X5_SRGB | Rodolfo Bogado | 1 | -1/+1 | |
2018-10-29 | Assert Control Flow Instructions using Control Codes | FernandoS27 | 2 | -3/+28 | |
2018-10-29 | Fixed black textures, pixelation and we no longer require to auto-generate mipmaps | FernandoS27 | 1 | -14/+2 | |
2018-10-29 | Fixed mipmap block autosizing algorithm | FernandoS27 | 3 | -13/+25 | |
2018-10-29 | Fixed Invalid Image size and Mipmap calculation | FernandoS27 | 1 | -4/+7 | |
2018-10-29 | Fixed Block Resizing algorithm and Clang Format | FernandoS27 | 3 | -12/+19 | |
2018-10-29 | Implement Mip Filter | FernandoS27 | 4 | -10/+33 | |
2018-10-29 | Zero out memory region of recreated surface before flushing | FernandoS27 | 1 | -0/+2 | |
2018-10-28 | Implement Mipmaps | FernandoS27 | 2 | -101/+211 | |
2018-10-28 | core: Make System references const where applicable | Lioncash | 2 | -3/+3 | |
2018-10-28 | core: Add missing const variants of getters for the System class | Lioncash | 2 | -10/+49 | |
Many of the Current<Thing> getters (as well as a few others) were missing const qualified variants, which makes it a pain to retrieve certain things from const qualified references to System. | |||||
2018-10-28 | Enable alpha channel for DXT1 texture format | Michael | 1 | -2/+2 | |
2018-10-28 | configure_system: Fix compiler warning | Frederic Laing | 1 | -1/+1 | |
2018-10-28 | Correct bpp value for ASTC_2D_8X5 | Tobias | 1 | -1/+1 | |
2018-10-28 | Refactor precise usage and add FMNMX, MUFU, FMUL32 and FADD332 | FernandoS27 | 2 | -74/+37 | |
2018-10-28 | compatdb: Use a seperate endpoint for testcase submission | fearlessTobi | 7 | -7/+65 | |
2018-10-28 | file_sys/patch_manager: Remove unnecessary if-statements (#1586) | Frederic L | 1 | -7/+6 | |
* remove unnecessary if-statements * Addressed feedback | |||||
2018-10-28 | Implement sRGB Support, including workarounds for nvidia driver issues and QT sRGB support | Rodolfo Bogado | 8 | -40/+197 | |
2018-10-28 | key_manager: Use isxdigit instead of isdigit when reading key file | Zach Hilman | 1 | -1/+1 | |
Crypto revisions are hex numbers and this function only checks if the string is valid for stoul in base 16, so it should be isxdigit. | |||||
2018-10-28 | Improved Shader accuracy on Vertex and Geometry Shaders with FFMA, FMUL and FADD | FernandoS27 | 2 | -6/+58 | |
2018-10-27 | Implement Default Block Height for each format | FernandoS27 | 1 | -0/+62 | |
2018-10-27 | loader/nsp: Move secondary loader initialization to constructor | Zach Hilman | 1 | -17/+20 | |
Prevents nullptr bug when trying to dump the RomFS of an NSP resulting from secondary_loader not being initialized. | |||||
2018-10-27 | gl_rasterizer_cache: Fix compiler warning | Frederic Laing | 1 | -2/+2 | |
2018-10-27 | service/filesystem: Add DirectoryDelete & DirectoryDeleteRecursively | DeeJayBro | 1 | -2/+26 | |
2018-10-27 | configure_system: Make GetIcon() return the scaled 64x64 icon | Lioncash | 1 | -14/+7 | |
Avoids the need to put the scaling parameters all over the place for the common case. The only other time scaling is done is to generate the smaller 48x48 image, so this is fine. | |||||
2018-10-27 | configure_system: Move entry formatting for the user account list entries to its own function | Lioncash | 1 | -18/+22 | |
Avoids the need to duplicate this all over the place, and makes it translator-friendly across the board. | |||||
2018-10-27 | configure_system: Display errors to the user if file operations fail when setting user images | Lioncash | 1 | -24/+46 | |
We should display an error to the user if setting a user image for an account fails, rather than continuing onwards. | |||||
2018-10-27 | cubeb_sink: ignore null-name device when selecting | Weiyi Wang | 1 | -1/+2 | |
We already ignore them on listing devices. We should do the same when selecting devices. This fix a crash when opening a specific device while there is a null device in the list | |||||
2018-10-26 | svc: Localize the GetInfo enum class to the function itself | Lioncash | 2 | -32/+31 | |
Nothing from this enum is intended to be used outside of this function. | |||||
2018-10-26 | svc: Implement svcGetInfo command 0xF0000002 | Lioncash | 6 | -4/+98 | |
This retrieves: if (curr_thread == handle_thread) { result = total_thread_ticks + (hardware_tick_count - last_context_switch_ticks); } else if (curr_thread == handle_thread && sub_id == current_core_index) { result = hardware_tick_count - last_context_switch_ticks; } | |||||
2018-10-26 | gl_rasterizer: Implement primitive restart. | bunnei | 5 | -1/+40 | |
2018-10-26 | maxwell_3d: Add code for initializing register defaults. | bunnei | 2 | -1/+21 | |
2018-10-26 | gl_rasterizer: Implement depth range. | bunnei | 4 | -13/+20 | |
2018-10-26 | ldr: Partially implement LoadNro. | bunnei | 1 | -3/+49 | |
- This is an incomplete implementation. It was tested with Super Mario Party. | |||||
2018-10-26 | process: LoadModule should clear JIT instruction cache. | bunnei | 1 | -0/+6 | |
2018-10-26 | Kernel/Memory: Added a function to first a suitable guest address at which to allocate a region of a given size. | bunnei | 2 | -0/+28 | |
2018-10-26 | nro: Make LoadNro method accessible outside of apploader code. | bunnei | 2 | -6/+18 | |
2018-10-25 | configure_system: Make the file selector text translatable | Lioncash | 1 | -1/+1 | |
This should be localizable, since it's user-facing text. | |||||
2018-10-25 | configure_system: Make GetAccountUsername() an internal function | Lioncash | 2 | -25/+28 | |
We can just make the function accept an arbitrary ProfileManager reference and operate on that instead of tying the function to the class itself. This allows us to keep the function internal to the cpp file and removes the need to forward declare the UUID struct. | |||||
2018-10-25 | configure_system: Default initialize member variables | Lioncash | 1 | -4/+5 | |
These should be initialized to deterministic values so it's easier to catch improper behavior, as it'll always be reproducable, instead of performing uninitialized reads. | |||||
2018-10-25 | configure_system: Simplify UUID generation call in AddUser() | Lioncash | 1 | -2/+1 | |
This is a static function so we can just perform an assignment directly. | |||||
2018-10-25 | configure_system: Amend function casing | Lioncash | 2 | -6/+6 | |
2018-10-25 | configure_system: Add missing override specifier on the destructor | Lioncash | 1 | -1/+1 | |
2018-10-25 | configure_system: Make public slots private | Lioncash | 1 | -7/+5 | |
These are only used within this class, so we can make them private to keep their use contained. This also gets rid of the pre-Qt5 'slot' identifier, since Qt 5's connection syntax doesn't require a function to be declared a slot anymore. | |||||
2018-10-25 | ips_layer: Use rle_size instead of data_size in RLE patch application | Zach Hilman | 1 | -1/+1 | |
Prevents a potential bug when using RLE records in an IPS patch. | |||||
2018-10-25 | service/usb: Update service function tables | Lioncash | 1 | -21/+22 | |
Updated based off the information provided by Hexkyz on Switchbrew. | |||||
2018-10-25 | service/acc: Move fallback image to file scope | Lioncash | 1 | -14/+13 | |
This is just flat data, so it doesn't really need to be in the function itself. This also allows deduplicating the constant for the backup size in GetImageSize(). | |||||
2018-10-25 | service/acc: Silence compiler warnings | Lioncash | 1 | -5/+8 | |
Silences compiler warnings related to truncation. This also introduces a small helper function to perform the clamping of the image size. | |||||
2018-10-25 | service/acc: Early return in failure case in LoadImage() | Lioncash | 1 | -8/+8 | |
Allows unindenting the other branch's code. | |||||
2018-10-24 | Implemented LD_L and ST_L | FernandoS27 | 3 | -12/+112 | |
2018-10-24 | Implement Shader Local Memory | FernandoS27 | 1 | -0/+37 | |
2018-10-24 | kernel/errors: Remove now-unused, unnecessary, error codes | Lioncash | 2 | -13/+0 | |
Now that we've gotten the innaccurate error codes out of the way, we can finally toss away a bunch of these, trimming down the error codes to ones that are actually used and knocking out two TODO comments. | |||||
2018-10-24 | kernel/shared_memory: Return ERR_INVALID_MEMORY_PERMISSIONS instead of ERR_INVALID_COMBINATION | Lioncash | 1 | -4/+3 | |
This is more consistent with what the kernel does. | |||||
2018-10-24 | kernel/server_port: Simplify emptiness check within ShouldWait() | Lioncash | 1 | -1/+1 | |
2018-10-24 | kernel/server_port: Change error case return value in Accept() to ERR_NOT_FOUND | Lioncash | 2 | -3/+1 | |
This is what the kernel does in this instance. | |||||
2018-10-24 | kernel/error: Remove leftover 3DS error codes | Lioncash | 1 | -5/+0 | |
These are now entirely unused and can be removed. | |||||
2018-10-24 | kernel/svc: Amend returned error code for invalid priorities in CreateThread | Lioncash | 1 | -1/+1 | |
Like with the previous change, the kernel doesn't return NOT_AUTHORIZED here. It returns INVALID_THREAD_PRIORITY. | |||||
2018-10-24 | kernel/svc: Move and correct returned error code for invalid thread priorities in SetThreadPriority() | Lioncash | 1 | -5/+6 | |
All priority checks are supposed to occur before checking the validity of the thread handle, we're also not supposed to return ERR_NOT_AUTHORIZED here. | |||||
2018-10-24 | kernel/error: Add error code for invalid pointers | Lioncash | 1 | -1/+1 | |
The kernel appears to return 0xE601 for this situation. Particularly in svcWaitSynchronization, svcReplyAndReceive, and svcGetThreadContext | |||||
2018-10-24 | kernel/error: Add error code for closed sessions | Lioncash | 1 | -1/+3 | |
The kernel appears to return 0xF601 for this case. | |||||
2018-10-24 | game_list_worker: Use QString's formatting instead of fmt in FormatPatchNameVersions() | Lioncash | 1 | -4/+9 | |
Using fmt here requires unnecessary string conversions back into QString. Instead, we can just use QString's formatting and get the end result of the formatting operation in the proper type. | |||||
2018-10-24 | profile_manager: Use std::optional instead of boost::optional | Lioncash | 5 | -48/+53 | |
Now that we can actually use std::optional on macOS, we don't need to continue using boost::optional here. | |||||
2018-10-24 | graphic_breakpoints: Correct translation of strings in BreakpointModel's data() function | Lioncash | 2 | -15/+20 | |
tr() will not function properly on static/global data like this, as the object is only ever constructed once, so the strings won't translate if the language is changed without restarting the program, which is undesirable. Instead we can just turn the map into a plain old function that maps the values to their equivalent strings. This is also lessens the memory allocated, since it's only allocating memory for the strings themselves, and not an encompassing map as well. | |||||
2018-10-24 | yuzu/main: Notify user of loading errors with Amiibo data | Lioncash | 3 | -17/+40 | |
We shouldn't silently continue if loading failed, since the general assumption is that no messages showing up implicitly indicates success. | |||||
2018-10-24 | configure_system: Clear current username before overwriting | Zach Hilman | 2 | -5/+15 | |
Prevents bug where old username would remain if the new username was shorter in length. | |||||
2018-10-24 | game_list: Use QFileInfo instead of common's file functions | Lioncash | 1 | -4/+3 | |
We can just use the facilities that Qt provides instead of pulling in stuff from common. While we're at it, we can also simplify the nearby logging statement's argument by just calling .toStdString() | |||||
2018-10-24 | game_list: Make game list column headers translatable | Lioncash | 1 | -5/+5 | |
These are user-facing strings, so they should be marked as translatable | |||||
2018-10-24 | bootmanager: Use QStringLiteral instead of std::string to represent the window title | Lioncash | 1 | -4/+2 | |
This gets rid of an unnecessary type conversion. We can just use the regular QStringLiteral to already format the string as the type setWindowTitle accepts instead of converting from a std::string instance. | |||||
2018-10-24 | time_stretch: Remove unused m_channel_count member variable | Lioncash | 2 | -3/+1 | |
This is only stored to, but never read from. | |||||
2018-10-24 | npad: Remove unused controller variable from OnInit() | Lioncash | 1 | -2/+3 | |
This also gets rid of variable shadowing related to the lambda parameter a little bit below this code as well. | |||||
2018-10-24 | perf_stats: Remove unused variable within DoFrameLimiting() | Lioncash | 1 | -4/+0 | |
This hasn't been used since ba8ff096fdc9f7ab101851c4cd06c3244a7d84c3 | |||||
2018-10-24 | yuzu/configuration/config: Use a std::unique_ptr for qt_config instead of a raw pointer | Lioncash | 2 | -8/+8 | |
Same behavior, less code. | |||||
2018-10-24 | aoc_u: Make use of previously-unused CheckAOCTitleIDMatchesBase() function | Lioncash | 1 | -3/+3 | |
We can just call the function instead of duplicating the code here. This also prevents an unused function warning. We also don't need to take the lambda capture by reference. It's just a u64 value, so by value is fine here. | |||||
2018-10-24 | vfs: Handle failure of file reading within VfsRawCopy() | Lioncash | 1 | -2/+6 | |
Also gets rid of an unused variable. | |||||
2018-10-24 | key_manager: Remove unused variable in DeriveBase() | Lioncash | 1 | -1/+0 | |
2018-10-24 | decoders: Remove unused variable within SwizzledData() | Lioncash | 1 | -1/+0 | |
2018-10-24 | maxwell_3d: Remove unused variable within ProcessQueryGet() | Lioncash | 1 | -1/+0 | |
2018-10-24 | logging/backend: Add missing services to the log filters | Lioncash | 2 | -0/+5 | |
Just a few overlooked services. | |||||
2018-10-24 | yuzu/configuration/config: Reorganize member variable and function layout | Lioncash | 1 | -6/+7 | |
Makes the class layout consistent with the others. | |||||
2018-10-24 | profile_manager: Create save data if it doesn't exist on use | Zach Hilman | 4 | -18/+42 | |
2018-10-24 | acc: Fix account UUID duplication error | Zach Hilman | 8 | -80/+106 | |
2018-10-24 | configure_system: Clear selection after user delete | Zach Hilman | 2 | -12/+18 | |
2018-10-24 | profile_manager: Load user icons, names, and UUIDs from system save | Zach Hilman | 11 | -133/+308 | |
2018-10-24 | acc: Load user images from config dir | Zach Hilman | 1 | -9/+45 | |
2018-10-24 | qt: Allow user to select emu user on open save data | Zach Hilman | 1 | -3/+24 | |
2018-10-24 | qt: Add Profile Manager UI to system settings | Zach Hilman | 3 | -76/+350 | |
2018-10-24 | am: Pass current user UUID to launch parameters | Zach Hilman | 1 | -7/+9 | |
2018-10-24 | profile_manager: Load users from emulator settings | Zach Hilman | 2 | -5/+7 | |
2018-10-24 | settings: Add users and current_user settings and remove username | Zach Hilman | 3 | -6/+54 | |
2018-10-24 | Added Amiibo support (#1390) | David | 12 | -80/+386 | |
* Fixed conflict with nfp * Few fixups for nfc * Conflict 2 * Fixed AttachAvailabilityChangeEvent * Conflict 3 * Fixed byte padding * Refactored amiibo to not reside in "System" * Removed remaining references of nfc from system * used enum for Nfc GetStateOld * Added missing newline * Moved file operations to front end * Conflict 4 * Amiibos now use structs and added mutexes * Removed amiibo_path | |||||
2018-10-23 | Implement PointSize | FernandoS27 | 3 | -5/+28 | |
2018-10-23 | Fixed Layered Textures Loading and Cubemaps | FernandoS27 | 3 | -72/+109 | |
2018-10-23 | common: Remove memory_util.cpp/.h | Lioncash | 3 | -200/+0 | |
Everything from here is completely unused and also written with the notion of supporting 32-bit architecture variants in mind. Given the Switch itself is on a 64-bit architecture, we won't be supporting 32-bit architectures. If we need specific allocation functions in the future, it's likely more worthwhile to new functions for that purpose. | |||||
2018-10-23 | only redefine 64 bit file operation for MSVC | Weiyi Wang | 1 | -5/+8 | |
MinGW provides POSIX functions | |||||
2018-10-23 | Added assertion failed, reworked logging levels | David Marcec | 1 | -16/+24 | |
2018-10-23 | gl_shader_decompiler: Implement VSETP | ReinUsesLisp | 2 | -0/+26 | |
2018-10-23 | gl_shader_decompiler: Abstract VMAD into a video subset | ReinUsesLisp | 2 | -75/+82 | |
2018-10-23 | Added break types to svcBreak | David Marcec | 1 | -4/+42 | |
There seems to be more such as type 1, and 2. Unsure what these currently are but when a game hits them we can investigate and add the rest | |||||
2018-10-23 | Added Saturation to FMUL32I | FernandoS27 | 2 | -3/+8 | |
2018-10-22 | Assert that multiple render targets are not set while alpha testing | FernandoS27 | 3 | -3/+17 | |
2018-10-22 | Use standard UBO and fix/stylize the code | FernandoS27 | 8 | -91/+51 | |
2018-10-22 | Cache uniform locations and restructure the implementation | FernandoS27 | 3 | -33/+29 | |
2018-10-22 | Remove SyncAlphaTest and clang format | FernandoS27 | 4 | -8/+9 | |
2018-10-22 | Added Alpha Func | FernandoS27 | 2 | -3/+43 | |
2018-10-22 | Implemented Alpha Testing | FernandoS27 | 6 | -3/+59 | |
2018-10-22 | Fixed FSETP and FSET | FernandoS27 | 2 | -30/+12 | |
2018-10-22 | Fixed VAOs Float types only returning GL_FLOAT in cases that they had to return GL_HALF_FLOAT | FernandoS27 | 1 | -2/+14 | |
2018-10-22 | psm: Stub GetChargerType | Zach Hilman | 2 | -24/+27 | |
Used by LovePotion Lua Homebrew. Stubbed as connected to official Nintendo Switch dock. | |||||
2018-10-21 | service: Add the basic skeleton for the NPNS services | Lioncash | 4 | -2/+109 | |
2018-10-21 | hid: Update service function table for hidbus | Lioncash | 1 | -0/+1 | |
Updated based off information provided by Switchbrew. | |||||
2018-10-21 | am: Add the basic skeleton for the tcap service | Lioncash | 4 | -0/+44 | |
Added based off information provided by Switchbrew. | |||||
2018-10-21 | am: Update service function tables | Lioncash | 4 | -15/+60 | |
Updated based off information from Switchbrew | |||||
2018-10-21 | prepo: Update service function table. | Lioncash | 1 | -8/+13 | |
Also introduces the new prepo:a2 service. Updated based off information provided by Switchbrew. | |||||
2018-10-21 | lbl: Update service function table names | Lioncash | 1 | -28/+28 | |
Updated based off information provided by Switchbrew. | |||||
2018-10-21 | qt: Move Reinitialize Keys to Tools menu | Zach Hilman | 1 | -1/+7 | |
2018-10-21 | psm: Stub GetBatteryChargePercentage | Zach Hilman | 2 | -1/+14 | |
Used by LovePotion Lua Homebrew. Stubbed to return 100% charge. | |||||
2018-10-21 | service: Add skeleton for psm service | Zach Hilman | 5 | -0/+75 | |
Seems to be the power controller. Listed in switchbrew under the category PTM services. | |||||
2018-10-20 | CMakeLists: Use PROJECT_SOURCE_DIR instead of CMAKE_SOURCE_DIR | Lioncash | 2 | -5/+5 | |
This is more localized to what we want to enforce directory-wise with the project. CMAKE_SOURCE_DIR indicates the root of the source tree, but this would cause the wrong behavior if someone included yuzu as part of a larger buildsystem (for whatever reason). Instead, we want to use the directory where the "project(yuzu)" command was declared as the root path reference. | |||||
2018-10-20 | CMakeLists: Use target_compile_definitions instead of add_definitions to define YUZU_ENABLE_COMPATIBILITY_REPORTING | Lioncash | 1 | -1/+1 | |
Keeps the definition constrained to the yuzu target and prevents polluting anything else in the same directory (should that ever happen). It also keeps it consistent with how the USE_DISCORD_PRESENCE definition is introduced below it. | |||||
2018-10-20 | web_service/CMakeLists: Make the CPPHTTPLIB_OPENSSL_SUPPORT constrained to the web_service library only | Lioncash | 1 | -1/+1 | |
Given we link in httplib privately, we can also make the definition enabling OpenSSL support private as well. Prevents leaking a definition into other libraries that link with this one, like the core library. | |||||
2018-10-20 | kernel/process: Make the handle table per-process | Lioncash | 9 | -100/+97 | |
In the kernel, there isn't a singular handle table that everything gets tossed into or used, rather, each process gets its own handle table that it uses. This currently isn't an issue for us, since we only execute one process at the moment, but we may as well get this out of the way so it's not a headache later on. | |||||
2018-10-20 | engines/maxwell_*: Use nested namespace specifiers where applicable | Lioncash | 3 | -12/+6 | |
These three source files are the only ones within the engines directory that don't use nested namespaces. We may as well change these over to keep things consistent. | |||||
2018-10-20 | maxwell_dma: Make variables const where applicable within HandleCopy() | Lioncash | 1 | -3/+3 | |
These are never modified, so we can make that assumption explicit. | |||||
2018-10-20 | maxwell_dma: Make FlushAndInvalidate's size parameter a u64 | Lioncash | 1 | -1/+1 | |
This prevents truncation warnings at the lambda's usage sites. | |||||
2018-10-20 | maxwell_dma: Remove unused variables in HandleCopy() | Lioncash | 1 | -3/+0 | |
These pointer variables are never used, so we can get rid of them. | |||||
2018-10-20 | svc: Fix vma boundary check in svcQueryMemory | Lioncash | 1 | -1/+1 | |
This should be comparing against the queried process' vma_map, not the current process'. The only reason this hasn't become an issue yet is we currently only handle one process being active at any time. | |||||
2018-10-20 | gl_shader_decompiler: Allow std::move to function in SetPredicate | Lioncash | 1 | -1/+1 | |
If the variable being moved is const, then std::move will always perform a copy (since it can't actually move the data). | |||||
2018-10-20 | gl_shader_decompiler: Get rid of variable shadowing warnings | Lioncash | 1 | -2/+2 | |
A variable with the same name was previously declared in an outer scope. | |||||
2018-10-20 | gl_shader_decompiler: Fix a few comment typos | Lioncash | 1 | -3/+4 | |
2018-10-20 | gl_shader_decompiler: Move position varying declaration back to gl_shader_gen | ReinUsesLisp | 3 | -13/+9 | |
The intention of declaring them in gl_shader_decompiler was to be able to use blocks to implement geometry shaders. But that wasn't needed in the end and it caused issues when both vertex stages were being used, resulting in a redeclaration of "position". | |||||
2018-10-20 | Added auto controller switching to supported controllers and single joycon button rotation | David Marcec | 2 | -4/+189 | |
This is a subset of the better-hid-2 changes, this fixes input in various games which don't support dual joycons. This pr will search for the next best controller which is supported by the current game | |||||
2018-10-20 | aoc_u: Stub GetAddOnContentListChangedEvent | Zach Hilman | 2 | -1/+16 | |
This event signals the game when new DLC is purchased from the eShop while the game is running. Since, for the forseeable future, yuzu will not have this ability, it seems safe to stub with a dummy event that will never fire. This is needed to boot Sonic Mania Plus (update v1.04). | |||||
2018-10-20 | crypto: Use compressed sizes in offset calculation for KIP decompression | Zach Hilman | 1 | -1/+2 | |
Fixes a fatal crash on start when deriving keys. | |||||
2018-10-19 | vfs: Remove InterpretAsDirectory and related functions | Zach Hilman | 17 | -95/+1 | |
When writing VFS, it initally seemed useful to include a function to in-place convert container files into directories in one homogenous directory structure, but re-evaluating it now there have been plenty of chances to use it and there has always been a better way. Removing as it is unused and likely will not be used. | |||||
2018-10-19 | Stubbed home blocking | David Marcec | 2 | -4/+36 | |
Needed by arms due to new hid rework | |||||
2018-10-19 | es: Update service function tables | Lioncash | 1 | -7/+11 | |
Updated based off information provided by Switchbrew. | |||||
2018-10-19 | audio: Update service function tables | Lioncash | 1 | -17/+20 | |
Updated based off information provided by Switchbrew. | |||||
2018-10-19 | omm: Update service function tables | Lioncash | 1 | -16/+18 | |
Updated based off information provided by Switchbrew. | |||||
2018-10-19 | nifm: Update service function tables | Lioncash | 1 | -0/+1 | |
Updated based off information provided by switchbrew. | |||||
2018-10-19 | hid: Update service function tables | Lioncash | 1 | -6/+45 | |
Updated based off information provided by Switchbrew. | |||||
2018-10-19 | nim: Add the basic skeleton of the nim:eca service | Lioncash | 1 | -0/+17 | |
Added based off information provided by Switchbrew | |||||
2018-10-19 | ns: Update service function table | Lioncash | 1 | -6/+49 | |
Updated based off information provided by Switchbrew. | |||||
2018-10-19 | set_cal: Update service function table | Lioncash | 1 | -1/+2 | |
Updated based on information from Switchbrew. | |||||
2018-10-19 | GPU: Improved implementation of maxwell DMA (Subv). | bunnei | 3 | -17/+66 | |
2018-10-19 | decoders: Introduce functions for un/swizzling subrects. | bunnei | 2 | -0/+49 | |
2018-10-19 | GPU: Invalidate destination address of kepler_memory writes. | bunnei | 3 | -3/+17 | |
2018-10-19 | fermi_2d: Add support for more accurate surface copies. | bunnei | 2 | -3/+12 | |
2018-10-18 | svc: Check for word alignment of addresses within svcArbitrateLock/svcArbitrateUnlock | Lioncash | 1 | -0/+8 | |
The kernel itself checks whether or not the provided addresses are word aligned before continuing, so we should be doing the same. | |||||
2018-10-18 | common: Add function for checking word alignment to alignment.h | Lioncash | 1 | -0/+6 | |
This will be used in a following change to svcArbitrateLock() and svcArbitrateUnlock() | |||||
2018-10-18 | common: Move Is4KBAligned() to alignment.h | Lioncash | 2 | -9/+13 | |
Aligning on 4KB pages isn't a Switch-specific thing, so this can be moved to common so it can be used with other things as well. | |||||
2018-10-18 | core: Remove unnecessary assert in ArmInterface() | Lioncash | 1 | -2/+1 | |
CpuCore already does this sort of checking, so we can just call that instead of duplicating the assertions. | |||||
2018-10-18 | Used better names for mm:u and fixed bad stub | David Marcec | 1 | -8/+42 | |
InitializeWithId needs to return an id which is a u32 which should be a non zero value | |||||
2018-10-18 | svc: Add missing sanitizing checks for MapSharedMemory/UnmapSharedMemory | Lioncash | 3 | -3/+50 | |
Now that the changes clarifying the address spaces has been merged, we can wrap the checks that the kernel performs when mapping shared memory (and other forms of memory) into its own helper function and then use those within MapSharedMemory and UnmapSharedMemory to complete the sanitizing checks that are supposed to be done. | |||||
2018-10-18 | hid/controller: Remove unused header inclusions | Lioncash | 9 | -9/+0 | |
swap.h only needs to be present in the header for the type aliases and definitions, it's not actually needed in the cpp files though. input.h is just unused entirely in xpad.h | |||||
2018-10-18 | hid/controller/npad: Remove unused dump_idx member variable | Lioncash | 1 | -1/+0 | |
Given it's unused, we may as well toss it. | |||||
2018-10-18 | hid/controller/npad: Remove unnecessary semicolon from the closing brace of LedPattern's constructor | Lioncash | 1 | -1/+1 | |
2018-10-18 | hid/controller/npad: Remove #pragma once from the cpp file | Lioncash | 1 | -2/+0 | |
This is only useful in headers. | |||||
2018-10-18 | hid/controller/npad: Move npad_id_list into the cpp file | Lioncash | 2 | -2/+10 | |
This is just a lookup table, and since it's private, there's nothing really stateful about it, so we can just move it into the cpp file. | |||||
2018-10-18 | hid/controller/npad: Remove unnecessary const from void return type | Lioncash | 2 | -2/+2 | |
This literally does nothing. | |||||
2018-10-18 | hid/controller: Default the destructors of all controller types in the cpp file | Lioncash | 16 | -0/+16 | |
These classes are non-trivial and are definitely going to be changed in the future, so we default these to prevent issues with forward declarations, and to keep the compiler from inlining tear-down code. | |||||
2018-10-18 | controller_base: Default the base class constructor and destructor in the cpp file | Lioncash | 2 | -2/+4 | |
The destructor doesn't need to be a pure-virtual function. | |||||
2018-10-18 | gl_shader_decompiler: Implement PBK and BRK | ReinUsesLisp | 2 | -22/+43 | |
2018-10-18 | Clang format and other fixes | FernandoS27 | 1 | -16/+0 | |
2018-10-18 | Implement Reinterpret Surface, to accurately blit 3D textures | FernandoS27 | 1 | -2/+4 | |
2018-10-18 | Implement GetInRange in the Rasterizer Cache | FernandoS27 | 1 | -0/+16 | |
2018-10-18 | Implement 3D Textures | FernandoS27 | 4 | -1/+10 | |
2018-10-18 | qt: Add support for dumping a DLC Data RomFS | Zach Hilman | 4 | -11/+73 | |
2018-10-18 | gl_rasterizer_cache: Remove unnecessary block_depth=1 on Flush. | bunnei | 1 | -1/+0 | |
2018-10-18 | gl_rasterizer_cache: Remove unnecessary temporary buffer with unswizzle. | bunnei | 1 | -5/+2 | |
2018-10-17 | registered_cache: Deduplicate results of ListEntry and ListEntryFilter | Zach Hilman | 2 | -2/+16 | |
Prevents a Entry from appearing in the list twice if the user has it installed in two places (e.g. User NAND and SDMC) | |||||
2018-10-17 | Using dual joycons as the default controller | David Marcec | 3 | -77/+59 | |
Reason for the change is to allow both docked and undocked mode to work | |||||
2018-10-17 | fsp_srv: Apply patches to Data storage in OpenDataStorageByDataId | Zach Hilman | 1 | -1/+5 | |
2018-10-17 | patch_manager: Add support for using LayeredFS with Data | Zach Hilman | 1 | -2/+3 | |
2018-10-16 | gl_rasterizer_cache: Use AccurateCopySurface for use_accurate_gpu_emulation. | bunnei | 2 | -2/+18 | |
2018-10-16 | config: Rename use_accurate_framebuffers -> use_accurate_gpu_emulation. | bunnei | 10 | -20/+20 | |
- This will be used as a catch-all for slow-but-accurate GPU emulation paths. | |||||
2018-10-16 | rasterizer_cache: Refactor to support in-order flushing. | bunnei | 6 | -63/+116 | |
2018-10-16 | content_archive: Simpify assignment of bktr_base_romfs in the constructor | Lioncash | 1 | -2/+1 | |
std::move doesn't actually dereference the data, so it doesn't matter whether or not the type is null. | |||||
2018-10-16 | content_archive: Make IsValidNCA() an internally linked function | Lioncash | 2 | -3/+1 | |
This is only ever used within the cpp file, so it can just be an internal function. | |||||
2018-10-16 | content_archive: Simplify rights ID check | Lioncash | 1 | -2/+2 | |
This is the same as using std::any_of with an inverted predicate. | |||||
2018-10-16 | content_archive: Split loading into separate functions | Lioncash | 2 | -253/+290 | |
The constructor alone is pretty large, the reading code should be split into its consistuent parts to make it easier to understand it without having to build a mental model of a 300+ line function. | |||||
2018-10-16 | content_archive: Pass and take NCASectionHeader instance by reference | Lioncash | 2 | -3/+3 | |
Each header is 512 bytes in size, which is kind of an excessive amount to copy all the time when it's possible to avoid doing so. | |||||
2018-10-16 | XCI: Add function for checking the existence of the program NCA | Lioncash | 3 | -7/+8 | |
The only reason the getter existed was to check whether or not the program NCA was null. Instead, we can just provide a function to query for the existence of it, instead of exposing it entirely. | |||||
2018-10-16 | gl_rasterizer_cache: Refactor to only call GetRegionEnd on surface creation. | bunnei | 2 | -16/+23 | |
2018-10-16 | gl_rasterizer_cache: Only flush when use_accurate_framebuffers is enabled. | bunnei | 2 | -2/+13 | |
2018-10-16 | gl_rasterizer_cache: Separate guest and host surface size managment. | bunnei | 2 | -92/+94 | |
2018-10-16 | gl_rasterizer_cache: Rename GetGLBytesPerPixel to GetBytesPerPixel. | bunnei | 2 | -17/+18 | |
- This does not really have anything to do with OpenGL. | |||||
2018-10-16 | gl_rasterizer_cache: Remove unused FlushSurface method. | bunnei | 2 | -7/+0 | |
2018-10-16 | gl_rasterizer: Implement flushing. | bunnei | 1 | -1/+25 | |
2018-10-16 | gl_rasterizer_cache: Remove usage of Memory::Read/Write functions. | bunnei | 1 | -13/+8 | |
- These cannot be used within the cache, as they change cache state. | |||||
2018-10-16 | gl_rasterizer_cache: Clamp cached surface size to mapped GPU region size. | bunnei | 2 | -19/+37 | |
2018-10-16 | memory_manager: Add a method for querying the end of a mapped GPU region. | bunnei | 2 | -0/+11 | |
2018-10-16 | rasterizer_cache: Reintroduce method for flushing. | bunnei | 3 | -0/+23 | |
2018-10-16 | gl_rasterizer_cache: Reintroduce code for handling swizzle and flush to guest RAM. | bunnei | 2 | -28/+119 | |
2018-10-16 | Implement VI ConvertScalingMode (#1475) | David | 1 | -1/+49 | |
* Implement VI ConvertScalingMode * Fixed push enum * Scale mode now uses Nintendo scale mode as an enum as well | |||||
2018-10-16 | savedata_factory: Add TemporaryStorage SaveDataSpaceId | Zach Hilman | 1 | -1/+4 | |
Required for TemporaryStorage saves (in addition to SaveDataType) | |||||
2018-10-16 | savedata_factory: Add support for DeviceSaveData | Zach Hilman | 1 | -0/+8 | |
Uses the same path as SaveData except with UID 0. Adds a warning if UID is not 0. | |||||
2018-10-16 | file_sys/registered_cache: Use unique_ptr and regular pointers instead of shared_ptrs where applicable | Lioncash | 12 | -51/+53 | |
The data retrieved in these cases are ultimately chiefly owned by either the RegisteredCache instance itself, or the filesystem factories. Both these should live throughout the use of their contained data. If they don't, it should be considered an interface/design issue, and using shared_ptr instances here would mask that, as the data would always be prolonged after the main owner's lifetime ended. This makes the lifetime of the data explicit and makes it harder to accidentally create cyclic references. It also makes the interface slightly more flexible than the previous API, as a shared_ptr can be created from a unique_ptr, but not the other way around, so this allows for that use-case if it ever becomes necessary in some form. | |||||
2018-10-16 | file_sys/control_metadata: Get rid of magic constants | Lioncash | 1 | -3/+6 | |
These are just the size of the data being passed in, so we can specify that via the size() member function. | |||||
2018-10-15 | nso: Return an optional address from LoadModule | Lioncash | 5 | -16/+29 | |
If a malformed NSO is attempted to be loaded, we shouldn't continue onwards. We should be reporting an error and bailing out. | |||||
2018-10-15 | shader_bytecode: Add Control Code enum 0xf | ReinUsesLisp | 1 | -1/+1 | |
Control Code 0xf means to unconditionally execute the instruction. This value is passed to most BRA, EXIT and SYNC instructions (among others) but this may not always be the case. | |||||
2018-10-15 | gl_shader_decompiler: Fixup style inconsistencies | ReinUsesLisp | 1 | -5/+3 | |
2018-10-15 | gl_rasterizer: Silence implicit cast warning in glBindBufferRange | ReinUsesLisp | 1 | -1/+2 | |
2018-10-15 | core_cpu: Make Cpu scheduler instances unique_ptrs instead of shared_ptrs | Lioncash | 10 | -31/+50 | |
2018-10-15 | core: Make the live Cpu instances unique_ptrs instead of shared_ptrs | Lioncash | 1 | -9/+9 | |
There's no need for shared ownership here, as the only owning class instance of those Cpu instances is the System class itself. We can also make the thread_to_cpu map use regular pointers instead of shared_ptrs, given that the Cpu instances will always outlive the cases where they're used with that map. | |||||
2018-10-15 | core: Make the exclusive monitor a unique_ptr instead of a shared_ptr | Lioncash | 5 | -15/+13 | |
Like the barrier, this is owned entirely by the System and will always outlive the encompassing state, so shared ownership semantics aren't necessary here. | |||||
2018-10-15 | core: Make CPUBarrier a unique_ptr instead of a shared_ptr | Lioncash | 3 | -11/+10 | |
This will always outlive the Cpu instances, since it's destroyed after we destroy the Cpu instances on shutdown, so there's no need for shared ownership semantics here. | |||||
2018-10-15 | gl_shader_decompiler: Implement HSET2_R | ReinUsesLisp | 2 | -0/+62 | |
2018-10-15 | gl_shader_decompiler: Implement HSETP2_R | ReinUsesLisp | 2 | -0/+65 | |
2018-10-15 | gl_shader_decompiler: Implement HFMA2 instructions | ReinUsesLisp | 2 | -0/+85 | |
2018-10-15 | gl_shader_decompiler: Implement HADD2_IMM and HMUL2_IMM | ReinUsesLisp | 2 | -0/+73 | |
2018-10-15 | gl_shader_decompiler: Implement non-immediate HADD2 and HMUL2 instructions | ReinUsesLisp | 2 | -0/+75 | |
2018-10-15 | gl_shader_decompiler: Setup base for half float unpacking and setting | ReinUsesLisp | 2 | -0/+98 | |
2018-10-15 | crypto: Various crypto fixes for quickstart guide | Zach Hilman | 2 | -4/+8 | |
2018-10-15 | nso: Make LoadModule take a VfsFile by const reference | Lioncash | 3 | -11/+9 | |
2018-10-15 | nro: Make LoadNro take a VfsFile by const reference | Lioncash | 2 | -6/+6 | |
This function doesn't need to care about ownership semantics, so we can just pass it a reference to the file itself, rather than a std::shared_ptr alias. | |||||
2018-10-15 | svc: Clarify enum values for AddressSpaceBaseAddr and AddressSpaceSize in svcGetInfo() | Lioncash | 4 | -28/+44 | |
So, one thing that's puzzled me is why the kernel seemed to *not* use the direct code address ranges in some cases for some service functions. For example, in svcMapMemory, the full address space width is compared against for validity, but for svcMapSharedMemory, it compares against 0xFFE00000, 0xFF8000000, and 0x7FF8000000 as upper bounds, and uses either 0x200000 or 0x8000000 as the lower-bounds as the beginning of the compared range. Coincidentally, these exact same values are also used in svcGetInfo, and also when initializing the user address space, so this is actually retrieving the ASLR extents, not the extents of the address space in general. | |||||
2018-10-15 | aoc: Read DLC base title ID from RegisteredCache | Zach Hilman | 3 | -2/+18 | |
Falls back to title ID + 0x1000, which is what HOS does. | |||||
2018-10-14 | Implement Arrays on Tex Instruction | FernandoS27 | 1 | -14/+55 | |
2018-10-14 | Stop all threads on svcBreak | David Marcec | 1 | -0/+6 | |
This should help diagnose crashes easier and prevent many users thinking that a game is still running when in fact it's just an audio thread still running(this is typically not killed when svcBreak is hit since the game expects us to do this) | |||||
2018-10-14 | aoc: Return size in ListAddOnContent | Zach Hilman | 1 | -1/+2 | |
2018-10-14 | Fix TLDS | FernandoS27 | 1 | -1/+5 | |
2018-10-14 | Shorten the implementation of 3D swizzle to only 3 functions | FernandoS27 | 1 | -70/+27 | |
2018-10-13 | svc: Implement svcGetProcessInfo | Lioncash | 3 | -4/+50 | |
A fairly basic service function, which only appears to currently support retrieving the process state. This also alters the ProcessStatus enum to contain all of the values that a kernel process seems to be able of reporting with regards to state. | |||||
2018-10-13 | Fix a Crash on Zelda BotW and Splatoon 2, and simplified LoadGLBuffer | FernandoS27 | 2 | -19/+2 | |
2018-10-13 | Propagate depth and depth_block on modules using decoders | FernandoS27 | 8 | -54/+67 | |
2018-10-13 | Remove old Swizzle algorithms and use 3d Swizzle | FernandoS27 | 1 | -93/+69 | |
2018-10-13 | Implement Precise 3D Swizzle | FernandoS27 | 1 | -3/+71 | |
2018-10-13 | Implement Fast 3D Swizzle | FernandoS27 | 1 | -2/+74 | |
2018-10-13 | filesystem: Make CreateFactories() and InstallInterface() take a VfsFilesystem instance by reference | Lioncash | 7 | -20/+19 | |
Neither of these functions alter the ownership of the provided pointer, so we can simply make the parameters a reference rather than a direct shared pointer alias. This way we also disallow passing incorrect memory values like nullptr. | |||||
2018-10-13 | yuzu/main: Simplify OnMenuLoadFile() | Lioncash | 1 | -14/+12 | |
We can utilize QStringList's join() function to perform all of the appending in a single function call. While we're at it, make the extension list a single translatable string and add a disambiguation comment to explain to translators what %1 actually is. | |||||
2018-10-13 | yuzu/main: Apply the [[maybe_unused]] attribute to the parameter of SetDiscordEnabled() | Lioncash | 1 | -1/+1 | |
Depending on whether or not USE_DISCORD_PRESENCE is defined, the "state" parameter can be used or unused. If USE_DISCORD_PRESENCE is not defined, the parameter will be considered unused, which can lead to compiler warnings. So, we can explicitly mark it with [[maybe_unused]] to inform the compiler that this is intentional. | |||||
2018-10-13 | Added ASTC 5x4; 8x5 | Hexagon12 | 3 | -6/+32 | |
2018-10-13 | partition_data_manager: Reserve and insert data within output vector in DecryptPackage2() | Lioncash | 1 | -20/+16 | |
We can just reserve the memory then perform successive insertions instead of needing to use memcpy. This also avoids the need to zero out the output vector's memory before performing the insertions. We can also std::move the output std::vector into the destination so that we don't need to make a completely new copy of the vector, getting rid of an unnecessary allocation. Additionally, we can use iterators to determine the beginning and end ranges of the std::vector instances that comprise the output vector, as the end of one range just becomes the beginning for the next successive range, and since std::vector's iterator constructor copies data within the range [begin, end), this is more straightforward and gets rid of the need to have an offset variable that keeps getting incremented to determine where to do the next std::memcpy. | |||||
2018-10-13 | partition_data_manager: Remove unused std::map instance within DecryptPackage2() | Lioncash | 1 | -2/+0 | |
Aside from emplacing elements into the map, the map itself is never actually queried for contained data. | |||||
2018-10-13 | partition_data_manager: Take package2_keys by const reference | Lioncash | 2 | -2/+3 | |
These are only ever read from, so we don't need to make a copy of all the keys here. | |||||
2018-10-13 | partition_data_manager: Move IV data to where it's needed in DecryptPackage2() | Lioncash | 1 | -3/+1 | |
Given it's only used in one spot and has a fairly generic name, we can just specify it directly in the function call. This also the benefit of automatically moving it. | |||||
2018-10-13 | partition_data_manager: Remove commented out code | Lioncash | 1 | -2/+0 | |
Commented out code shouldn't be left in without a reason indicating why in a comment. | |||||
2018-10-13 | key_manager/partition_data_manager: Silence truncation compiler warnings | Lioncash | 4 | -10/+15 | |
2018-10-13 | partition_data_manager: Dehardcode array bounds | Lioncash | 2 | -7/+12 | |
Instead, we can make it part of the type and make named variables for them, so they only require one definition (and if they ever change for whatever reason, they only need to be changed in one spot). | |||||
2018-10-13 | partition_data_manager: Take VirtualFile by const reference in constructor | Lioncash | 2 | -2/+2 | |
Given the VirtualFile instance isn't stored into the class as a data member, or written to, this can just be turned into a const reference, as the constructor doesn't need to make a copy of it. | |||||
2018-10-13 | partition_data_manager: Amend constructor initializer list order | Lioncash | 1 | -2/+3 | |
Orders the members in the exact order they would be initialized. This also prevents compiler warnings about this sort of thing. | |||||
2018-10-13 | partition_data_manager: Remove unused includes | Lioncash | 2 | -4/+1 | |
Gets unused includes out of the headers and moves them into the cpp file if they're used there instead. | |||||
2018-10-13 | key_manager: Use std::vector's insert() instead of std::copy with a back_inserter | Lioncash | 1 | -2/+2 | |
If the data is unconditionally being appended to the back of a std::vector, we can just directly insert it there without the need to insert all of the elements one-by-one with a std::back_inserter. | |||||
2018-10-13 | key_manager: Brace long conditional body | Lioncash | 1 | -1/+2 | |
If a conditional (or it's body) travels more than one line, it should be braced. | |||||
2018-10-13 | key_manager: Don't assume file seeks and reads will always succeed | Lioncash | 1 | -7/+17 | |
Given the filesystem should always be assumed to be volatile, we should check and bail out if a seek operation isn't successful. This'll prevent potentially writing/returning garbage data from the function in rare cases. This also allows removing a check to see if an offset is within the bounds of a file before perfoming a seek operation. If a seek is attempted beyond the end of a file, it will fail, so this essentially combines two checks into one in one place. | |||||
2018-10-13 | key_manager: Remove unnecessary seek in DeriveSDSeed() | Lioncash | 1 | -1/+0 | |
Given the file is opened a few lines above and no operations are done, other than check if the file is in a valid state, the read/write pointer will always be at the beginning of the file. | |||||
2018-10-13 | patch_manager: Move non-Program RomFS patch log to Debug | Zach Hilman | 1 | -2/+8 | |
Normal Program-type patches will still be logged to aid in debugging, but for others (mainly Control), it was moved to Debug. | |||||
2018-10-13 | content_archive: Move get key log to Trace level | Zach Hilman | 1 | -1/+1 | |
Avoids printing live keys in the general log. | |||||
2018-10-12 | Implemented helper function to correctly calculate a texture's size | FernandoS27 | 2 | -0/+22 | |
2018-10-12 | kernel/process: Make CodeSet a regular non-inherited object | Lioncash | 7 | -83/+45 | |
These only exist to ferry data into a Process instance and end up going out of scope quite early. Because of this, we can just make it a plain struct for holding things and just std::move it into the relevant function. There's no need to make this inherit from the kernel's Object type. | |||||
2018-10-12 | thread: Remove unnecessary memset from ResetThreadContext() | Lioncash | 1 | -4/+1 | |
Regular value initialization is adequate here for zeroing out data. It also has the benefit of not invoking undefined behavior if a non-trivial type is ever added to the struct for whatever reason. | |||||
2018-10-12 | Returned an error before processing other remaps | David Marcec | 1 | -6/+2 | |
2018-10-12 | Made the minimum alignment more clear | David Marcec | 1 | -2/+3 | |
2018-10-12 | svc: Fix typos in sanitizing checks for MapMemory/UnmapMemory | Lioncash | 1 | -3/+3 | |
2018-10-12 | Wip | David Marcec | 2 | -3/+23 | |
2018-10-11 | Dynamically decide handheld variant based on supported npad id priority | David Marcec | 3 | -19/+62 | |
Kirby input still doesn't work, should fix a lot of other games | |||||
2018-10-11 | Added error codes for nvmap | David Marcec | 1 | -12/+59 | |
2018-10-11 | Passing an invalid nmap handle to Remap should throw an error | David Marcec | 1 | -3/+14 | |
Added error for invalid nmap handles | |||||
2018-10-11 | gl_shader_decompiler: Implement VMAD | ReinUsesLisp | 2 | -0/+118 | |
2018-10-11 | nvhost_as_gpu: Flush CPU VAddr on UnmapBuffer. | bunnei | 1 | -3/+4 | |
2018-10-11 | core/CMakeLists: Make all web_service-related libraries private | Lioncash | 1 | -1/+1 | |
Now that all external dependencies are hidden, we can remove json-headers from the publically linked libraries, as the use of this library is now completely hidden from external users of the web_service library. We can also make the web_services library private as well, considering it's not a requirement. If a library needs to link in web_service, it should be done explicitly -- not via indirect linking. | |||||
2018-10-11 | web_backend: Make Client use the PImpl idiom | Lioncash | 5 | -142/+154 | |
Like with TelemetryJson, we can make the implementation details private and avoid the need to expose httplib to external libraries that need to use the Client class. | |||||
2018-10-11 | HwOpus, Implemented DecodeInterleavedWithPerformance | David Marcec | 1 | -3/+34 | |
Used by sonic ages | |||||
2018-10-11 | telemetry_json: Use the PImpl idiom to avoid unnecessary dependency exposure | Lioncash | 2 | -49/+55 | |
Users of the web_service library shouldn't need to care about an external library like json.h. However, given it's exposed in our interface, this requires that other libraries publicly link in the JSON library. We can do better. By using the PImpl idiom, we can hide this dependency in the cpp file and remove the need to link that library in altogether. | |||||
2018-10-11 | telemetry_json: Add missing override specifier to the destructor of TelemetryJson | Lioncash | 1 | -1/+1 | |
2018-10-11 | telemetry_json: Take std::string parameters by value | Lioncash | 2 | -3/+2 | |
Taking them by const reference isn't advisable here, because it means the std::move calls were doing nothing and we were always copying the std::string instances. | |||||
2018-10-11 | telemetry_json: Remove unnecessary includes | Lioncash | 2 | -3/+1 | |
Removes unused includes. Also rectifies a missing <chrono> include. | |||||
2018-10-11 | core/CMakeLists: Use target_compile_definitions instead of add_definitions for specifying ENABLE_WEB_SERVICE | Lioncash | 1 | -1/+1 | |
Avoids introducing the definition to the whole directory space and localizes it to being added to the library that needs it. | |||||
2018-10-11 | svc: Add missing address range sanitizing checks to MapMemory/UnmapMemory | Lioncash | 2 | -12/+81 | |
This adds the missing address range checking that the service functions do before attempting to map or unmap memory. Given that both service functions perform the same set of checks in the same order, we can wrap these into a function and just call it from both functions, which deduplicates a little bit of code. | |||||
2018-10-10 | Added BeginPermitVibrationSession and EndPermitVibrationSession | David Marcec | 3 | -2/+26 | |
Used by Mario Party | |||||
2018-10-10 | Added GetLedPattern and HandheldVariant | David Marcec | 3 | -6/+63 | |
HandheldVariant is for specific games which expect handheld controllers to be at position 8(kirby), however this doesn't fix all games as some games require handhelds to be at position 0(snipperclips) | |||||
2018-10-10 | kernel/thread: Use a regular pointer for the owner/current process | Lioncash | 10 | -39/+41 | |
There's no real need to use a shared pointer in these cases, and only makes object management more fragile in terms of how easy it would be to introduce cycles. Instead, just do the simple thing of using a regular pointer. Much of this is just a hold-over from citra anyways. It also doesn't make sense from a behavioral point of view for a process' thread to prolong the lifetime of the process itself (the process is supposed to own the thread, not the other way around). | |||||
2018-10-10 | Kirby expects handheld controllers to be at position 8 | David Marcec | 1 | -2/+8 | |
2018-10-10 | Add memory Layout to Render Targets and Depth Buffers | FernandoS27 | 3 | -21/+33 | |
2018-10-10 | Added the ability to "disconnect" individual npads | David Marcec | 3 | -16/+40 | |
Fixes arms | |||||
2018-10-10 | Removed unneeded forward declarations | David Marcec | 2 | -13/+2 | |
2018-10-10 | Addressed changes for better hid | David Marcec | 19 | -167/+238 | |
2018-10-10 | "Better Hid" rework part 1 | David Marcec | 22 | -644/+1500 | |
2018-10-10 | Changed all casts in svc_wrap.h to be static_cast instead | David Marcec | 1 | -25/+28 | |
2018-10-10 | Use a better name than "dont_kill_application" | David Marcec | 1 | -2/+2 | |
signal_debugger seems like a more fitting name | |||||
2018-10-10 | Fixed incorrect types for svcBreak | David Marcec | 2 | -3/+8 | |
svcBreak reason should be a u32, not a u64. | |||||
2018-10-10 | Fixed block height settings for RenderTargets and Depth Buffers, and added block width and block depth | FernandoS27 | 5 | -12/+63 | |
2018-10-09 | gl_shader_decompiler: Remove unused variables in TMML's implementation | Lioncash | 1 | -7/+3 | |
Given "y" isn't always used, but "x" is, we can rearrange this to avoid unused variable warnings by changing the names of op_a and op_b | |||||
2018-10-09 | telemetry_session: Remove doxygen comment for a non-existent parameter | Lioncash | 1 | -1/+0 | |
There's no "func" parameter, so this can just be removed. | |||||
2018-10-09 | telemetry_session: Add missing includes | Lioncash | 2 | -2/+5 | |
Prevents potential compilation issues in the future by including missing headers for certain functions and types. | |||||
2018-10-09 | telemetry_session: Remove unimplemented FinalizeAsyncJob prototype | Lioncash | 1 | -2/+0 | |
This isn't implemented anywhere, so it can just be removed. | |||||
2018-10-09 | telemetry_session: Use a std::array in GenerateTelemetryId() | Lioncash | 1 | -2/+4 | |
We don't need to potentially heap-allocate a std::string instance here, given the data is known ahead of time. We can just place it within an array and pass this to the mbedtls functions. | |||||
2018-10-09 | patch_manager: Return a std::unique_ptr from ParseControlNCA() and GetControlMetadata() instead of a std::shared_ptr | Lioncash | 7 | -21/+18 | |
Neither of these functions require the use of shared ownership of the returned pointer. This makes it more difficult to create reference cycles with, and makes the interface more generic, as std::shared_ptr instances can be created from a std::unique_ptr, but the vice-versa isn't possible. This also alters relevant functions to take NCA arguments by const reference rather than a const reference to a std::shared_ptr. These functions don't alter the ownership of the memory used by the NCA instance, so we can make the interface more generic by not assuming anything about the type of smart pointer the NCA is contained within and make it the caller's responsibility to ensure the supplied NCA is valid. | |||||
2018-10-09 | implemented touch in Qt and SDL | NeatNit | 4 | -10/+131 | |
change TouchToPixelPos to return std::pair<int, int> static_cast (SDL) various minor style and code improvements style - PascalCase for function names made touch events private const pointer arg in touch events make TouchToPixelPos a const member function did I do this right? braces on barely-multiline if remove question comment (confirmed in Discord) fixed consts remove unused parameter from TouchEndEvent DRY - High-DPI scaled touch put in separate function also fixes a bug where if you start touching (with either mouse or touchscreen) and drag the mouse to the LEFT of the emulator window, the touch point jumps to the RIGHT side of the touchscreen; draggin to above the window would make it jump to the bottom. implicit conversion from QPoint to QPointF, apparently I have no idea what const even means but I'll put it here anyway remove unused or used-once variables make touch scaling functions const, and put their implementations together removed unused FingerID parameters QTouchEvent forward declaration; add comment to TouchBegin that was lost in an edit better DRY in SDL To do -> TODO(NeatNit) remove unused include | |||||
2018-10-09 | ips_layer: Avoid constructing std::vector instances where not necessary | Lioncash | 1 | -6/+25 | |
We can just compare the existing std::vector instance with a constexpr std::array containing the desired match. This is lighter resource-wise, as we don't need to allocate on the heap. | |||||
2018-10-09 | ips_layer: Remove unnecessary explicit std::pair constructor in std::array | Lioncash | 1 | -5/+13 | |
Makes the layout of the array consistent, by making all elements match, instead of special-casing the first one. | |||||
2018-10-09 | ips_layer: Add missing includes | Lioncash | 2 | -7/+17 | |
Adds missing includes to prevent potential compilation issues in the future. Also moves the definition of a struct into the cpp file, so that some includes don't need to be introduced within the header. | |||||
2018-10-09 | ips_layer: std::move data within PatchIPS() and Apply() | Lioncash | 1 | -2/+5 | |
We don't need to make a copy of the read data, so we can std::move it into the make_shared call here. | |||||
2018-10-09 | ips_layer: Silence truncation and conversion warnings | Lioncash | 1 | -3/+3 | |
Makes type conversions explicit to avoid compiler warnings. | |||||
2018-10-09 | Implement Scissor Test | FernandoS27 | 1 | -4/+9 | |
2018-10-09 | Added bitfield instead of manually checking if the bit is set | David Marcec | 1 | -4/+12 | |
2018-10-09 | Assert Scissor tests | FernandoS27 | 3 | -1/+31 | |
2018-10-09 | EffectOutStatus padding is now in hex | David Marcec | 1 | -1/+1 | |
2018-10-09 | Actual kill execution when the bit isn't set, not the other way around | David Marcec | 1 | -1/+1 | |
2018-10-09 | svcBreak, Signalling to the debugger should not kill execution | David Marcec | 1 | -5/+12 | |
When loading NROs, svcBreak is called to signal to the debugger that a new "module" is loaded. As no debugger is technically attached we shouldn't be killing the programs execution. | |||||
2018-10-08 | Unmapping an unmapped buffer should succeed | David Marcec | 1 | -1/+6 | |
Hardware tests show that trying to unmap an unmapped buffer already should always succeed. Hardware test was tested up to 32 iterations of attempting to unmap | |||||
2018-10-07 | gl_shader_decompiler: Move position varying location from 15 to 0 and apply an offset | ReinUsesLisp | 1 | -6/+10 | |
2018-10-07 | gl_shader_decompiler: Implement geometry shaders | ReinUsesLisp | 10 | -107/+522 | |
2018-10-07 | video_core: Allow LabelGLObject to use extra info on any object | ReinUsesLisp | 1 | -10/+14 | |
2018-10-07 | nso/nro: Use default allocation size for arg_data | Zach Hilman | 4 | -14/+20 | |
2018-10-07 | cmd: Support passing game arguments from command line | Zach Hilman | 4 | -10/+14 | |
Uses -p (--program) and following string as args. | |||||
2018-10-07 | qt: Add UI option to configure arguments | Zach Hilman | 3 | -0/+27 | |
2018-10-07 | settings: Add program_args string setting | Zach Hilman | 1 | -0/+1 | |
2018-10-07 | nso/nro: Add NSO arguments structure to data section | Zach Hilman | 4 | -3/+38 | |
Only added if arguments string is non-empty and a pass is requested by loader. | |||||
2018-10-07 | partition_data_manager: Rename system files for hekate | Zach Hilman | 6 | -195/+247 | |
x | |||||
2018-10-07 | qt: Add rederive keyset menu option | Zach Hilman | 3 | -49/+89 | |
2018-10-07 | qt: Add key derivation progress bar on initial setup | Zach Hilman | 1 | -0/+52 | |
2018-10-07 | crypto: Add PartitionDataManager | Zach Hilman | 3 | -0/+692 | |
Keeps track of system files for key derivation | |||||
2018-10-07 | key_manager: Add support for loading keys from partition data | Zach Hilman | 2 | -0/+88 | |
2018-10-07 | key_manager: Add ETicket key derivation | Zach Hilman | 3 | -2/+277 | |
Derives titlekeys | |||||
2018-10-07 | key_manager: Add base key derivation | Zach Hilman | 2 | -4/+220 | |
Derives master keys, game encryption keys, and package1/2 keys | |||||
2018-10-07 | key_manager: Add BIS key getter | Zach Hilman | 2 | -2/+19 | |
2018-10-07 | key_manager: Add support for more keys | Zach Hilman | 2 | -3/+99 | |
TSEC, SBK, BIS, and other Sources for proper derivation | |||||
2018-10-07 | key_manager: Add keyblob support | Zach Hilman | 2 | -0/+14 | |
2018-10-07 | key_manager: Add support for crypto revisions past 04 | Zach Hilman | 1 | -43/+63 | |
2018-10-07 | key_manager: Add support for comments in keyfiles | Zach Hilman | 1 | -0/+3 | |
2018-10-07 | vfs: Move forward declarations to separate file | Zach Hilman | 2 | -9/+22 | |
2018-10-07 | key_manager: Add support for console-specific keyfile | Zach Hilman | 2 | -3/+13 | |
2018-10-07 | key_manager: Rename KEK to Kek | Zach Hilman | 2 | -8/+9 | |
2018-10-07 | Fixed assertion due to CountAddOnContent | David Marcec | 1 | -5/+5 | |
Word count should be 3 since we're pushing a result code and a u32. Also fixed up compiler warnings due to casting | |||||
2018-10-07 | Fixups for softlock | David Marcec | 2 | -6/+7 | |
2018-10-07 | Fixed missing return | David Marcec | 1 | -1/+1 | |
Softlock explanation: after effects are initialized in smo, nothing actually changes the state. It expects the state to always be initialized. With the previous testing, updating the states much like how we handle the memory pools continue to have the softlock(which is why I said it probably wasn't effects) after further examination it seems like effects need to be initialized but the state remains unchanged until further notice. For now, assertions are added for the aux buffers to see if they update, unable to check as I haven't gotten smo to actually update them yet. | |||||
2018-10-07 | Fixed smo softlock | David Marcec | 2 | -13/+120 | |
2018-10-07 | logging: Add DebuggerBackend for logging to Visual Studio | Carl Kenner | 4 | -2/+29 | |
2018-10-07 | gl_rasterizer: Fixup undefined behaviour in SetupDraw | ReinUsesLisp | 1 | -0/+1 | |
2018-10-06 | yuzu/yuzu_cmd: Add checks for required extension ARB_copy_image. | bunnei | 2 | -0/+4 | |
2018-10-06 | Implemented Depth Compare and Shadow Samplers | FernandoS27 | 6 | -65/+224 | |
2018-10-06 | Remove "#" in the version number | fearlessTobi | 1 | -1/+1 | |
So that people can stop using it in issue/pr comments and randomly link some other issue/pr unintentionally. | |||||
2018-10-06 | citra_qt/configuration: misc input tab improvements | zhupengfei | 5 | -19/+119 | |
* Added a context menu on the buttons including Clear & Restore Default * Allow clearing (unsetting) inputs. Added a Clear All button * Allow restoring a single input to default (instead of all) | |||||
2018-10-06 | Added forward define for ServerPort | David Marcec | 2 | -4/+6 | |
2018-10-06 | fermi_2d: Implement simple copies with AccelerateSurfaceCopy. | bunnei | 3 | -24/+36 | |
2018-10-06 | gl_rasterizer: Add rasterizer cache code to handle accerated fermi copies. | bunnei | 5 | -16/+60 | |
2018-10-06 | gl_rasterizer_cache: Implement a simpler surface copy using glCopyImageSubData. | bunnei | 1 | -0/+21 | |
2018-10-06 | qt: Update telemetry links | Lioncash | 2 | -2/+2 | |
These were pointing to a non-existent webpage. | |||||
2018-10-06 | Ported #4296 from citra | David Marcec | 3 | -1/+25 | |
This will allow us to easily remove the use of "NFC" in "System" | |||||
2018-10-06 | kernel/mutex: Amend behavior of TransferMutexOwnership() | Lioncash | 1 | -1/+1 | |
This was the result of a typo accidentally introduced in e51d715700a35a8f14e5b804b6f7553c9a40888b. This restores the previous correct behavior. The behavior with the reference was incorrect and would cause some games to fail to boot. | |||||
2018-10-05 | thread: Make the scheduler pointer a regular pointer | balika011 | 2 | -4/+4 | |
Conceptually, it doesn't make sense for a thread to be able to persist the lifetime of a scheduler. A scheduler should be taking care of the threads; the threads should not be taking care of the scheduler. If the threads outlive the scheduler (or we simply don't actually terminate/shutdown the threads), then it should be considered a bug that we need to fix. Attributing this to balika011, as they opened #1317 to attempt to fix this in a similar way, but my refactoring of the kernel code caused quite a few conflicts. | |||||
2018-10-05 | romfs_factory: Extract packed update setter to new function | Zach Hilman | 10 | -9/+38 | |
2018-10-05 | patch_manager: Add support for NSP packed updates | Zach Hilman | 2 | -3/+10 | |
Reads as Update (NSP) in add-ons | |||||
2018-10-05 | game_list: Add XCI update versioning to game list | Zach Hilman | 1 | -4/+8 | |
2018-10-05 | patch_manager: Add support for packed updates | Zach Hilman | 4 | -5/+18 | |
Will prefer any installed update over the packed version. | |||||
2018-10-05 | loader: Add getter for packed update | Zach Hilman | 6 | -3/+58 | |
Reads the update included with the game if it has one and adds the new ErrorNoPackedUpdate status. | |||||
2018-10-05 | loader: Add ReadRomFSIVFCOffset to NSP, XCI, and NAX loaders | Zach Hilman | 6 | -6/+20 | |
Fixes errors with certain updates | |||||
2018-10-05 | text_formatter: Avoid unnecessary string temporary creation in PrintMessage() | Lioncash | 1 | -1/+1 | |
operator+ for std::string creates an entirely new string, which is kind of unnecessary here if we just want to append a null terminator to the existing one. Reduces the total amount of potential allocations that need to be done in the logging path. | |||||
2018-10-04 | patch_manager: Avoid romfs_ext requirement for patching | Zach Hilman | 1 | -4/+1 | |
2018-10-04 | fsmitm_romfsbuild: Extract stubs and IPS to romfs_ext dir | Zach Hilman | 5 | -21/+38 | |
2018-10-04 | fsmitm_romfsbuild: Add support for stubbing and IPS patches in LFS | Zach Hilman | 1 | -0/+14 | |
2018-10-04 | ips_layer: Fix inaccuracies with comments and flags | Zach Hilman | 3 | -16/+51 | |
Specifically bugs/crashes that arise when putting them in positions that are legal but not typical, such as midline, between patch data, or between patch records. | |||||
2018-10-04 | ips_layer: Deduplicate resource usage | Zach Hilman | 5 | -33/+39 | |
2018-10-04 | ips_layer: Add support for escape sequences and midline comments | Zach Hilman | 3 | -8/+41 | |
More accurately follows IPSwitch specification. | |||||
2018-10-04 | patch_manager: Add support for IPSwitch format patches | Zach Hilman | 1 | -22/+56 | |
2018-10-04 | ips_layer: Add IPSwitchCompiler to process IPSwitch format | Zach Hilman | 2 | -0/+168 | |
2018-10-04 | hex_util: Add HexVectorToString and HexStringToVector | Zach Hilman | 2 | -0/+24 | |
Converts between bytes and strings when the size is not known at compile time. | |||||
2018-10-04 | ui_settings: Place definition of the theme array within the cpp file | Lioncash | 3 | -5/+10 | |
Placing the array wholesale into the header places a copy of the whole array into every translation unit that uses the data, which is wasteful. Particularly given that this array is referenced from three different translation units. This also changes the array to contain pairs of const char*, rather than QString instances. This way, the string data is able to be fixed into the read-only segment of the program, as well as eliminate static constructors/heap allocation immediately on program start. | |||||
2018-10-04 | kernel/thread: Make all instance variables private | Lioncash | 15 | -227/+418 | |
Many of the member variables of the thread class aren't even used outside of the class itself, so there's no need to make those variables public. This change follows in the steps of the previous changes that made other kernel types' members private. The main motivation behind this is that the Thread class will likely change in the future as emulation becomes more accurate, and letting random bits of the emulator access data members of the Thread class directly makes it a pain to shuffle around and/or modify internals. Having all data members public like this also makes it difficult to reason about certain bits of behavior without first verifying what parts of the core actually use them. Everything being public also generally follows the tendency for changes to be introduced in completely different translation units that would otherwise be better introduced as an addition to the Thread class' public interface. | |||||
2018-10-04 | gl_rasterizer: Implement quads topology | ReinUsesLisp | 8 | -46/+236 | |
2018-10-03 | Implemented Texture Processing Modes in TEXS and TLDS | FernandoS27 | 1 | -5/+42 | |
2018-10-03 | submission_package: Avoid dangling std::string_view within SetTicketKeys() | Lioncash | 1 | -2/+5 | |
GetName() returns a std::string by value, not by reference, so after the std::string_view is constructed, it's not well defined to actually execute any member functions of std::string_view that attempt to access the data, as the std::string has already been destroyed. Instead, we can just use a std::string and erase the last four characters. | |||||
2018-10-03 | submission_package: Correct location of null check within SetTicketKeys() | Lioncash | 1 | -3/+6 | |
If a ticket file was ever a null pointer, we'd cause a null pointer dereference, as we were calling GetExtension() on the pointer instance. | |||||
2018-10-03 | submission_package: Use std::string's rfind() when looking for the extension in InitializeExeFSAndRomFS() | Lioncash | 1 | -1/+1 | |
When searching for a file extension, it's generally preferable to begin the search at the end of the string rather than the beginning, as the whole string isn't going to be walked just to check for something at the end of it. | |||||
2018-10-03 | submission_package: Ensure the 'extracted' member variable is always initialized | Lioncash | 2 | -3/+1 | |
If an error occurs when constructing the PartitionFilesystem instance, the constructor would be exited early, which wouldn't initialize the extracted data member, making it possible for other code to perform an uninitialized read by calling the public IsExtractedType() member function. This prevents that. | |||||
2018-10-03 | submission_package: Move ExeFS and RomFS initialization to its own function | Lioncash | 2 | -10/+18 | |
Like the other two bits of factored out code, this can also be put within its own function. We can also modify the code so that it accepts a const reference to a std::vector of files, this way, we can deduplicate the file retrieval. Now the constructor for NSP isn't a combination of multiple behaviors in one spot. It's nice and separate. | |||||
2018-10-03 | submission_package: Move NCA reading code to its own function | Lioncash | 2 | -43/+48 | |
This too, is completely separate behavior from what is in the constructor, so we can move this to its own isolated function to keep everything self-contained. | |||||
2018-10-03 | submission_package: Move ticket key setting to its own function | Lioncash | 1 | -21/+28 | |
This behavior is entirely independent of the surrounding code, so it can be put in its own function to keep the behavior separate. | |||||
2018-10-03 | submission_package: Invert conditionals within NSP's constructor to reduce nesting | Lioncash | 1 | -45/+49 | |
We can use early continues here to reduce the amount of nesting. | |||||
2018-10-03 | card_image: Ensure program_nca_status is always initialized | Lioncash | 1 | -1/+3 | |
If any of the error paths before the NCA retrieval are taken, it'll result in program_nca_status being left in an inconsistent state. So we initialize it by default with a value indicating an error. | |||||
2018-10-03 | aoc_u: Fix edge case with DLC that causes breaks | Zach Hilman | 1 | -1/+1 | |
In some games (Splatoon 2 and Splatoon 2 Splatfest World Premiere, notably), pass offset=0 and count=2047 into the ListAddOnContent method which should return all DLCs for the current title. The (presumably) intended behavior is to successfully return a empty array but because of a < v. <= in an if statement, a failure error code was returned causing these games to svcBreak. This fixes that if statement. | |||||
2018-10-03 | services/fsp_srv: Amend service function table | Lioncash | 1 | -0/+2 | |
Adds new functions that have been given names to the table. Information is based off what is provided on Switchbrew. | |||||
2018-10-03 | service/lbl: Update service function table | Lioncash | 1 | -19/+19 | |
Amends the lbl service table to include new names of functions that were added to Switchbrew. | |||||
2018-10-03 | configure_input: Make analog mapping strings translatable | Lioncash | 1 | -3/+3 | |
These strings are user-facing, so they should be specified as translatable with tr(). | |||||
2018-10-03 | configure_audio: Move combo box index setting to their own functions | Lioncash | 2 | -11/+25 | |
Keeps the individual behaviors in their own functions, and cleanly separate. We can also do a little better by converting the relevant IDs within the core to a QString only once, instead of converting every string into a std::string. | |||||
2018-10-03 | configure_audio: Use QString::fromStdString() for converting audio device names | Lioncash | 1 | -3/+3 | |
This ensures that the proper codec will always be used no matter what. It also avoids relying on ASCII conversions. | |||||
2018-10-03 | configure_audio: Add disambiguation comment for the volume percentage string | Lioncash | 2 | -4/+8 | |
Disambiguates what the string represents to help translators more easily understand what it is that they're translating. While we're at it, we can move the code to its own function, so that we don't need to specify the same string twice. | |||||
2018-10-03 | configure_graphics: Make functions internally linked where applicable | Lioncash | 1 | -21/+23 | |
These aren't used outside of this translation unit, so they can be internally linked. | |||||
2018-10-02 | nso: Optimize loading of IPS patches | Zach Hilman | 5 | -51/+43 | |
Avoid resource-heavy classes and remove quasi-duplicated code. | |||||
2018-10-02 | string_util: unify UTF8<->UTF16 conversion to codecvt | Weiyi Wang | 1 | -109/+6 | |
2018-10-02 | string_util: remove TString conversion for windows | Weiyi Wang | 2 | -19/+1 | |
First of all they are foundamentally broken. As our convention is that std::string is always UTF-8, these functions assume that the multi-byte character version of TString (std::string) from windows is also in UTF-8, which is almost always wrong. We are not going to build multi-byte character build, and even if we do, this dirty work should be handled by frontend framework early. | |||||
2018-10-02 | string_util: remove ShiftJIS/CP1252 conversion function | Weiyi Wang | 2 | -22/+0 | |
We always use unicode internally. Any dirty work of conversion with other codec should be handled by frontend framework (Qt). Further more, ShiftJIS/CP1252 are not special (they are not code set used by 3ds, or any guest/host dependencies we have), so there is no reason to specifically include them | |||||
2018-10-02 | Review comments - part 5 | fearlessTobi | 4 | -8/+7 | |
2018-10-02 | Review comments -part 4 | fearlessTobi | 3 | -2/+7 | |
2018-10-02 | Review comments - part 3 | fearlessTobi | 6 | -25/+7 | |
2018-10-02 | web_backend: protect jwt cache with a mutex | Weiyi Wang | 2 | -1/+4 | |
2018-10-02 | Address more review comments | fearlessTobi | 1 | -1/+1 | |
2018-10-02 | Address a bunch of review comments | fearlessTobi | 11 | -19/+27 | |
2018-10-02 | Port web_service from Citra | fearlessTobi | 37 | -34/+1554 | |
2018-10-01 | deconstructed_rom_directory: Force NSO loader to patch NSOs | Zach Hilman | 1 | -1/+3 | |
2018-10-01 | nso: Add framework to support patching of uncompressed NSOs | Zach Hilman | 2 | -2/+17 | |
2018-10-01 | patch_manager: Add PatchNSO function | Zach Hilman | 3 | -0/+104 | |
While PatchExeFS operated on the entire directory, this function operates on the uncompressed NSO. Avoids copying decompression code to PatchManager. | |||||
2018-10-01 | patch_manager: Use strings for patch type instead of enum | Zach Hilman | 3 | -33/+36 | |
2018-10-01 | file_sys: Implement function to apply IPS patches | Zach Hilman | 2 | -0/+103 | |
2018-10-01 | nso: Replace NSOHeader padding bytes with build ID | Zach Hilman | 1 | -2/+1 | |
2018-10-01 | gl_rasterizer: Fixup unassigned point sizes | ReinUsesLisp | 1 | -1/+4 | |
2018-10-01 | aoc_u: Extract AccumulateAOCTitleIDs to separate function | Zach Hilman | 2 | -21/+28 | |
2018-10-01 | aoc_u: Implement GetAddOnContentBaseId | Zach Hilman | 3 | -5/+8 | |
Command #5 | |||||
2018-10-01 | aoc_u: Implement Count, List and Prepare AddOnContent | Zach Hilman | 2 | -3/+78 | |
Commands #2, #3, and #7 | |||||
2018-10-01 | romfs_factory: Read from all locations with StorageId None | Zach Hilman | 1 | -26/+25 | |
Previous behavior was to assert. Seems to mirror expected game behavior. | |||||
2018-10-01 | patch_manager: Add DLC recognition to PatchManager | Zach Hilman | 2 | -0/+27 | |
2018-09-30 | gl_rasterizer_cache: Fixes to how we do render to cubemap. | bunnei | 2 | -32/+5 | |
- Fixes issues with Splatoon 2. | |||||
2018-09-30 | gl_rasterizer_cache: Add check for array rendering to cubemap texture. | bunnei | 1 | -0/+8 | |
2018-09-30 | gl_rasterizer_cache: Implement render to cubemap. | bunnei | 3 | -119/+218 | |
2018-09-30 | gl_shader_decompiler: TEXS: Implement TextureType::TextureCube. | bunnei | 1 | -0/+8 | |
2018-09-30 | gl_rasterizer_cache: Add support for SurfaceTarget::TextureCubemap. | bunnei | 2 | -1/+36 | |
2018-09-30 | gl_rasterizer_cache: Implement LoadGLBuffer for Texture2DArray. | bunnei | 1 | -0/+8 | |
2018-09-30 | gl_rasterizer_cache: Update BlitTextures to support non-Texture2D ColorTexture surfaces. | bunnei | 1 | -23/+88 | |
2018-09-30 | gl_rasterizer_cache: Track texture target and depth in the cache. | bunnei | 1 | -2/+3 | |
2018-09-30 | gl_rasterizer_cache: Workaround for Texture2D -> Texture2DArray scenario. | bunnei | 3 | -6/+21 | |
2018-09-30 | gl_rasterizer_cache: Keep track of surface 2D size separately from total size. | bunnei | 2 | -32/+46 | |
2018-09-30 | Fix trailing whitespace | raven02 | 1 | -1/+4 | |
2018-09-30 | kernel/svc: Implement svcGetThreadContext() | Lioncash | 3 | -2/+37 | |
Now that we have all of the rearranging and proper structure sizes in place, it's fairly trivial to implement svcGetThreadContext(). In the 64-bit case we can more or less just write out the context as is, minus some minor value sanitizing. In the 32-bit case we'll need to clear out the registers that wouldn't normally be accessible from a 32-bit AArch32 exectuable (or process). | |||||
2018-09-30 | kernel/process: Add a data member to determine if a process is 64-bit or not. | Lioncash | 2 | -0/+11 | |
This will be necessary for the implementation of svcGetThreadContext(), as the kernel checks whether or not the process that owns the thread that has it context being retrieved is a 64-bit or 32-bit process. If the process is 32-bit, then the upper 15 general-purpose registers and upper 16 vector registers are cleared to zero (as AArch32 only has 15 GPRs and 16 128-bit vector registers. not 31 general-purpose registers and 32 128-bit vector registers like AArch64). | |||||
2018-09-30 | kernel/process: Make data member variables private | Lioncash | 18 | -75/+120 | |
Makes the public interface consistent in terms of how accesses are done on a process object. It also makes it slightly nicer to reason about the logic of the process class, as we don't want to expose everything to external code. | |||||
2018-09-30 | arm_interface: Add missing fpsr/tpidr members to the ThreadContext struct | Lioncash | 3 | -5/+15 | |
Internally within the kernel, it also includes a member variable for the floating-point status register, and TPIDR, so we should do the same here to match it. While we're at it, also fix up the size of the struct and add a static assertion to ensure it always stays the correct size. | |||||
2018-09-30 | Implement ISystemDisplayService::GetDisplayMode | raven02 | 1 | -1/+19 | |
2018-09-29 | loader: Make the Load() function take a process as a regular reference, not a SharedPtr | Lioncash | 18 | -42/+28 | |
A process should never require being reference counted in this situation. If the handle to a process is freed before this function is called, it's definitely a bug with our lifetime management, so we can put the requirement in place for the API that the process must be a valid instance. | |||||
2018-09-28 | kernel/object: Remove unnecessary std::move from DynamicObjectCast() | Lioncash | 2 | -3/+2 | |
boost::static_pointer_cast for boost::intrusive_ptr (what SharedPtr is), takes its parameter by const reference. Given that, it means that this std::move doesn't actually do anything other than obscure what the function's actual behavior is, so we can remove this. To clarify, this would only do something if the parameter was either taking its argument by value, by non-const ref, or by rvalue-reference. | |||||
2018-09-28 | video_core: Implement point_size and add point state sync | ReinUsesLisp | 5 | -1/+27 | |
2018-09-28 | gl_state: Pack sampler bindings into a single ARB_multi_bind | ReinUsesLisp | 5 | -8/+25 | |
2018-09-27 | qt: Install System TitleTypes to System NAND | Zach Hilman | 1 | -4/+14 | |
Fixes an issue where installed system archive NCAs would be installed to user NAND and not recognized by games. | |||||
2018-09-26 | fsmitm_romfsbuild: std::move std::vector instances in Build() | Lioncash | 1 | -2/+2 | |
Avoids making copies of large std::vector instances where it's trivially avoidable to do so. | |||||
2018-09-26 | fsmitm_romfsbuild: Replace manual value aligning with Common::AlignUp() | Lioncash | 1 | -12/+11 | |
Theres no need to do explicit bitwise arithmetic here, when we have a function that does this with a more descriptive name. | |||||
2018-09-26 | patch_manager: Invert conditionals within ApplyLayeredFS() | Lioncash | 1 | -27/+30 | |
Avoids the need to nest code quite a bit by early-exiting in error cases. | |||||
2018-09-26 | video_core: Add asserts for CS, TFB and alpha testing | ReinUsesLisp | 5 | -3/+92 | |
Add asserts for compute shader dispatching, transform feedback being enabled and alpha testing. These have in common that they'll probably break rendering without logging. | |||||
2018-09-26 | vfs_vector: Amend initializer list order in VectorVfsFile's constructor initializer list | Lioncash | 1 | -1/+1 | |
Orders the initializer list members to be in the same order that they would be initialized in. Avoids compiler warnings. | |||||
2018-09-26 | fsmitm_romfsbuild: Avoid type truncation warnings | Lioncash | 1 | -7/+10 | |
Cast where explicitly necessary and in other cases we can simply modify the algorithm to accomodate larger data. | |||||
2018-09-26 | fsmitm_romfsbuild: Remove unnecessary constructors and initializers for RomFSBuildFileContext and RomFSBuildDirectoryContext | Lioncash | 1 | -5/+3 | |
There's no need to duplicate in-class initializers with a constructor initializer list. std::strings also initialize to empty by default. | |||||
2018-09-26 | fsmitm_romfsbuild: Remove unnecessary loops in Build() | Lioncash | 1 | -6/+0 | |
The std::vector instances are already initially allocated with all entries having these values, there's no need to loop through and fill them with it again when they aren't modified. | |||||
2018-09-26 | fsmitm_romfsbuild: Make auto variable into a std::size_t variable within Build() | Lioncash | 1 | -1/+1 | |
auto x = 0; auto-deduces x to be an int. This is undesirable when working with unsigned values. It also causes sign conversion warnings. Instead, we can make it a proper unsigned value with the correct width that the following expressions operate on. | |||||
2018-09-26 | yuzu/main: Resolve precedence bug within CalculateRomFSEntrySize() | Lioncash | 1 | -1/+1 | |
Ternary operators have a lower precedence than arithmetic operators, so what was actually occurring here is "return (out + full) ? x : y" which most definitely isn't intended, given we calculate out recursively above. We were essentially doing a lot of work for nothing. | |||||
2018-09-26 | yuzu/main: Move functions stored into static std::function instances out of OnGameListDumpRomFS() | Lioncash | 1 | -42/+42 | |
This can cause warnings about static constructors, and is also not ideal performance-wise due to the indirection through std::function. This also keeps the behavior itself separate from the surrounding code, which can make it nicer to read, due to the size of the code. | |||||
2018-09-26 | vfs/etc: Append std:: to size_t usages | Lioncash | 7 | -29/+30 | |
Given we just recently had a patch backport this from citra, let's try and keep the convention uniform. | |||||
2018-09-26 | vfs_concat/vfs_layered: Remove friend declarations from ConcatenatedVfsFile | Lioncash | 8 | -61/+59 | |
Given these are only added to the class to allow those functions to access the private constructor, it's a better approach to just make them static functions in the interface, to make the dependency explicit. | |||||
2018-09-25 | vfs_static: Remove template byte parameter from StaticVfsFile | Lioncash | 4 | -42/+42 | |
This converts it into a regular constructor parameter. There's no need to make this a template parameter on the class when it functions perfectly well as a constructor argument. This also reduces the amount of code bloat produced by the compiler, as it doesn't need to generate the same code for multiple different instantiations of the same class type, but with a different fill value. | |||||
2018-09-25 | service: Add missing headers inclusions where applicable | Lioncash | 5 | -1/+7 | |
Gets rid of a few indirect inclusions. | |||||
2018-09-25 | core_cpu: Make arm_interface instances a std::unique_ptr | Lioncash | 2 | -4/+4 | |
This is only exposed by reference, so we can just make it a unique pointer to get rid of the need to also use reference counting for the pointer. | |||||
2018-09-25 | kernel/scheduler: Take ARM_Interface instance by reference in the constructor | Lioncash | 3 | -10/+10 | |
It doesn't make sense to allow a scheduler to be constructed around a null pointer. | |||||
2018-09-25 | memory: Dehardcode the use of fixed memory range constants | Lioncash | 11 | -75/+60 | |
The locations of these can actually vary depending on the address space layout, so we shouldn't be using these when determining where to map memory or be using them as offsets for calculations. This keeps all the memory ranges flexible and malleable based off of the virtual memory manager instance state. | |||||
2018-09-25 | svc: Report correct memory-related values within some of the cases in svcGetInfo() | Lioncash | 3 | -28/+41 | |
Previously, these were reporting hardcoded values, but given the regions can change depending on the requested address spaces, these need to report the values that the memory manager contains. | |||||
2018-09-25 | memory: Dehardcode the use of a 36-bit address space | Lioncash | 6 | -22/+61 | |
Given games can also request a 32-bit or 39-bit address space, we shouldn't be hardcoding the address space range as 36-bit. | |||||
2018-09-24 | process/vm_manager: Amend API to allow reading parameters from NPDM metadata | Lioncash | 10 | -38/+259 | |
Rather than hard-code the address range to be 36-bit, we can derive the parameters from supplied NPDM metadata if the supplied exectuable supports it. This is the bare minimum necessary for this to be possible. The following commits will rework the memory code further to adjust to this. | |||||
2018-09-24 | Implemented fatal:u properly (#1347) | David | 3 | -4/+140 | |
* Implemented fatal:u properly fatal:u now is properly implemented with all the ipc cmds. Error reports/Crash reports are also now implemented for fatal:u. Crash reports save to yuzu/logs/crash_reports/ The register dump is currently known as sysmodules send all zeros. If there are any non zero values for the "registers" or the unknown values, let me know! * Fatal:U fixups * Made fatal:u execution break more clear * Fatal fixups | |||||
2018-09-24 | Stubbed IRS (#1349) | David | 4 | -18/+169 | |
* Stubbed IRS Currently we have no ideal way of implementing IRS. For the time being we should have the functions stubbed until we come up with a way to emulate IRS properly. * Added IRS to logging backend * Forward declared shared memory for irs | |||||
2018-09-24 | fsmitm: Cleanup and modernize fsmitm port | Zach Hilman | 22 | -378/+378 | |
2018-09-24 | stream: Preserve enum class type in GetState() | Lioncash | 5 | -12/+12 | |
Preserves the meaning/type-safetiness of the stream state instead of making it an opaque u32. This makes it usable for other things outside of the service HLE context. | |||||
2018-09-24 | svc: Updated svc names | tech4me | 1 | -7/+7 | |
2018-09-23 | Added glObjectLabels for renderdoc for textures and shader programs (#1384) | David | 4 | -0/+48 | |
* Added glObjectLabels for renderdoc for textures and shader programs * Changed hardcoded "Texture" name to reflect the texture type instead * Removed string initialize | |||||
2018-09-23 | correct BC6H | greggameplayer | 1 | -2/+2 | |
2018-09-23 | Added audren:u#GetAudioRendererState | David Marcec | 5 | -1/+21 | |
2018-09-23 | FPCR register was uninitialized at start up | Philippe Babin | 1 | -1/+1 | |
2018-09-22 | common/thread: remove YieldCPU() | Weiyi Wang | 1 | -8/+0 | |
simply use the standard library yield() | |||||
2018-09-22 | game_list: Add Qt SmoothTransformation to picture scaling | Zach Hilman | 1 | -1/+1 | |
2018-09-22 | qt: Add UI elements for LayeredFS and related tools | Zach Hilman | 6 | -5/+162 | |
2018-09-22 | romfs: Implement CreateRomFS | Zach Hilman | 2 | -4/+25 | |
2018-09-22 | file_sys: Port Atmosphere-NX fs_mitm implementation | Zach Hilman | 2 | -0/+474 | |
2018-09-22 | filesystem: Add LayeredFS VFS directory getter | Zach Hilman | 2 | -1/+14 | |
2018-09-22 | bis_factory: Add mod directory VFS getter | Zach Hilman | 3 | -3/+18 | |
2018-09-22 | patch_manager: Add LayeredFS mods support | Zach Hilman | 2 | -1/+44 | |
2018-09-22 | vfs_concat: Rewrite and fix ConcatenatedVfsFile | Zach Hilman | 2 | -14/+59 | |
2018-09-22 | vfs_layered: Add LayeredVfsDirectory | Zach Hilman | 2 | -0/+178 | |
Reads multiple dirs through as if a waterfall. | |||||
2018-09-22 | vfs_vector: Add VectorVfsFile | Zach Hilman | 2 | -0/+75 | |
Maps a vector into the VFS interface. | |||||
2018-09-22 | vfs_static: Add StaticVfsFile | Zach Hilman | 2 | -0/+78 | |
Always returns the template argument byte for all reads. Doesn't support writes. | |||||
2018-09-22 | vfs: Add and rewite VfsRawCopy functions | Zach Hilman | 2 | -6/+36 | |
2018-09-22 | vfs: Add GetEntries method | Zach Hilman | 4 | -0/+32 | |
Maps name string to directory or file. | |||||
2018-09-22 | common_paths: Add Load and Dump dirs | Zach Hilman | 3 | -0/+6 | |
2018-09-22 | gl_state: Remove unused type alias | Lioncash | 2 | -4/+1 | |
This isn't used anywhere within the header, so we can remove it, along with the include that was previously necessary. This also uncovers an indirect include in the cpp file for the assertion macros. | |||||
2018-09-21 | Update config.cpp | Valentin Vanelslande | 1 | -1/+1 | |
2018-09-21 | shader_bytecode: Lay out the Ipa-related enums better | Lioncash | 1 | -2/+12 | |
This is more consistent with the surrounding enums. | |||||
2018-09-21 | shader_bytecode: Make operator== and operator!= of IpaMode const qualified | Lioncash | 1 | -6/+7 | |
These don't affect the state of the struct and can be const member functions. | |||||
2018-09-21 | game_list: move SearchField to game_list_p.h and fix untranslated text | zhupengfei | 3 | -35/+51 | |
I have tested and made sure the text is translatable, but this would require a translation update to take effect. | |||||
2018-09-21 | Reverse stride align restriction on FastSwizzle due to lost performance | FernandoS27 | 1 | -3/+2 | |
2018-09-21 | Join both Swizzle methods within one interface function | FernandoS27 | 1 | -11/+19 | |
2018-09-21 | Standarized Legacy Swizzle to look alike FastSwizzle and use a Swizzling Table instead | FernandoS27 | 1 | -42/+38 | |
2018-09-21 | Remove same output bpp restriction on FastSwizzle | FernandoS27 | 1 | -4/+5 | |
2018-09-21 | Improved Legacy Swizzler to be better documented and work better | FernandoS27 | 1 | -15/+21 | |
2018-09-21 | gl_stream_buffer: Fix use of bitwise OR instead of logical OR in Map() | Lioncash | 1 | -1/+1 | |
This was very likely intended to be a logical OR based off the conditioning and testing of inversion in one case. Even if this was intentional, this is the kind of non-obvious thing one should be clarifying with a comment. | |||||
2018-09-21 | svc: Move most process termination code to its own function within Process | Lioncash | 3 | -32/+56 | |
Reduces the use of Process class members externally and keeps most code related to tearing down a process with the rest of the process code. | |||||
2018-09-21 | thread/process: Move TLS slot marking/freeing to the process class | Lioncash | 4 | -68/+89 | |
Allows making several members of the process class private, it also avoids going through Core::CurrentProcess() just to retrieve the owning process. | |||||
2018-09-21 | Added support for uncompressed NSOs (#1374) | David | 1 | -3/+12 | |
* Added support for uncompressed NSOs * Moved compressed section check to NsoHeader | |||||
2018-09-21 | Logging: Change the TimeStretch::Process log from debug to trace level. | Subv | 1 | -1/+1 | |
This function is called too many times and makes the debug logging basically unusable due to the spam. | |||||
2018-09-21 | RasterizerGL: Use the correct framebuffer when clearing via the CLEAR_BUFFERS register. | Subv | 1 | -1/+1 | |
Previously we were clearing the default backbuffer framebuffer. Found thanks to a Piglit test :) | |||||
2018-09-21 | Improved fast swizzle and removed restrictions to it | FernandoS27 | 1 | -7/+12 | |
2018-09-21 | Revert GetRequestState | David Marcec | 1 | -1/+1 | |
Even though setting this value to 3 is more correct. We break more games than we fix due to missing implementations. We should keep this as 0 for the time being | |||||
2018-09-21 | kernel/thread: Use owner_process when setting the page table in SetupMainThread() | Lioncash | 3 | -5/+5 | |
The owning process of a thread is required to exist before the thread, so we can enforce this API-wise by using a reference. We can also avoid the reliance on the system instance by using that parameter to access the page table that needs to be set. | |||||
2018-09-21 | arm_interface: Replace kernel vm_manager include with a forward declaration | Lioncash | 5 | -1/+11 | |
Avoids an unnecessary inclusion and also uncovers three places where indirect inclusions were relied upon, which allows us to also resolve those. | |||||
2018-09-20 | Correct endianness of BKPT | Jarek Syrylak | 1 | -1/+1 | |
2018-09-20 | arm_dynarmic: Halt when BRK encountered | MerryMage | 1 | -0/+1 | |
2018-09-20 | Fixed submit | David Marcec | 1 | -2/+1 | |
2018-09-20 | Added IRequest::Submit | David Marcec | 1 | -1/+8 | |
This fixes updated versions of SMO. Currently unable to test as I don't have an updated version | |||||
2018-09-20 | game_list: Handle plurals within setFilterResult() better | Lioncash | 1 | -9/+1 | |
Qt provides an overload of tr() that operates on quantities in relation to pluralization. This also allows the translation to adapt based on the target language rules better. For example, the previous code would result in an incorrect translation for the French language (which doesn't use the pluralized version of "result" in the case of a total of zero. While in English it's correct to use the pluralized version of "result", that is, "results" --- For example: English: "0 results" French: "0 résultat" (uses the singular form) In French, the noun being counted is singular if the quantity is 0 or 1. In English, on the other hand, if the noun being counted has a quantity of 0 or N > 1, then the noun is pluralized. --- For another example in a language that has different counting methods than the above, consider English and Irish. Irish has a special form of of a grammatical number called a dual. Which alters how a word is written when N of something is 2. This won't appear in this case with a direct number "2", but it would change if we ever used "Two" to refer to two of something. For example: English: "Zero results" Irish: "Toradh ar bith" English: "One result" Irish: "Toradh amháin" English: "Two results" Irish: "Dhá thorthaí" <- Dual case Which is an important distinction to make between singular and plural, because in other situations, "two" on its own would be written as "dó" in Irish. There's also a few other cases where the order the words are placed *and* whether or not the plural or singular variant of the word is used *and* whether or not the word is placed after or between a set of numbers can vary. Counting in Irish also differs depending on whether or not you're counting things (like above) or counting people, in which case an entirely different set of numbers are used. It's not important for this case, but it's provided as an example as to why one should never assume the placement of values in text will be like that of English or other languages. Some languages have very different ways to represent counting, and breaking up the translated string like this isn't advisable because it makes it extremely difficult to get right depending on what language a translator is translating text into due to the ambiguity of the strings being presented for translation. In this case a translator would see three fragmented strings on Transifex (and not necessarily grouped beside one another, but even then, it would still be annoying to decipher): - "of" - "result" - "results" There is no way a translator is going to know what those sets of words are actually used for unless they look at the code to see what is being done with them (which they shouldn't have to do). | |||||
2018-09-20 | Removed unneeded event clear | David Marcec | 1 | -1/+0 | |
2018-09-20 | Implemented NTC & IEnsureNetworkClockAvailabilityService | David Marcec | 1 | -3/+100 | |
Needed because of the recent nim fixes | |||||
2018-09-20 | file-sys: Default heavy-weight class destructors in the cpp file | Lioncash | 25 | -1/+45 | |
Several classes have a lot of non-trivial members within them, or don't but likely should have the destructor defaulted in the cpp file for future-proofing/being more friendly to forward declarations. Leaving the destructor unspecified allows the compiler to inline the destruction code all over the place, which is generally undesirable from a code bloat perspective. | |||||
2018-09-20 | control_metadata: Remove unnecessary else within GetLanguageEntry() | Lioncash | 1 | -8/+8 | |
There's no need to indent the code here, given the if case contains a return statement at the end of it. | |||||
2018-09-20 | control_metadata: Move language name array definition to the cpp file | Lioncash | 2 | -6/+9 | |
This was used in two different translation units (deconstructed_rom_directory and patch_manager). This means we'd be pointlessly duplicating the whole array twice due to it being defined within the header. | |||||
2018-09-19 | arm_dynarmic: Support BKPT instruction | MerryMage | 1 | -0/+11 | |
2018-09-19 | xts_archive: Remove unused variables from CalculateHMAC256() | Lioncash | 1 | -3/+0 | |
These variables aren't used, which still has an impact, as std::vector cannot be optimized away by the compiler (it's constructor and destructor are both non-trivial), so this was just wasting memory. | |||||
2018-09-19 | xts_archive: Make AsNCA() return a std::unique_ptr instead of a std::shared_ptr | Lioncash | 2 | -3/+3 | |
std::shared_ptr isn't strictly necessary here and is only ever used in contexts where the object doesn't depend on being shared. This also makes the interface more flexible, as it's possible to create a std::shared_ptr from a std::unique_ptr (std::shared_ptr has a constructor that accepts a std::unique_ptr), but not the other way around. | |||||
2018-09-19 | nax: Avoid re-parsing NAX data with GetFileType() | Lioncash | 2 | -13/+19 | |
An instance of the NAX apploader already has an existing NAX instance in memory. Calling directly into IdentifyType() directly would re-parse the whole file again into yet another NAX instance, only to toss it away again. This gets rid of unnecessary/redundant file parsing and allocations. | |||||
2018-09-19 | nax: Avoid unnecessary calls to AsNCA() in IdentifyType() | Lioncash | 1 | -4/+8 | |
AsNCA() allocates an NCA instance every time it's called. In the current manner it's used, it's quite inefficient as it's making a redundant allocation. We can just amend the order of the conditionals to make it easier to just call it once. | |||||
2018-09-19 | xts_archive: Ensure NAX's type member is always initialized | Lioncash | 1 | -1/+1 | |
Ensures that the member always has a deterministic value. | |||||
2018-09-19 | xts_archive: Amend initializer order of NAX's constructor | Lioncash | 1 | -2/+2 | |
Orders the initializer list in the same order the members would be initialized. Avoids compiler warnings. | |||||
2018-09-19 | Reworked incorrect nifm stubs (#1355) | David | 1 | -3/+10 | |
* Reworked incorrect nifm stubs Need confirmation on `CreateTemporaryNetworkProfile`, unsure which game uses it but according to reversing. It should return a uuid which we currently don't do. Any 0 client id is considered an invalid client id. GetRequestState 0 is considered invalid. * Fixups for nifm | |||||
2018-09-19 | Fixed GetAccountId stub, Added error code for OpenDirectory and added ActivateNpadWithRevision | David Marcec | 3 | -7/+12 | |
With these, `Nintendo Entertainment System - Nintendo Switch Online` loads | |||||
2018-09-19 | yuzu-cmd: Add call to CreateFactories | Zach Hilman | 1 | -1/+3 | |
Ensures all relevant filesystem objects are initialized and eliminates a crash related to the RegisteredCache. | |||||
2018-09-19 | savedata_factory: Add TemporaryStorage SaveDataType | Zach Hilman | 1 | -4/+7 | |
Seems to be used by NSO NES Emulator | |||||
2018-09-19 | gl_rasterizer: Fix StartAddress handling with indexed draw calls. | Markus Wick | 1 | -6/+7 | |
We uploaded the wrong data before. So the offset on the host GPU pointer may work for the first vertices, the last ones run out bounds. Let's just offset the upload instead. | |||||
2018-09-19 | Corrected SSL::SetInterfaceVersion | David Marcec | 1 | -3/+3 | |
Should be a single u32 | |||||
2018-09-19 | Removed MakeBuilder as it's not needed anymore | David Marcec | 1 | -7/+0 | |
2018-09-19 | Removed the use of rp.MakeBuilder | David Marcec | 6 | -27/+26 | |
Due to keeping the code style consistent in the yuzu codebase. `rb = rp.MakeBuilder(...)` was replaced with `rb{ctx, ...}` | |||||
2018-09-19 | ring_buffer: Use std::atomic_size_t in a static assert | Lioncash | 1 | -1/+1 | |
Avoids the need to repeat "std::" twice | |||||
2018-09-19 | ring_buffer: Use std::hardware_destructive_interference_size to determine alignment size for avoiding false sharing | Lioncash | 1 | -2/+10 | |
MSVC 19.11 (A.K.A. VS 15.3)'s C++ standard library implements P0154R1 (http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2016/p0154r1.html) which defines two new constants within the <new> header, std::hardware_destructive_interference_size and std::hardware_constructive_interference_size. std::hardware_destructive_interference_size defines the minimum recommended offset between two concurrently-accessed objects to avoid performance degradation due to contention introduced by the implementation (with the lower-bound being at least alignof(max_align_t)). In other words, the minimum offset between objects necessary to avoid false-sharing. std::hardware_constructive_interference_size on the other hand defines the maximum recommended size of contiguous memory occupied by two objects accessed wth temporal locality by concurrent threads (also defined to be at least alignof(max_align_t)). In other words the maximum size to promote true-sharing. So we can simply use this facility to determine the ideal alignment size. Unfortunately, only MSVC supports this right now, so we need to enclose it within an ifdef for the time being. | |||||
2018-09-19 | Invalid default value of username in yuzu_cmd (#1334) | Philippe Babin | 3 | -3/+8 | |
* Fix bug where default username value for yuzu_cmd create an userprofile with uninitialize data as username * Fix format * Apply code review changes * Remove nullptr check | |||||
2018-09-18 | Added ActivateGesture | David Marcec | 1 | -1/+7 | |
2018-09-18 | Implemented GetDefaultDisplayResolution | David Marcec | 2 | -1/+18 | |
2018-09-18 | Added StopSixAxisSensor | David Marcec | 1 | -1/+7 | |
2018-09-18 | Stubbed ActivateConsoleSixAxisSensor & StartConsoleSixAxisSensor | David Marcec | 1 | -2/+14 | |
2018-09-18 | Implemented GetImageSize | David Marcec | 1 | -1/+9 | |
2018-09-18 | svc_wrap: Convert the PARAM macro into a function | Lioncash | 1 | -37/+36 | |
This can just be a regular function, getting rid of the need to also explicitly undef the define at the end of the file. Given FuncReturn() was already converted into a function, it's #undef can also be removed. | |||||
2018-09-18 | arm_dynarmic: Correct ExclusiveWrite128()'s operation | Lioncash | 1 | -2/+2 | |
Previously the second half of the value being written would overwrite the first half. Thankfully this wasn't a bug that was being encountered, as the function is currently unused. | |||||
2018-09-18 | arm_interface: Remove ARM11-isms from the CPU interface | Lioncash | 7 | -99/+86 | |
This modifies the CPU interface to more accurately match an AArch64-supporting CPU as opposed to an ARM11 one. Two of the methods don't even make sense to keep around for this interface, as Adv Simd is used, rather than the VFP in the primary execution state. This is essentially a modernization change that should have occurred from the get-go. | |||||
2018-09-18 | kernel/mutex: Replace ResultCode construction for invalid addresses with the named variant | Lioncash | 1 | -2/+2 | |
We already have a ResultCode constant for the case of an invalid address, so we can just use it instead of re-rolling that ResultCode type. | |||||
2018-09-18 | kernel/svc: Handle error cases for svcArbitrateLock() and svcArbitrateUnlock() | Lioncash | 1 | -0/+8 | |
The kernel does the equivalent of the following check before proceeding: if (address + 0x8000000000 < 0x7FFFE00000) { return ERR_INVALID_MEMORY_STATE; } which is essentially what our IsKernelVirtualAddress() function does. So we should also be checking for this. The kernel also checks if the given input addresses are 4-byte aligned, however our Mutex::TryAcquire() and Mutex::Release() functions already handle this, so we don't need to add code for this case. | |||||
2018-09-18 | Implemented Internal Flags | FernandoS27 | 1 | -13/+35 | |
2018-09-18 | gl_shader_decompiler: Avoid truncation warnings within LD_A and ST_A code | Lioncash | 1 | -4/+4 | |
These are internally stored as u64 values, so using u32 here causes truncation warnings. Instead, we can just use u64 and preserve the bit width. | |||||
2018-09-18 | core/core_cpu: Replace exclusive monitor include with forward declaration | Lioncash | 2 | -2/+6 | |
We don't need to include this as a dependency within the header. A regular forward declaration will suffice here. | |||||
2018-09-17 | Implemented I2I.CC on the NEU control code, used by SMO | FernandoS27 | 2 | -14/+18 | |
2018-09-17 | Implemented CSETP | FernandoS27 | 2 | -14/+49 | |
2018-09-17 | Implemented Control Codes | FernandoS27 | 2 | -0/+51 | |
2018-09-17 | time_stretch: Remove unused <array> include | Lioncash | 1 | -1/+0 | |
This isn't used within this header and isn't necessary. | |||||
2018-09-17 | stream: Replace includes with forward declarations where applicable | Lioncash | 2 | -3/+7 | |
Avoids propagating includes in headers where it's not necessary to do so. | |||||
2018-09-17 | audio_renderer: Replace includes with forward declarations where applicable | Lioncash | 2 | -39/+52 | |
Avoids including unnecessary headers within the audio_renderer.h header, lessening the likelihood of needing to rebuild source files including this header if they ever change. Given std::vector allows forward declaring contained types, we can move VoiceState to the cpp file and hide the implementation entirely. | |||||
2018-09-17 | Added asserts for texture misc modes to texture instructions | FernandoS27 | 1 | -2/+45 | |
2018-09-17 | Added texture misc modes to texture instructions | FernandoS27 | 1 | -1/+147 | |
2018-09-17 | Add 1D sampler for TLDS - TexelFetch (Mario Rabbids) | raven02 | 1 | -7/+12 | |
2018-09-17 | yuzu/util: Antialias game list compatibility pixmaps | Lioncash | 1 | -1/+2 | |
We pass a hint to the QPainter instance that we want anti-aliasing on the compatibility icons, which prevents the circles from looking fairly jagged, and actually makes them look circular. | |||||
2018-09-17 | game_list_p: Amend typo in GameListItemCompat's constructor parameter | Lioncash | 1 | -4/+4 | |
Adds a missing 'i' character that was missing in compatibility. | |||||
2018-09-17 | game_list_p: Take map iterator contents by const reference | Lioncash | 1 | -1/+1 | |
We don't need to copy the whole struct in this instance, we can just utilize a reference instead. | |||||
2018-09-16 | Implement ASTC_2D_8X8 (Bayonetta 2) | raven02 | 3 | -6/+20 | |
2018-09-15 | Implement RenderTargetFormat::BGR5A1_UNORM (Pokken Tournament DX) | raven02 | 2 | -0/+4 | |
2018-09-15 | Shaders: Implemented multiple-word loads and stores to and from attribute memory. | Subv | 2 | -7/+58 | |
This seems to be an optimization performed by nouveau. | |||||
2018-09-15 | Port # #4192 from Citra: "svc: change unknown to thread in CreateThread" | Valentin Vanelslande | 1 | -1/+1 | |
2018-09-15 | Tests: Remove glad test OS X work-around | Yuri Kunde Schlesner | 2 | -16/+0 | |
2018-09-15 | Port #4182 from Citra: "Prefix all size_t with std::" | fearlessTobi | 146 | -751/+780 | |
2018-09-14 | Optimized Texture Swizzling | FernandoS27 | 1 | -2/+49 | |
2018-09-14 | cubeb_sink: Get rid of variable shadowing within CubebSink's constructor | Lioncash | 1 | -4/+4 | |
The parameter of the lambda was shadowing the variable that was being assigned to. | |||||
2018-09-14 | cubeb_sink: Correct context name in ListCubebSinkDevices() | Lioncash | 1 | -1/+1 | |
This ain't Citra. | |||||
2018-09-14 | services/sm: Amend error code constants | Lioncash | 2 | -8/+6 | |
Courtesy of @ogniK5377. This also moves them into the cpp file and limits the visibility to where they're directly used. It also gets rid of unused or duplicate error codes. | |||||
2018-09-14 | kernel/svc: Sanitize creation of shared memory via svcCreateSharedMemory() | Lioncash | 1 | -2/+18 | |
The kernel caps the size limit of shared memory to 8589930496 bytes (or (1GB - 512 bytes) * 8), so approximately 8GB, where every GB has a 512 byte sector taken off of it. It also ensures the shared memory is created with either read or read/write permissions for both permission types passed in, allowing the remote permissions to also be set as "don't care". | |||||
2018-09-14 | kernel/svc: Sanitize addresses, permissions, and sizes within svcMapSharedMemory() and svcUnmapSharedMemory() | Lioncash | 1 | -17/+25 | |
Part of the checking done by the kernel is to check if the given address and size are 4KB aligned, as well as checking if the size isn't zero. It also only allows mapping shared memory as readable or read/write, but nothing else, and so we shouldn't allow mapping as anything else either. | |||||
2018-09-14 | gl_shader_decompiler: Get rid of variable shadowing within LEA instructions | Lioncash | 1 | -2/+0 | |
These variables are already defined within an outer scope. | |||||
2018-09-14 | kernel/svc: Sanitize addresses and sizes within svcMapMemory() and svcUnmapMemory() | Lioncash | 1 | -0/+23 | |
The kernel checks if the addresses and given size is 4KB aligned before continuing onwards to map the memory. | |||||
2018-09-14 | kernel/svc: Sanitize heap sizes within svcSetHeapSize() | Lioncash | 2 | -0/+8 | |
The kernel checks if the given size is a multiple of 2MB and <= to 4GB before going ahead and attempting to allocate that much memory. | |||||
2018-09-14 | audio_core/time_stretch: Silence truncation warnings in Process() | Lioncash | 1 | -2/+2 | |
The SoundTouch API only accepts uint amount of samples. | |||||
2018-09-13 | kernel/errors: Amend error code for ERR_NOT_FOUND | Lioncash | 1 | -1/+2 | |
This is the value returned by the kernel for svcConnectToNamedPort() if the named port cannot be found. | |||||
2018-09-13 | service/vi: Replace includes with forward declarations where applicable | Lioncash | 3 | -7/+9 | |
2018-09-13 | kernel/thread: Include thread-related enums within the kernel namespace | Lioncash | 5 | -38/+39 | |
Previously, these were sitting outside of the Kernel namespace, which doesn't really make sense, given they're related to the Thread class which is within the Kernel namespace. | |||||
2018-09-13 | service: Use nested namespace specifiers where applicable | Lioncash | 3 | -12/+6 | |
There were a few places where nested namespace specifiers weren't being used where they could be within the service code. This amends that to make the namespacing a tiny bit more compact. | |||||
2018-09-13 | ipc: minor fix | Valentin Vanelslande | 1 | -1/+1 | |
2018-09-13 | Use ARB_multi_bind for uniform buffers (#1287) | ReinUsesLisp | 4 | -3/+27 | |
* gl_rasterizer: use ARB_multi_bind for uniform buffers * address feedback | |||||
2018-09-13 | services/pl_u: Add missing Korean font to the fallback case for shared fonts | Lioncash | 1 | -2/+4 | |
Previously this wasn't using the Korean font at all. | |||||
2018-09-13 | gl_rasterizer_cache: B5G6R5U should use GL_RGB8 as an internal format. | bunnei | 1 | -1/+1 | |
- Fixes a regression with Sonic Mania with ARB_texture_storage. | |||||
2018-09-12 | GPU: Basic implementation of the Kepler Inline Memory engine (p2mf). | Subv | 6 | -0/+146 | |
This engine writes data from a FIFO register into the configured address. | |||||
2018-09-12 | audio_core: Flush stream when not playing anything | MerryMage | 6 | -0/+23 | |
2018-09-12 | Implemented Texture Processing Modes | FernandoS27 | 2 | -1/+43 | |
2018-09-12 | svc: Return ERR_INVALID_PROCESSOR_ID in CreateThread() if an invalid processor ID is given | Lioncash | 1 | -2/+2 | |
This is what the kernel does for an out-of-range processor ID. | |||||
2018-09-12 | kernel/errors: Correct error codes for invalid thread priority and invalid processor ID | Lioncash | 3 | -7/+9 | |
2018-09-12 | svc: Do nothing if svcOutputDebugString() is given a length of zero | Lioncash | 1 | -0/+4 | |
While unlikely, it does avoid constructing a std::string and unnecessarily calling into the memory code if a game or executable decides to be really silly about their logging. | |||||
2018-09-12 | svc: Correct parameter type for OutputDebugString() | Lioncash | 2 | -3/+3 | |
This should be a u64 to represent size. | |||||
2018-09-12 | yuzu/configure_gamelist: Make combo box strings translatable | Lioncash | 2 | -21/+47 | |
Given these are shown to the user, they should be translatable. While we're at it, also set up the dialog to automatically retranslate the dialog along with the combo boxes if it receives a LanguageChange event. | |||||
2018-09-12 | yuzu/configure_gamelist: Use std::array instead of std::vector for translatable strings | Lioncash | 1 | -6/+9 | |
We don't need to use an allocating container for these, given we know the fixed amount of strings being used. This is just a waste of memory. | |||||
2018-09-12 | yuzu/configure_gamelist: Move combo box initializtion to their own functions | Lioncash | 2 | -23/+32 | |
Keeps the individual initialization of the combo boxes logically separate. We also shouldn't be dumping this sort of thing in the constructor directly. | |||||
2018-09-12 | gl_rasterizer_cache: Always blit on recreate, regardless of format. | bunnei | 1 | -6/+10 | |
- Fixes several rendering issues with Super Mario Odyssey. | |||||
2018-09-12 | game_list: Resolve variable shadowing within LoadCompatibilityList() | Lioncash | 1 | -3/+3 | |
"value" is already a used variable name within the outermost ranged-for loop, so this variable was shadowing the outer one. This isn't a bug, but it will get rid of a -Wshadow warning. | |||||
2018-09-12 | game_list: Use QJsonValueRef() within LoadCompatibilityList() | Lioncash | 1 | -2/+2 | |
This way, we aren't constructing unnecessary QJsonValue instances. | |||||
2018-09-12 | service/audio: Replace includes with forward declarations where applicable | Lioncash | 7 | -17/+34 | |
A few headers were including other headers when a forward declaration can be used instead, allowing the include to be moved to the cpp file. | |||||
2018-09-12 | audio_core/sink_details: Change std::string parameter into std::string_view | Lioncash | 2 | -2/+4 | |
The given string is only ever used for lookup and comparison, so we can just utilize a non-owning view to string data here | |||||
2018-09-12 | pl_u: Eliminate mutable file-scope state | Lioncash | 2 | -66/+88 | |
Converts the PL_U internals to use the PImpl idiom and makes the state part of the Impl struct, eliminating mutable global/file state. | |||||
2018-09-12 | service/prepo: Move class into the cpp file | Lioncash | 2 | -39/+40 | |
This doesn't need to be exposed within the header and be kept in the translation unit, eliminating the need to include anything within the header. | |||||
2018-09-12 | gl_shader_cache: Remove cache_width/cache_height. | bunnei | 2 | -12/+2 | |
- This was once an optimization, but we no longer need it with the cache reserve. - This is also inaccurate. | |||||
2018-09-11 | gl_rasterizer: Use ARB_texture_storage. | Markus Wick | 3 | -11/+12 | |
It allows us to use texture views and it reduces the overhead within the GPU driver. But it disallows us to reallocate the texture, but we don't do so anyways. In the end, it is the new way to allocate textures, so there is no need to use the old way. | |||||
2018-09-11 | Implemented LEA and PSET | FernandoS27 | 1 | -0/+91 | |
2018-09-11 | Implemented encodings for LEA and PSET | FernandoS27 | 1 | -0/+64 | |
2018-09-11 | Replace old FragmentHeader for the new Header | FernandoS27 | 2 | -31/+18 | |
2018-09-11 | Implemented (Partialy) Shader Header | FernandoS27 | 3 | -2/+102 | |
2018-09-11 | externals: Place font data within cpp files | Lioncash | 1 | -6/+6 | |
This places the font data within cpp files, which mitigates the possibility of the font data being duplicated within the binary if it's referred to in more than one translation unit in the future. It also stores the data within a std::array, which is more flexible when it comes to operating with the standard library. Furthermore, it makes the data arrays const. This is what we want, as it allows the compiler to store the data within the read-only segment. As it is, having several large sections of mutable data like this just leaves spots in memory that we can accidentally write to (via accidental overruns, what have you) and actually have it work. This ensures the font data remains the same no matter what. | |||||
2018-09-11 | hle/service: Default constructors and destructors in the cpp file where applicable | Lioncash | 148 | -45/+291 | |
When a destructor isn't defaulted into a cpp file, it can cause the use of forward declarations to seemingly fail to compile for non-obvious reasons. It also allows inlining of the construction/destruction logic all over the place where a constructor or destructor is invoked, which can lead to code bloat. This isn't so much a worry here, given the services won't be created and destroyed frequently. The cause of the above mentioned non-obvious errors can be demonstrated as follows: ------- Demonstrative example, if you know how the described error happens, skip forwards ------- Assume we have the following in the header, which we'll call "thing.h": \#include <memory> // Forward declaration. For example purposes, assume the definition // of Object is in some header named "object.h" class Object; class Thing { public: // assume no constructors or destructors are specified here, // or the constructors/destructors are defined as: // // Thing() = default; // ~Thing() = default; // // ... Some interface member functions would be defined here private: std::shared_ptr<Object> obj; }; If this header is included in a cpp file, (which we'll call "main.cpp"), this will result in a compilation error, because even though no destructor is specified, the destructor will still need to be generated by the compiler because std::shared_ptr's destructor is *not* trivial (in other words, it does something other than nothing), as std::shared_ptr's destructor needs to do two things: 1. Decrement the shared reference count of the object being pointed to, and if the reference count decrements to zero, 2. Free the Object instance's memory (aka deallocate the memory it's pointing to). And so the compiler generates the code for the destructor doing this inside main.cpp. Now, keep in mind, the Object forward declaration is not a complete type. All it does is tell the compiler "a type named Object exists" and allows us to use the name in certain situations to avoid a header dependency. So the compiler needs to generate destruction code for Object, but the compiler doesn't know *how* to destruct it. A forward declaration doesn't tell the compiler anything about Object's constructor or destructor. So, the compiler will issue an error in this case because it's undefined behavior to try and deallocate (or construct) an incomplete type and std::shared_ptr and std::unique_ptr make sure this isn't the case internally. Now, if we had defaulted the destructor in "thing.cpp", where we also include "object.h", this would never be an issue, as the destructor would only have its code generated in one place, and it would be in a place where the full class definition of Object would be visible to the compiler. ---------------------- End example ---------------------------- Given these service classes are more than certainly going to change in the future, this defaults the constructors and destructors into the relevant cpp files to make the construction and destruction of all of the services consistent and unlikely to run into cases where forward declarations are indirectly causing compilation errors. It also has the plus of avoiding the need to rebuild several services if destruction logic changes, since it would only be necessary to recompile the single cpp file. | |||||
2018-09-11 | Fixed renderdoc input/output textures not working due to render targets | David Marcec | 2 | -2/+9 | |
2018-09-11 | Use open-source shared fonts if no dumped file is available (#1269) | Tobias | 2 | -2/+26 | |
* Add open-source shared fonts * Address review comments | |||||
2018-09-11 | Port #4141 from citra: Joystick hotplug support (#1275) | Tobias | 7 | -101/+339 | |
* Joystick hotplug support (#4141) * use SDL_PollEvent instead of SDL_JoystickUpdate Register hot plugged controller by GUID if they were configured in a previous session * Move SDL_PollEvent into its own thread * Don't store SDLJoystick pointer in Input Device; Get pointer on each GetStatus call * Fix that joystick_list gets cleared after SDL_Quit * Add VirtualJoystick for InputDevices thats never nullptr * fixup! Add VirtualJoystick for InputDevices thats never nullptr * fixup! fixup! Add VirtualJoystick for InputDevices thats never nullptr * Remove SDL_GameController, make SDL_Joystick* unique_ptr * fixup! Remove SDL_GameController, make SDL_Joystick* unique_ptr * Adressed feedback; fixed handling of same guid reconnects * fixup! Adressed feedback; fixed handling of same guid reconnects * merge the two joystick_lists into one * make SDLJoystick a member of VirtualJoystick * fixup! make SDLJoystick a member of VirtualJoystick * fixup! make SDLJoystick a member of VirtualJoystick * fixup! fixup! make SDLJoystick a member of VirtualJoystick * SDLJoystick: Addressed review comments * Address one missed review comment | |||||
2018-09-10 | video_core: Refactor command_processor. | Markus Wick | 2 | -44/+42 | |
Inline the WriteReg helper as it is called ~20k times per frame. | |||||
2018-09-10 | video_core: Move command buffer loop. | Markus Wick | 5 | -77/+84 | |
This moves the hot loop into video_core. This refactoring shall reduce the CPU overhead of calling ProcessCommandList. | |||||
2018-09-10 | Remove multicore configure_general.ui | MysticExile | 1 | -7/+0 | |
2018-09-10 | remove multicore in configure_general.cpp | MysticExile | 1 | -3/+0 | |
2018-09-10 | rasterizer: Drop unused handler. | Markus Wick | 4 | -8/+0 | |
This virtual function is called in a very hot spot, and it does nothing. If this kind of feature is required, please be more specific and add callbacks in the switch statement within Maxwell3D::WriteReg. There is no point in having another switch statement within the rasterizer. | |||||
2018-09-10 | gl_rasterizer_cache: Only use depth for applicable texture formats. | bunnei | 1 | -6/+22 | |
- Fixes an issue with Octopath Traveler leaving stale data here. | |||||
2018-09-10 | gl_rasterizer: Implement clear for non-zero render targets. | bunnei | 2 | -50/+66 | |
- Several misc. changes to ConfigureFramebuffers in support of this. | |||||
2018-09-10 | gl_rasterizer_cache: Implement RenderTargetFormat::BGRA8_SRGB. | bunnei | 3 | -0/+4 | |
- Used by Octopath Traveler (with multiple render targets). | |||||
2018-09-10 | gl_rasterizer: Implement multiple color attachments. | bunnei | 5 | -132/+95 | |
2018-09-10 | service: Remove unused g_kernel_named_ports variable | Lioncash | 1 | -2/+0 | |
With the named port functionality all migrated over to the kernel, there's no need to keep this around anymore. | |||||
2018-09-10 | Implemented TMML | FernandoS27 | 2 | -5/+67 | |
2018-09-10 | game_list: Make CompatibilityList parameter of NavigateToGamedbEntryRequested() a const reference | Lioncash | 3 | -3/+5 | |
The compatibility list isn't modified within any of the slots connected to this signal, so we can make it const to enforce immutability. | |||||
2018-09-10 | yuzu: Move compatibility list specifics to their own source files | Lioncash | 10 | -33/+54 | |
Lets us keep the generic portions of the compatibility list code together, and allows us to introduce a type alias that makes it so we don't need to type out a very long type declaration anymore, making the immediate readability of some code better. | |||||
2018-09-09 | Implemented TXQ dimension query type, used by SMO. | FernandoS27 | 2 | -1/+36 | |
2018-09-09 | video_core: fixed arithmetic overflow warnings & improved code style | Patrick Elsässer | 5 | -89/+101 | |
- Fixed all warnings, for renderer_opengl items, which were indicating a possible incorrect behavior from integral promotion rules and types larger than those in which arithmetic is typically performed. - Added const for variables where possible and meaningful. - Added constexpr where possible. | |||||
2018-09-09 | cubeb_sink: Downsample arbitrary number of channels | MerryMage | 1 | -10/+9 | |
2018-09-09 | Port Citra #4047 & #4052: add change background color support | tech4me | 6 | -0/+46 | |
2018-09-09 | hid: Implement ReloadInputDevices | fearlessTobi | 2 | -4/+6 | |
2018-09-09 | Change name of TEXQ to TXQ, in order to match NVIDIA's naming | FernandoS27 | 1 | -2/+2 | |
2018-09-08 | GPU/DMA: Partially implemented the 'enable_2d' bit in the DMA engine. | Subv | 1 | -2/+10 | |
When not set, this tells the GPU to only use the X size when performing a DMA copy. This is only implemented for linear->linear and tiled->tiled copies. Conversion copies still retain the assert. This bit is unset by some games for various purposes, and by nouveau when copying the vertex buffers. | |||||
2018-09-08 | cubeb_sink: Perform audio stretching | MerryMage | 3 | -24/+26 | |
2018-09-08 | audio_core: Add audio stretcher | MerryMage | 3 | -0/+101 | |
2018-09-08 | cubeb_sink: Hold last available value instead of writing zeros | MerryMage | 1 | -5/+15 | |
This reduces clicking in output audio should we underrun. | |||||
2018-09-08 | cubeb_sink: Use RingBuffer | MerryMage | 1 | -40/+26 | |
2018-09-08 | common: Implement a ring buffer | MerryMage | 4 | -0/+243 | |
2018-09-08 | Add audio stretching support | fearlessTobi | 12 | -0/+43 | |
2018-09-08 | audio_renderer: Rename AudioOut instance to audio_out | MerryMage | 2 | -7/+7 | |
2018-09-08 | yuzu: fix title bar display | Pengfei Zhu | 1 | -2/+2 | |
Previously the version number got hidden after starting a game. | |||||
2018-09-08 | gl_rasterizer: Use baseInstance instead of moving the buffer points. | bunnei | 3 | -21/+29 | |
This hopefully helps our cache not to redundant upload the vertex buffer. # Conflicts: # src/video_core/renderer_opengl/gl_rasterizer.cpp | |||||
2018-09-08 | yuzu-cmd: fix SDL logging | tgsm | 1 | -2/+3 | |
2018-09-08 | video_core: Arithmetic overflow warning fix for gl_rasterizer (#1262) | Patrick Elsässer | 1 | -12/+14 | |
* video_core: Arithmetic overflow fix for gl_rasterizer - Fixed warnings, which were indicating incorrect behavior from integral promotion rules and types larger than those in which arithmetic is typically performed. - Added const for variables where possible and meaningful. * Changed the casts from C to C++ style Changed the C-style casts to C++ casts as proposed. Took also care about signed / unsigned behaviour. | |||||
2018-09-08 | gl_rasterizer_cache: Improve accuracy of RecreateSurface for non-2D textures. | bunnei | 2 | -27/+45 | |
2018-09-08 | maxwell_3d: Remove assert that no longer applies. | bunnei | 1 | -4/+0 | |
2018-09-08 | gl_rasterizer_cache: Partially implement several non-2D texture types. | bunnei | 1 | -30/+111 | |
2018-09-08 | gl_shader_decompiler: Partially implement several non-2D texture types (Subv). | bunnei | 2 | -32/+143 | |
2018-09-08 | gl_rasterizer: Implement texture wrap mode p. | bunnei | 2 | -2/+8 | |
2018-09-08 | gl_rasterizer_cache: Track texture depth. | bunnei | 3 | -4/+15 | |
2018-09-08 | gl_rasterizer_cache: Remove impl. of FlushGLBuffer. | bunnei | 1 | -34/+1 | |
- Will not work for non-2d textures, and was not used anyways. | |||||
2018-09-08 | gl_rasterizer_cache: Keep track of texture type per surface. | bunnei | 3 | -32/+84 | |
2018-09-08 | gl_rasterizer_cache: Remove unused DownloadGLTexture. | bunnei | 2 | -51/+0 | |
2018-09-08 | gl_state: Keep track of texture target. | bunnei | 5 | -26/+28 | |
2018-09-07 | yuzu: Move GameListWorker to its own source files | Lioncash | 5 | -286/+324 | |
This has gotten sufficiently large enough to warrant moving it to its own source files. Especially given it dumps the file_sys headers around code that doesn't use it for the most part. This'll also make it easier to introduce a type alias for the compatibility list, so a large unordered_map type declaration doesn't need to be specified all the time (we don't want to propagate the game_list_p.h include via the main game_list.h header). | |||||
2018-09-07 | For SDL Frontend | CaptV0rt3x | 1 | -2/+2 | |
2018-09-07 | Better Title Bar Display | CaptV0rt3x | 5 | -8/+28 | |
2018-09-07 | core: Migrate current_process pointer to the kernel | Lioncash | 4 | -5/+34 | |
Given we now have the kernel as a class, it doesn't make sense to keep the current process pointer within the System class, as processes are related to the kernel. This also gets rid of a subtle case where memory wouldn't be freed on core shutdown, as the current_process pointer would never be reset, causing the pointed to contents to continue to live. | |||||
2018-09-06 | gl_rasterizer: Call state.Apply only once on SetupShaders. | bunnei | 1 | -4/+2 | |
2018-09-06 | gl_shader_decompiler: Implement saturate mode for IPA. | bunnei | 1 | -1/+5 | |
2018-09-06 | gl_buffer_cache: Default initialize member variables | Lioncash | 1 | -3/+3 | |
Ensures that the cache always has a deterministic initial state. | |||||
2018-09-06 | gl_buffer_cache: Make GetHandle() a const member function | Lioncash | 2 | -2/+2 | |
GetHandle() internally calls GetHandle() on the stream_buffer instance, which is a const member function, so this can be made const as well. | |||||
2018-09-06 | gl_buffer_cache: Remove unnecessary includes | Lioncash | 2 | -2/+4 | |
2018-09-06 | gl_buffer_cache: Make constructor explicit | Lioncash | 1 | -1/+1 | |
Implicit conversions during construction isn't desirable here. | |||||
2018-09-06 | video_core/CMakeLists: Add missing gl_buffer_cache.h | Lioncash | 1 | -0/+1 | |
Without this, the header file won't show up by default within IDEs such as Visual Studio. | |||||
2018-09-06 | core/core: Remove unnecessary sm/controller include | Lioncash | 5 | -2/+5 | |
The only reason this include was necessary, was because the constructor wasn't defaulted in the cpp file and the compiler would inline it wherever it was used. However, given Controller is forward declared, all those inlined constructors would see an incomplete type, causing a compilation failure. So, we just place the constructor in the cpp file, where it can see the complete type definition, allowing us to remove this include. | |||||
2018-09-06 | file_sys/nca_patch: Amend constructor initializer list order | Lioncash | 1 | -2/+2 | |
Orders the elements in the initializer list in the order they're specified in the class. This prevents compiler warnings about initialization order. | |||||
2018-09-06 | file_sys/nca_patch: Remove unnecessary includes | Lioncash | 2 | -2/+9 | |
romfs.h doesn't need to be included in the header, the only real dependency here is common's swap.h that needs to be included. | |||||
2018-09-06 | file_sys/patch_manager: Add missing includes | Lioncash | 2 | -0/+5 | |
These includes were previously being satisfied indirectly. | |||||
2018-09-06 | frontend: Set swap interval to 0 | fearlessTobi | 2 | -0/+2 | |
2018-09-06 | gl_shader_gen: Initialize position. | Markus Wick | 1 | -0/+1 | |
IMO the old code is fine, but nvidia raises shader compiler warnings. Trivial fix through... | |||||
2018-09-06 | Implemented IPA Properly | FernandoS27 | 2 | -47/+98 | |
2018-09-05 | gl_rasterizer: Skip TODO log. | Markus Wick | 1 | -1/+1 | |
This is called ~3k times per frame in SMO ingame. My laptop spends ~3ms per frame on allocating and freeing this string. Let's just stop printing this kind of redundant information. | |||||
2018-09-05 | file_sys/submission_package: Correct constructor initialization list order | Lioncash | 1 | -2/+2 | |
Orders the elements in the sequence to match the order in which they'll actually be initialized in. | |||||
2018-09-05 | gl_rasterizer: Implement a VAO cache. | Markus Wick | 3 | -53/+60 | |
This patch caches VAO objects instead of re-emiting all pointers per draw call. Configuring this pointers is known as a fast task, but it yields too many GL calls. So for better performance, just bind the VAO instead of 16 pointers. | |||||
2018-09-05 | file_sys/submission_package: Replace includes with forward declarations where applicable | Lioncash | 2 | -6/+15 | |
2018-09-05 | renderer_opengl: Implement a buffer cache. | Markus Wick | 5 | -86/+182 | |
The idea of this cache is to avoid redundant uploads. So we are going to cache the uploaded buffers within the stream_buffer and just reuse the old pointers. The next step is to implement a VBO cache on GPU memory, but for now, I want to check the overhead of the cache management. Fetching the buffer over PCI-E should be quite fast. | |||||
2018-09-04 | bktr: Fix bucket overlap error | Zach Hilman | 8 | -9/+11 | |
2018-09-04 | drd: Parse title ID from program metadata | Zach Hilman | 2 | -4/+29 | |
2018-09-04 | patch_manager: Centralize Control-type NCA parsing | Zach Hilman | 6 | -80/+89 | |
2018-09-04 | nsp: Fix error masking issue with XCI files | Zach Hilman | 3 | -6/+13 | |
Now display correct error instead of catch-all MissingProgramNCA | |||||
2018-09-04 | game_list: Fix version display on non-NAND titles | Zach Hilman | 4 | -30/+52 | |
2018-09-04 | bktr: Add logging on successful patch | Zach Hilman | 3 | -7/+24 | |
2018-09-04 | game_list: Use friendly game versions | Zach Hilman | 1 | -13/+32 | |
Mainly, from control.nacp metadata instead of cnmt metadata | |||||
2018-09-04 | bktr: Implement IVFC offset shifting | Zach Hilman | 8 | -8/+36 | |
Fixes base game read errors | |||||
2018-09-04 | bktr: Fix missing includes and optimize style | Zach Hilman | 12 | -103/+109 | |
2018-09-04 | main: Make game updates installable | Zach Hilman | 1 | -1/+5 | |
2018-09-04 | game_list: Display patch names and versions on list | Zach Hilman | 2 | -0/+27 | |
2018-09-04 | loader: Add BKTR-specific error messages and codes | Zach Hilman | 3 | -7/+28 | |
2018-09-04 | loader: Ignore patches on NRO and DRD | Zach Hilman | 4 | -0/+11 | |
2018-09-04 | patch_manager: Add usages of patches to ExeFS | Zach Hilman | 5 | -9/+41 | |
2018-09-04 | file_sys: Add class to manage game patches | Zach Hilman | 2 | -0/+132 | |
Right now only includes Updates, but should eventually contain all of the other patches we need. | |||||
2018-09-04 | file_sys: Add BKTR patching mechanism | Zach Hilman | 2 | -0/+352 | |
2018-09-04 | content_archive: Add BKTR header parsing to NCA | Zach Hilman | 2 | -19/+160 | |
2018-09-04 | registration: Add RegisteredCacheUnion | Zach Hilman | 4 | -0/+164 | |
Aggregates multiple caches into one interface | |||||
2018-09-04 | game_list: Use RegisteredCacheUnion for installed | Zach Hilman | 3 | -5/+3 | |
Reduces code | |||||
2018-09-04 | aes_util: Fix error involving reads of less than 0x10 | Zach Hilman | 1 | -0/+14 | |
Issues with block size are fixed by making all reads minimum length of 0x10 | |||||
2018-09-04 | gl_shader_cache: Use an u32 for the binding point cache. | Markus Wick | 4 | -15/+23 | |
The std::string generation with its malloc and free requirement was a noticeable overhead. Also switch to an ordered_map to avoid the std::hash call. As those maps usually have a size of two elements, the lookup time shall not matter. | |||||
2018-09-04 | main: Only show DRD deprecation warning once | Zach Hilman | 7 | -6/+19 | |
2018-09-04 | control_metadata: Use alternate language names if AmericanEnglish isn't available | Zach Hilman | 2 | -4/+17 | |
2018-09-04 | card_image: Add program title ID getter | Zach Hilman | 2 | -0/+6 | |
2018-09-04 | qt: Add deprecation warnings for DRD format | Zach Hilman | 1 | -0/+10 | |
2018-09-04 | registration: Fix NSP installation errors | Zach Hilman | 1 | -1/+1 | |
2018-09-04 | nsp: Comply with style and performance guidelines | Zach Hilman | 7 | -29/+48 | |
2018-09-04 | qt: Add UI support for NSP files | Zach Hilman | 3 | -2/+7 | |
2018-09-04 | registration: Add support for installing NSP files | Zach Hilman | 3 | -16/+34 | |
2018-09-04 | loader: Add AppLoader for NSP files | Zach Hilman | 2 | -0/+182 | |
2018-09-04 | card_image: Parse XCI secure partition with NSP | Zach Hilman | 4 | -11/+38 | |
Eliminated duplicate code and adds support for Rev1+ carts | |||||
2018-09-04 | file_sys: Add Nintendo Submission Package (NSP) | Zach Hilman | 2 | -0/+296 | |
2018-09-04 | drd: Load title ID from program metadata | Zach Hilman | 1 | -3/+1 | |
Previously only loaded from control metadata | |||||
2018-09-04 | loader: Add NSP file type and NSP-specific errors | Zach Hilman | 2 | -2/+14 | |
2018-09-04 | key_manager: Avoid autogeneration if key exists | Zach Hilman | 1 | -3/+13 | |
2018-09-04 | common/logging: Amend documentation comments | Lioncash | 2 | -6/+6 | |
Multi-line doc comments still need the '<' after the ///, otherwise it's treated as a regular comment and makes the original doc comment broken in viewers, IDEs, etc. While we're at it, also fix some typos in the comments. | |||||
2018-09-04 | common/logging/filter: Replace C-style case with C++ static_cast | Lioncash | 1 | -1/+1 | |
2018-09-04 | common/logging/filter: Make constructor explicit | Lioncash | 1 | -1/+1 | |
Implicit conversions aren't desirable here. | |||||
2018-09-04 | core: Use a raw pointer in GetGPUDebugContext. | Markus Wick | 2 | -3/+3 | |
This helper is called very often. The memory ownership shall not be transfered, so just return the raw pointer. | |||||
2018-09-04 | command_processor: Use std::array for bound_engines. | Markus Wick | 2 | -4/+4 | |
subchannel is a 3 bit field. So there must not be more than 8 bound engines. And using a hashmap for up to 8 values is a bit overpowered. | |||||
2018-09-04 | Update microprofile scopes. | Markus Wick | 4 | -5/+21 | |
Blame the subsystems which deserve the blame :) The updated list is not complete, just the ones I've spotted on random sampling the stack trace. | |||||
2018-09-04 | file_sys: Replace includes with forward declarations where applicable | Lioncash | 22 | -27/+64 | |
Cuts down on include dependencies, resulting in less files that need to be rebuilt when certain things are changed. | |||||
2018-09-04 | qt: Add message about not moving contents on dir change | Zach Hilman | 2 | -6/+23 | |
2018-09-04 | qt: Add UI options to change NAND/SD dirs | Zach Hilman | 3 | -0/+36 | |
2018-09-04 | settings: Save and load NAND/SD dirs from config | Zach Hilman | 3 | -0/+26 | |
2018-09-02 | gl_shader_decompiler: Use used_shaders member variable directly within GenerateDeclarations() | Lioncash | 1 | -1/+1 | |
Using the getter function intended for external code here makes an unnecessary copy of the already-accessible used_shaders vector. | |||||
2018-09-02 | vfs_real: Forward declare IOFile | Lioncash | 13 | -15/+45 | |
Eliminates the need to rebuild some source files if the file_util header ever changes. This also uncovered some indirect inclusions, which have also been fixed. | |||||
2018-09-02 | service: Migrate global named port map to the KernelCore class | Lioncash | 5 | -19/+51 | |
Now that we have a class representing the kernel in some capacity, we now have a place to put the named port map, so we move it over and get rid of another piece of global state within the core. | |||||
2018-09-02 | ssl: Move SSL class to cpp file | Lioncash | 2 | -37/+39 | |
This isn't required to be visible to anything outside of the main source file, and will eliminate needing to rebuild anything else including the header if the SSL class needs to be changed in the future. | |||||
2018-09-02 | filesystem: Move dir retrieval after path checking in DeleteFile() | Lioncash | 1 | -2/+5 | |
We don't need to do the lookup if the path is considered empty currently. | |||||
2018-09-01 | citra_qt: Display the unsupported GL extensions in the popup | fearlessTobi | 2 | -8/+10 | |
2018-09-01 | Removed saturate assert | David Marcec | 2 | -2/+0 | |
Unneeded as we already implement it | |||||
2018-09-01 | Removed saturate assert | David Marcec | 2 | -2/+0 | |
Saturate already implemented | |||||
2018-09-01 | Changed tab5980_0 default from 0 -> 1 | David Marcec | 1 | -2/+2 | |
2018-09-01 | Added FMUL asserts | David Marcec | 2 | -0/+15 | |
2018-09-01 | Added FFMA asserts | David Marcec | 2 | -0/+11 | |
2018-09-01 | Added assert for TEXS nodep | David Marcec | 2 | -0/+3 | |
2018-09-01 | Added better asserts to IPA, Renamed IPA modes to match mesa | David Marcec | 2 | -6/+13 | |
IpaMode is changed to IpaInterpMode IpaMode is suppose to be 2 bits not 3 Added IpaSampleMode Added Saturate Renamed modes based on https://github.com/mesa3d/mesa/blob/d27c7918916cdc8092959124955f887592e37d72/src/gallium/drivers/nouveau/codegen/nv50_ir_emit_gm107.cpp#L2530 | |||||
2018-09-01 | maxwell_3d: Use CoreTiming for query timestamp | Zach Hilman | 1 | -2/+3 | |
2018-09-01 | filesystem: Implement OpenReadOnlySaveDataFilesystem | Zach Hilman | 2 | -1/+7 | |
2018-09-01 | filesystem: Add OpenFileSystemWithPatch | Zach Hilman | 2 | -1/+23 | |
2018-08-31 | core/core: Replace includes with forward declarations where applicable | Lioncash | 29 | -66/+185 | |
The follow-up to e2457418dae19b889b2ad85255bb95d4cd0e4bff, which replaces most of the includes in the core header with forward declarations. This makes it so that if any of the headers the core header was previously including change, then no one will need to rebuild the bulk of the core, due to core.h being quite a prevalent inclusion. This should make turnaround for changes much faster for developers. | |||||
2018-08-31 | gl_rasterizer_cache: Use accurate framebuffer setting for accurate copies. | bunnei | 2 | -73/+54 | |
2018-08-31 | gl_rasterizer_cache: Also use reserve cache for RecreateSurface. | bunnei | 2 | -24/+18 | |
2018-08-31 | rasterizer_cache: Use boost::interval_map for a more accurate cache. | bunnei | 1 | -33/+45 | |
2018-08-31 | gl_renderer: Cache textures, framebuffers, and shaders based on CPU address. | bunnei | 11 | -138/+70 | |
2018-08-31 | gl_rasterizer: Fix issues with the rasterizer cache. | bunnei | 4 | -46/+57 | |
- Use a single cached page map. - Fix calculation of ending page. | |||||
2018-08-31 | Implement BC6H_UF16 & BC6H_SF16 (#1092) | greggameplayer | 3 | -31/+55 | |
* Implement BC6H_UF16 & BC6H_SF16 Require by ARMS * correct coding style * correct coding style part 2 | |||||
2018-08-31 | core: Make the main System class use the PImpl idiom | Lioncash | 5 | -279/+387 | |
core.h is kind of a massive header in terms what it includes within itself. It includes VFS utilities, kernel headers, file_sys header, ARM-related headers, etc. This means that changing anything in the headers included by core.h essentially requires you to rebuild almost all of core. Instead, we can modify the System class to use the PImpl idiom, which allows us to move all of those headers to the cpp file and forward declare the bulk of the types that would otherwise be included, reducing compile times. This change specifically only performs the PImpl portion. | |||||
2018-08-31 | Report correct shader size. | Markus Wick | 1 | -1/+1 | |
Seems like this was an oversee in regards to 1fd979f50a9f4c21fa8cafba7268d959e3076924 It changed GLShader::ProgramCode to a std::vector, so sizeof is wrong. | |||||
2018-08-31 | Added predicate comparison GreaterEqualWithNan | Hexagon12 | 2 | -3/+4 | |
2018-08-31 | gl_shader_decompiler: Implement POPC (#1203) | Laku | 2 | -0/+19 | |
* Implement POPC * implement invert | |||||
2018-08-29 | Shaders: Implemented IADD3 | tech4me | 2 | -1/+84 | |
2018-08-29 | Show game compatibility within yuzu | fearlessTobi | 8 | -3/+174 | |
2018-08-29 | gl_shader_decompiler: Improve IPA for Pass mode with Position attribute. | bunnei | 2 | -1/+39 | |
2018-08-29 | kernel: Eliminate kernel global state | Lioncash | 54 | -442/+671 | |
As means to pave the way for getting rid of global state within core, This eliminates kernel global state by removing all globals. Instead this introduces a KernelCore class which acts as a kernel instance. This instance lives in the System class, which keeps its lifetime contained to the lifetime of the System class. This also forces the kernel types to actually interact with the main kernel instance itself instead of having transient kernel state placed all over several translation units, keeping everything together. It also has a nice consequence of making dependencies much more explicit. This also makes our initialization a tad bit more correct. Previously we were creating a kernel process before the actual kernel was initialized, which doesn't really make much sense. The KernelCore class itself follows the PImpl idiom, which allows keeping all the implementation details sealed away from everything else, which forces the use of the exposed API and allows us to avoid any unnecessary inclusions within the main kernel header. | |||||
2018-08-28 | gl_shader_cache: Remove unused program_code vector in GetShaderAddress() | Lioncash | 1 | -2/+1 | |
Given std::vector is a type with a non-trivial destructor, this variable cannot be optimized away by the compiler, even if unused. Because of that, something that was intended to be fairly lightweight, was actually allocating 32KB and deallocating it at the end of the function. | |||||
2018-08-28 | gpu: Make memory_manager private | Lioncash | 7 | -26/+40 | |
Makes the class interface consistent and provides accessors for obtaining a reference to the memory manager instance. Given we also return references, this makes our more flimsy uses of const apparent, given const doesn't propagate through pointers in the way one would typically expect. This makes our mutable state more apparent in some places. | |||||
2018-08-28 | gl_rasterizer: Remove unused variables | Lioncash | 1 | -2/+0 | |
2018-08-28 | hle/result: Make ResultVal's move constructor as noexcept | Lioncash | 1 | -1/+1 | |
Many containers within the standard library provide different behaviors based on whether or not a move constructor/assignment operator can be guaranteed not to throw or not. Notably, implementations will generally use std::move_if_noexcept (or an internal implementation of it) to provide strong exception guarantees. If a move constructor potentially throws (in other words, is not noexcept), then certain behaviors will create copies, rather than moving the values. For example, consider std::vector. When a std::vector calls resize(), there are two ways the elements can be relocated to the new block of memory (if a reallocation happens), by copy, or by moving the existing elements into the new block of memory. If a type does not have a guarantee that it will not throw in the move constructor, a copy will happen. However, if it can be guaranteed that the move constructor won't throw, then the elements will be moved. This just allows ResultVal to be moved instead of copied all the time if ever used in conjunction with containers for whatever reason. | |||||
2018-08-28 | Fix two stupid errors made in #1141 | fearlessTobi | 2 | -1/+2 | |
2018-08-28 | yuzu: Fix stick UI direction order | fearlessTobi | 1 | -2/+2 | |
2018-08-28 | renderer_opengl: Implement a new shader cache. | bunnei | 9 | -285/+250 | |
2018-08-28 | gl_rasterizer_cache: Update to use RasterizerCache base class. | bunnei | 3 | -132/+20 | |
2018-08-28 | video_core: Add RasterizerCache class for common cache management code. | bunnei | 2 | -0/+117 | |
2018-08-27 | vfs_real: Remove unused variable in CreateDirectoryRelative() | Lioncash | 1 | -1/+0 | |
2018-08-27 | registered_cache: Get rid of variable shadowing in ProcessFiles() | Lioncash | 1 | -3/+3 | |
Prevents compiler warnings. | |||||
2018-08-26 | set: Fixed GetAvailableLanguageCodes() to follow the max_entries | tech4me | 2 | -8/+45 | |
Rightnow, in games use GetAvailableLanguageCodes(), there is a WriteBuffer() with size larger than the buffer_size. (Core Critical core\hle\kernel\hle_ipc.cpp:WriteBuffer:296: size (0000000000000088) is greater than buffer_size (0000000000000078)) 0x88 = 17(languages) * 8 0x78 = 15(languages) * 8 GetAvailableLanguageCodes() can only support 15 languages. After firmware 4.0.0 there are 17 supported language instead of 15, to enable this GetAvailableLanguageCodes2() need to be used. So GetAvailableLanguageCodes() will be caped at 15 languages. Reference: http://switchbrew.org/index.php/Settings_services | |||||
2018-08-25 | kernel/error: Amend error code for ERR_MAX_CONNECTIONS_REACHED | Lioncash | 1 | -2/+4 | |
We can make this error code an alias of the resource limit exceeded error code, allowing us to get rid of the lingering 3DS error code of the same type. | |||||
2018-08-25 | kernel/error: Amend error code for ERR_PORT_NAME_TOO_LONG | Lioncash | 1 | -2/+1 | |
We can treat this as an alias of TooLarge for documentation purposes. This also lets us get rid of another lingering 3DS-related error code. | |||||
2018-08-25 | kernel/error: Add error code for the handle table being full | Lioncash | 3 | -4/+4 | |
This replaces the lingering 3DS constant with the proper one, and utilizes it within HandleTable's Create() member function. | |||||
2018-08-25 | kernel/error: Add error code for invalid memory permissions | Lioncash | 2 | -3/+4 | |
2018-08-25 | kernel/error: Correct kernel error code for invalid combination | Lioncash | 1 | -1/+2 | |
2018-08-25 | svc: Return process title ID if queried in GetInfo() | Lioncash | 1 | -2/+1 | |
We already have the variable itself set up to perform this task, so we can just return its value from the currently executing process instead of always stubbing it to zero. | |||||
2018-08-25 | file_sys/crypto: Fix missing/unnecessary includes | Zach Hilman | 9 | -5/+10 | |
2018-08-25 | core: Namespace all code in the arm subdirectory under the Core namespace | Lioncash | 13 | -12/+42 | |
Gets all of these types and interfaces out of the global namespace. | |||||
2018-08-25 | debug_utils: Remove unused includes | Lioncash | 5 | -24/+4 | |
Quite a bit of these aren't necessary directly within the debug_utils header and can be removed or included where actually necessary. | |||||
2018-08-25 | debug_utils: Make BreakpointObserver class' constructor explicit | Lioncash | 1 | -1/+1 | |
Avoids implicit conversions. | |||||
2018-08-25 | debug_utils: Initialize active_breakpoint member of DebugContext | Lioncash | 1 | -2/+2 | |
Ensures that all class members are initialized. | |||||
2018-08-25 | maxwell3d: Move FinishedPrimitiveBatch event after AcceleratedDrawBatch() | Lioncash | 1 | -4/+4 | |
The start and finish events should likely not be right after one another like this, otherwise the batch will appear to complete immediately | |||||
2018-08-24 | core: Remove always true conditionals in Load() | Lioncash | 1 | -7/+4 | |
These conditions are always true, since the outer conditional already checks for these conditions. | |||||
2018-08-24 | file_util: Correct return value in early exit of ReadFileToString() | Lioncash | 1 | -1/+1 | |
While still essentially being zero, we should be returning a numeric value here, not a boolean typed value. | |||||
2018-08-24 | fix SEL_IMM bitstring | Laku | 1 | -1/+1 | |
2018-08-24 | hid: Move core include to cpp file | Lioncash | 2 | -1/+4 | |
This isn't required to be in the header. Instead, directly include what this header needs and move it to the cpp file where it belongs. | |||||
2018-08-24 | gl_rasterizer: Correct assertion condition in SyncLogicOpState() | Lioncash | 1 | -1/+2 | |
Previously the assert would always be hit, since it was the equivalent of: array == nullptr, which is never true. | |||||
2018-08-24 | filesystem: Fix typo in log message | Lioncash | 1 | -1/+1 | |
2018-08-24 | Port #4013 from Citra: "Init logging sooner so we dont miss some logs on startup" (#1142) | Tobias | 1 | -11/+11 | |
* Port #4013 from Citra: "Init logging sooner so we dont miss some logs on startup" * Fix compilation | |||||
2018-08-24 | xci: Ignore NCA files with updates in secure | Zach Hilman | 1 | -0/+3 | |
2018-08-24 | content_archive: Add update title detection | Zach Hilman | 2 | -0/+11 | |
This is needed because the title IDs of update NCAs will not use the update title ID. The only sure way to tell is to look for a partition with BKTR crypto. | |||||
2018-08-24 | Added GetBootMode (#1107) | David | 4 | -3/+25 | |
* Added GetBootMode Used by homebrew * Added enum for GetBootMode | |||||
2018-08-23 | Shaders: Added decodings for IADD3 instructions | tech4me | 1 | -0/+6 | |
2018-08-23 | hex_util: Replace logic_errors with LOG_CRITICAL | Zach Hilman | 1 | -5/+17 | |
Makes it so malformed hex strings do not crash the entire program. | |||||
2018-08-23 | qt: Add filename and title id to window title while running | Zach Hilman | 2 | -0/+18 | |
2018-08-23 | Addressed plu TTF changes | David Marcec | 1 | -6/+7 | |
2018-08-23 | key_manager: Eliminate indexed for loop | Zach Hilman | 1 | -6/+13 | |
2018-08-23 | key_manager: Create keys dir if it dosen't exist | Zach Hilman | 2 | -0/+2 | |
On call to WriteKeyToFile, so that the autogenerated file can be written. | |||||
2018-08-23 | file_sys: Cut down on includes and copies | Zach Hilman | 7 | -19/+30 | |
2018-08-23 | crypto: Eliminate magic constants | Zach Hilman | 4 | -32/+38 | |
2018-08-23 | key_manager: Add support for autogenerated keys | Zach Hilman | 2 | -3/+45 | |
Stored in a separate file than manual keys. | |||||
2018-08-23 | key_manager: Add support for KEK and SD seed derivation | Zach Hilman | 2 | -5/+135 | |
2018-08-23 | key_manager: Switch to boost flat_map for keys | Zach Hilman | 2 | -32/+14 | |
Should make key gets marginally faster. | |||||
2018-08-23 | game_list: Add SD registration loading to game list | Zach Hilman | 2 | -12/+12 | |
2018-08-23 | file_sys: Implement NAX containers | Zach Hilman | 3 | -0/+238 | |
2018-08-23 | registration: Add GetEntryUnparsed methods | Zach Hilman | 2 | -0/+15 | |
Returns the file before calling parser on it. | |||||
2018-08-23 | sdmc_factory: Add SDMC RegisteredCache getter | Zach Hilman | 2 | -1/+14 | |
2018-08-23 | qt: Make default row data title name and title id | Zach Hilman | 1 | -2/+2 | |
Helps with installed games by making the title not a hexadecimal id string, instead the name. | |||||
2018-08-23 | vfs: Add GetOrCreateDirectoryRelative method | Zach Hilman | 3 | -9/+13 | |
2018-08-23 | filesystem: Add CreateFactories methods to fs | Zach Hilman | 3 | -10/+12 | |
Allows frontend to create registration caches for use before a game has booted. | |||||
2018-08-23 | filesystem: Add logging to registration getters | Zach Hilman | 1 | -4/+25 | |
2018-08-23 | loader: Add new NAX-specific errors and messages | Zach Hilman | 2 | -1/+27 | |
2018-08-23 | nax: Add AppLoader_NAX and update loader to support it | Zach Hilman | 4 | -2/+121 | |
2018-08-23 | xts_encryption_layer: Implement XTSEncryptionLayer | Zach Hilman | 3 | -1/+81 | |
2018-08-23 | aes_util: Make XTSTranscode stricter about sizes | Zach Hilman | 1 | -5/+2 | |
XTS with Nintendo Tweak will fail mysteriously if the sector size is not 0x4000. Upgrade the critical log to an assert to prevent undefined behavior. | |||||
2018-08-23 | ctr_encryption_layer: Fix bug when transcoding small data | Zach Hilman | 1 | -5/+3 | |
Fixes a bug where data lengths of less than size 0x10 will fail or have misleading return values. | |||||
2018-08-23 | xci: Fix error masking issue | Zach Hilman | 3 | -5/+17 | |
Prevents NCA-related errors from being masked into MissingProgramNCA or MissingKeyFile | |||||
2018-08-23 | gl_rasterizer_cache: Blit when possible on RecreateSurface. | bunnei | 1 | -5/+12 | |
2018-08-23 | gl_rasterizer_cache: Reserve surfaces that have already been created for later use. | bunnei | 2 | -3/+61 | |
2018-08-23 | gl_rasterizer_cache: Remove assert for RecreateSurface type. | bunnei | 1 | -1/+0 | |
2018-08-23 | gl_rasterizer_cache: Implement compressed texture copies. | bunnei | 1 | -8/+18 | |
2018-08-23 | gl_rasterizer: Implement stencil test. | bunnei | 3 | -4/+58 | |
- Used by Splatoon 2. | |||||
2018-08-23 | gl_rasterizer: Implement partial color clear and stencil clear. | bunnei | 1 | -12/+42 | |
2018-08-23 | maxwell_3d: Update to include additional stencil registers. | bunnei | 1 | -20/+50 | |
2018-08-23 | gl_state: Update to handle stencil front/back face separately. | bunnei | 2 | -33/+38 | |
2018-08-23 | Added SharedFonts loading via TTF | David Marcec | 1 | -5/+50 | |
By having the following TTF files in your yuzu sysdata directory. You can load sharedfonts via TTF files. FontStandard.ttf FontChineseSimplified.ttf FontExtendedChineseSimplified.ttf FontChineseTraditional.ttf FontKorean.ttf FontNintendoExtended.ttf FontNintendoExtended2.ttf | |||||
2018-08-23 | Swap "Plus" with "Minus" on the controller GUI (#1150) | literalmente-game | 1 | -8/+8 | |
* Swap "Plus" with "Minus" on the controller GUI Major fix /s | |||||
2018-08-22 | gl_shader_gen: Make ShaderSetup's constructor explicit | Lioncash | 1 | -1/+1 | |
Prevents implicit conversions. | |||||
2018-08-22 | gl_shader_gen: Use a std::vector to represent program code instead of std::array | Lioncash | 2 | -11/+16 | |
While convenient as a std::array, it's also quite a large set of data as well (32KB). It being an array also means data cannot be std::moved. Any situation where the code is being set or relocated means that a full copy of that 32KB data must be done. If we use a std::vector we do need to allocate on the heap, however, it does allow us to std::move the data we have within the std::vector into another std::vector instance, eliminating the need to always copy the program data (as std::move in this case would just transfer the pointers and bare necessities over to the new vector instance). | |||||
2018-08-22 | more fixes | Laku | 1 | -6/+7 | |
2018-08-22 | fixes | Laku | 1 | -6/+12 | |
2018-08-22 | renderer_opengl: Namespace OpenGL code | Lioncash | 21 | -23/+70 | |
Namespaces all OpenGL code under the OpenGL namespace. Prevents polluting the global namespace and allows clear distinction between other renderers' code in the future. | |||||
2018-08-22 | remove debug logging | Laku | 1 | -2/+0 | |
2018-08-22 | implement lop3 | Laku | 2 | -0/+55 | |
2018-08-22 | config: Fixed icon size get set to 0 | tech4me | 1 | -1/+1 | |
2018-08-22 | maxwell_to_gl: Implement PrimitiveTopology::Lines | OatmealDome | 1 | -0/+2 | |
Used by Splatoon 2's debug menu. | |||||
2018-08-22 | Added missing include for pl:u | David Marcec | 1 | -0/+1 | |
Should fix any compile errors | |||||
2018-08-22 | PL:U Added BFTTF loading(Loading from System NAND dumps) (#1088) | David | 1 | -25/+140 | |
* Added bfttf loading We can now load system bfttf fonts from system archives AND shared memory dumps. This allows people who have installed their system nand dumps to yuzu to automatically get shared font support. We also now don't hard code the offsets or the sizes of the shared fonts and it's all calculated for us now. * Addressed plu fixups * Style changes for plu * Fixed logic error for plu and added more error checks. | |||||
2018-08-22 | Revert "Shader: Use the right sampler type in the TEX, TEXS and TLDS instructions." | bunnei | 2 | -153/+31 | |
- This reverts commit 3ef4b3d4b445960576f10d1ba6521580d03e3da8. - This commit had broken a lot of games. We really should do a full implementation of this in one change. | |||||
2018-08-21 | shader_bytecode: Parenthesize conditional expression within GetTextureType() | Lioncash | 1 | -1/+1 | |
Resolves a -Wlogical-op-parentheses warning. | |||||
2018-08-21 | vfs: Replace mode.h include with forward declarations where applicable | Lioncash | 5 | -4/+7 | |
Avoids the need to rebuild these source files if the mode header changes. | |||||
2018-08-21 | audio_core/filter: Add explicit cast to assignment in Process() | Lioncash | 1 | -1/+1 | |
Previously this would cause warnings about implicit conversions to s16 from a double | |||||
2018-08-21 | logging/text_formatter: Use empty braces for initializing CONSOLE_SCREEN_BUFFER_INFO instance | Lioncash | 1 | -1/+1 | |
The previous form of initializing done here is a C-ism, an empty set of braces is sufficient for initializing (and doesn't potentially cause missing brace warnings, given the first member of the struct is a COORD struct). | |||||
2018-08-21 | am: Utilize std::array within PopLaunchParameter() | Lioncash | 1 | -3/+4 | |
Gets rid of the potential for C array-to-pointer decay, and also makes pointer arithmetic to get the end of the copy range unnecessary. We can just use std::array's begin() and end() member functions. | |||||
2018-08-21 | perf_stats: Change MAX_LAG_TIME_US to an appropriate value | MerryMage | 1 | -1/+1 | |
25us is far too small, and would result in std::this_thread::sleep_for being called with this as a maximum value. This means that a guest application that produces frames instantly would only be limited to 40 kHz. 25ms is a more appropriate value, as it allows for a 60 Hz refresh rate while providing enough slack in the negative region. | |||||
2018-08-21 | sdmc_factory: Remove unnecessary core include | Lioncash | 2 | -1/+1 | |
This doesn't require the central core header to be included, it just needs the vfs headers. | |||||
2018-08-21 | Port #3902 from Citra: "Add restart hotkey & menu option" | fearlessTobi | 2 | -0/+18 | |
2018-08-21 | Port #4056 from Citra: "Add Clear Recent Files menu action" | fearlessTobi | 2 | -0/+14 | |
2018-08-21 | bit_field: Convert ToBool() into explicit operator bool | Lioncash | 1 | -2/+1 | |
Gets rid of a TODO that is long overdue. | |||||
2018-08-21 | qt/main: Port part of citra(#3411), open savedata works | tech4me | 6 | -11/+45 | |
2018-08-21 | renderer_opengl: Use LOG_DEBUG for GL_DEBUG_SEVERITY_NOTIFICATION and GL_DEBUG_SEVERITY_LOW logs | Lioncash | 1 | -1/+1 | |
LOG_TRACE is only enabled on debug builds which can be quite slow when trying to debug graphics issues. Instead we can log the messages to the debug log, which is available on both release and debug builds. | |||||
2018-08-21 | service/filesystem: Use forward declarations where applicable | Lioncash | 9 | -5/+28 | |
Avoids the need to rebuild multiple source files if the filesystem code headers change. This also gets rid of a few instances of indirect inclusions being relied upon | |||||
2018-08-21 | gl_stream_buffer: Add missing header guard | Lioncash | 1 | -0/+2 | |
Prevents potential compilation errors from occuring due to multiple inclusions | |||||
2018-08-21 | Shaders: Implement depth writing in fragment shaders. | Subv | 1 | -1/+6 | |
We'll write <last color output reg + 2> to gl_FragDepth. | |||||
2018-08-21 | shader_bytecode: Replace some UNIMPLEMENTED logs. | bunnei | 1 | -2/+6 | |
2018-08-21 | gl_shader_decompiler: Implement Texture3D for TEXS. | bunnei | 1 | -0/+7 | |
2018-08-21 | gl_shader_decompiler: Implement TextureCube for TEX. | bunnei | 1 | -0/+8 | |
2018-08-21 | Shaders: Fixed the coords in TEX with Texture2D. | Subv | 1 | -1/+1 | |
The X and Y coordinates should be in gpr8 and gpr8+1, respectively. This fixes the cutscene rendering in Sonic Mania. | |||||
2018-08-21 | Shaders: Log and crash when using an unimplemented texture type in a texture sampling instruction. | Subv | 1 | -5/+14 | |
2018-08-21 | romfs_factory: Remove unnecessary includes and use forward declarations where applicable | Lioncash | 3 | -3/+12 | |
Avoids the need to rebuild whatever includes the romfs factory header if the loader header ever changes. We also don't need to include the main core header. We can instead include the headers we specifically need. | |||||
2018-08-21 | telemetry_session: Don't allocate std::string instances for program lifetime in GetTelemetryId() and RegenerateTelemetryId() | Lioncash | 1 | -4/+4 | |
Given these functions aren't intended to be used frequently, there's no need to keep the std::string instances allocated for the whole lifetime of the program. It's just a waste of memory. | |||||
2018-08-21 | acc: Replace profile_manager include with a forward declaration | Lioncash | 2 | -2/+6 | |
This is only used in a shared_ptr, so we can forward declare it. | |||||
2018-08-21 | acc: Simplify WriteBuffer call within LoadImage() | Lioncash | 1 | -3/+3 | |
We have an overload of WriteBuffer that accepts containers that satisfy the ContiguousContainer concept, which std::array does, so we only need to pass in the array itself. | |||||
2018-08-21 | acc: Correct IProfile's constructor initializer list order | Lioncash | 1 | -1/+1 | |
Arranges them in the order the members would be initialized | |||||
2018-08-21 | acc: Remove unused DEFAULT_USER_ID | Lioncash | 1 | -3/+0 | |
This is no longer used, so it can be removed. | |||||
2018-08-21 | profile_manager: Use INVALID_UUID in the initializer of last_opened_user | Lioncash | 1 | -1/+1 | |
Makes it a little bit more self-documenting. | |||||
2018-08-21 | profile_manager: Remove unnecessary memcpy in GetProfileBaseAndData() | Lioncash | 1 | -1/+1 | |
Given the source and destination types are the same std::array type, we can simply use regular assignment to perform the same behavior. | |||||
2018-08-21 | profile_manager: Use type aliases for username data, profile data, and user arrays | Lioncash | 2 | -19/+22 | |
Avoids the need to repeatedly specify the whole array type in multiple places. | |||||
2018-08-21 | profile_manager: Take ProfileInfo by const reference where applicable | Lioncash | 2 | -8/+8 | |
ProfileInfo is quite a large struct in terms of data, and we don't need to perform a copy in these instances, so we can just pass constant references instead. | |||||
2018-08-21 | profile_manager: Make array parameter to CreateNewUser a const reference | Lioncash | 2 | -2/+2 | |
This doesn't modify the passed in array, so this can be a const reference. | |||||
2018-08-21 | profile_manager: Remove unnecessary static | Lioncash | 1 | -1/+1 | |
This can just be constexpr like the others | |||||
2018-08-21 | profile_manager: Simplify UUID's two param constructor, operator==, and operator bool | Lioncash | 1 | -6/+4 | |
We can use the constructor initializer list and just compare the contained u128's together instead of comparing each element individually. Ditto for comparing against an invalid UUID. | |||||
2018-08-21 | profile_manager: Move UUID generation function to the cpp file | Lioncash | 2 | -10/+12 | |
This avoids needing to dump the contents of <random> into other files that include the profile manager header. | |||||
2018-08-21 | GPU: Implemented the logic op functionality of the GPU. | Subv | 3 | -0/+61 | |
This will ASSERT if blending is enabled at the same time as logic ops. | |||||
2018-08-21 | GLState: Allow enabling/disabling GL_COLOR_LOGIC_OP independently from blending. | Subv | 2 | -6/+19 | |
2018-08-21 | rasterizer_interface: Remove ScreenInfo from AccelerateDraw()'s signature | Lioncash | 5 | -17/+14 | |
This is an OpenGL renderer-specific data type. Given that, this type shouldn't be used within the base interface for the rasterizer. Instead, we can pass this information to the rasterizer via reference. | |||||
2018-08-21 | GPU: Added registers for the logicop functionality. | Subv | 1 | -1/+28 | |
2018-08-21 | renderer_base: Make creation of the rasterizer, the responsibility of the renderers themselves | Lioncash | 4 | -14/+12 | |
Given we use a base-class type within the renderer for the rasterizer (RasterizerInterface), we want to allow renderers to perform more complex initialization if they need to do such a thing. This makes it important to reserve type information. Given the OpenGL renderer is quite simple settings-wise, this is just a simple shuffling of the initialization code. For something like Vulkan however this might involve doing something like: // Initialize and call rasterizer-specific function that requires // the full type of the instance created. auto raster = std::make_unique<VulkanRasterizer>(some, params); raster->CallSomeVulkanRasterizerSpecificFunction(); // Assign to base class variable rasterizer = std::move(raster) | |||||
2018-08-21 | Port #3353 from Citra | fearlessTobi | 10 | -25/+94 | |
2018-08-21 | Shaders: Write all the enabled color outputs when a fragment shader exits. | Subv | 2 | -6/+45 | |
We were only writing to the first render target before. Note that this is only the GLSL side of the implementation, supporting multiple render targets requires more changes in the OpenGL renderer. Dual Source blending is not implemented and stuff that uses it might not work at all. | |||||
2018-08-20 | registration: Add Data_Unknown5 NCAContentType | Zach Hilman | 3 | -2/+3 | |
2018-08-20 | profile_manager: Remove unnecessary std::move in AddToProfiles() and CreateNewUser() | Lioncash | 1 | -2/+2 | |
Moving a const reference isn't possible, so this just results in a copy (and given ProfileInfo is composed of trivial types and aggregates, a move wouldn't really do anything). | |||||
2018-08-20 | Rasterizer: Reinterpret the raw texture bytes instead of blitting (and thus doing format conversion) to a new texture when a game requests an old texture address with a different format. | Subv | 1 | -3/+49 | |
2018-08-20 | Rasterizer: Don't attempt to copy over the old texture's data when doing a format reinterpretation if we're only going to clear the framebuffer. | Subv | 4 | -13/+21 | |
2018-08-20 | Implemented RGBA8_UINT | David Marcec | 4 | -45/+58 | |
Needed by kirby | |||||
2018-08-20 | game_list: Avoid uninitialized variables when retrieving program ID | Lioncash | 1 | -2/+2 | |
Avoids potentially leaving this variable uninitialized based off the loader failing to retrieve the ID value. | |||||
2018-08-20 | Added CheckFreeCommunicationPermission | David Marcec | 1 | -1/+8 | |
This fixes save files not loading in splatoon 2 | |||||
2018-08-20 | Shaders/TEXS: Fixed the component mask in the TEXS instruction. | Subv | 1 | -18/+18 | |
Previously we could end up with a TEXS that didn't write any outputs, this was wrong. | |||||
2018-08-19 | Shaders/TEXS: Fixed the component mask in the TEXS instruction. | Subv | 1 | -6/+11 | |
Previously we could end up with a TEXS that didn't write any outputs, this was wrong. | |||||
2018-08-19 | Shader: Implemented the TLD4 and TLD4S opcodes using GLSL's textureGather. | Subv | 1 | -0/+51 | |
It is unknown how TLD4S determines the sampler type, more research is needed. | |||||
2018-08-19 | Shader: Use the right sampler type in the TEX, TEXS and TLDS instructions. | Subv | 2 | -29/+127 | |
Different sampler types have their parameters in different registers. | |||||
2018-08-19 | Shader: Added bitfields for the texture type of the various sampling instructions. | Subv | 1 | -1/+65 | |
2018-08-19 | Shaders: Added decodings for TLD4 and TLD4S | Subv | 1 | -3/+7 | |
2018-08-19 | Shaders: Added decodings for the LDG and STG instructions. | Subv | 1 | -0/+4 | |
2018-08-19 | Shaders: Implemented the gl_FrontFacing input attribute (attr 63). | Subv | 2 | -0/+7 | |
2018-08-19 | Added check to see if ARB_texture_mirror_clamp_to_edge is supported | David Marcec | 2 | -0/+4 | |
2018-08-19 | filesystem: Add support for loading of system archives | Zach Hilman | 7 | -20/+99 | |
2018-08-18 | Shader: Remove an unneeded assert, the negate bit is implemented for conversion instructions. | Subv | 1 | -2/+0 | |
2018-08-18 | GLRasterizer: Implemented instanced vertex arrays. | Subv | 2 | -4/+30 | |
Before each draw call, for every enabled vertex array configured as instanced, we take the current instance id and divide it by its configured divisor, then we multiply that by the corresponding stride and increment the start address by the resulting amount. This way we can simulate the vertex array being incremented once per instance without actually using OpenGL's instancing functions. | |||||
2018-08-18 | Shader: Implemented the predicate and mode arguments of LOP. | Subv | 2 | -11/+39 | |
The mode can be used to set the predicate to true depending on the result of the logic operation. In some cases, this means discarding the result (writing it to register 0xFF (Zero)). This is used by Super Mario Odyssey. | |||||
2018-08-18 | Added WrapMode MirrorOnceClampToEdge | David Marcec | 1 | -0/+2 | |
Used by splatoon 2 | |||||
2018-08-18 | Shaders: Implemented a stack for the SSY/SYNC instructions. | Subv | 1 | -3/+36 | |
The SSY instruction pushes an address into the stack, and the SYNC instruction pops it. The current stack depth is 20, we should figure out if this is enough or not. | |||||
2018-08-18 | Shaders: Corrected the 'abs' and 'neg' bit usage in the float arithmetic instructions. | Subv | 2 | -16/+38 | |
We should definitely audit our shader generator for more errors like this. | |||||
2018-08-18 | Added predcondition GreaterThanWithNan | David Marcec | 2 | -5/+8 | |
2018-08-17 | Implement SetIdleTimeDetectionExtension & GetIdleTimeDetectionExtension (#1059) | greggameplayer | 2 | -2/+22 | |
* Used by Mario Tennis Aces | |||||
2018-08-17 | gl_rasterizer_cache: Remove asserts for supported blits. | bunnei | 1 | -2/+0 | |
2018-08-17 | renderer_opengl: Treat OpenGL errors as critical. | bunnei | 1 | -1/+1 | |
2018-08-16 | correct coding style | greggameplayer | 1 | -1/+1 | |
2018-08-16 | Implement GetDefaultDisplayResolutionChangeEvent | greggameplayer | 2 | -1/+13 | |
Require by Toki Tori and Toki Tori 2+ | |||||
2018-08-16 | qt/main: Unindent code in OnMenuInstallToNAND() | Lioncash | 1 | -70/+70 | |
We can change this into an early-return if the filename is empty. There's no need to include all of the code within the if statement. | |||||
2018-08-16 | qt/main: Make installation dialog text within OnMenuInstallToNAND() translatable | Lioncash | 1 | -14/+15 | |
This is user-facing text, so it should be marked as translatable by Qt. | |||||
2018-08-16 | qt/main: Get rid of compilation warnings | Lioncash | 1 | -4/+8 | |
Gets rid of truncation warnings about conversion to int. While we're at it, we can also de-hardcode the buffer size being used. | |||||
2018-08-16 | core: Delete System copy/move constructors and assignment operators | Lioncash | 1 | -0/+6 | |
Prevents potentially making copies or doing silly things by accident with the System instance, particularly given our current core is designed (unfortunately) around one instantiable instance. This will prevent the accidental case of: auto instance = System::Instance(); being compiled without warning when it's supposed to be: auto& instance = System::Instance(); | |||||
2018-08-16 | dynarmic: Update to 550d662 | MerryMage | 1 | -0/+3 | |
550d662 load_store_exclusive: Define s == t state to be Constraint_NONE 0b69381 A64/translate: Allow for unpredictable behaviour to be defined 6d236d4 system: Implement MRS CNTFRQ_EL0 6cbb6fb A32/testenv: Add missing headers 6729328 externals: Update xbyak to v5.67 1812bd2 Squashed 'externals/xbyak/' changes from 2794cde7..671fc805 9a95802 externals: Document subtrees 714a840 A64: Implement SQ{ADD, SUB}, and UQ{ADD, SUB}'s vector variants 8cab459 A64: Implement UQADD/UQSUB's scalar variants 18a8151 ir: Add opcodes for unsigned saturating add and subtract a5660ee x64/reg_alloc: Use type alias for array returned by GetArgumentInfo() 29489b5 ir/value: Use type alias CoprocessorInfo for std::array<u8, 8> e23ba26 status_register_access: Add support for bits 0 and 1 of mask to MSR 55190bd fuzz_with_unicorn: Split utility functions into fuzz_util 23b049d A32/translate/load_store: Correct detection of writeback 7ec9f15 A32/translate: Add TranslateSingleInstruction efeecb4 A32/ir_emitter: Bug fix: IREmitter::ExceptionRaised using incorrect opcode 08d1d19 A32/decoders: Split instruction list into include file 2d929cc tests: Refactor unicorn_emu to allow for A32 unicorn f672368 microinstruction: Improve assert messages 7ebff50 emit_x64_vector: EmitVectorNarrow16: AVX512 implementation edce230 emit_x64_vector: EmitVectorNarrow32: prefer pblendw to loading constant | |||||
2018-08-16 | common: Namespace hex_util.h/.cpp | Lioncash | 4 | -12/+22 | |
It's in the common code, so it should be under the Common namespace like everything else. | |||||
2018-08-16 | gl_rasterizer_cache: Treat Depth formats differently from DepthStencil. | bunnei | 2 | -16/+26 | |
2018-08-15 | Shader/Conversion: Implemented the negate bit in F2F and I2I instructions. | Subv | 1 | -4/+12 | |
2018-08-15 | Shader/I2F: Implemented the negate I2F_C instruction variant. | Subv | 1 | -7/+23 | |
2018-08-15 | Shader/F2I: Implemented the negate bit in the I2F instruction | Subv | 1 | -0/+4 | |
2018-08-15 | Shader/F2I: Implemented the F2I_C instruction variant. | Subv | 1 | -2/+10 | |
2018-08-15 | Shader/F2I: Implemented the negate bit in the F2I instruction. | Subv | 1 | -0/+4 | |
2018-08-15 | kernel/server_session: Add IsSession() member function | Lioncash | 3 | -3/+8 | |
Allows querying the inverse of IsDomain() to make things more readable. This will likely also be usable in the event of implementing ConvertDomainToSession(). | |||||
2018-08-15 | sm/controller: Correct return value of QueryPointerBufferSize | Lioncash | 1 | -1/+1 | |
This should be returning a u16 according to Switch Brew. | |||||
2018-08-15 | loader: Make ResultStatus directly compatible with fmt | Lioncash | 5 | -14/+18 | |
We can make the enum class type compatible with fmt by providing an overload of operator<<. While we're at it, perform proper bounds checking. If something exceeds the array, it should be a hard fail, because it's, without a doubt, a programmer error in this case. | |||||
2018-08-15 | loader/nca: Remove unnecessary includes and member variables | Lioncash | 2 | -20/+11 | |
2018-08-15 | loader/xci: Remove unnecessary includes and member variables | Lioncash | 2 | -15/+11 | |
Many of these aren't necessary and will cause this file to be required to be recompiled whenever any changes to those files are made, which lengthens compile times for no reason. This also removes an unused metadata variable from AppLoader_XCI | |||||
2018-08-15 | lm: Use LOG_DEBUG for printing out trace logs | Lioncash | 1 | -1/+1 | |
Using LOG_TRACE here isn't a good idea because LOG_TRACE is only enabled when yuzu is compiled in debug mode. Debug mode is also quite slow, and so we're potentially throwing away logging messages that can provide value when trying to boot games. | |||||
2018-08-15 | lm: Handle threads and modules within the logger | Lioncash | 1 | -1/+19 | |
The thread field serves to indicate which thread a log is related to and provides the length of the thread's name, so we can print that out, ditto for modules. Now we can know what threads are potentially spawning off logging messages (for example Lydie & Suelle bounces between MainThread and LoadingThread when initializing the game). | |||||
2018-08-15 | gl_rasterizer_cache: Cleanup some PixelFormat names and logging. | bunnei | 2 | -41/+71 | |
2018-08-15 | Rasterizer: Implemented instanced rendering. | Subv | 7 | -5/+28 | |
We keep track of the current instance and update an uniform in the shaders to let them know which instance they are. Instanced vertex arrays are not yet implemented. | |||||
2018-08-15 | gl_rasterizer_cache: Add RGBA16U to PixelFormatFromTextureFormat. | bunnei | 1 | -1/+9 | |
- Used by Breath of the Wild. | |||||
2018-08-15 | Implement Z16_UNORM in PixelFormatFromTextureFormat function | greggameplayer | 1 | -0/+2 | |
Require by Zelda Breath Of The Wild | |||||
2018-08-15 | loader: Remove address mapping remnants from citra | Lioncash | 6 | -17/+0 | |
These mappings are leftovers from citra and don't apply to the Switch. | |||||
2018-08-15 | kernel/svc: Log svcBreak parameters | Lioncash | 1 | -2/+5 | |
Given if we hit here all is lost, we should probably be logging the break reason code and associated information to distinguish between the causes. | |||||
2018-08-15 | gl_shader_decompiler: Several fixes for indirect constant buffer loads. | bunnei | 1 | -13/+22 | |
2018-08-15 | gl_rasterizer: Fix upload size for constant buffers. | bunnei | 1 | -3/+3 | |
2018-08-15 | maxwell_to_gl: Properly handle UnsignedInt/SignedInt sizes. | bunnei | 1 | -5/+20 | |
2018-08-15 | gl_rasterizer_cache: Implement G8R8S format. | bunnei | 2 | -34/+49 | |
- Used by Super Mario Odyssey. | |||||
2018-08-15 | emu_window: Ensure WindowConfig members are always initialized | Lioncash | 1 | -3/+3 | |
Previously we weren't always initializing all members of the struct. Prevents potentially wonky behavior from occurring. | |||||
2018-08-15 | common/telemetry: Migrate core-independent info gathering to common | Lioncash | 3 | -62/+84 | |
Previously core itself was the library containing the code to gather common information (build info, CPU info, and OS info), however all of this isn't core-dependent and can be moved to the common code and use the common interfaces. We can then just call those functions from the core instead. This will allow replacing our CPU detection with Xbyak's which has better detection facilities than ours. It also keeps more architecture-dependent code in common instead of core. | |||||
2018-08-15 | common/xbyak_abi: Mark defined functions in header as inline | Lioncash | 1 | -7/+7 | |
Avoids potential One Definition Rule violations when these are used in the future. | |||||
2018-08-15 | common/xbyak: Use nested namespace specifiers where applicable | Lioncash | 2 | -8/+4 | |
2018-08-15 | common: Remove unused old breakpoint source files | Lioncash | 3 | -141/+0 | |
These currently aren't used and contain commented out source code that corresponds to Dolphin's JIT. Given our CPU code is organized quite differently, we shouldn't be keeping this around (at the moment it just adds to compile times marginally). | |||||
2018-08-14 | logging/backend: Use const reference to refer to log filter | Lioncash | 1 | -2/+3 | |
The filter is returned via const reference, so this was making a pointless copy of the entire filter every time a message was being pushed into the logger instance. | |||||
2018-08-14 | Fix BC7U | greggameplayer | 1 | -1/+1 | |
2018-08-14 | mm_u: Forward all old variants of functions to the new ones | Lioncash | 1 | -5/+11 | |
Ensures both variants go through the same interface, and while we're at it, add Finalize to provide the inverse of Initialize for consistency. | |||||
2018-08-14 | mm_u: Move implementation class into the cpp file | Lioncash | 2 | -46/+46 | |
Now if changes are ever made to the behavior of the class, it doesn't involve rebuilding everything that includes the mm_u header. | |||||
2018-08-14 | audout_u: Correct IAudioOut initializer list order | Lioncash | 1 | -1/+1 | |
Orders elements in the precise order they'll be initialized. | |||||
2018-08-14 | renderer_opengl: Implement RenderTargetFormat::RGBA16_UNORM. | bunnei | 4 | -37/+48 | |
- Used by Breath of the Wild. | |||||
2018-08-13 | common/misc: use windows.h | Zhu PengFei | 1 | -1/+1 | |
linux-mingw does not really like this. | |||||
2018-08-13 | arm_dynarmic: Remove IsExecuting check from PrepareReschedule | MerryMage | 1 | -3/+1 | |
No longer required. HaltExecution is a no-op if it is not currently executing. | |||||
2018-08-13 | Implement RG32UI and R32UI | David Marcec | 4 | -7/+45 | |
Needed for xenoblade | |||||
2018-08-13 | Core::CoreTiming: add UnscheduleEventThreadsafe | B3n30 | 3 | -1/+12 | |
2018-08-13 | audio_renderer: samples_remaining counts frames, not samples | MerryMage | 1 | -1/+1 | |
2018-08-13 | audio_core: Interpolate | MerryMage | 5 | -0/+121 | |
2018-08-13 | audio_core: Implement low-pass filter | MerryMage | 3 | -2/+145 | |
2018-08-13 | maxwell_to_gl: Implement VertexAttribute::Size::Size_8. | bunnei | 1 | -0/+1 | |
- Used by Breath of the Wild. | |||||
2018-08-13 | kernel/object: Tighten object against data races | Lioncash | 2 | -8/+9 | |
Despite being covered by a global mutex, we should still ensure that the class handles its reference counts properly. This avoids potential shenanigans when it comes to data races. Given this is the root object that drives quite a bit of the kernel object hierarchy, ensuring we always have the correct behavior (and no races) is a good thing. | |||||
2018-08-13 | renderer_opengl: Implement RenderTargetFormat::RGBA16_UINT. | bunnei | 4 | -34/+45 | |
- Used by Breath of the Wild. | |||||
2018-08-13 | Registered missing channel devices | David Marcec | 1 | -0/+4 | |
2018-08-13 | Added missing channel devices | David Marcec | 5 | -0/+144 | |
2018-08-13 | maxwell_to_gl: Implement PrimitiveTopology::LineStrip. | bunnei | 1 | -0/+2 | |
- Used by Breath of the Wild. | |||||
2018-08-13 | renderer_opengl: Implement RenderTargetFormat::RG8_UNORM. | bunnei | 4 | -26/+61 | |
- Used by Breath of the Wild. | |||||
2018-08-13 | CPU/Timing: Use an approximated amortized amount of ticks when advancing timing. | Subv | 2 | -1/+11 | |
We divide the number of ticks to add by the number of cores (4) to obtain a more or less rough estimate of the actual number of ticks added. This assumes that all 4 cores are doing similar work. Previously we were adding ~4 times the number of ticks, thus making the games think that time was going way too fast. This lets us bypass certain hangs in some games like Breath of the Wild. We should modify our CoreTiming to support multiple cores (both running in a single thread, and in multiple host threads). | |||||
2018-08-13 | Kernel/SVC: Don't reschedule the current core when creating a new thread. | Subv | 1 | -1/+0 | |
The current core may have nothing to do with the core where the new thread was scheduled to run. In case it's the same core, then the following PrepareReshedule call will take care of that. | |||||
2018-08-13 | Core/HLE: Make the 'reschedule_pending' flag atomic. | Subv | 1 | -1/+1 | |
Another thread may write to this variable while the core in question is in the middle of checking for a reschedule request. | |||||
2018-08-13 | CPU/HLE: Lock the HLE mutex before performing a reschedule. | Subv | 1 | -0/+3 | |
Another thread might be in the middle of an SVC, thus altering the state of the schedulers. | |||||
2018-08-13 | Kernel/Threads: Lock the HLE mutex when executing the wakeup callback. | Subv | 1 | -0/+5 | |
Another thread might be in the middle of a reschedule, thus altering the state of the schedulers. | |||||
2018-08-13 | Kernel/Thread: Always use the threadsafe option when scheduling wakeups. | Subv | 2 | -4/+4 | |
WakeAfterDelay might be called from any host thread, so err on the side of caution and use the thread-safe CoreTiming::ScheduleEventThreadsafe. Note that CoreTiming is still far from thread-safe, there may be more things we have to work on for it to be up to par with what we want. | |||||
2018-08-13 | gl_shader_decompiler: Implement XMAD instruction. | bunnei | 2 | -4/+120 | |
2018-08-12 | Kernel/Mutex: Don't duplicate threads in the mutex waiter list. | Subv | 2 | -2/+22 | |
Exit from AddMutexWaiter early if the thread is already waiting for a mutex owned by the owner thread. This accounts for the possibility of a thread that is waiting on a condition variable being awakened twice in a row. Also added more validation asserts. This should fix one of the random crashes in Breath Of The Wild. | |||||
2018-08-12 | vfs: Make VfsFilesystem constructor explicit | Lioncash | 1 | -1/+1 | |
Makes it consistent with the other VFS interfaces and prevents implicit construction. | |||||
2018-08-12 | vfs: Make type hierarchy objects classes instead of structs | Lioncash | 4 | -10/+16 | |
struct should be used when the data type is very simple or otherwise has no invariants associated with it. Given these are used to form a hierarchy, class should be used instead. | |||||
2018-08-12 | registration: Various style and documentation improvements | Zach Hilman | 3 | -18/+22 | |
Fix logic in RealVfsFilesystem Create methods Remove magic numbers Fix regex errors | |||||
2018-08-12 | cubeb_sink: Protect queue with a mutex | MerryMage | 1 | -0/+6 | |
2018-08-12 | scheduler: Make HaveReadyThreads() a const member function | Lioncash | 2 | -2/+2 | |
This function doesn't modify instance state, so the const qualifier can be added to it. | |||||
2018-08-12 | thread_queue_list: Make contains() and get_first() const member functions | Lioncash | 1 | -4/+4 | |
These don't directly modify the contained data. | |||||
2018-08-12 | thread_queue_list: Convert typedef to a type alias | Lioncash | 1 | -1/+1 | |
2018-08-12 | gl_rasterizer: Use a shared helper to upload from CPU memory. | Markus Wick | 2 | -28/+33 | |
2018-08-12 | gl_state: Don't track constant buffer mappings. | Markus Wick | 3 | -41/+3 | |
2018-08-12 | gl_rasterizer: Use the stream buffer for constant buffers. | Markus Wick | 4 | -29/+32 | |
2018-08-12 | gl_rasterizer: Use the streaming buffer itself for the constant buffer. | Markus Wick | 2 | -33/+15 | |
Don't emut copies, especially not for data, which is used once. They just end in a huge GPU overhead. | |||||
2018-08-12 | gl_rasterizer: Use a helper for aligning the buffer. | Markus Wick | 2 | -15/+22 | |
2018-08-12 | Update the stream_buffer helper from Citra. | Markus Wick | 4 | -184/+98 | |
Please see https://github.com/citra-emu/citra/pull/3666 for more details. | |||||
2018-08-12 | GetAudioDeviceServiceWithRevisionInfo | David Marcec | 2 | -1/+13 | |
As we're not handling any anything about the revision data for GetAudioDeviceServiceWithRevisionInfo, it's currently marked as stubbed. However for games this shouldn't affect the result. Proper revision info would be more for homebrew. | |||||
2018-08-12 | hid: disable clang-format around tables | Lioncash | 1 | -4/+5 | |
Prevents clang-format from butchering them. | |||||
2018-08-12 | hid: Stub DisconnectNpad() | Lioncash | 1 | -1/+7 | |
This is required by ARMS. | |||||
2018-08-12 | vfs: Use sanitized paths within MoveFile() and MoveDirectory() | Lioncash | 1 | -10/+10 | |
Previously these were being unused (or partially unused). While we're at it, use better naming to make it visibly obvious which variant of the path is being used. | |||||
2018-08-12 | card_image: Use type aliases to shorten definitions | Lioncash | 2 | -6/+6 | |
We have the aliases, so we may as well use 'em. | |||||
2018-08-12 | card_image: Simplify return statement of GetSubdirectories() | Lioncash | 1 | -1/+1 | |
We don't need to write out the construction long-form, we can just let the language itself work it out off the return type. | |||||
2018-08-12 | gl_shader_decompiler: Fix SetOutputAttributeToRegister empty check. | bunnei | 1 | -2/+2 | |
2018-08-12 | Pushed the requested sample rate instead of our fixed sample rate | David Marcec | 2 | -5/+3 | |
2018-08-12 | made ResultStatus a u16 | David Marcec | 3 | -3/+3 | |
2018-08-12 | Added GetAudioRendererSampleRate, GetAudioRendererSampleCount & GetAudioRendererMixBufferCount | David Marcec | 3 | -6/+44 | |
GetAudioRendererSampleRate is set as a "STUB" as a game could check if the sample rate it sent and the sample rate it wants don't match. Just a thought of something which could happen so keeping it as stub for the mean time | |||||
2018-08-12 | gl_shader_decompiler: Fix GLSL compiler error with KIL instruction. | bunnei | 1 | -0/+8 | |
2018-08-12 | Stub UpdateUserPresence | David Marcec | 1 | -1/+8 | |
Needed for Retro City Rampage to go in game | |||||
2018-08-12 | Fixed invalid cast in loader | David Marcec | 1 | -1/+1 | |
GetMessageForResultStatus takes a u16, not a size_t. | |||||
2018-08-12 | registration: Add support for force overwrite of installed | Zach Hilman | 4 | -53/+106 | |
2018-08-12 | game_list: Split game list scans to multiple functions | Zach Hilman | 2 | -9/+16 | |
Avoids unnecessary rebuilds of control data on every layer of recursion in AddFstEntriesToGameList | |||||
2018-08-12 | vfs_real: Add CreateFullPath to Create* operations | Zach Hilman | 2 | -13/+6 | |
2018-08-12 | control_metadata: Remove unnecessary reference to base file | Zach Hilman | 2 | -2/+1 | |
2018-08-12 | romfs: Remove cyclic shared_ptr leak in romfs code | Zach Hilman | 3 | -8/+8 | |
2018-08-12 | registration: Update documentation and style | Zach Hilman | 5 | -42/+69 | |
2018-08-12 | nca_metadata: Remove unnecessary reference to base file | Zach Hilman | 2 | -3/+2 | |
2018-08-12 | bis_factory: Create NAND dirs if they don't exist | Zach Hilman | 1 | -2/+9 | |
2018-08-12 | qt: Use custom RawCopy with progress bar for installs | Zach Hilman | 1 | -2/+28 | |
2018-08-12 | registration: Take RawCopy function as parameter | Zach Hilman | 2 | -10/+15 | |
Instead of defaulting to VfsRawCopy | |||||
2018-08-12 | game_list: Populate control data from installed NAND | Zach Hilman | 2 | -31/+35 | |
2018-08-12 | registered_cache: Fix missing reading from yuzu_meta | Zach Hilman | 1 | -7/+16 | |
2018-08-12 | file_sys: Comply to style guidelines | Zach Hilman | 8 | -47/+60 | |
2018-08-12 | qt: Add 'Install to NAND' option to menu | Zach Hilman | 5 | -1/+99 | |
Prompts for title type on NCA files. | |||||
2018-08-12 | game_list: Modify game list to scan installed titles | Zach Hilman | 1 | -0/+45 | |
2018-08-12 | file_sys: Add RegisteredCache | Zach Hilman | 2 | -0/+543 | |
Manages NAND NCA get and install. | |||||
2018-08-12 | file_sys: Add support for parsing NCA metadata (CNMT) | Zach Hilman | 3 | -0/+238 | |
2018-08-12 | card_image: Add accessor for all NCAs in XCI | Zach Hilman | 2 | -0/+5 | |
2018-08-12 | vfs_real: Add CreateFullPath to CreateFile | Zach Hilman | 1 | -3/+6 | |
Fixes bugs with calling CreateFile when the immediate directory does not exist. | |||||
2018-08-12 | filesystem: Add Open and Register functions for BISFactory | Zach Hilman | 2 | -4/+23 | |
2018-08-12 | bis_factory: Add partial implementation of BISFactory | Zach Hilman | 2 | -0/+54 | |
Creates and stores RegisteredCaches for user and system NAND, as creation of a RegisteredCache is expensive. | |||||
2018-08-12 | loader: Join 0* files in directory if filename is 00 | Zach Hilman | 1 | -1/+33 | |
i.e. Load the concatenated 00+01 if 01 exists as well. Needed for split NAND NCAs. | |||||
2018-08-12 | loader: Recognize filename '00' as NCA | Zach Hilman | 1 | -0/+2 | |
Needed to avoid mismatch filetype warnings on split NAND NCAs | |||||
2018-08-12 | vfs: Add ConcatenatedVfsFile | Zach Hilman | 2 | -0/+134 | |
2018-08-12 | crypto: Remove hex utilities from key_manager | Zach Hilman | 2 | -36/+2 | |
Move to hex_util.h in common | |||||
2018-08-12 | file_util: Add getter for NAND registration directory | Zach Hilman | 2 | -0/+8 | |
2018-08-12 | common: Move hex string processing to separate file | Zach Hilman | 3 | -0/+64 | |
2018-08-12 | GPU/Maxwell3D: Implemented an alternative set of blend factors. | Subv | 2 | -0/+40 | |
These are used by nouveau and some games like SMO. | |||||
2018-08-12 | Implement R8_UINT RenderTargetFormat & PixelFormat (#1014) | greggameplayer | 4 | -55/+74 | |
- Used by Go Vacation | |||||
2018-08-12 | RasterizerGL: Ignore invalid/unset vertex attributes. | Subv | 2 | -1/+11 | |
This should make the es2gears example not crash anymore. | |||||
2018-08-12 | friend: Stub DeclareCloseOnlinePlaySession. | bunnei | 1 | -1/+10 | |
- Used by Splatoon 2. | |||||
2018-08-12 | friend: Fix CreateFriendService to return an IFriendService interface. | bunnei | 1 | -2/+86 | |
2018-08-12 | server_session: Provide more useful information and don't crash on bad IPC request. | bunnei | 1 | -0/+8 | |
2018-08-12 | gl_rasterizer: Silence implicit truncation warning in SetupShaders() | Lioncash | 1 | -1/+1 | |
Previously this would warn of truncating a std::size_t to a u32. This is safe because we'll obviously never have more than UINT32_MAX amount of uniform buffers. | |||||
2018-08-12 | core: Namespace EmuWindow | Lioncash | 14 | -22/+44 | |
Gets the class out of the global namespace. | |||||
2018-08-12 | gl_shader_decompiler: Improve handling of unknown input/output attributes. | bunnei | 2 | -10/+11 | |
2018-08-12 | gl_rasterizer: Implement render target format RG8_SNORM. | bunnei | 4 | -8/+18 | |
- Used by Super Mario Odyssey. | |||||
2018-08-12 | gl_rasterizer: Implement render target format RGBA8_SNORM. | bunnei | 4 | -64/+83 | |
- Used by Super Mario Odyssey. | |||||
2018-08-11 | GPU/Shader: Don't predicate instructions that don't have a predicate field (SSY). | Subv | 2 | -2/+13 | |
2018-08-11 | GPU/Shaders: Implemented SSY and SYNC as a way to modify control flow during shader execution. | Subv | 1 | -6/+25 | |
SSY sets the target label to jump to when the SYNC instruction is executed. | |||||
2018-08-11 | Implement R16S & R16UI & R16I RenderTargetFormats & PixelFormats and more (R16_UNORM needed by Fate Extella) (#848) | greggameplayer | 4 | -19/+92 | |
* Implement R16S & R16UI & R16I RenderTargetFormats & PixelFormats Do a separate function in order to get Bytes Per Pixel of DepthFormat Apply the new function in gpu.h delete unneeded white space * correct merging error | |||||
2018-08-11 | Better UUID randomness | David Marcec | 1 | -2/+7 | |
2018-08-11 | Removed un-needed count from ListOpenUsers and ListAllUsers | David Marcec | 1 | -4/+2 | |
2018-08-11 | Added better explanations in the profile manager | David Marcec | 2 | -1/+34 | |
2018-08-11 | Code cleanup for profile manager | David Marcec | 3 | -40/+47 | |
2018-08-11 | Removed const from ProfileBase Invalidate | David Marcec | 1 | -1/+1 | |
2018-08-11 | fixed invalid uuid bool operator | David Marcec | 1 | -1/+1 | |
2018-08-11 | Added GetOpenUserCount | David Marcec | 3 | -3/+14 | |
2018-08-11 | Removed all for loops from the profile manager | David Marcec | 1 | -9/+4 | |
2018-08-11 | Added missing ListAllUsers count | David Marcec | 1 | -1/+2 | |
2018-08-11 | If statement style change | David Marcec | 1 | -11/+19 | |
2018-08-11 | Second round of account changes | David Marcec | 3 | -18/+21 | |
2018-08-11 | First round of account changes | David Marcec | 3 | -49/+55 | |
2018-08-11 | Refactored profile manager sharing | David Marcec | 10 | -20/+28 | |
2018-08-11 | Added IsUserRegistrationRequestPermitted | David Marcec | 7 | -3/+19 | |
2018-08-11 | video_core; Get rid of global g_toggle_framelimit_enabled variable | Lioncash | 8 | -30/+44 | |
Instead, we make a struct for renderer settings and allow the renderer to update all of these settings, getting rid of the need for global-scoped variables. This also uncovered a few indirect inclusions for certain headers, which this commit also fixes. | |||||
2018-08-11 | renderer_base: Remove unused kFramebuffer enumeration | Lioncash | 1 | -3/+0 | |
This is entirely unused and can be removed. | |||||
2018-08-11 | video_core: Remove unused Renderer enumeration | Lioncash | 1 | -2/+0 | |
Currently we only have an OpenGL renderer, so this is unused in code (and occupies the Renderer identifier in the VideoCore namespace). | |||||
2018-08-11 | qt/game_list: Resolve truncation warning within GameListItemPath's constructor | Lioncash | 1 | -4/+4 | |
Silences a warning about truncating from size_t to u32 | |||||
2018-08-11 | gt/game_list: Use std::array in GameListItemPath's data() function | Lioncash | 1 | -7/+8 | |
We don't need to use a heap-allocated std::vector here, given we explicitly know the bounds. | |||||
2018-08-11 | qt/game_list: Remove redundant base class constructor from initializer list | Lioncash | 1 | -3/+1 | |
This is called automatically anyways. | |||||
2018-08-10 | maxwell_to_gl: Implement VertexAttribute::Size::Size_8_8. | bunnei | 1 | -0/+1 | |
- Used by Super Mario Odyssey. | |||||
2018-08-10 | maxwell_to_gl: Implement VertexAttribute::Size::Size_32_32_32. | bunnei | 1 | -0/+2 | |
- Used by Super Mario Odyssey. | |||||
2018-08-10 | Revert "gl_state: Temporarily disable culling and depth test." | bunnei | 1 | -3/+1 | |
2018-08-10 | game_list: Reorder error checks | Zach Hilman | 1 | -2/+1 | |
clang-format fix | |||||
2018-08-10 | loader: Add more descriptive errors | Zach Hilman | 17 | -179/+249 | |
Full list of new errors and descriptions in core/loader/loader.h | |||||
2018-08-10 | gl_rasterizer_cache: Remove unused viewport parameter of GetFramebufferSurfaces() | Lioncash | 3 | -8/+6 | |
2018-08-10 | video_core: Use variable template variants of type_traits interfaces where applicable | Lioncash | 2 | -4/+2 | |
2018-08-10 | textures: Refactor out for Texture/Depth FormatFromPixelFormat. | bunnei | 5 | -181/+31 | |
2018-08-10 | gl_rasterizer_cache: Add bounds checking for gl_buffer copies. | bunnei | 1 | -10/+12 | |
2018-08-10 | Implement SNORM for BC5/DXN2 (#998) | Khangaroo | 2 | -38/+55 | |
* Implement BC5/DXN2 (#996) - Used by Kirby Star Allies. * Implement BC5/DXN2 SNORM UNORM for Kirby Star Allies SNORM for Super Mario Odyssey | |||||
2018-08-09 | gl_shader_decompiler: Reserve element memory beforehand in BuildRegisterList() | Lioncash | 1 | -0/+2 | |
Avoids potentially perfoming multiple reallocations when we know the total amount of memory we need beforehand. | |||||
2018-08-09 | gl_rasterizer_cache: Avoid iterator invalidation issues within InvalidateRegion() | Lioncash | 1 | -2/+4 | |
A range-based for loop can't be used when the container being iterated is also being erased from. | |||||
2018-08-09 | Implement BC5/DXN2 (#996) | Khangaroo | 3 | -33/+45 | |
- Used by Kirby Star Allies. | |||||
2018-08-09 | buffer_queue: Make reference parameter of SetPreallocatedBuffer const | Lioncash | 2 | -2/+2 | |
This is simply copied by value, so there's no need to make it a modifiable reference. While we're at it, make the names of the parameters match its definition. | |||||
2018-08-09 | hle_ipc: Make WriteToOutgoingCommandBuffer()'s reference parameter const | Lioncash | 2 | -2/+2 | |
This function doesn't modify anything within the reference Thread instance. | |||||
2018-08-09 | gl_rasterizer_cache: Invert conditional in LoadGLBuffer() | Lioncash | 1 | -5/+5 | |
It's generally easier to follow code using conditionals that operate in terms of the true case followed by the false case (no chance of overlooking the exclamation mark). | |||||
2018-08-09 | gl_rasterizer_cache: Use std::vector::assign in LoadGLBuffer() for the non-tiled case | Lioncash | 1 | -4/+6 | |
resize() causes the vector to expand and zero out the added members to the vector, however we can avoid this zeroing by using assign(). Given we have the pointer to the data we want to copy, we can calculate the end pointer and directly copy the range of data without the need to perform the resize() beforehand. | |||||
2018-08-09 | Don't add user if the uuid already exists | David Marcec | 1 | -0/+4 | |
2018-08-09 | maxwell_to_gl: Implement VertexAttribute::Size::Size_16_16_16_16. | bunnei | 1 | -0/+1 | |
- Used by Super Mario Odyssey (in game). | |||||
2018-08-09 | maxwell_to_gl: Implement PrimitiveTopology::Points. | bunnei | 1 | -0/+2 | |
- Used by Super Mario Odyssey (in game). | |||||
2018-08-09 | gl_shader_decompiler: Declare predicates on use. | bunnei | 1 | -4/+5 | |
- Used by Super Mario Odyssey (when going in game). | |||||
2018-08-09 | maxwell_3d: Ignore macros that have not been uploaded yet. | bunnei | 1 | -4/+9 | |
- Used by Super Mario Odyssey (in game). | |||||
2018-08-09 | gl_rasterizer_cache: Make pointer const in LoadGLBuffer() | Lioncash | 1 | -1/+1 | |
This is only ever read from, so we can make the data it's pointing to const. | |||||
2018-08-09 | vfs: Fix documentation | Zach Hilman | 2 | -2/+4 | |
2018-08-09 | vfs: Fix typo in VfsFilesystem docs | Zach Hilman | 2 | -4/+5 | |
2018-08-09 | file_util: Use enum instead of bool for specifing path behavior | Zach Hilman | 4 | -24/+37 | |
2018-08-09 | loader: Remove unused IdentifyFile overload | Zach Hilman | 2 | -12/+0 | |
2018-08-09 | vfs: Use RealVfsFilesystem for fs-operations in RealVfsDirectory | Zach Hilman | 1 | -2/+10 | |
2018-08-09 | file_sys: Add missing include in savedata_factory | Zach Hilman | 1 | -0/+1 | |
2018-08-09 | core: Port core to VfsFilesystem for file access | Zach Hilman | 12 | -22/+52 | |
2018-08-09 | vfs: Add unreachable assert to file permissions converter | Zach Hilman | 1 | -1/+3 | |
2018-08-09 | vfs: Add RealVfsFilesystem implementation | Zach Hilman | 2 | -81/+290 | |
2018-08-09 | file_util: Add platform-specific slash option to SanitizePath | Zach Hilman | 2 | -5/+16 | |
2018-08-09 | vfs: Add VfsFilesystem interface and default implementation | Zach Hilman | 2 | -3/+211 | |
2018-08-09 | filesystem: Remove unnecessary if conditions | Zach Hilman | 1 | -1/+1 | |
2018-08-09 | gl_rasterizer: Do not render when no render target is configured. | bunnei | 1 | -0/+5 | |
- Used by Super Mario Odyssey. | |||||
2018-08-09 | fsp_srv: Use std::string_view's copy() function instead of strncpy() | Lioncash | 2 | -8/+10 | |
Given elements inserted into a vector are zeroed out, we can just copy MAX_LEN - 1 elements and the data will already be properly null terminated. | |||||
2018-08-09 | fsp_srv: Emplace entries first when building index instead of emplacing last | Lioncash | 1 | -2/+3 | |
The current way were doing it would require copying a 768 character buffer (part of the Entry struct) to the new element in the vector. Given it's a plain array, std::move won't eliminate that. Instead, we can emplace an instance directly into the destination buffer and then fill it out, avoiding the need to perform any unnecessary copies. Given this is done in a loop, we can request the destination to allocate all of the necessary memory ahead of time, avoiding the need to potentially keep reallocating over and over on every few insertions into the vector. | |||||
2018-08-08 | common/logging: Add missing service log categories | Lioncash | 2 | -0/+16 | |
These weren't added when the services were introduced. | |||||
2018-08-08 | common/color: Remove unnecessary const qualifiers on return types | Lioncash | 1 | -7/+7 | |
These are just superfluous and not necessesary | |||||
2018-08-08 | common/color: Get rid of undefined behavior | Lioncash | 1 | -12/+24 | |
Gets rid of type punning via reinterpret_cast within functions. Instead, we use memcpy to transfer the contents across types. | |||||
2018-08-08 | vector_math: Use variable template version of is_signed in Vec classes | Lioncash | 1 | -3/+3 | |
Same behavior, less code | |||||
2018-08-08 | Open first user added | David Marcec | 1 | -1/+3 | |
2018-08-08 | Inital pass of account backend implementation | David Marcec | 3 | -12/+22 | |
This commit verified working on puyo | |||||
2018-08-08 | GetProfileBase and GetProfileBaseAndData added | David Marcec | 3 | -44/+106 | |
2018-08-08 | began initial implementation of "ProfileManager" | David Marcec | 5 | -44/+202 | |
2018-08-08 | Service/Account: stub LoadImage function | mailwl | 1 | -1/+22 | |
2018-08-08 | Switched uuids from u128 to new UUID struct | David Marcec | 2 | -10/+49 | |
2018-08-08 | gpu: Add R11G11B10_FLOAT to RenderTargetBytesPerPixel. | bunnei | 1 | -0/+1 | |
- Used by Super Mario Odyssey. | |||||
2018-08-08 | hid: fix IsSixAxisSensorAtRest() response | mailwl | 1 | -1/+1 | |
2018-08-08 | gl_shader_decompiler: Stub input attribute Unknown_63. | bunnei | 2 | -0/+9 | |
2018-08-08 | maxwell_3d: Use correct const buffer size and check bounds. | bunnei | 4 | -3/+12 | |
- Fixes mem corruption with Super Mario Odyssey and Pokkén Tournament DX. | |||||
2018-08-08 | renderer_opengl: Use trace log in a few places. | bunnei | 2 | -2/+2 | |
2018-08-08 | maxwell_to_gl: Implement VertexAttribute::Size::Size_8_8. | bunnei | 1 | -0/+1 | |
2018-08-08 | nvhost_gpu: Don't over copy IoctlSubmitGpfifo. | bunnei | 1 | -1/+1 | |
2018-08-08 | gl_rasterizer_cached: Implement RenderTargetFormat::B5G6R5_UNORM. | bunnei | 2 | -0/+4 | |
- Used by Super Mario Odyssey. | |||||
2018-08-08 | gl_shader_decompiler: Let OpenGL interpret floats. | bunnei | 2 | -11/+6 | |
- Accuracy is lost in translation to string, e.g. with NaN. - Needed for Super Mario Odyssey. | |||||
2018-08-08 | am: Stub SetScreenShotImageOrientation. | bunnei | 2 | -1/+9 | |
- Used by Super Mario Odyssey. | |||||
2018-08-08 | acc: Add missing function table entries for GetUserCount | Lioncash | 2 | -2/+2 | |
Given this is stubbed within the common module in 5ac7b84, it should be added to the other relevant tables as well. | |||||
2018-08-08 | acc: Stub GetUserCount. (#973) | bunnei | 3 | -1/+9 | |
- Used by Pokken Tournament DX. | |||||
2018-08-08 | nvdrv: Get rid of global std::weak_ptr | Lioncash | 5 | -11/+22 | |
Rather than use global state, we can simply pass the instance into the NVFlinger instance directly. | |||||
2018-08-08 | vector_math: Remove unimplemented function prototypes | Lioncash | 1 | -23/+0 | |
2018-08-08 | vector_math: Make functions constexpr where applicable | Lioncash | 1 | -154/+179 | |
2018-08-08 | vector_math: Convert typedefs to type aliases | Lioncash | 1 | -3/+3 | |
2018-08-08 | common: Convert type traits templates over to variable template versions where applicable | Lioncash | 5 | -11/+11 | |
Uses the C++17 inline variable variants | |||||
2018-08-08 | hle: Remove unused romfs.cpp/.h | Lioncash | 3 | -126/+0 | |
These files are no longer used, so we can get rid of them. | |||||
2018-08-08 | externals: Update catch to 2.3.0 | Lioncash | 4 | -4/+4 | |
Updates the library from 2.2.3 to 2.3.0 | |||||
2018-08-08 | Fixed the sRGB pixel format (#963) | Hexagon12 | 1 | -1/+2 | |
* Changed the sRGB pixel format return * Add a message about SRGBA -> RGBA conversion | |||||
2018-08-07 | configure_gamelist: Use explicit QVariant constructor | Zach Hilman | 1 | -2/+4 | |
2018-08-07 | file_util: Avoid sign-conversions in WriteArray() and ReadArray() | Lioncash | 1 | -4/+8 | |
Prevents compiler warnings. | |||||
2018-08-07 | Lowered down the logging for methods | Hexagon12 | 1 | -4/+4 | |
2018-08-07 | loader: Fix scope error in DeconstructedRomDirectory | Zach Hilman | 1 | -1/+1 | |
2018-08-07 | service/apm: Add the apm:sys service | Lioncash | 3 | -0/+34 | |
Adds the basic skeleton of the apm:sys service based off the information on Switch Brew. | |||||
2018-08-07 | nvflinger: Correct typo in name of composition event | Lioncash | 1 | -1/+1 | |
2018-08-07 | nvdrv: Make Ioctl()'s definition match its prototype | Lioncash | 1 | -1/+1 | |
The only reason this wasn't a compilation error is because we use little-endian systems. | |||||
2018-08-07 | nvdrv: Get rid of indirect inclusions | Lioncash | 12 | -15/+17 | |
2018-08-07 | nvflinger: Get rid of indirect inclusions | Lioncash | 2 | -1/+7 | |
2018-08-07 | nvflinger: Use std::string_view in OpenDisplay() | Lioncash | 2 | -2/+3 | |
We don't need to use a std::string here, given all that's done is comparing the character sequence against another. This allows passing regular const char* without needing to heap allocate. | |||||
2018-08-07 | Make building cubeb optional | KAMiKAZOW | 1 | -2/+2 | |
2018-08-07 | services/hid: Add ActivateNpadWithRevision() to the hid function info array | Lioncash | 1 | -0/+1 | |
Updated based off the information on Switch Brew. | |||||
2018-08-07 | service/time: Amend command IDs of ToPosixTime() and ToPosixTimeWithMyRule() | Lioncash | 1 | -2/+2 | |
Updates the ID of these based off the information on Switch Brew. | |||||
2018-08-07 | service: Add usb services | Lioncash | 6 | -0/+259 | |
Adds basic skeleton for the usb services based off the information provided by Switch Brew. | |||||
2018-08-07 | qt/hotkey: Get rid of global hotkey map instance | Lioncash | 8 | -119/+159 | |
Instead, we make a proper registry class and house it within the main window, then pass it to whatever needs access to the loaded hotkeys. This way, we avoid a global variable, and don't need to initialize a std::map instance before the program can do anything. | |||||
2018-08-07 | loader: Add icon and title support to XCI | Zach Hilman | 7 | -5/+46 | |
2018-08-07 | Use const where applicable | Zach Hilman | 4 | -7/+7 | |
2018-08-07 | Avoid parsing RomFS to directory in NCA | Zach Hilman | 18 | -19/+439 | |
2018-08-07 | client_port: Make all data members private | Lioncash | 3 | -7/+21 | |
These members don't need to be entirely exposed, we can instead expose an API to operate on them without directly needing to mutate them We can also guard against overflow/API misuse this way as well, given active_sessions is an unsigned value. | |||||
2018-08-07 | GDBStub works with both Unicorn and Dynarmic now (#941) | Hedges | 5 | -9/+26 | |
* GDBStub works with both Unicorn and Dynarmic now * Tidy up | |||||
2018-08-06 | qt/main: Avoid sign conversions in UpdateRecentFiles() | Lioncash | 1 | -4/+6 | |
This was intermixing signed and unsigned values when they could all just be signed. | |||||
2018-08-06 | game_list: Remove unnecessary conversion to std::string in ValidateEntry() | Lioncash | 1 | -8/+10 | |
We can just use the file interfaces that Qt provides to prevent needing to convert to std::string. | |||||
2018-08-06 | game_list: Use QString::fromStdString() where applicable instead of c_str() | Lioncash | 1 | -5/+7 | |
The codec used by Qt for const char* and std::string don't necessarily have to be the same depending on locale. Therefore, we should be using the correct functions to do the conversions. | |||||
2018-08-06 | game_list: Join declarations and assignments in onTextChanged() | Lioncash | 1 | -7/+7 | |
There's no need to keep these separate from one another. | |||||
2018-08-06 | qt/main: Collapse if statement in UpdateRecentFiles() | Lioncash | 1 | -6/+2 | |
Given the function accepts a boolean, we don't need to use an if statement here and repeat ourselves. | |||||
2018-08-06 | qt/main: Better file-existence checking within OnMenuRecentFile() and UpdateUITheme() | Lioncash | 1 | -8/+6 | |
In OnMenuRecentFile() we don't need to construct a QFileInfo instance just to check if a file exists, we can just use the static member function to do that (which Qt's documentation also notes as quicker than constructing an instance). In UpdateUITheme(), we just want to try and open the file and check the success of that operation. Technically speaking, between the existence check and the open call, the file can be deleted or moved, but still appear to succeed in code. i.e. 1. Existence check -> Returns true 2. File is moved/deleted 3. Open is called, the return value of which isn't checked 4. Nonsense behavior This way we combine the existence check and the open into one. | |||||
2018-08-06 | qt: Don't show error dialog when canceling the Load Folder dialog | Lioncash | 1 | -2/+8 | |
Previously, when canceling out of the Load Folder dialog, a user would get an error dialog about the selected folder not containing a main file, however, by canceling out of the dialog, no selection was actually made. | |||||
2018-08-06 | qt/game_list_p: Remove redundant base class constructor invocations | Lioncash | 1 | -1/+2 | |
These occur automatically without the need to call them. While we're at it, also std::move the QString instance into its member variable. | |||||
2018-08-06 | qt: Add missing override specifiers where applicable | Lioncash | 5 | -7/+9 | |
2018-08-06 | qt: Default destructors where applicable | Lioncash | 9 | -16/+15 | |
Makes code consistent with our style of defaulting special member functions where applicable. | |||||
2018-08-06 | kernel/event: Make data members private | Lioncash | 2 | -5/+9 | |
Instead we can simply provide accessors to the required data instead of giving external read/write access to the variables directly. | |||||
2018-08-06 | Service/Audio: audout_a.cpp: remove pragma once | mailwl | 1 | -2/+0 | |
2018-08-06 | maxwell_3d: Remove outdated assert. | bunnei | 1 | -2/+0 | |
2018-08-06 | gl_rasterizer_cache: Avoid superfluous surface copies. | bunnei | 2 | -4/+21 | |
2018-08-06 | perf_stats: Correct literal used for MAX_LAG_TIME_US | Lioncash | 1 | -2/+2 | |
ms is shorthand for milliseconds, not microseconds, and given there's no comment indicating that this was intentional, it probably wasn't. | |||||
2018-08-06 | core_timing: Make GetGlobalTimeUs() return std::chrono::microseconds | Lioncash | 4 | -14/+14 | |
Enforces the time unit being returned and also allows using the standard time utilities to manipulate it. | |||||
2018-08-06 | memory: Make prototype parameter names match their definitions | Lioncash | 1 | -5/+5 | |
Keeps the code consistent. | |||||
2018-08-06 | memory: Correct prototype of ZeroBlock | Lioncash | 1 | -1/+1 | |
Previously, the prototype wasn't matching the definition, which has a Processor parameter before the destination address. | |||||
2018-08-06 | memory: Remove unnecessary const qualifiers in prototypes | Lioncash | 1 | -9/+8 | |
These aren't necessary, as value-wise const only matters in the definition. | |||||
2018-08-06 | core_timing: Convert typedef into a type alias | Lioncash | 1 | -4/+4 | |
Makes the alias a little more readable from left-to-right. | |||||
2018-08-06 | core_timing: Use transparent functors where applicable | Lioncash | 1 | -5/+5 | |
Gets rid of the need to hardcode the type in multiple places. This will now be deduced automatically, based off the elements in the container being provided to the algorithm. | |||||
2018-08-06 | loader: Make AppLoader_NCA rely on directory loading code | Zach Hilman | 4 | -37/+24 | |
Eliminates duplicate code shared between their Load methods, after all the only difference is how the romfs is handled. | |||||
2018-08-05 | gdbstub: Use type alias for breakpoint maps | Lioncash | 1 | -37/+42 | |
Rather than having to type out the full std::map type signature, we can just use a straightforward alias. While we're at it, rename GetBreakpointList to GetBreakpointMap, which makes the name more accurate. We can also get rid of unnecessary u64 static_casts, since VAddr is an alias for a u64. | |||||
2018-08-05 | gdbstub: Move all file-static variables into the GDBStub namespace | Lioncash | 1 | -35/+36 | |
Keeps everything under the same namespace. While we're at it, enclose them all within an inner anonymous namespace. | |||||
2018-08-05 | address_arbiter: Return by value from GetThreadsWaitingOnAddress() | Lioncash | 1 | -15/+15 | |
In all cases the vector being supplied is empty, so we can just return by value in these instances. | |||||
2018-08-05 | gdbstub: Replace PAddr alias with VAddr | Lioncash | 2 | -14/+14 | |
In all cases, a virtual address is being passed in, not a physical one. | |||||
2018-08-05 | gl_shader_decompiler: Fix TEXS mask and dest. | bunnei | 1 | -2/+5 | |
2018-08-05 | audio_core: Implement audren_u audio playback. | bunnei | 5 | -218/+451 | |
2018-08-05 | added braces for conditions | David Marcec | 1 | -2/+3 | |
2018-08-05 | fix the attrib format for ints | David Marcec | 1 | -2/+7 | |
2018-08-05 | audio_core: Use s16 where possible for audio samples. | bunnei | 9 | -36/+27 | |
2018-08-05 | audio_core: Port codec code from Citra for ADPCM decoding. | bunnei | 5 | -11/+126 | |
2018-08-05 | service: Add arp services | Lioncash | 6 | -0/+97 | |
Adds the basic skeleton of the arp services based off the information provided by Switch Brew. | |||||
2018-08-04 | service: Remove redundant #pragma once directives | Lioncash | 5 | -10/+0 | |
These don't do anything within .cpp files (we don't include cpp files, so...) | |||||
2018-08-04 | aes_util: Add static assertion to Transcode() and XTSTranscode() to ensure well-defined behavior | Lioncash | 1 | -0/+4 | |
These functions should only be given trivially-copyable types. | |||||
2018-08-04 | aes_util: Make CalculateNintendoTweak() an internally linked function | Lioncash | 2 | -12/+10 | |
This function doesn't directly depend on class state, so it can be hidden entirely from the interface in the cpp file. | |||||
2018-08-04 | aes_util: Make Transcode() a const member function | Lioncash | 2 | -8/+9 | |
This doesn't modify member state, so it can be made const. | |||||
2018-08-04 | core/crypto: Remove unnecessary includes | Lioncash | 4 | -5/+5 | |
2018-08-04 | key_manager: Use regular std::string instead of std::string_view | Lioncash | 2 | -10/+7 | |
The benefit of std::string_view comes from the idea of avoiding copies (essentially acting as a non-owning view), however if we're just going to copy into a local variable immediately, there's not much benefit gained here. | |||||
2018-08-04 | cubeb_sink: Support variable sample_rate and num_channels. | bunnei | 1 | -15/+25 | |
2018-08-04 | content_archive: Add support for titlekey cryptography | Zach Hilman | 2 | -7/+39 | |
2018-08-04 | audio_core: Sinks need unique names as well. | bunnei | 5 | -9/+14 | |
2018-08-04 | audio_core: Streams need unique names for CoreTiming. | bunnei | 5 | -10/+14 | |
2018-08-04 | gl_shader_manager: Invert conditional in SetShaderUniformBlockBinding() | Lioncash | 1 | -7/+9 | |
This lets us indent the majority of the code and places the error case first. | |||||
2018-08-04 | gl_shader_manager: Amend sign differences in an assertion comparison in SetShaderUniformBlockBinding() | Lioncash | 1 | -3/+2 | |
Ensures both operands have the same sign in the comparison. While we're at it, we can get rid of the redundant casting of ub_size to an int. This type will always be trivial and alias a built-in type (not doing so would break backwards compatibility at a standard level). | |||||
2018-08-04 | renderer_base: Make Rasterizer() return the rasterizer by reference | Lioncash | 5 | -11/+15 | |
All calling code assumes that the rasterizer will be in a valid state, which is a totally fine assumption. The only way the rasterizer wouldn't be is if initialization is done incorrectly or fails, which is checked against in System::Init(). | |||||
2018-08-04 | video_core: Eliminate the g_renderer global variable | Lioncash | 19 | -74/+100 | |
We move the initialization of the renderer to the core class, while keeping the creation of it and any other specifics in video_core. This way we can ensure that the renderer is initialized and doesn't give unfettered access to the renderer. This also makes dependencies on types more explicit. For example, the GPU class doesn't need to depend on the existence of a renderer, it only needs to care about whether or not it has a rasterizer, but since it was accessing the global variable, it was also making the renderer a part of its dependency chain. By adjusting the interface, we can get rid of this dependency. | |||||
2018-08-04 | kernel/thread: Fix potential crashes introduced in 26de4bb521b1ace7af76eff4f6956cb23ac0d58c | Lioncash | 3 | -13/+38 | |
This amends cases where crashes can occur that were missed due to the odd way the previous code was set up (using 3DS memory regions that don't exist). | |||||
2018-08-03 | kernel/process: Use std::array where applicable | Lioncash | 1 | -1/+2 | |
2018-08-03 | kernel/process: Use accessors instead of class members for referencing segment array | Lioncash | 5 | -20/+40 | |
Using member variables for referencing the segments array increases the size of the class in memory for little benefit. The same behavior can be achieved through the use of accessors that just return the relevant segment. | |||||
2018-08-03 | memory: Remove unused GetSpecialHandlers() function | Lioncash | 1 | -16/+0 | |
This is just unused code, so we may as well get rid of it. | |||||
2018-08-03 | video_core: Remove unimplemented Start() function prototype | Lioncash | 1 | -3/+0 | |
Given this has no definition, we can just remove it entirely. | |||||
2018-08-03 | gl_shader_decompiler: Remove unused variable in GenerateDeclarations() | Lioncash | 1 | -2/+0 | |
This variable was being incremented, but we were never actually using it. | |||||
2018-08-03 | gl_shader_manager: Make ProgramManager's GetCurrentProgramStage() a const member function | Lioncash | 1 | -1/+1 | |
This function doesn't modify class state, so it can be made const. | |||||
2018-08-03 | core/memory: Get rid of 3DS leftovers | Lioncash | 16 | -559/+29 | |
Removes leftover code from citra that isn't needed. | |||||
2018-08-03 | Added ability to change username & language code in the settings ui. Added IProfile::Get and SET::GetLanguageCode for libnx tests (#851) | David | 9 | -8/+95 | |
2018-08-03 | yuzu: Use Qt 5 signal/slots where applicable | Lioncash | 7 | -46/+49 | |
Makes the signal/slot connections type-safe instead of string-based. | |||||
2018-08-03 | input_common: Use std::move where applicable | Lioncash | 2 | -5/+6 | |
Avoids unnecessary atomic reference count increments and decrements | |||||
2018-08-03 | input_common: Add missing override specifiers | Lioncash | 3 | -14/+2 | |
2018-08-02 | Implement RGB32F PixelFormat (#886) (used by Go Vacation) | greggameplayer | 3 | -9/+23 | |
2018-08-02 | kernel/vm_manager: Convert loop into std::any_of() | Lioncash | 1 | -4/+4 | |
2018-08-02 | kernel/vm_manager: Use const where applicable | Lioncash | 3 | -19/+19 | |
Makes our immutable state explicit. | |||||
2018-08-02 | kernel/vm_manager: Use the VAddr type alias in CarveVMA() | Lioncash | 1 | -2/+2 | |
These two variables correspond to address ranges. | |||||
2018-08-02 | kernel/thread: Make GetFreeThreadLocalSlot()'s loop indices size_t | Lioncash | 1 | -8/+5 | |
Avoids using a u32 to compare against a range of size_t, which can be a source of warnings. While we're at it, compress a std::tie into a structured binding. | |||||
2018-08-02 | kernel/thread: Make GetFreeThreadLocalSlot() reference parameter a const reference | Lioncash | 1 | -1/+2 | |
This function only reads the data being referenced, it doesn't modify it, so we can turn the reference into a const reference. | |||||
2018-08-02 | kernel/thread: Make GetFreeThreadLocalSlot() internally linked | Lioncash | 1 | -1/+1 | |
This function isn't used outside of this translation unit, so we can make it internally linked. | |||||
2018-08-02 | vfs_vector: Remove unused variable in FindAndRemoveVectorElement() | Lioncash | 1 | -2/+2 | |
This wasn't being used for anything, so it can be removed. | |||||
2018-08-02 | vfs_vector: Avoid unnecessary copies where applicable | Lioncash | 1 | -2/+5 | |
The lambda elements should be taken by const reference here, and we can move the virtual directory passed to ReplaceFileWithSubdirectory() | |||||
2018-08-02 | gl_state: Make texture_units a std::array | Lioncash | 1 | -2/+3 | |
Gets rid of the use of a raw C array. | |||||
2018-08-02 | gl_shader_manager: Take ShaderSetup instances by const reference in UseProgrammableVertexShader() and UseProgrammableFragmentShader() | Lioncash | 1 | -2/+2 | |
Avoids performing unnecessary copies of 65560 byte sized ShaderSetup instances, considering it's only used as part of lookup and not modified. Given the parameters were already const, it's likely taking these parameters by reference was intended but the ampersand was forgotten. | |||||
2018-08-02 | math_util: Always initialize members of Rectangle | Lioncash | 1 | -5/+5 | |
Prevents potentially using the members uninitialized. | |||||
2018-08-02 | hw: Remove unused files | Lioncash | 7 | -334/+0 | |
None of these files are used in any meaningful way. They're just leftovers from citra. Also has the benefit of getting rid of an unused global variable. | |||||
2018-08-02 | service: Add migration services | Lioncash | 6 | -0/+55 | |
Adds the basic skeleton for the mig:usr service based off information provided by Switch Brew. | |||||
2018-08-02 | audio_out: Use Buffer::Tag alias in GetTagsAndReleaseBuffers()'s prototype | Lioncash | 2 | -2/+2 | |
This makes the Buffer::Tag usage consistent with the Stream class's prototype of GetTagsAndReleaseBuffers(). | |||||
2018-08-02 | sink_details: Deduplicate long std::function repetition | Lioncash | 1 | -4/+6 | |
We can just use type aliases to avoid needing to write the same long type twice | |||||
2018-08-02 | sink_details: std::move std::function instances | Lioncash | 1 | -1/+2 | |
Given std::function is allowed to potentially allocate, these should be std::move'd to prevent potential reallocation (should that ever happen). | |||||
2018-08-02 | kernel: Move object class to its own source files | Lioncash | 44 | -156/+186 | |
General moving to keep kernel object types separate from the direct kernel code. Also essentially a preliminary cleanup before eliminating global kernel state in the kernel code. | |||||
2018-08-02 | logging/log: Remove incorrect description in PCV doc comment | Lioncash | 1 | -1/+1 | |
PCV isn't the parental control service. | |||||
2018-08-02 | service: Add psc services | Lioncash | 6 | -0/+98 | |
Adds the basic skeleton for the psc services based off the information provided by Switch Brew. | |||||
2018-08-02 | video_core: Make global EmuWindow instance part of the base renderer class | Lioncash | 13 | -64/+54 | |
Makes the global a member of the RendererBase class. We also change this to be a reference. Passing any form of null pointer to these functions is incorrect entirely, especially given the code itself assumes that the pointer would always be in a valid state. This also makes it easier to follow the lifecycle of instances being used, as we explicitly interact the renderer with the rasterizer, rather than it just operating on a global pointer. | |||||
2018-08-02 | service/ns: Add missing ns services | Lioncash | 1 | -0/+447 | |
Implements the basic skeleton of ns:am2, ns:ec, ns:rid, ns:rt, ns:su, ns:vm, and ns:web based off the information provided by Switch Brew and SwIPC. | |||||
2018-08-01 | lm: Amend name of ILogger | Lioncash | 1 | -4/+4 | |
Previously this was being registered with the name "Logger". While we're at it, also change the name of the class to match it. | |||||
2018-08-01 | service/filesystem: Add fsp:ldr and fsp:pr services | Lioncash | 6 | -0/+89 | |
Adds the basic skeleton for the remaining fsp services based off information provided by Switch Brew. | |||||
2018-08-01 | service: Add capture services | Lioncash | 6 | -0/+173 | |
Adds the basic skeleton for the capture services based off information provided by Switch Brew. | |||||
2018-08-01 | service: Add bpc and pcv services | Lioncash | 8 | -0/+183 | |
Adds the basic skeleton for the remaining pcv-related services based off information on Switch Brew. | |||||
2018-08-01 | Implement R32_FLOAT RenderTargetFormat | Unknown | 3 | -0/+5 | |
2018-08-01 | Add missing parameter to files.push_back() | Zach Hilman | 1 | -5/+5 | |
2018-08-01 | Fix merge conflicts with opus and update docs | Zach Hilman | 4 | -6/+8 | |
2018-08-01 | Use more descriptive error codes and messages | Zach Hilman | 9 | -34/+101 | |
2018-08-01 | Use static const instead of const static | Zach Hilman | 1 | -2/+2 | |
2018-08-01 | Use ErrorEncrypted where applicable and fix no keys crash | Zach Hilman | 4 | -17/+37 | |
2018-08-01 | Add missing includes and use const where applicable | Zach Hilman | 11 | -24/+40 | |
2018-08-01 | Allow key loading from %YUZU_DIR%/keys in addition to ~/.switch | Zach Hilman | 5 | -7/+23 | |
2018-08-01 | Use SHGetKnownFolderPath instead of SHGetFolderPathA | Zach Hilman | 1 | -3/+4 | |
2018-08-01 | Make XCI comply to review and style guidelines | Zach Hilman | 16 | -482/+223 | |
2018-08-01 | Extract mbedtls to cpp file | Zach Hilman | 5 | -87/+127 | |
2018-08-01 | Add missing string.h include | Zach Hilman | 1 | -0/+1 | |
2018-08-01 | Update mbedtls and fix compile error | Zach Hilman | 1 | -0/+1 | |
2018-08-01 | Remove files that are not used | Zach Hilman | 33 | -43/+1455 | |
2018-08-01 | kernel/thread: Remove unimplemented function prototype | Lioncash | 1 | -6/+0 | |
Given there's no implementation, we may as well remove the code entirely. | |||||
2018-08-01 | audio_core: Add configuration settings. | bunnei | 12 | -21/+330 | |
2018-08-01 | service/audio: Add missing services | Lioncash | 14 | -2/+289 | |
Adds the missing audctl service, as well as the :a and :d services for audin, audout, audrec, and audren. | |||||
2018-07-31 | kernel: Remove unused object_address_table.cpp/.h | Lioncash | 6 | -104/+0 | |
These source files were entirely unused throughout the rest of the codebase. This also has the benefit of getting rid of a global variable as well. | |||||
2018-07-31 | audout_u: Remove std::move in OpenAudioOutImpl() | Lioncash | 1 | -1/+1 | |
Previously the code was using the values from params further below after it was std::moved. Thankfully, given AudoutParams is a trivially copyable struct, the values would have simply been copied in this instance and not invalidated to garbage values. | |||||
2018-07-31 | kernel: Remove unnecessary includes | Lioncash | 23 | -28/+47 | |
Removes unnecessary direct dependencies in some headers and also gets rid of indirect dependencies that were being relied on to be included. | |||||
2018-07-31 | service/am: Add missing am services | Lioncash | 8 | -0/+156 | |
Adds the basic skeleton for missing am services idle:sys, omm, and spsm based off the information provided by Switch Brew. | |||||
2018-07-31 | service: Add fgm services | Lioncash | 6 | -0/+96 | |
Adds the basic skeleton for the fgm services based off the information provided by Switch Brew. | |||||
2018-07-31 | arm_dynarmic: Make SetTlsAddress() prototype and definition consistent | Lioncash | 1 | -1/+1 | |
Makes the definition use the same type aliases as in its prototype. | |||||
2018-07-31 | arm_dynarmic: Remove unnecessary qualifying of ThreadContext | Lioncash | 1 | -3/+3 | |
Given the ARM_Dynarmic class inherits from ARM_Interface, we don't need to qualify here. | |||||
2018-07-31 | arm_dynarmic: Correct initializer list order | Lioncash | 1 | -5/+3 | |
Amends the initializer list to be in the same order that each variable would be initialized in. We also do this to ensure we don't use a bogus uninitialized instance of the exclusive monitor within MakeJit() We can also remove the jit member from the initializer list as this is initialized by PageTableChanged() | |||||
2018-07-31 | service: Add the pcie service | Lioncash | 6 | -0/+85 | |
Adds the basic skeleton of the pcie service based off information on Switch Brew. | |||||
2018-07-31 | audio_core: Implement Sink and SinkStream interfaces with cubeb. | bunnei | 8 | -6/+261 | |
2018-07-31 | audio_core: Add interfaces for Sink and SinkStream. | bunnei | 6 | -0/+163 | |
2018-07-31 | MacroInterpreter: Avoid left shifting negative values. | Subv | 2 | -2/+6 | |
The branch target is signed, so multiply by 4 instead of left shifting by 2 | |||||
2018-07-31 | nvhost_gpu: Added checks to ensure we don't read past the end of the entries when handling a GPU command list. | Subv | 1 | -3/+6 | |
2018-07-31 | nvhost_ctrl_gpu: Only read the input parameters if they are actually there. | Subv | 1 | -3/+11 | |
Passing nullptr to memcpy is undefined behavior. | |||||
2018-07-31 | Port #3758 from Citra (#852): Add missing std::string import in text_formatter | Tobias | 1 | -0/+1 | |
2018-07-31 | audio_core: Misc. improvements to stream/buffer/audio_out. | bunnei | 5 | -20/+32 | |
2018-07-31 | audio_core: Move to audout_u impl. | bunnei | 4 | -13/+6 | |
- This is necessary so streams are created on the same thread. | |||||
2018-07-31 | Implemented various hwopus functions (#853) | David | 3 | -6/+132 | |
2018-07-30 | Port #3769 from Citra: "Update Dark theme to latest version" | Tobias | 1 | -1/+1 | |
2018-07-30 | Add some HID commands (#843) | Hexagon12 | 1 | -2/+16 | |
* Added some HID commands * Addressed comments | |||||
2018-07-29 | Port #3732 from Citra: "common: Fix compilation on ARM" | Cameron Cawley | 2 | -4/+2 | |
2018-07-29 | remove polymorphism issue | B3n30 | 1 | -2/+30 | |
2018-07-29 | Port #3913 from Citra: "citra_qt: Remove obsolete application attribute" | fearlessTobi | 1 | -1/+0 | |
2018-07-29 | common/string_utils: replace boost::transform with std counterpart | zhupengfei | 1 | -3/+5 | |
Note: according to cppreference it is necessary to convert char to unsigned char when using std::tolower and std::toupper, otherwise the behaviour would be undefined. | |||||
2018-07-29 | Port #3972 from Citra: "common/timer: use std::chrono, avoid platform-dependent code" | zhupengfei | 2 | -81/+31 | |
2018-07-29 | Port #3911 from Citra: "Optimize settings application" | fearlessTobi | 5 | -6/+3 | |
2018-07-29 | Port #3837 from Citra: "Add build date in about dialog" | fearlessTobi | 2 | -3/+4 | |
2018-07-29 | partition_filesystem: Remove dynamic_cast in PrintDebugInfo() | Lioncash | 1 | -3/+2 | |
We shouldn't be upcasting our file instances. Given a PartitionFilesystem is currently designed to accept any arbitrary VfsFile instances, casting to a more specific type than that is just bad design, and shows an interface design issue. | |||||
2018-07-29 | service: Add wlan services | Lioncash | 6 | -1/+194 | |
Adds the basic skeleton for the wlan services based off the information on Switch Brew. | |||||
2018-07-29 | service/btm: Add basic implementation of GetCoreImpl() | Lioncash | 1 | -1/+35 | |
Based off information on SwIPC and Switch Brew. | |||||
2018-07-29 | service: Add btm services | Lioncash | 6 | -0/+108 | |
Adds the skeleton for the btm services based off the information on Switch Brew. | |||||
2018-07-28 | audout: Implement IAudioOut interface with AudioCore. | bunnei | 2 | -93/+114 | |
2018-07-28 | core: Add AudioCore to global state. | bunnei | 2 | -0/+9 | |
2018-07-28 | audio_core: Add initial code for keeping track of audout state. | bunnei | 8 | -1/+336 | |
2018-07-28 | RomFS Extraction | Zach Hilman | 12 | -20/+351 | |
2018-07-27 | service: Add ncm services | Lioncash | 6 | -0/+80 | |
Adds the basic skeleton for the ncm services based off information on Switch Brew. | |||||
2018-07-27 | service: Add mii services | Lioncash | 6 | -0/+128 | |
Adds the skeleton for the mii services based off information provided by Switch Brew | |||||
2018-07-27 | service/nfc: Implement Create[x]Interface functions | Lioncash | 1 | -4/+43 | |
These simply return the respective interface. | |||||
2018-07-27 | service: Add nfc services | Lioncash | 6 | -0/+204 | |
Adds the skeleton of the nfc service based off the information provided on Switch Brew. | |||||
2018-07-27 | service/lbl: Implement EnableVrMode, DisableVrMode and GetVrMode | Lioncash | 3 | -3/+37 | |
Implements these functions according to the information available on Switch Brew. | |||||
2018-07-27 | service: Add the lbl service | Lioncash | 4 | -0/+77 | |
Adds the skeleton of the lbl service based off the information provided by Switch Brew. | |||||
2018-07-27 | service: Add the btdrv service | Lioncash | 4 | -1/+93 | |
Adds the skeleton for the btdrv service based off the information provided by Switch Brew | |||||
2018-07-26 | service/hid: Add the hidbus, hid:dbg, hid:sys, and hid:tmp services | Lioncash | 1 | -0/+220 | |
2018-07-26 | service/hid: Add the xcd:sys service | Lioncash | 4 | -0/+57 | |
2018-07-26 | service/hid: Add irs services | Lioncash | 4 | -0/+75 | |
2018-07-26 | Port #3594 from Citra | fearlessTobi | 1 | -0/+16 | |
2018-07-26 | service: Add the grc:c service | Lioncash | 4 | -0/+50 | |
Adds the basic skeleton for the grc:c service based off the information provided by Switch Brew. | |||||
2018-07-26 | GPU: Allow using R16F as a render target format. | Subv | 2 | -1/+4 | |
2018-07-26 | kernel/timer: Make data members private where applicable | Lioncash | 2 | -8/+20 | |
Instead, we can just expose functions that return the queryable state instead of letting anything modify it. | |||||
2018-07-26 | Port #3665 from Citra | fearlessTobi | 2 | -0/+4 | |
2018-07-26 | Port #3641 from Citra | fearlessTobi | 1 | -1/+1 | |
2018-07-26 | service: Add the nim services | Lioncash | 4 | -0/+143 | |
Adds the skeleton for the nim services based off information from Switch Brew. | |||||
2018-07-26 | service: Add ldn services | Lioncash | 6 | -0/+164 | |
Adds ldn services based off information provided by Switch Brew. | |||||
2018-07-26 | service/sockets: Add ethc:c and ethc:i services | Lioncash | 4 | -0/+66 | |
2018-07-26 | service/sockets: Add missing bsdcfg socket service | Lioncash | 3 | -0/+29 | |
2018-07-26 | service: Add ldr services | Lioncash | 4 | -0/+101 | |
Adds the skeleton for the ldr-related services based off the information provided on Switch Brew. | |||||
2018-07-26 | lm: Move LM's class declaration into the cpp file | Lioncash | 2 | -37/+31 | |
This isn't used directly outside of this translation unit, so we can hide it from external use. | |||||
2018-07-26 | lm: Amend names of Initialize() in Logger and Initialize() in LM | Lioncash | 2 | -7/+7 | |
Amends these to match the information on Switch Brew. | |||||
2018-07-26 | lm: Add missing function entry to Logger's function table | Lioncash | 1 | -0/+1 | |
2018-07-26 | service: Add eupld services | Lioncash | 4 | -0/+72 | |
Adds the skeleton for the eupld services based off information on Switch Brew. | |||||
2018-07-26 | service: Add the erpt services | Lioncash | 4 | -0/+71 | |
Adds the basic skeleton of the erpt service based off information on Switch Brew. | |||||
2018-07-26 | Implement R16_G16 | Unknown | 4 | -19/+100 | |
correct trailing white spaces Delete tabs correct placement Add RG16F & RG16UI & RG16I & RG16S PixelFormats Return correct data according to changes done previously correct PixelFormat declaration correct coding style error correct coding style error part 2 correct RG16S Declaration error correct alignment | |||||
2018-07-25 | service/nvdrv: Take std::string in Open() by const reference | Lioncash | 2 | -2/+2 | |
Avoids copies from being made, since the string is only ever used for lookup, the data is never transfered anywhere. Ideally, we'd use a std::string_view here, but devices is a std::unordered_map, not a std::map, so we can't use heterogenous lookup here. | |||||
2018-07-25 | service/nvdrv: Use std::move where applicable | Lioncash | 1 | -3/+5 | |
Avoids unnecessary reference count increments and decrements. In one case, we don't need to make a shared_ptr copy at all, just to call a member function. | |||||
2018-07-25 | service/nifm: Deduplicate interface code | Lioncash | 9 | -141/+30 | |
Rather than having the same code for each nifm service variant, we can centralize it on one class and get rid of a bit of extra code. | |||||
2018-07-25 | service: Add pm services | Lioncash | 4 | -0/+90 | |
Adds the skeleton for the process management services based off information on Switch Brew. | |||||
2018-07-25 | wait_tree: Add missing switch case for WaitTreeThread::GetText() | Lioncash | 1 | -0/+4 | |
We were missing the enum entry for WaitIPC | |||||
2018-07-25 | service: Add the es service | Lioncash | 4 | -0/+77 | |
Adds the skeleton for the ETicket service based off the information on Switch Brew | |||||
2018-07-25 | time: Add the time:a service | Lioncash | 3 | -10/+11 | |
Given we already have time:s and time:u, we should also have time:a | |||||
2018-07-25 | GPU: Use the right texture format for sRGBA framebuffers. | Subv | 2 | -9/+17 | |
2018-07-25 | GPU: Allow the use of Z24S8 as a texture format. | Subv | 1 | -0/+4 | |
2018-07-25 | GPU: Implemented the Z32_S8_X24 depth buffer format. | Subv | 4 | -1/+16 | |
2018-07-25 | GPU: Allow using Z32 as a texture format. | Subv | 1 | -0/+4 | |
2018-07-25 | GPU: Allow the usage of R8 as a render target format. | Subv | 2 | -0/+4 | |
2018-07-24 | GPU: Remove the assert that required the CODE_ADDRESS to be 0. | Subv | 1 | -8/+0 | |
Games usually just leave it at 0 but nouveau sets it to something else. This already works fine, the assert is useless. | |||||
2018-07-24 | GPU: Implemented the R16 and R16F texture formats. | Subv | 3 | -5/+32 | |
2018-07-24 | gl_rasterizer: Replace magic number with GL_INVALID_INDEX in SetupConstBuffers() | Lioncash | 1 | -3/+5 | |
This is just the named constant that OpenGL provides, so we can use that instead of using a literal -1 | |||||
2018-07-24 | gl_rasterizer: Use std::string_view instead of std::string when checking for extensions | Lioncash | 1 | -1/+3 | |
We can avoid heap allocations here by just using a std::string_view instead of performing unnecessary copying of the string data. | |||||
2018-07-24 | gl_rasterizer: Use in-class member initializers where applicable | Lioncash | 2 | -12/+5 | |
We can just assign to the members directly in these cases. | |||||
2018-07-24 | video_core/memory_manager: Replace a loop with std::array's fill() function in PageSlot() | Lioncash | 1 | -3/+1 | |
We already have a function that does what this code was doing, so let's use that instead. | |||||
2018-07-24 | video_core/memory_manager: Avoid repeated unnecessary page slot lookups | Lioncash | 1 | -11/+21 | |
We don't need to keep calling the same function over and over again in a loop, especially when the behavior is slightly non-trivial. We can just keep a reference to the looked up location and do all the checking and assignments based off it instead. | |||||
2018-07-24 | deconstructed_rom_directory: Remove unused FindRomFS() function | Lioncash | 1 | -29/+0 | |
2018-07-24 | friend: Add friend:m, friend:s, and friend:v services | Lioncash | 1 | -0/+3 | |
Given we already have friend:a and friend:u, we should add the remaining services as well. | |||||
2018-07-24 | friend/interface: Add missing CreateDaemonSuspendSessionService() to the function handler table | Lioncash | 1 | -0/+1 | |
2018-07-24 | friend: Deduplicate interfaces | Lioncash | 6 | -48/+11 | |
2018-07-24 | svc: Resolve sign comparison warnings in WaitSynchronization() | Lioncash | 1 | -4/+7 | |
The loop's induction variable was signed, but we were comparing against an unsigned variable. | |||||
2018-07-24 | svc: Log parameters in SetMemoryAttribute() | Lioncash | 1 | -1/+3 | |
Provides slightly more context than only logging out the address value. | |||||
2018-07-24 | time: Simplify interface creation | Lioncash | 6 | -64/+15 | |
We can use one instance of the interface instead of duplicating code. | |||||
2018-07-24 | core_timing: Split off utility functions into core_timing_util | MerryMage | 12 | -105/+137 | |
2018-07-24 | CMakeLists: Sort filenames | MerryMage | 1 | -9/+9 | |
2018-07-24 | wait_tree: Silence warning about all code paths not returning a value | Lioncash | 1 | -0/+3 | |
If code execution hits this spot, something has gone very wrong, so mark the path as unreachable. This silences a warning on MSVC. | |||||
2018-07-24 | set_sys: Implement SetColorSetId() | Lioncash | 2 | -5/+25 | |
2018-07-24 | ipc_helper: Add helper member function for popping enum values to RequestParser | Lioncash | 1 | -0/+8 | |
2018-07-24 | gl_rasterizer: Implement texture border color. | bunnei | 3 | -11/+11 | |
2018-07-24 | maxwell_to_gl: Implement Texture::WrapMode::Border. | bunnei | 1 | -0/+2 | |
2018-07-24 | GPU: Implement texture format R32F. | Subv | 3 | -6/+19 | |
2018-07-24 | arm_dynarmic: Make MakeJit() a const member function | Lioncash | 2 | -3/+3 | |
This functions doesn't modify instance state, so it can be a made a const member function. | |||||
2018-07-24 | core: Make converting constructors explicit where applicable | Lioncash | 5 | -5/+5 | |
Avoids unwanted implicit conversions. Thankfully, given the large amount of cleanup in past PRs, only this tiny amount is left over to cover. | |||||
2018-07-24 | maxwell_to_gl: Implement VertexAttribute::Type::UnsignedInt. | bunnei | 1 | -0/+3 | |
2018-07-24 | apm/interface: Remove redundant declaration of InstallInterfaces() | Lioncash | 1 | -3/+0 | |
This is already declared in apm/apm.h | |||||
2018-07-24 | mutex: Pass SharedPtr to GetHighestPriorityMutexWaitingThread() by reference | Lioncash | 1 | -1/+1 | |
The pointed to thread's members are simply observed in this case, so we don't need to copy it here. | |||||
2018-07-24 | VFS Regression and Accuracy Fixes (#776) | Zach Hilman | 5 | -37/+75 | |
* Regression and Mode Fixes * Review Fixes * string_view correction * Add operator& for FileSys::Mode * Return std::string from SanitizePath * Farming Simulator Fix * Use != With mode operator& | |||||
2018-07-24 | hle_ipc: Make constructors explicit where applicable | Lioncash | 2 | -12/+13 | |
2018-07-24 | gl_shader_decompiler: Correct return value of WriteTexsInstruction() | Lioncash | 1 | -2/+2 | |
This should be returning void, not a std::string | |||||
2018-07-24 | ipc_helpers: Make member variables of ResponseBuilder private | Lioncash | 1 | -5/+6 | |
These aren't used externally at all, so they can be made private. | |||||
2018-07-24 | gl_shader_decompiler: Implement shader instruction TLDS. | bunnei | 1 | -29/+43 | |
2018-07-24 | gl_rasterizer_cache: Implement RenderTargetFormat RG32_FLOAT. | bunnei | 5 | -7/+25 | |
2018-07-24 | gl_rasterizer_cache: Implement RenderTargetFormat RGBA32_FLOAT. | bunnei | 2 | -10/+34 | |
2018-07-24 | gl_rasterizer_cache: Implement RenderTargetFormat BGRA8_UNORM. | bunnei | 4 | -8/+22 | |
2018-07-24 | gl_rasterizer_cache: Add missing log statements. | bunnei | 1 | -0/+2 | |
2018-07-24 | gl_shader_decompiler: Print instruction value in shader comments. | bunnei | 1 | -1/+2 | |
2018-07-24 | gl_shader_decompiler: Check if SetRegister result is ZeroIndex. | bunnei | 1 | -0/+6 | |
2018-07-24 | exclusive_monitor: Use consistent type alias for u64 | Lioncash | 3 | -22/+18 | |
Uses the same type aliases we use for virtual addresses, and converts one lingering usage of std::array<uint64_t, 2> to u128 for consistency. | |||||
2018-07-24 | partition_filesystem: Use std::move where applicable | Lioncash | 1 | -3/+3 | |
Avoids copying a std::string instance and avoids unnecessary atomic reference count incrementing and decrementing. | |||||
2018-07-23 | loader: Remove unnecessary constructor call in IdentifyFile() | Lioncash | 1 | -1/+1 | |
RealVfsFile inherits from VfsFile, the instance from std::make_shared is already compatible with the function argument type, making the copy constructor call unnecessary. | |||||
2018-07-23 | linker: Remove unused parameter from WriteRelocations() | Lioncash | 2 | -7/+4 | |
is_jump_relocation is never used within the function, so we can just remove it. | |||||
2018-07-23 | nro: Replace inclusion with a forward declaration | Lioncash | 2 | -1/+8 | |
It's sufficient to use a forward declaration instead of a direct inclusion here. | |||||
2018-07-23 | nro: Make bracing consistent | Lioncash | 1 | -10/+24 | |
Makes the code more uniform, and also braces cases where the body of an unbraced conditional travels more than one line. | |||||
2018-07-23 | nro: Make constructor explicit | Lioncash | 1 | -1/+1 | |
Makes it consistent with the other Apploader constructors, and prevents implicit conversions. | |||||
2018-07-23 | nro: Remove unused forward declaration | Lioncash | 1 | -2/+0 | |
This isn't used anywhere in the header. | |||||
2018-07-23 | gl_shader_decompiler: Simplify GetCommonDeclarations() | Lioncash | 1 | -5/+5 | |
2018-07-23 | vi: Add std::is_trivially_copyable checks to Read and Write functions | Lioncash | 1 | -2/+13 | |
It's undefined behavior to memcpy an object that isn't considered trivially copyable, so put a compile-time check in to make sure this doesn't occur. | |||||
2018-07-23 | vi: std::move std::vector in constructors where applicable | Lioncash | 1 | -9/+9 | |
Allows avoiding unnecessary copies of the vector depending on the calling code. While we're at it, remove a redundant no-parameter base constructor call | |||||
2018-07-23 | hle: Remove config_mem.h/.cpp | Lioncash | 6 | -102/+0 | |
This is just an unused hold-over from citra, so we can get rid of this to trim off an exposed global, among other things. | |||||
2018-07-23 | hle: Remove shared_page.h/.cpp | Lioncash | 6 | -161/+0 | |
This is a holdover from citra that's essentially unused. | |||||
2018-07-23 | set: Add missing log call in GetAvailableLanguageCodeCount() | Lioncash | 1 | -0/+2 | |
Forgot to include this in 22f448b6327044076959e338811ee576f3dcf093 | |||||
2018-07-23 | NRO Assets and NACP file format | Zach Hilman | 5 | -1/+215 | |
Cleanup Review fixes | |||||
2018-07-23 | set: Implement GetAvailableLanguageCodeCount() | Lioncash | 2 | -21/+29 | |
This just returns the size of the language code buffer. | |||||
2018-07-23 | set: Correct return code size of value in GetAvailableLanguageCodes() | Lioncash | 1 | -2/+2 | |
The return code should be 32-bit in size. | |||||
2018-07-22 | string_util: Get rid of separate resize() in CPToUTF16(), UTF16ToUTF8(), CodeToUTF8() and UTF8ToUTF16() | Lioncash | 1 | -20/+22 | |
There's no need to perform the resize separately here, since the constructor allows presizing the buffer. Also move the empty string check before the construction of the string to make the early out more straightforward. | |||||
2018-07-22 | string_util: Use emplace_back() in SplitString() instead of push_back() | Lioncash | 1 | -2/+3 | |
This is equivalent to doing: push_back(std::string("")); which is likely not to cause issues, assuming a decent std::string implementation with small-string optimizations implemented in its design, however it's still a little unnecessary to copy that buffer regardless. Instead, we can use emplace_back() to directly construct the empty string within the std::vector instance, eliminating any possible overhead from the copy. | |||||
2018-07-22 | string_util: Remove unnecessary std::string instance in TabsToSpaces() | Lioncash | 2 | -8/+7 | |
We can just use the variant of std::string's replace() function that can replace an occurrence with N copies of the same character, eliminating the need to allocate a std::string containing a buffer of spaces. | |||||
2018-07-22 | Kernel/SVC: Perform atomic accesses in SignalProcessWideKey as per the real kernel. | Subv | 1 | -7/+31 | |
2018-07-22 | Frontend: Check for more required OpenGL extensions during startup. | Subv | 2 | -2/+24 | |
2018-07-22 | Implement exclusive monitor | MerryMage | 9 | -13/+160 | |
2018-07-22 | gl_shader_decompiler: Remove redundant Subroutine construction in AddSubroutine() | Lioncash | 1 | -4/+8 | |
We don't need to toss away the Subroutine instance after the find() call and reconstruct another instance with the same data right after it. Particularly give Subroutine contains a std::set. | |||||
2018-07-22 | shader_bytecode: Implement other TEXS masks. | bunnei | 1 | -5/+9 | |
2018-07-22 | vfs: Correct file_p variable usage within InterpretAsDirectory() | Lioncash | 1 | -2/+5 | |
ReplaceFileWithSubdirectory() takes a VirtualFile and a VirtualDir, but it was being passed a string as one of its arguments. The only reason this never caused issues is because this template isn't instantiated anywhere yet. This corrects an issue before it occurs. | |||||
2018-07-22 | file_util, vfs: Use std::string_view where applicable | Lioncash | 10 | -131/+208 | |
Avoids unnecessary construction of std::string instances where applicable. | |||||
2018-07-22 | gl_shader_decompiler: Remove unused state tracking and minor cleanup. | bunnei | 1 | -78/+15 | |
2018-07-22 | gl_shader_decompiler: Implement SEL instruction. | bunnei | 2 | -0/+20 | |
2018-07-22 | file_util: Remove goto usages from Copy() | Lioncash | 1 | -24/+14 | |
We can just leverage std::unique_ptr to automatically close these for us in error cases instead of jumping to the end of the function to call fclose on them. | |||||
2018-07-22 | file_util: Use a u64 to represent number of entries | Lioncash | 5 | -18/+18 | |
This avoids a truncating cast on size. I doubt we'd ever traverse a directory this large, however we also shouldn't truncate sizes away. | |||||
2018-07-22 | file_util: std::move FST entries in ScanDirectoryTree() | Lioncash | 1 | -1/+1 | |
Avoids unnecessary copies when building up the FST entries. | |||||
2018-07-22 | gl_rasterizer_cache: Blit surfaces on recreation instead of flush and load. | bunnei | 2 | -2/+86 | |
2018-07-22 | gl_rasterizer_cache: Use GPUVAddr as cache key, not parameter set. | bunnei | 3 | -57/+46 | |
2018-07-22 | gl_rasterizer_cache: Use zeta_width and zeta_height registers for depth buffer. | bunnei | 2 | -11/+11 | |
2018-07-22 | gl_rasterizer: Use zeta_enable register to enable depth buffer. | bunnei | 1 | -2/+2 | |
2018-07-22 | maxwell_3d: Add depth buffer enable, width, and height registers. | bunnei | 1 | -2/+14 | |
2018-07-21 | GPU: Implement the NVGPU_IOCTL_CHANNEL_KICKOFF_PB ioctl2 command. | Subv | 3 | -6/+34 | |
This behaves quite similarly to the SubmitGPFIFO command. Referenced from Ryujinx. Many thanks to @gdkchan for investigating this! | |||||
2018-07-21 | file_util: Use an enum class for GetUserPath() | Lioncash | 11 | -73/+85 | |
Instead of using an unsigned int as a parameter and expecting a user to always pass in the correct values, we can just convert the enum into an enum class and use that type as the parameter type instead, which makes the interface more type safe. We also get rid of the bookkeeping "NUM_" element in the enum by just using an unordered map. This function is generally low-frequency in terms of calls (and I'd hope so, considering otherwise would mean we're slamming the disk with IO all the time) so I'd consider this acceptable in this case. | |||||
2018-07-21 | file_util: Remove explicit type from std::min() in GetPathWithoutTop() | Lioncash | 1 | -1/+1 | |
Given both operands are the same type, there won't be an issue with overload selection that requires making this explicit. | |||||
2018-07-21 | file_util: Remove redundant duplicate return in GetPathWithoutTop() | Lioncash | 1 | -1/+0 | |
2018-07-21 | common: Remove synchronized_wrapper.h | Lioncash | 2 | -86/+0 | |
This is entirely unused in the codebase. | |||||
2018-07-21 | file_sys/errors: Remove redundant object constructor calls | Lioncash | 1 | -8/+8 | |
Given we're already constructing the error code, we don't need to call the constructor inside of it. | |||||
2018-07-21 | vfs_real: Remove redundant copying of std::vector instances in GetFiles() and GetSubdirectories() | Lioncash | 1 | -2/+3 | |
We already return by value, so we don't explicitly need to make the copy. | |||||
2018-07-21 | partition_filesystem, vfs_real: Add missing standard includes | Lioncash | 2 | -0/+4 | |
2018-07-21 | partition_filesystem, vfs_real: Use std::move in ReplaceFileWithSubdirectory() where applicable | Lioncash | 2 | -2/+3 | |
Avoids unnecessary atomic increment and decrement operations. | |||||
2018-07-21 | partition_filesystem, vfs_real: Use std::distance() instead of subtraction | Lioncash | 2 | -4/+10 | |
This is a little bit more self-documenting on what is being done here. | |||||
2018-07-21 | vfs_offset: Simplify TrimToFit() | Lioncash | 1 | -1/+2 | |
We can simply use std::clamp() here, instead of using an equivalent with std::max() and std::min(). | |||||
2018-07-21 | vfs: Make WriteBytes() overload taking a std::vector pass the std::vector by const reference | Lioncash | 4 | -4/+4 | |
Given the data is intended to be directly written, there's no need to take the std::vector by value and copy the data. | |||||
2018-07-21 | vfs: Use variable template variants of std::is_trivially_copyable | Lioncash | 1 | -13/+6 | |
Provides the same behavior, but with less writing | |||||
2018-07-21 | vfs: Amend constness on pointers in WriteBytes() and WriteArrays() member functions to be const qualified | Lioncash | 1 | -3/+3 | |
These functions don't modify the data being pointed to, so these can be pointers to const data | |||||
2018-07-21 | Loader: Only print the module names and addresses if they actually exist. | Subv | 1 | -5/+2 | |
2018-07-21 | CPU: Save and restore the TPIDR_EL0 system register on every context switch. | Subv | 8 | -0/+39 | |
Note that there's currently a dynarmic bug preventing this register from being written. | |||||
2018-07-21 | arm_interface: Remove unused tls_address member of ThreadContext | Lioncash | 3 | -9/+0 | |
Currently, the TLS address is set within the scheduler, making this member unused. | |||||
2018-07-21 | gl_shader_manager: Replace unimplemented function prototype | Lioncash | 2 | -3/+3 | |
This was just a linker error waiting to happen. | |||||
2018-07-21 | gpu: Rename Get3DEngine() to Maxwell3D() | Lioncash | 4 | -14/+17 | |
This makes it match its const qualified equivalent. | |||||
2018-07-21 | video_core: Use nested namespaces where applicable | Lioncash | 11 | -48/+24 | |
Compresses a few namespace specifiers to be more compact. | |||||
2018-07-20 | arm_test_common: Get rid of truncation warnings | Lioncash | 1 | -2/+5 | |
Explicitly cast the value to a u8 to show that this is intentional. | |||||
2018-07-20 | arm_test_common: Make file static variable a member variable of the testing environment | Lioncash | 2 | -2/+5 | |
Gets rid of file-static behavior. | |||||
2018-07-20 | arm_test_common: Add missing header guard | Lioncash | 1 | -0/+2 | |
2018-07-20 | param_package: Take std::string by value in string-based Set() function | Lioncash | 2 | -4/+6 | |
Allows avoiding string copies by letting the strings be moved into the function calls. | |||||
2018-07-20 | param_package: Use std::unordered_map's insert_or_assign instead of map indexing | Lioncash | 1 | -3/+3 | |
This avoids a redundant std::string construction if a key doesn't exist in the map already. e.g. data[key] requires constructing a new default instance of the value in the map (but this is wasteful, since we're already setting something into the map over top of it). | |||||
2018-07-20 | param_package: Get rid of file-static std::string construction | Lioncash | 1 | -3/+4 | |
Avoids potential dynamic allocation occuring during program launch | |||||
2018-07-20 | logging/filter: Use std::string_view in ParseFilterString() | Lioncash | 2 | -41/+40 | |
Allows avoiding constructing std::string instances, since this only reads an arbitrary sequence of characters. We can also make ParseFilterRule() internal, since it doesn't depend on any private instance state of Filter | |||||
2018-07-20 | logging/backend: Add missing standard includes | Lioncash | 2 | -4/+3 | |
A few inclusions were being satisfied indirectly. To prevent breakages in the future, include these directly. | |||||
2018-07-20 | logging/backend: Use std::string_view in RemoveBackend() and GetBackend() | Lioncash | 2 | -12/+13 | |
These can just use a view to a string since its only comparing against two names in both cases for matches. This avoids constructing std::string instances where they aren't necessary. | |||||
2018-07-20 | apm: Improve stub for GetPerformanceConfiguration. | bunnei | 1 | -1/+16 | |
2018-07-20 | ipc_helpers: Add PushEnum() member function to ResponseBuilder | Lioncash | 1 | -0/+19 | |
Allows pushing strongly-typed enum members without the need to always cast them at the call sites. Note that we *only* allow strongly-typed enums in this case. The reason for this is that strongly typed enums have a guaranteed defined size, so the size of the data being pushed is always deterministic. With regular enums this can be a little more error-prone, so we disallow them. This function simply uses the underlying type of the enum to determine the size of the data. For example, if an enum is defined as: enum class SomeEnum : u16 { SomeEntry }; if PushEnum(SomeEnum::SomeEntry); is called, then it will push a u16-size amount of data. | |||||
2018-07-20 | HLE/ACC: Stub IManagerForApplication::GetAccountId to return an error. | Subv | 1 | -6/+8 | |
And make IManagerForApplication::CheckAvailability always return false. Returning a bogus id from GetAccountId causes games to crash on boot. We should investigate this with a hwtest and either stub it properly or implement it. | |||||
2018-07-20 | gl_state: Make references const where applicable in Apply() | Lioncash | 1 | -2/+3 | |
2018-07-20 | gl_state: Get rid of mismatched sign conversions | Lioncash | 1 | -14/+17 | |
While we're at it, amend the loop variable type to be the same width as that returned by the .size() call. | |||||
2018-07-20 | loader/{nca, nro}: std::move VirtualFile in the constructors where applicable | Lioncash | 2 | -2/+4 | |
This avoids unnecessary atomic reference count increments and decrements | |||||
2018-07-20 | vfs_offset: std::move file and name parameters of OffsetVfsFile | Lioncash | 2 | -3/+5 | |
Avoids potentially unnecessary atomic reference count incrementing and decrementing, as well as string copying. | |||||
2018-07-20 | audren_u: Use a std::array instead of std::string for holding the audio interface/device name | Lioncash | 1 | -2/+4 | |
std::string doesn't include the null-terminator in its data() + size() range. This ensures that the null-terminator will also be written to the buffer | |||||
2018-07-20 | audout_u: Use a std::array instead of std::string for holding the audio interface name | Lioncash | 1 | -1/+2 | |
Uses a type that doesn't potentially dynamically allocate, and ensures that the name of the interface is properly null-terminated when writing it to the buffer. | |||||
2018-07-20 | maxwell_3d: Remove unused variable within GetStageTextures() | Lioncash | 1 | -2/+0 | |
2018-07-20 | thread: Convert ThreadStatus into an enum class | Lioncash | 10 | -93/+92 | |
Makes the thread status strongly typed, so implicit conversions can't happen. It also makes it easier to catch mistakes at compile time. | |||||
2018-07-20 | partition_filesystem: Return pfs_dirs member variable within GetSubdirectories() | Lioncash | 1 | -1/+1 | |
This should be returned here, otherwise pfs_dirs is effectively only ever added to, but never read. | |||||
2018-07-20 | nso: Silence implicit sign conversion warnings | Lioncash | 1 | -4/+6 | |
2018-07-20 | nso: Remove unused function ReadSegment() | Lioncash | 1 | -13/+0 | |
2018-07-20 | gl_shader_decompiler: Eliminate variable and declaration shadowing | Lioncash | 1 | -6/+4 | |
Ensures that no identifiers are being hidden, which also reduces compiler warnings. | |||||
2018-07-20 | gl_shader_decompiler: Remove unnecessary const from return values | Lioncash | 1 | -2/+2 | |
This adds nothing from a behavioral point of view, and can inhibit the move constructor/RVO | |||||
2018-07-20 | pl_u: Simplify WriteBuffer() calls in GetSharedFontInOrderOfPriority() | Lioncash | 1 | -3/+3 | |
With the new overload, we can simply pass the container directly. | |||||
2018-07-19 | HLE/ACC: Return an IProfile that is consistent with what was requested. | Subv | 1 | -5/+15 | |
The default username for now is "yuzu". We should eventually allow the creation of users in the emulator and have the ability to modify their parameters. | |||||
2018-07-19 | HLE/ACC: Change the default user id to be consistent with what we tell games on startup. | Subv | 1 | -2/+1 | |
In IApplicationFunctions::PopLaunchParameter we tell the games that they were launched as user id 1. | |||||
2018-07-19 | HLE/ACC: Write a single whole user id in ListAllUsers and ListOpenUsers. | Subv | 1 | -4/+6 | |
We only emulate a single user id for now. | |||||
2018-07-19 | hle_ipc: Introduce generic WriteBuffer overload for multiple container types | Lioncash | 5 | -10/+25 | |
This introduces a slightly more generic variant of WriteBuffer(). Notably, this variant doesn't constrain the arguments to only accepting std::vector instances. It accepts whatever adheres to the ContiguousContainer concept in the C++ standard library. This essentially means, std::array, std::string, and std::vector can be used directly with this interface. The interface no longer forces you to solely use containers that dynamically allocate. To ensure our overloads play nice with one another, we only enable the container-based WriteBuffer if the argument is not a pointer, otherwise we fall back to the pointer-based one. | |||||
2018-07-19 | pl_u: Specify correct size for buffers in GetSharedFontInOrderOfPriority() | Lioncash | 1 | -3/+3 | |
This WriteBuffer overload expects its size argument to be in bytes, not elements. | |||||
2018-07-19 | svc: Correct always true assertion case in SetThreadCoreMask | Lioncash | 1 | -3/+4 | |
The reason this would never be true is that ideal_processor is a u8 and THREADPROCESSORID_DEFAULT is an s32. In this case, it boils down to how arithmetic conversions are performed before performing the comparison. If an unsigned value has a lesser conversion rank (aka smaller size) than the signed type being compared, then the unsigned value is promoted to the signed value (i.e. u8 -> s32 happens before the comparison). No sign-extension occurs here either. An alternative phrasing: Say we have a variable named core and it's given a value of -2. u8 core = -2; This becomes 254 due to the lack of sign. During integral promotion to the signed type, this still remains as 254, and therefore the condition will always be true, because no matter what value the u8 is given it will never be -2 in terms of 32 bits. Now, if one type was a s32 and one was a u32, this would be entirely different, since they have the same bit width (and the signed type would be converted to unsigned instead of the other way around) but would still have its representation preserved in terms of bits, allowing the comparison to be false in some cases, as opposed to being true all the time. --- We also get rid of two signed/unsigned comparison warnings while we're at it. | |||||
2018-07-19 | pl_u: Remove printf specifier in log call in a log call in GetSharedFontInOrderOfPriority() | Lioncash | 1 | -1/+1 | |
This can just use the fmt specifiers and be type-agnostic. | |||||
2018-07-19 | gdbstub: Get rid of a few signed/unsigned comparisons | Lioncash | 1 | -7/+7 | |
Ensures both operands in comparisons are the same signedness. | |||||
2018-07-19 | hid: Use a ranged-for loops in UpdatePadCallback | Lioncash | 1 | -7/+3 | |
Modernizes the loops themselves while also getting rid of a signed/unsigned comparison in a loop condition. | |||||
2018-07-19 | hid: Use HID_NUM_LAYOUTS constant for indicating size of the layouts array | Lioncash | 1 | -1/+1 | |
Gets rid of the use of a magic constant | |||||
2018-07-19 | Filesystem: Return EntryType::Directory for the root directory. | Subv | 1 | -0/+4 | |
It is unknown if this is correct behavior, but it makes sense and fixes a regression with Stardew Valley. | |||||
2018-07-19 | loader: Amend Doxygen comments | Lioncash | 2 | -5/+5 | |
These weren't adjusted when VFS was introduced | |||||
2018-07-19 | loader/nso: Check if read succeeded in IdentifyFile() before checking magic value | Lioncash | 1 | -4/+6 | |
We should always assume the filesystem is volatile and check each IO operation. While we're at it reorganize checks so that early-out errors are near one another. | |||||
2018-07-19 | hle/service: Make constructors explicit where applicable | Lioncash | 22 | -25/+25 | |
Prevents implicit construction and makes these lingering non-explicit constructors consistent with the rest of the other classes in services. | |||||
2018-07-19 | nvflinger: Emplace Display instances directly | Lioncash | 1 | -9/+4 | |
We can use emplace_back to construct the Display instances directly, instead of constructing them separately and copying them, avoiding the need to copy std::string and std::vector instances that are part of the Display struct. | |||||
2018-07-19 | nvdrv: Take std::string by const reference in GetDevice() | Lioncash | 1 | -1/+1 | |
This is only ever used as a lookup into the device map, so we don't need to take the std::string instance by value here. | |||||
2018-07-19 | hle_ipc: Amend usage of buffer_index within one of HLERequestContext's WriteBuffer() overloads | Lioncash | 1 | -1/+1 | |
Previously, the buffer_index parameter was unused, causing all writes to use the buffer index of zero, which is not necessarily what is wanted all the time. Thankfully, all current usages don't use a buffer index other than zero, so this just prevents a bug before it has a chance to spring. | |||||
2018-07-19 | fsp_srv: Remove unnecessary vector construction in IFile's Write() function | Lioncash | 1 | -2/+3 | |
We can avoid constructing a std::vector here by simply passing a pointer to the original data and the size of the copy we wish to perform to the backend's Write() function instead, avoiding copying the data where it's otherwise not needed. | |||||
2018-07-19 | fsp_srv: Remove unnecessary std::vector construction in IDirectory's Read() function | Lioncash | 1 | -10/+8 | |
We were using a second std::vector as a buffer to convert another std::vector's data into a byte sequence, however we can just use pointers to the original data and use them directly with WriteBuffer, which avoids copying the data at all into a separate std::vector. We simply cast the pointers to u8* (which is allowed by the standard, given std::uint8_t is an alias for unsigned char on platforms that we support). | |||||
2018-07-19 | filesystem: std::move VirtualDir instance in VfsDirectoryServiceWrapper's constructor | Lioncash | 1 | -1/+3 | |
Avoids unnecessary atomic reference count incrementing and decrementing | |||||
2018-07-19 | filesystem: Use std::string's empty() function instead of comparing against a literal | Lioncash | 1 | -1/+1 | |
This is simply a basic value check as opposed to potentially doing string based operations (unlikely, but still, avoiding it is free). | |||||
2018-07-19 | filesystem: Remove pragma disabling global optimizations | Lioncash | 1 | -2/+0 | |
This was just an artifact missed during PR review. | |||||
2018-07-19 | fsp_srv: Make IStorage constructor explicit | Lioncash | 1 | -1/+1 | |
Prevents implicit conversions. | |||||
2018-07-19 | fsp_srv: Add missing includes | Lioncash | 1 | -0/+5 | |
Gets rid of relying on indirect inclusions. | |||||
2018-07-19 | fsp_srv: Resolve sign-mismatch warnings in assertion comparisons | Lioncash | 1 | -3/+3 | |
2018-07-19 | fsp_srv: Respect write length in Write() | Lioncash | 1 | -4/+5 | |
Previously we were just copying the data whole-sale, even if the length was less than the total data size. This effectively makes the actual_data vector useless, which is likely not intended. Instead, amend this to only copy the given length amount of data. At the same time, we can avoid zeroing out the data before using it by passing iterators to the constructor instead of a size. | |||||
2018-07-19 | common/swap: Remove unnecessary const on return value of swap() | Lioncash | 1 | -1/+1 | |
2018-07-19 | common/swap: Use static_cast where applicable | Lioncash | 1 | -16/+16 | |
2018-07-19 | common/swap: Use using aliases where applicable | Lioncash | 1 | -33/+33 | |
2018-07-19 | common/common_funcs: Remove unused rotation functions | Lioncash | 1 | -38/+0 | |
These are unused and essentially don't provide much benefit either. If we ever need rotation functions, these can be introduced in a way that they don't sit in a common_* header and require a bunch of ifdefing to simply be available | |||||
2018-07-19 | common/misc: Deduplicate code in GetLastErrorMsg() | Lioncash | 2 | -12/+8 | |
Android and macOS have supported thread_local for quite a while, but most importantly is that we don't even really need it. Instead of using a thread-local buffer, we can just return a non-static buffer as a std::string, avoiding the need for that quality entirely. | |||||
2018-07-19 | file_util: return string by const reference for GetExeDirectory() | Lioncash | 2 | -2/+2 | |
This disallows modifying the internal string buffer (which shouldn't be modified anyhow). | |||||
2018-07-19 | string_util: Remove AsciiToHex() | Lioncash | 2 | -15/+0 | |
Easy TODO | |||||
2018-07-19 | savedata_factory: Make SaveDataDescriptor's DebugInfo() function a const member function | Lioncash | 2 | -2/+2 | |
This function doesn't alter class state. | |||||
2018-07-19 | partition_filesystem: Ensure all class members of PartitionFilesystem are initialized | Lioncash | 2 | -24/+15 | |
Previously is_hfs and pfs_header members wouldn't be initialized in the constructor, as they were stored in locals instead. This would result in things like GetName() and PrintDebugInfo() behaving incorrectly. While we're at it, initialize the members to deterministic values as well, in case loading ever fails. | |||||
2018-07-19 | gl_state: Temporarily disable culling and depth test. | bunnei | 1 | -1/+3 | |
2018-07-19 | content_archive: Make IsDirectoryExeFS() take a shared_ptr as a const reference | Lioncash | 1 | -1/+1 | |
There's no need to take this by value when it's possible to avoid unnecessary copies entirely like this. | |||||
2018-07-19 | content_archive: Add missing standard includes | Lioncash | 1 | -0/+5 | |
2018-07-19 | content_archive: std::move VirtualFile in NCA's constructor | Lioncash | 1 | -1/+4 | |
Gets rid of unnecessary atomic reference count incrementing and decrementing. | |||||
2018-07-19 | vfs: Deduplicate accumulation code in VfsDirectory's GetSize() | Lioncash | 1 | -6/+6 | |
We can just use a generic lambda to avoid writing the same thing twice. | |||||
2018-07-19 | loader/nro: Resolve sign mismatch warnings | Lioncash | 1 | -1/+1 | |
2018-07-19 | loader/nso: Remove unnecessary vector resizes | Lioncash | 1 | -4/+2 | |
We can just initialize these vectors directly via their constructor. | |||||
2018-07-19 | loader/nso: Resolve sign mismatch warnings | Lioncash | 1 | -1/+1 | |
2018-07-19 | decoders: Fix calc of swizzle image_width_in_gobs. | bunnei | 1 | -1/+4 | |
2018-07-19 | Virtual Filesystem 2: Electric Boogaloo (#676) | Zach Hilman | 54 | -1959/+1926 | |
* Virtual Filesystem * Fix delete bug and documentate * Review fixes + other stuff * Fix puyo regression | |||||
2018-07-19 | core/memory: Remove unused function GetSpecialHandlers() and an unused variable in ZeroBlock() | Lioncash | 1 | -7/+0 | |
2018-07-19 | address_arbiter: Correct assignment within an assertion statement in WakeThreads() | Lioncash | 1 | -1/+1 | |
This was introduced within 4f81bc4e1bd12e4df7410c6790ba818d8dbba9c0, and considering there's no comment indicating that this is intentional, this is very likely a bug. | |||||
2018-07-19 | service/prepo: Add missing header guard | Lioncash | 1 | -0/+2 | |
2018-07-19 | vm_manager: Add missing commas to string literal array elements in GetMemoryStateName() | Lioncash | 1 | -22/+12 | |
Without these, this would perform concatenation, which is definitely not what we want here. | |||||
2018-07-19 | core/memory, core/hle/kernel: Use std::move where applicable | Lioncash | 9 | -16/+26 | |
Avoids pointless copies | |||||
2018-07-19 | core: Make System's default constructor private | Lioncash | 2 | -0/+4 | |
This makes it a compilation error to construct additional instances of the System class directly, preventing accidental wasteful constructions over and over. | |||||
2018-07-19 | core: Don't construct instance of Core::System, just to access its live instance | Lioncash | 5 | -22/+22 | |
This would result in a lot of allocations and related object construction, just to toss it all away immediately after the call. These are definitely not intentional, and it was intended that all of these should have been accessing the static function GetInstance() through the name itself, not constructed instances. | |||||
2018-07-18 | externals: update fmt to version 5.1.0 | Lioncash | 1 | -1/+1 | |
Previously, we were on 4.1.0, which was a major version behind. | |||||
2018-07-18 | hle/filesystem: Amend trace log in OpenSaveData() to compile in debug mode | Lioncash | 1 | -1/+1 | |
Previously this wouldn't compile, since no such function named SaveStructDebugInfo() exists. | |||||
2018-07-18 | game_list: Make ContainsAllWords an internally linked non-member function | Lioncash | 2 | -2/+1 | |
This function actually depends on no internal class state, so it doesn't even need to be a part of the class interface. | |||||
2018-07-18 | Fill in more fields in TouchScreenEntryTouch | Zach Hilman | 1 | -4/+9 | |
2018-07-18 | Single touch support | Zach Hilman | 1 | -4/+19 | |
2018-07-18 | telemetry: Remove unnecessary Field constructor | Lioncash | 1 | -4/+1 | |
We can just take the value parameter by value which allows both moving into it, and copies at the same time, depending on the calling code. | |||||
2018-07-18 | telemetry: Make operator== and operator!= const member functions of Field | Lioncash | 1 | -2/+2 | |
These operators don't modify internal class state, so they can be made const member functions. While we're at it, drop the unnecessary inline keywords. Member functions that are defined in the class declaration are already inline by default. | |||||
2018-07-18 | telemetry: Default copy/move constructors and assignment operators | Lioncash | 1 | -14/+4 | |
This provides the equivalent behavior, but without as much boilerplate. While we're at it, explicitly default the move constructor, since we have a move-assignment operator defined. | |||||
2018-07-18 | game_list: Upper-case containsAllWords to ContainsAllWords() | Lioncash | 2 | -3/+3 | |
This makes it consistent with most of the other private utility functions. | |||||
2018-07-18 | game_list: Make containsAllWords a const member function | Lioncash | 2 | -4/+6 | |
This doesn't actually modify the internal class state, so it can be a const member function. While we're at it, amend the function to take its arguments by const reference. | |||||
2018-07-18 | game_list: Remove unnecessary QString initialization in KeyReleaseEater | Lioncash | 1 | -4/+1 | |
QString initializes to an empty string by default, so this does nothing meaningful. While we're at it, use a constructor initializer list for initializing the gamelist member variable. | |||||
2018-07-18 | astc: Initialize vector size directly in Decompress | Lioncash | 1 | -2/+1 | |
There's no need to perform a separate resize. | |||||
2018-07-18 | astc: Mark functions as internally linked where applicable | Lioncash | 1 | -17/+20 | |
2018-07-18 | astc: const-correctness changes where applicable | Lioncash | 1 | -14/+13 | |
A few member functions didn't actually modify class state, so these can be amended as necessary. | |||||
2018-07-18 | astc: Delete Bits' copy contstructor and assignment operator | Lioncash | 1 | -8/+6 | |
This also potentially avoids warnings, considering the copy assignment operator is supposed to have a return value. | |||||
2018-07-18 | astc: In-class initialize member variables where appropriate | Lioncash | 1 | -39/+22 | |
2018-07-18 | settings: Turn docked mode off by default. | bunnei | 3 | -3/+3 | |
2018-07-18 | vi: Change TransactionId::CancelBuffer to LOG_CRITICAL. | bunnei | 1 | -1/+1 | |
2018-07-18 | vi: Fix size for ListDisplays default display. | bunnei | 1 | -2/+2 | |
2018-07-18 | vi: Partially implement buffer crop parameters. | bunnei | 9 | -14/+46 | |
2018-07-17 | GPU: Added register definitions for the stencil parameters. | Subv | 1 | -2/+25 | |
2018-07-17 | General Filesystem and Save Data Fixes (#670) | Zach Hilman | 16 | -212/+256 | |
2018-07-17 | nvflinger: Fix for BufferQueue event handling. | bunnei | 6 | -32/+21 | |
2018-07-17 | Kernel/Arbiter: Fix bug in WaitIfLessThan | Michael Scire | 1 | -2/+4 | |
2018-07-16 | scheduler: Clear exclusive state when switching contexts | MerryMage | 6 | -0/+11 | |
2018-07-15 | HID: Update controllers less often | James Rowe | 1 | -3/+3 | |
2018-07-15 | Logging: Dump all logs in the queue on close in debug mode | James Rowe | 3 | -1/+12 | |
2018-07-15 | gl_rasterizer_cache: Implement texture format G8R8. | bunnei | 3 | -9/+40 | |
2018-07-15 | gl_rasterizer_cache: Fix incorrect offset in ConvertS8Z24ToZ24S8. | bunnei | 1 | -1/+2 | |
2018-07-15 | gl_rasterizer_cache: Implement depth format Z16_UNORM. | bunnei | 3 | -1/+15 | |
2018-07-14 | Logging: Don't lock the queue for the duration of the write | James Rowe | 1 | -3/+5 | |
2018-07-14 | Services/BSD: Corrected the return for StartMonitoring according to SwIPC. | Subv | 1 | -2/+1 | |
2018-07-14 | FileSys: Append the requested path to the filesystem base path in DeleteFile. | Subv | 1 | -2/+4 | |
We were trying to delete things in the current directory instead of the actual filesystem directory. This may fix some savedata issues in some games. | |||||
2018-07-14 | No need to use ASSERT_MSG with an empty message | David Marcec | 1 | -2/+2 | |
2018-07-14 | OpenGL: Use MakeCurrent/DoneCurrent for multithreaded rendering. | bunnei | 6 | -2/+39 | |
2018-07-14 | GPU: Always enable the depth write when clearing the depth buffer. | Subv | 1 | -3/+8 | |
The GPU ignores that register when clearing, but OpenGL obeys the glDepthMask parameter, so we set the depth mask to GL_TRUE when clearing the depth buffer. It will be restored to the correct value automatically on the next draw call. | |||||
2018-07-13 | More improvements to GDBStub (#653) | Hedges | 8 | -50/+173 | |
* More improvements to GDBStub - Debugging of threads should work correctly with source and assembly level stepping and modifying registers and memory, meaning threads and callstacks are fully clickable in VS. - List of modules is available to the client, with assumption that .nro and .nso are backed up by an .elf with symbols, while deconstructed ROMs keep N names. - Initial support for floating point registers. * Tidy up as requested in PR feedback * Tidy up as requested in PR feedback | |||||
2018-07-13 | gl_rasterizer: Fix check for if a shader stage is enabled. | bunnei | 3 | -35/+11 | |
2018-07-13 | gl_shader_gen: Implement dual vertex shader mode. | bunnei | 5 | -55/+139 | |
- When VertexA shader stage is enabled, we combine with VertexB program to make a single Vertex Shader stage. | |||||
2018-07-13 | We only need to alert for memory pool changes | David Marcec | 1 | -2/+0 | |
2018-07-13 | initialized voice status and unused sizes in the update data header | David Marcec | 1 | -1/+3 | |
2018-07-13 | gl_shader_decompiler: Implement PredCondition::LessThanWithNan. | bunnei | 2 | -5/+7 | |
2018-07-13 | gl_shader_decompiler: Use FlowCondition field in EXIT instruction. | bunnei | 2 | -8/+34 | |
2018-07-12 | GPU: Implement the FADD32I shader instruction. | Subv | 2 | -0/+32 | |
2018-07-12 | Port #3335 and #3373 from Citra: "Small SDL fixes" and "Print the actual error preventing SDL from working" (#637) | Tobias | 2 | -6/+4 | |
* Port #3335 and #3373 from Citra * Fixup: Use the new logging placeholders | |||||
2018-07-12 | GPU: Corrected the decoding of FFMA for immediate operands. | Subv | 1 | -1/+1 | |
2018-07-12 | yuzu - Fix duplicate logs | James Rowe | 2 | -2/+7 | |
2018-07-12 | yuzu-cmd Apply the filter string from settings | James Rowe | 1 | -2/+1 | |
2018-07-12 | Audout "Auto" functions | David Marcec | 2 | -14/+14 | |
Audout autos are identical to their counterpart except for the buffer type which yuzu already handles for us. | |||||
2018-07-12 | Added IsWirelessCommunicationEnabled, IsEthernetCommunicationEnabled, IsAnyInternetRequestAccepted | David Marcec | 1 | -3/+21 | |
Since we have no socket implementation we should be returning 0 to indicate we're currently offline. | |||||
2018-07-11 | hid: Fix timestamps and controller type. | bunnei | 1 | -7/+5 | |
- This fixes user input in SMO. | |||||
2018-07-10 | NvOsGetConfigU32 production impl | David Marcec | 1 | -17/+2 | |
Settings are only used when RMOS_SET_PRODUCTION_MODE is set to 0. If production mode is set, the error code 0x30006 is returned instead | |||||
2018-07-08 | savedata_factory: Always create a save directory for games. | bunnei | 1 | -0/+9 | |
2018-07-08 | nvhost_ctrl: Fix NvOsGetConfigU32 for Snipper Clips. | bunnei | 1 | -1/+1 | |
2018-07-08 | gl_rasterizer: Flip triangles when regs.viewport_transform[0].scale_y is negative. | bunnei | 1 | -1/+4 | |
- Fixes a regression with Binding of Isaac. | |||||
2018-07-08 | Revert "Virtual Filesystem (#597)" | bunnei | 45 | -1784/+1676 | |
This reverts commit 77c684c1140f6bf3fb7d4560d06d2efb1a2ee5e2. | |||||
2018-07-07 | GPU: Implemented the BC7U texture format. | Subv | 3 | -7/+21 | |
Note: Our version of glad exports GL_COMPRESSED_RGBA_BPTC_UNORM as GL_COMPRESSED_RGBA_BPTC_UNORM_ARB, maybe it's time we update it. | |||||
2018-07-07 | Port #3474 from Citra | fearlessTobi | 1 | -1/+1 | |
2018-07-07 | Port #3505 from CItra | fearlessTobi | 1 | -6/+7 | |
2018-07-07 | Port #3579 from Citra | fearlessTobi | 3 | -7/+7 | |
2018-07-06 | Virtual Filesystem (#597) | Zach Hilman | 45 | -1676/+1784 | |
* Add VfsFile and VfsDirectory classes * Finish abstract Vfs classes * Implement RealVfsFile (computer fs backend) * Finish RealVfsFile and RealVfsDirectory * Finished OffsetVfsFile * More changes * Fix import paths * Major refactor * Remove double const * Use experimental/filesystem or filesystem depending on compiler * Port partition_filesystem * More changes * More Overhaul * FSP_SRV fixes * Fixes and testing * Try to get filesystem to compile * Filesystem on linux * Remove std::filesystem and document/test * Compile fixes * Missing include * Bug fixes * Fixes * Rename v_file and v_dir * clang-format fix * Rename NGLOG_* to LOG_* * Most review changes * Fix TODO * Guess 'main' to be Directory by filename | |||||
2018-07-06 | Remove some references to Citra | fearlessTobi | 3 | -3/+3 | |
2018-07-05 | GPU: Allow using the old NV04 values for the depth test function. | Subv | 2 | -9/+29 | |
These seem to be just a valid as the GL token values. Thanks @ReinUsesLisp This restores graphical output to Disgaea 5 | |||||
2018-07-04 | GPU: Implemented the IMNMX shader instruction. | Subv | 2 | -3/+31 | |
It's similar to the FMNMX instruction but it works on integers. | |||||
2018-07-04 | GPU: Implemented the F2F 'round' rounding mode. | Subv | 1 | -0/+3 | |
It's implemented via the GLSL 'roundEven()' function. | |||||
2018-07-04 | GPU: Stub the shader SYNC and DEPBAR instructions. | Subv | 2 | -0/+12 | |
It is unknown at this moment if we actually need to do something with these instructions or if the GLSL compiler takes care of that for us. | |||||
2018-07-04 | GPU: Implement the Size_16_16 and Size_10_10_10_2 vertex attribute types. | Subv | 1 | -0/+8 | |
Both signed and unsigned variants. | |||||
2018-07-04 | GPU: Ignore textures that the GLSL compiler deemed unused when binding textures to the shaders. | Subv | 1 | -1/+4 | |
2018-07-04 | GPU: Corrected the decoding for the TEX shader instruction. | Subv | 1 | -1/+1 | |
2018-07-04 | GPU: Implemented the PSETP shader instruction. | Subv | 2 | -0/+43 | |
It's similar to the isetp and fsetp instructions but it works on predicates instead. | |||||
2018-07-04 | GPU: Implemented the 32 bit float depth buffer format. | Subv | 3 | -2/+15 | |
2018-07-04 | GPU: Flip the triangle front face winding if the GPU is configured to not flip the triangles. | Subv | 2 | -3/+29 | |
OpenGL's default behavior is already correct when the GPU is configured to flip the triangles. This fixes 1-2 Switch's splash screen. | |||||
2018-07-04 | GPU: Only configure the used framebuffers during clear. | Subv | 4 | -17/+48 | |
Don't try to configure the color buffer if it is not being cleared, it may not be completely valid at this point. | |||||
2018-07-03 | GPU: Factor out the framebuffer configuration code for both Clear and Draw commands. | Subv | 2 | -72/+39 | |
2018-07-03 | GPU: Support clears that don't clear the color buffer. | Subv | 2 | -6/+17 | |
2018-07-03 | GPU: Bind and clear the render target when the CLEAR_BUFFERS register is written to. | Subv | 4 | -0/+86 | |
2018-07-03 | GPU: Added registers for the CLEAR_BUFFERS and CLEAR_COLOR methods. | Subv | 1 | -2/+27 | |
2018-07-03 | gl_rasterizer_cache: Implement PixelFormat S8Z24. | bunnei | 3 | -11/+83 | |
2018-07-03 | Update AudioRenderer Voice Sections (#614) | David | 1 | -0/+87 | |
* voice section updating * fixed slight offset miscalculation * fixed overflow | |||||
2018-07-03 | gl_rasterizer: Only set cull mode and front face if enabled. | bunnei | 1 | -2/+5 | |
2018-07-03 | GPU: Use only the least significant 3 bits when reading the depth test func. | Subv | 1 | -9/+9 | |
Some games set the full GL define value here (including nouveau), but others just seem to set those last 3 bits. | |||||
2018-07-03 | GPU: Don't try to parse the depth test function if the depth test is disabled. | Subv | 1 | -0/+4 | |
2018-07-03 | Fix build and address review feedback | bunnei | 2 | -4/+5 | |
2018-07-03 | Add configurable logging backends | James Rowe | 14 | -22/+408 | |
2018-07-03 | Update clang format | James Rowe | 37 | -154/+141 | |
2018-07-03 | Rename logging macro back to LOG_* | James Rowe | 105 | -730/+730 | |
2018-07-03 | GPU: Set up the culling configuration on each draw. | Subv | 1 | -6/+8 | |
2018-07-03 | GPU: Implemented MUFU suboperation 8, sqrt. | Subv | 2 | -0/+5 | |
2018-07-02 | GPU: Set up the depth test state on every draw. | Subv | 2 | -0/+14 | |
2018-07-02 | MaxwellToGL: Added conversion functions for depth test and cull mode. | Subv | 1 | -0/+50 | |
2018-07-02 | GPU: Added registers for depth test and cull mode. | Subv | 1 | -3/+51 | |
2018-07-02 | GPU: Implemented the Z24S8 depth format and load the depth framebuffer. | Subv | 7 | -24/+124 | |
2018-07-02 | GPU: Implement offsetted rendering when using non-indexed drawing. | Subv | 1 | -1/+1 | |
2018-07-02 | GPU: Fixed the index offset rendering, and implemented the base vertex functionality. | Subv | 1 | -6/+8 | |
This fixes Stardew Valley. | |||||
2018-07-02 | GPU: Added register definitions for the vertex buffer base element. | Subv | 1 | -1/+6 | |
2018-07-02 | GPU: Directly copy the pixels when performing a same-layout DMA. | Subv | 1 | -1/+5 | |
2018-07-02 | GPU: Ignore disabled textures and textures with an invalid address. | Subv | 2 | -1/+10 | |
2018-07-02 | GPU: Allow GpuToCpuAddress to return boost::none for unmapped addresses. | Subv | 1 | -2/+2 | |
2018-07-01 | GPU: Remove a surface from the cache when its backing memory is being unmapped from the GPU's MMU. | Subv | 1 | -0/+5 | |
2018-07-01 | nvmap: Return the address of the nvmap object when Freeing it for the last time. | Subv | 2 | -4/+11 | |
This behavior is confirmed by reverse engineering. | |||||
2018-06-30 | GPU: Corrected the size of the MUFU subop field, and removed incorrect "min" operation. | Subv | 2 | -6/+1 | |
2018-06-30 | GPU: Implemented the RGBA32_UINT rendertarget format. | Subv | 4 | -9/+28 | |
2018-06-30 | GLCache: Specify the component type along the texture type in the format tuple. | Subv | 1 | -17/+21 | |
2018-06-30 | gl_shader_decompiler: Implement predicate NotEqualWithNan. | bunnei | 2 | -17/+24 | |
2018-06-29 | gl_rasterizer_cache: Only dereference color_surface/depth_surface if valid. | bunnei | 1 | -2/+6 | |
2018-06-27 | gl_shader_decompiler: Add a return path for unknown instructions. | bunnei | 1 | -0/+1 | |
2018-06-27 | gl_rasterizer_cache: Implement caching for texture and framebuffer surfaces. | bunnei | 3 | -16/+168 | |
gl_rasterizer_cache: Improved cache management based on Citra's implementation. gl_surface_cache: Add some docstrings. | |||||
2018-06-27 | gl_rasterizer_cache: Various fixes for ASTC handling. | bunnei | 2 | -35/+39 | |
2018-06-27 | gl_rasterizer_cache: Use SurfaceParams as a key for surface caching. | bunnei | 2 | -43/+72 | |
2018-06-27 | maxwell_3d: Add a struct for RenderTargetConfig. | bunnei | 1 | -17/+19 | |
2018-06-27 | settings: Add a configuration for use_accurate_framebuffers. | bunnei | 7 | -0/+21 | |
2018-06-27 | gl_rasterizer: Implement AccelerateDisplay to forward textures to framebuffers. | bunnei | 6 | -8/+62 | |
2018-06-27 | gl_rasterizer_cache: Cache size_in_bytes as a const per surface. | bunnei | 2 | -9/+13 | |
2018-06-27 | gl_rasterizer_cache: Refactor to make SurfaceParams members const. | bunnei | 2 | -52/+37 | |
2018-06-27 | gl_rasterizer_cache: Remove Citra's rasterizer cache, always load/flush surfaces. | bunnei | 4 | -1494/+210 | |
2018-06-27 | gl_rasterizer: Workaround for when exceeding max UBO size. | bunnei | 2 | -1/+7 | |
2018-06-26 | gl_state: Fix state management for texture swizzle. | bunnei | 5 | -12/+20 | |
2018-06-26 | gl_state: Remove unused state management from 3DS. | bunnei | 2 | -94/+0 | |
2018-06-26 | gl_rasterizer_cache: Fix inverted B5G6R5 format. | bunnei | 1 | -1/+1 | |
2018-06-26 | yuzu: Remove SSBOs check from Qt frontend. | bunnei | 1 | -2/+0 | |
2018-06-25 | Fix crash at exit | mailwl | 1 | -2/+4 | |
2018-06-25 | Send the correct RequestUpdateAudioRenderer revision in the output header (#587) | David | 1 | -1/+1 | |
* We should be returning our revision instead of what is requested. Hardware test on a 5.1.0 console * Added sysversion comment | |||||
2018-06-25 | Service/Audio: add hwopus service, stub GetWorkBufferSize function | mailwl | 4 | -0/+53 | |
2018-06-24 | Removed duplicate structs, changed AudioRendererResponse -> UpdateDataHeader (#583) | David | 2 | -34/+21 | |
* Removed duplicate structs, changed AudioRendererResponse -> UpdateDataHeader According to game symbols(SMO), there's references to UpdateDataHeader which seems to be what AudioRendererResponse actually is * oops * AudioRendererParameters should be AudioRendererParameter according to SMO | |||||
2018-06-23 | Fixed RequestUpdateAudioRenderer deadlocks and calculated section sizes properly (#580) | David | 2 | -44/+76 | |
* Fixed RequestUpdateAudioRenderer deadlocks and calculated section sizes properly This fixes RequestUpdateAudioRenderer deadlocks in games like Puyo Puyo Tetris and games which require a proper section size in games such as Retro City Rampage. This fixes causes various games to start rendering or trying to render | |||||
2018-06-22 | IPC: skip empty buffer write | mailwl | 1 | -0/+5 | |
prevent yuzu crash, if games, like Axiom Verge, trying to read 0 bytes from file | |||||
2018-06-22 | Kernel/Arbiters: Fix casts, cleanup comments/magic numbers | Michael Scire | 4 | -17/+27 | |
2018-06-22 | Add additional missing format. | Michael Scire | 2 | -21/+27 | |
2018-06-22 | Run clang-format on PR. | Michael Scire | 3 | -180/+181 | |
2018-06-22 | Kernel/Arbiters: HLE is atomic, adjust code to reflect that. | Michael Scire | 2 | -37/+13 | |
2018-06-21 | Add support for decrypted NCA files (#567) | Zach Hilman | 10 | -16/+453 | |
* Start to add NCA support in loader * More nca stuff * More changes to nca.cpp * Now identifies decrypted NCA cont. * Game list fixes and more structs and stuff * More updates to Nca class * Now reads ExeFs (i think) * ACTUALLY LOADS EXEFS! * RomFS loads and games execute * Cleanup and Finalize * plumbing, cleanup and testing * fix some things that i didnt think of before * Preliminary Review Changes * Review changes for bunnei and subv | |||||
2018-06-21 | Kernel/Arbiters: Initialize arb_wait_address in thread struct. | Michael Scire | 3 | -1/+7 | |
2018-06-21 | Kernel/Arbiters: Clear WaitAddress in SignalToAddress | Michael Scire | 1 | -0/+1 | |
2018-06-21 | Kernel/Arbiters: Mostly implement SignalToAddress | Michael Scire | 5 | -11/+111 | |
2018-06-21 | Kernel/Arbiters: Implement WaitForAddress | Michael Scire | 5 | -6/+71 | |
2018-06-21 | Service/Audio: update audren:u service | mailwl | 2 | -49/+60 | |
2018-06-21 | Kernel/Arbiters: Add stubs for 4.x SignalToAddress/WaitForAddres SVCs. | Michael Scire | 7 | -9/+147 | |
2018-06-20 | Build: Fixed some MSVC warnings in various parts of the code. | Subv | 12 | -22/+24 | |
2018-06-19 | Implement GetAvailableLanguageCodes2 (#575) | greggameplayer | 1 | -4/+1 | |
* Implement GetAvailableLanguageCodes2 * Revert "Implement GetAvailableLanguageCodes2" This reverts commit caadd9eea3497ae2a13382aecb8ca29e1c02c5af. * Implement GetAvailableLanguageCodes2 * Implement GetAvailableLanguageCodes2 | |||||
2018-06-19 | GPU: Perform negation after absolute value in the float shader instructions. | Subv | 1 | -7/+14 | |
2018-06-19 | GPU: Don't mark uniform buffers and registers as used for instructions which don't have them. | Subv | 2 | -14/+18 | |
Like the MOV32I and FMUL32I instructions. This fixes a potential crash when using these instructions. | |||||
2018-06-19 | Services/FS: Return the correct error code when trying to mount a nonexistent savedata. | Subv | 2 | -2/+12 | |
2018-06-18 | svc: Add a stub for UserExceptionContextAddr. | Jules Blok | 1 | -0/+5 | |
2018-06-18 | gl_rasterizer: Get loose on independent blending. | Jules Blok | 1 | -1/+1 | |
2018-06-18 | gl_rasterizer: Implement texture format ASTC_2D_4X4. | bunnei | 6 | -1/+1709 | |
2018-06-18 | gl_rasterizer_cache: Loosen things up a bit. | bunnei | 1 | -26/+8 | |
2018-06-17 | gl_shader_decompiler: Implement LOP instructions. | bunnei | 2 | -6/+42 | |
2018-06-17 | gl_shader_decompiler: Refactor LOP32I instruction a bit in support of LOP. | bunnei | 2 | -57/+42 | |
2018-06-16 | gl_shader_decompiler: Implement integer size conversions for I2I/I2F/F2I. | bunnei | 2 | -14/+43 | |
2018-06-16 | gl_shader_gen: Set position.w to 1. | bunnei | 1 | -0/+4 | |
2018-06-16 | gl_shader_decompiler: Implement LOP32I LogicOperation PassB. | bunnei | 1 | -6/+12 | |
2018-06-14 | Bug fixes, testing, and review changes | Zach Hilman | 2 | -7/+20 | |
2018-06-14 | Add 'Load Folder' menu option | Zach Hilman | 3 | -0/+17 | |
2018-06-14 | Add support for main files in file picker | Zach Hilman | 1 | -0/+2 | |
2018-06-14 | Recognize main files in game list | Zach Hilman | 1 | -2/+17 | |
2018-06-14 | Narrow down filter of layout configs | Zach Hilman | 2 | -10/+5 | |
2018-06-13 | Move loop condition to free function | Zach Hilman | 1 | -4/+9 | |
2018-06-13 | Avoid initializing single-joycon layouts with handheld controller | Zach Hilman | 2 | -1/+5 | |
2018-06-13 | Qt: Removed the Registers widget. | Subv | 6 | -292/+0 | |
It was crashing and nobody actually uses this. | |||||
2018-06-12 | GPU: Implemented the iadd32i shader instruction. | Subv | 2 | -2/+31 | |
2018-06-12 | GPU: Partially implemented the Maxwell DMA engine. | Subv | 7 | -1/+237 | |
Only tiled->linear and linear->tiled copies that aren't offsetted are supported for now. Queries are not supported. Swizzled copies are not supported. | |||||
2018-06-12 | gl_shader_decompiler: Implement saturate for float instructions. | bunnei | 2 | -39/+32 | |
2018-06-12 | hid: Update all layouts and only show handheld as connected, fixes libnx input for P1_AUTO | shinyquagsire23 | 2 | -2/+3 | |
2018-06-10 | GPU: Convert the gl_InstanceId and gl_VertexID variables to floats when reading from them. | Subv | 1 | -1/+1 | |
This corrects the invalid position values in some games when doing attribute-less rendering. | |||||
2018-06-10 | Rasterizer: Use UBOs instead of SSBOs for uploading const buffers. | Subv | 4 | -18/+39 | |
This should help a bit with GPU performance once we're GPU-bound. | |||||
2018-06-09 | GPU: Implement the iset family of shader instructions. | Subv | 2 | -2/+46 | |
2018-06-09 | GPU: Added decodings for the ISET family of instructions. | Subv | 1 | -0/+7 | |
2018-06-09 | gl_shader_decompiler: Implement SHR instruction. | bunnei | 2 | -0/+17 | |
2018-06-09 | GPU: Stub the SSY shader instruction. | Subv | 2 | -0/+7 | |
This instruction tells the GPU where the flow reconverges in a non-uniform control flow scenario, we can ignore this when generating GLSL code. | |||||
2018-06-09 | gl_shader_decompiler: Implement IADD instruction. | bunnei | 2 | -11/+37 | |
2018-06-09 | gl_shader_decompiler: Add missing asserts for saturate_a instructions. | bunnei | 2 | -8/+18 | |
2018-06-09 | GPU: Synchronize the blend state on every draw call. | Subv | 2 | -16/+20 | |
Only independent blending on render target 0 is implemented for now. This fixes the elongated squids in Splatoon 2's boot screen. | |||||
2018-06-09 | GPU: Added registers for normal and independent blending. | Subv | 2 | -31/+27 | |
2018-06-08 | GLCache: Align compressed texture sizes to their compression ratio, and then align that compressed size to the block height for tiled textures. | Subv | 1 | -2/+7 | |
This fixes issues with retrieving non-block-aligned tiled compressed textures from the cache. | |||||
2018-06-08 | Rasterizer: Flush the written region when writing shader uniform data before copying it to the uniform buffers. | Subv | 1 | -0/+3 | |
This fixes the flip_viewport uniform having invalid values when drawing. | |||||
2018-06-07 | GLRenderer: Write the shader stage configuration UBO data *before* copying it to the GPU. | Subv | 1 | -3/+4 | |
This should fix the bug with the vs_config UBO being uninitialized during shader execution. | |||||
2018-06-07 | Common/string_util: add StringFromBuffer function | mailwl | 3 | -22/+15 | |
convert input buffer (std::vector<u8>) to string, stripping zero chars | |||||
2018-06-07 | gl_shader_decompiler: Implement BFE_IMM instruction. | bunnei | 2 | -7/+44 | |
2018-06-07 | GLCache: Use the full uncompressed size when blitting from one texture to another. | Subv | 1 | -3/+6 | |
This avoids the problem of only copying a tiny piece of the textures when they are compressed. | |||||
2018-06-07 | GLCache: Simplify the logic to copy from one texture to another in BlitTextures. | Subv | 1 | -53/+3 | |
We now use glCopyImageSubData, this should avoid errors with trying to attach a compressed texture as a framebuffer's color attachment and then blitting to it. Maybe in the future we can change this to glCopyTextureSubImage which only requires GL_ARB_direct_state_access. | |||||
2018-06-07 | gl_shader_decompiler: F2F: Implement rounding modes. | bunnei | 2 | -10/+35 | |
2018-06-07 | gl_shader_decompiler: Remove some attribute stuff that has nothing to do with TEX/TEXS. | bunnei | 1 | -8/+4 | |
2018-06-07 | shader_bytecode: Add instruction decodings for BFE, IMNMX, and XMAD. | bunnei | 1 | -0/+20 | |
2018-06-07 | gl_shader_decompiler: Implement ISETP_IMM instruction. | bunnei | 1 | -8/+9 | |
2018-06-07 | GPU: Support changing the texture swizzles for Maxwell textures. | Subv | 3 | -0/+45 | |
2018-06-07 | GLState: Support changing the GL_TEXTURE_SWIZZLE parameter of each texture unit. | Subv | 3 | -0/+20 | |
2018-06-07 | gl_shader_decompiler: Implement LD_C instruction. | bunnei | 2 | -0/+43 | |
2018-06-07 | gl_shader_gen: Add uniform handling for indirect const buffer access. | bunnei | 3 | -4/+40 | |
2018-06-06 | gl_shader_decompiler: Refactor uniform handling to allow different decodings. | bunnei | 2 | -26/+29 | |
2018-06-06 | GPU: Implement sampling multiple textures in the generated glsl shaders. | Subv | 9 | -69/+172 | |
All tested games that use a single texture show no regression. Only Texture2D textures are supported right now, each shader gets its own "tex_fs/vs/gs" sampler array to maintain independent textures between shader stages, the textures themselves are reused if possible. | |||||
2018-06-06 | Stub IUser::AttachAvailabilityChangeEvent | mailwl | 1 | -5/+23 | |
2018-06-06 | nvdrv/devices/nvidia_ctrl_gpu : add IoctlCommands with their params (#524) | greggameplayer | 2 | -0/+53 | |
* add IoctlCommands with their params in nvidia_ctrl_gpu.h * add function related to the changes done previously * fix clang-format * delete trailing whitespace * correct mistake | |||||
2018-06-06 | Remove unused header files | mailwl | 1 | -2/+0 | |
2018-06-06 | GDB Stub Improvements (#508) | Hedges | 4 | -27/+194 | |
* GDB Stub should work now. * Applied clang-format. * Replaced htonll with swap64. * Tidy up. | |||||
2018-06-06 | gl_shader_decompiler: Fix un/signed mismatch with SHL. | bunnei | 1 | -1/+1 | |
2018-06-06 | maxwell_to_gl: Implement WrapMode Mirror. | bunnei | 1 | -0/+2 | |
2018-06-06 | nifm: Stub out IRequest::SetConnectionConfirmationOption. | bunnei | 1 | -1/+10 | |
2018-06-06 | am: Stub out IApplicationFunctions::GetPseudoDeviceId. | bunnei | 2 | -1/+13 | |
2018-06-06 | GPU: Allow the usage of RGBA16_FLOAT in the texture copy engine. | Subv | 1 | -0/+2 | |
2018-06-06 | GPU: Implemented the R11FG11FB10F texture and rendertarget formats. | Subv | 4 | -11/+30 | |
2018-06-06 | GPU: Fixed the compression factor for RGBA16F textures. | Subv | 1 | -1/+1 | |
They're not compressed. | |||||
2018-06-06 | GPU: Allow the usage of RGBA32_FLOAT in the texture copy engine. | Subv | 2 | -0/+3 | |
2018-06-05 | Small fixes | mailwl | 2 | -6/+8 | |
2018-06-05 | Service/MM: add service and stub some functions | mailwl | 6 | -0/+85 | |
2018-06-05 | GPU: Corrected the branch targets for the shader bra instruction. | Subv | 1 | -4/+5 | |
2018-06-05 | GPU: Implemented the F2I_R shader instruction. | Subv | 2 | -7/+64 | |
2018-06-05 | gl_shader_decompiler: Fix typo with ISCADD instruction. | bunnei | 1 | -1/+1 | |
2018-06-05 | gl_shader_decompiler: Implement SHL instruction. | bunnei | 2 | -14/+47 | |
2018-06-05 | gl_shader_decompiler: Implement PredCondition::NotEqual. | bunnei | 1 | -3/+3 | |
2018-06-05 | GPU: Implement the ISCADD shader instructions. | Subv | 2 | -0/+40 | |
2018-06-05 | GPU: Added decodings for the ISCADD instructions. | Subv | 1 | -0/+7 | |
2018-06-05 | GPU: Implement predicated exit instructions in the shader programs. | Subv | 1 | -4/+6 | |
2018-06-05 | GPU: Take into account predicated exits when performing shader control flow analysis. | Subv | 1 | -1/+10 | |
2018-06-04 | GPU: Use the bf bit in FSET to determine whether to write 0xFFFFFFFF or 1.0f. | Subv | 2 | -2/+7 | |
2018-06-04 | GPU: Corrected the I2F_R implementation. | Subv | 1 | -2/+12 | |
2018-06-04 | GPU: Calculate the correct viewport dimensions based on the scale and translate registers. | Subv | 2 | -14/+30 | |
This is how nouveau calculates the viewport width and height. For some reason some games set 0xFFFF in the VIEWPORT_HORIZ and VIEWPORT_VERT registers, maybe those are a misnomer and actually refer to something else? | |||||
2018-06-04 | Nvdrv/devices/nvhost_gpu : Add some IoctlCommands with their params (#511) | greggameplayer | 1 | -0/+47 | |
* Add some IoctlCommand with their params to nvhost_gpu * fix clang-format * delete trailing whitespace * fix some clang-format * delete one other trailing whitespace * last clang-format fix | |||||
2018-06-04 | GPU: Implemented the LOP32I instruction. | Subv | 2 | -1/+58 | |
2018-06-04 | GLCache: Corrected a mismatch between storing compressed sizes and verifying the uncompressed alignment in GetSurface. | Subv | 1 | -1/+2 | |
2018-06-04 | sdl: add check for GL extension support | BreadFish64 | 2 | -0/+26 | |
2018-06-04 | qt: add check for GL extension support | BreadFish64 | 2 | -0/+27 | |
2018-06-04 | GPU: Use explicit types when retrieving the uniform values for fsetp/fset and isetp instead of the type of an invalid output register. | Subv | 1 | -9/+18 | |
2018-06-04 | GPU: Implemented the ISETP_R and ISETP_C shader instructions. | Subv | 2 | -0/+48 | |
2018-06-04 | Correct function results | mailwl | 1 | -4/+16 | |
2018-06-04 | Service/nfp:user : stub some functions. | mailwl | 1 | -6/+70 | |
Used by Zelda: BoTW | |||||
2018-06-04 | am: Implement ILibraryAppletAccessor::PopOutData. | bunnei | 1 | -1/+11 | |
2018-06-04 | am: ISelfController:LaunchableEvent should be sticky. | bunnei | 1 | -1/+1 | |
2018-06-04 | am: Stub out ILibraryAppletAccessor Start and GetResult methods. | bunnei | 1 | -2/+16 | |
2018-06-04 | GPU: Partially implemented the shader BRA instruction. | Subv | 2 | -1/+43 | |
2018-06-04 | GPU: Added decoding for the BRA instruction. | Subv | 1 | -0/+2 | |
2018-06-04 | am: Implement ILibraryAppletAccessor::PushInData. | bunnei | 1 | -43/+55 | |
2018-06-04 | am: Implement IStorageAccessor::Write. | bunnei | 1 | -1/+17 | |
2018-06-04 | am: Cleanup IStorageAccessor::Read. | bunnei | 1 | -5/+3 | |
2018-06-04 | am: Implement ILibraryAppletCreator::CreateStorage. | bunnei | 2 | -21/+34 | |
2018-06-04 | GPU: Partial implementation of long GPU queries. | Subv | 1 | -9/+24 | |
Long queries write a 128-bit result value to memory, which consists of a 64 bit query value and a 64 bit timestamp. In this implementation, only select=Zero of the Crop unit is implemented, this writes the query sequence as a 64 bit value, and a 0u64 value for the timestamp, since we emulate an infinitely fast GPU. This specific type was hwtested, but more rigorous tests should be performed in the future for the other types. | |||||
2018-06-03 | gl_shader_decompiler: Implement TEXS component mask. | bunnei | 2 | -9/+26 | |
2018-06-03 | gl_shader_decompiler: Implement RRO as a register move. | bunnei | 2 | -9/+18 | |
2018-06-02 | Kernel/Threads: A thread waking up by timeout from a WaitProcessWideKey may already have an assigned lock owner. | Subv | 1 | -2/+5 | |
This situation may happen like so: Thread 1 with low priority calls WaitProcessWideKey with timeout. Thread 2 with high priority calls WaitProcessWideKey without timeout. Thread 3 calls SignalProcessWideKey - Thread 2 acquires the lock and awakens. - Thread 1 can't acquire the lock and is put to sleep with the lock owner being Thread 2. Thread 1's timeout expires, with the lock owner still being set to Thread 2. | |||||
2018-06-02 | GPU: Implemented the DXN1 (BC4) texture format. | Subv | 3 | -3/+16 | |
2018-06-01 | Service/time: implement posix time to calendar conversion | mailwl | 2 | -14/+72 | |
2018-06-01 | gl_shader_decompiler: Implement TEX instruction. | bunnei | 2 | -1/+36 | |
2018-06-01 | gl_shader_decompiler: Support multi-destination for TEXS. | bunnei | 2 | -2/+23 | |
2018-05-31 | gl_rasterizer_cache: Assert that component type is UNorm or format is RGBA16F. | bunnei | 1 | -1/+2 | |
2018-05-31 | Kernel/Thread: Corrected a typo that caused the affinity mask to never be changed. | Subv | 1 | -2/+2 | |
2018-05-31 | Kernel/SVC: Support special core values -2 and -3 in svcSetThreadCoreMask. | Subv | 2 | -1/+28 | |
Also added some proper error handling. | |||||
2018-05-31 | gl_rasterizer_cache: Implement PixelFormat RGBA16F. | bunnei | 3 | -6/+22 | |
2018-05-30 | add IPC CommandType & Some HID FunctionInfo (#487) | greggameplayer | 2 | -0/+33 | |
* add some CommandType * add some hid FunctionInfo * add some other HID FunctionInfo * delete non useful comments | |||||
2018-05-30 | Kernel/Thread: Corrected a typo in an assert about the processor id. | Subv | 1 | -1/+1 | |
2018-05-30 | Shaders: Implemented reading the gl_InstanceID and gl_VertexID variables in the vertex shader. | Subv | 2 | -1/+11 | |
2018-05-30 | Services/nvdrv: add '/dev/nvhost-nvdec' device | mailwl | 4 | -0/+74 | |
2018-05-30 | gl_shader_decompiler: F2F_R instruction: Implement abs. | bunnei | 1 | -1/+7 | |
2018-05-30 | gl_shader_decompiler: Partially implement F2F_R instruction. | bunnei | 2 | -4/+9 | |
2018-05-30 | GPU: Implemented the R8 texture format (0x1D) | Subv | 3 | -5/+18 | |
2018-05-30 | nvhost_ctrl: Stub out IocCtrlEventRegister. | bunnei | 2 | -0/+10 | |
2018-05-30 | nvhost_ctrl: Stub out IocCtrlEventWaitAsyncCommand. | bunnei | 2 | -5/+9 | |
2018-05-30 | gl_rasterize_cache: Invert order of tex format RGB565. | bunnei | 1 | -1/+1 | |
2018-05-29 | add all the known TextureFormat (#474) | greggameplayer | 1 | -2/+71 | |
2018-05-28 | Service/BCAT: add module and services | mailwl | 8 | -0/+120 | |
2018-05-27 | GPU: Implemented the A1B5G5R5 texture format (0x14) | Subv | 4 | -5/+21 | |
2018-05-27 | NvOsGetConfigU32 should return null instead of 0 for default output | David Marcec | 1 | -1/+1 | |
2018-05-26 | am: Stub IApplicationFunctions GetDisplayVersion. | bunnei | 2 | -1/+10 | |
2018-05-26 | gl_shader_decompiler: Implement GetPredicateComparison GreaterEqual. | bunnei | 1 | -4/+3 | |
2018-05-26 | shader_bytecode: Implement other variants of FMNMX. | bunnei | 2 | -4/+10 | |
2018-05-26 | Add & correct miscellaneous things (#470) | greggameplayer | 4 | -4/+55 | |
* add some InfoType * correct OpenApplicationProxy cmd number * add IDisplayController functions * fix clang-format * add more system languages | |||||
2018-05-26 | GetAudioRendererWorkBufferSize impl (#465) | David | 2 | -2/+88 | |
* GetAudioRendererWorkBufferSize impl Impl of GetAudioRendererWorkBufferSize based on RE, if this can be cleaned up, please contribute! * Naming conventions * Removed unneeded placeholder * lioncache changes * fixed const * switched to Common::AlignUp | |||||
2018-05-25 | Shader: Implemented compound predicates in fset. | Subv | 1 | -28/+12 | |
You can specify a predicate in the fset instruction: Result = ((Value1 Comp Value2) OP P0) ? 1.0 : 0.0; | |||||
2018-05-25 | Stubbed NVGPU_GPU_IOCTL_ZBC_SET_TABLE (#463) | David | 2 | -0/+22 | |
We have no clue on what this actually does yet so stubbing it since it's just input only should be fine for now | |||||
2018-05-25 | GPU: Allow command lists to rebind a channel to another engine in the middle of the command list. | Subv | 1 | -1/+0 | |
2018-05-25 | Shader: Implemented compound predicates in fsetp. | Subv | 1 | -19/+55 | |
You can specify three predicates in an fsetp instruction: P1 = (Value1 Comp Value2) OP P0; P2 = !(Value1 Comp Value2) OP P0; | |||||
2018-05-24 | Stub NVGPU_IOCTL_CHANNEL_SET_TIMEOUT | mailwl | 2 | -0/+16 | |
Used in Nintendo Labo ToyCon 1&2 | |||||
2018-05-24 | yuzu_cmd: Fix project for latest msvc. | bunnei | 1 | -14/+12 | |
2018-05-24 | Fix deadlocks caused from HID having too many layouts | David Marcec | 1 | -1/+1 | |
Games such as SMO deadlock if we have more than 2 layouts | |||||
2018-05-23 | Add & correct some error modules | greggameplayer | 1 | -2/+8 | |
2018-05-23 | change some functions | greggameplayer | 1 | -6/+6 | |
according to the changes made previously | |||||
2018-05-23 | correct placement and add size check | greggameplayer | 1 | -21/+25 | |
2018-05-23 | Add ioctl commands with their params and size check | greggameplayer | 1 | -2/+86 | |
2018-05-22 | Implemented NVHOST_IOCTL_CHANNEL_GET_WAITBASE (#440) | David | 2 | -1/+20 | |
* Implemented NVHOST_IOCTL_CHANNEL_GET_WAITBASE struct + 4 seems to be hard coded at 0 and struct + 0 seems to be ignored? * IocGetWaitbase -> IocChannelGetWaitbaseCommand * Added super late fixes | |||||
2018-05-21 | Correct audio command numbers & add or rename some functions (#455) | greggameplayer | 5 | -34/+34 | |
* Add unknown function at the number command 2 * correct audout:u commands numbers * correct audrec:u cmd number & add Unknown function * correct IAudioDevice command numbers * correct codecctl cmd numbers & rename the 8 function * correct place of unknown function & fix clang-format | |||||
2018-05-21 | Shaders: Implemented the FMNMX shader instruction. | Subv | 2 | -6/+26 | |
2018-05-20 | Mutex: Do not assert when the mutex waiting threads list isn't empty on mutex release. | Subv | 1 | -1/+0 | |
A thread may own multiple mutexes at the same time, and only release one of them while other threads are waiting for the other mutexes. | |||||
2018-05-20 | GPU: Implemented the nvmap Free ioctl. | Subv | 2 | -1/+48 | |
It releases a reference to an nvmap object | |||||
2018-05-20 | GPU: Implemented nvhost-as-gpu's UnmapBuffer ioctl. | Subv | 4 | -0/+70 | |
It removes a mapping previously created with the MapBufferEx ioctl. | |||||
2018-05-20 | Add and correct some Error Modules (#444) | greggameplayer | 1 | -6/+40 | |
* Add and correct some Error Modules | |||||
2018-05-19 | Kernel/SVC: Signal the highest priority threads first in svcSignalProcessWideKey. | Subv | 1 | -51/+68 | |
2018-05-19 | Kernel/Threads: Reschedule the proper core when operating on that core's threads. | Subv | 1 | -2/+6 | |
2018-05-19 | SVC: Removed unused WaitSynchronization1 function | Subv | 1 | -30/+0 | |
2018-05-19 | Qt/WaitTree: Display the callstack for each thread in the wait tree widget. | Subv | 2 | -0/+37 | |
2018-05-19 | ShadersDecompiler: Added decoding for the PSETP instruction. | Subv | 1 | -0/+3 | |
2018-05-19 | GLRenderer: Remove unused hw_vao_enabled_attributes variable. | Subv | 2 | -4/+0 | |
2018-05-19 | GLRenderer: Remove unused vertex buffer and increase the size of the stream buffer to 128 MB. | Subv | 2 | -9/+3 | |
The stream buffer is where all the vertex data is copied, some games require this to be much bigger than the 4 MB we used to have. | |||||
2018-05-19 | GLRenderer: Log the shader source code when program linking fails. | Subv | 1 | -0/+27 | |
2018-05-18 | rename fatal:u functions & add ThrowFatal | greggameplayer | 1 | -2/+3 | |
2018-05-18 | Properly update fatal.h void name | greggameplayer | 1 | -2/+2 | |
2018-05-18 | Properly rename fatal module functions | greggameplayer | 1 | -2/+2 | |
2018-05-17 | Added RequestWithContext & ControlWithContext | David Marcec | 3 | -1/+7 | |
2018-05-13 | Updated nfp with more service names | Hexagon12 | 1 | -24/+24 | |
2018-05-11 | More accurate GetTPCMasks impl | David Marcec | 2 | -4/+8 | |
2018-05-11 | core: Add several missing docstrings. | bunnei | 1 | -0/+8 | |
2018-05-11 | thread: Rename mask to affinity_masks. | bunnei | 4 | -5/+6 | |
2018-05-11 | core: Run all CPU cores separately, even in single-thread mode. | bunnei | 2 | -13/+23 | |
2018-05-11 | thread: Support core change on ResumeFromWait and improve ChangeCore. | bunnei | 1 | -37/+68 | |
2018-05-11 | scheduler: Protect scheduling functions with a global mutex. | bunnei | 2 | -0/+18 | |
2018-05-11 | wait_tree: Add ideal core and affinity mask. | bunnei | 1 | -0/+2 | |
2018-05-11 | thread: Initialize ideal_core and mask members. | bunnei | 1 | -0/+2 | |
2018-05-11 | threading: Reschedule only on cores that are necessary. | bunnei | 4 | -3/+10 | |
2018-05-11 | svc: Implement GetThreadCoreMask and SetThreadCoreMask. | bunnei | 1 | -7/+22 | |
2018-05-11 | thread: Implement ChangeCore function. | bunnei | 2 | -1/+58 | |
2018-05-11 | svc: SignalProcessWideKey should apply to all cores. | bunnei | 1 | -43/+50 | |
2018-05-11 | svc: Implement GetCurrentProcessorNumber. | bunnei | 1 | -2/+2 | |
2018-05-11 | wait_tree: Show all threads on all schedulers. | bunnei | 1 | -6/+14 | |
2018-05-11 | core: Add a configuration setting for use_multi_core. | bunnei | 10 | -17/+56 | |
2018-05-11 | core: Support session close with multicore. | bunnei | 4 | -16/+47 | |
2018-05-11 | core: Implement multicore support. | bunnei | 13 | -78/+113 | |
2018-05-11 | core: Create a thread for each CPU core, keep in lock-step with a barrier. | bunnei | 4 | -18/+94 | |
2018-05-11 | core: Move common CPU core things to its own class. | bunnei | 5 | -58/+135 | |
2018-05-07 | Stubs for QLaunch (#428) | Hexagon12 | 4 | -5/+221 | |
* Stubs for QLaunch * Wiped unrelated stuff * Addressed comment * Dropped GetPopFromGeneralChannelEvent | |||||
2018-05-07 | hid: Tweaks, Analog Sticks (#435) | Max Thomas | 3 | -68/+224 | |
* hid: Update mouse/keyboard state * hid: Working analog sticks * hid: Nits * hid: Nits * hid: Update mystery sections * hid: Tweaks | |||||
2018-05-03 | memory_hook: Default virtual destructor in the cpp file | Lioncash | 3 | -1/+13 | |
Prevents creating multiple copies of the vtable in every translation unit that uses the class. Also silences a -Wweak-vtables warning | |||||
2018-05-03 | core_timing: Don't include the log header in core timing's header | Lioncash | 2 | -48/+55 | |
Avoids propagating logging macros and facilities to files that may not need them. This also allows hiding an internal constant. | |||||
2018-05-02 | general: Make formatting of logged hex values more straightforward | Lioncash | 29 | -104/+105 | |
This makes the formatting expectations more obvious (e.g. any zero padding specified is padding that's entirely dedicated to the value being printed, not any pretty-printing that also gets tacked on). | |||||
2018-05-02 | ipc: Add support for PopIpcInterface() method. | bunnei | 4 | -0/+23 | |
- This can be used for domain objects as inputs to service functions. | |||||
2018-05-02 | vector_math: Ensure members are always initialized | Lioncash | 1 | -9/+9 | |
Ensures that values are always in a well-defined state. | |||||
2018-05-01 | GetSharedFontInOrderOfPriority (#381) | David | 4 | -24/+54 | |
* GetSharedFontInOrderOfPriority * Update pl_u.cpp * Ability to use ReadBuffer and WriteBuffer with different buffer indexes, fixed up GetSharedFontInOrderOfPriority * switched to NGLOG * Update pl_u.cpp * Update pl_u.cpp * language_code is actually language code and not index * u32->u64 * final cleanups | |||||
2018-05-01 | GPU: Don't write to invalid memory locations when handling ioctls that don't have an output. | Subv | 2 | -5/+0 | |
2018-04-30 | core_timing: Namespace all functions and constants in core_timing's header | Lioncash | 9 | -14/+18 | |
All of these variables and functions are related to timings and should be within the namespace. | |||||
2018-04-30 | string_util: Remove StringFromFormat() and related functions | Lioncash | 8 | -99/+19 | |
Given we utilize fmt, we don't need to provide our own functions for formatting anymore | |||||
2018-04-30 | file_util: Make move constructor/assignment operator and related functions noexcept | Lioncash | 2 | -6/+6 | |
Without this, it's possible to get compilation failures in the (rare) scenario where a container is used to store a bunch of live IOFile instances, as they may be using std::move_if_noexcept under the hood. Given these definitely don't throw exceptions this is also not incorrect to add either. | |||||
2018-04-30 | file_util: Add static assertions to ReadBytes() and WriteBytes() | Lioncash | 1 | -2/+6 | |
Ensure that the actual types being passed in are trivially copyable. The internal call to ReadArray() and WriteArray() will always succeed, since they're passed a pointer to char* which is always trivially copyable. | |||||
2018-04-29 | maxwell_3d: Reset vertex counts after drawing. | bunnei | 1 | -0/+10 | |
2018-04-29 | gl_shader_decompiler: Implement MOV_R. | bunnei | 1 | -1/+2 | |
2018-04-29 | maxwell_to_gl: Implement type SignedNorm, Size_8_8_8_8. | bunnei | 1 | -0/+12 | |
2018-04-29 | shader_bytecode: Add decoding for FMNMX instruction. | bunnei | 1 | -0/+2 | |
2018-04-29 | Shaders: Implemented predicate condition 3 (LessEqual) in the fset and fsetp instructions. | Subv | 1 | -0/+7 | |
2018-04-29 | gl_shader_decompiler: Implement MOV_C. | bunnei | 1 | -0/+5 | |
2018-04-29 | am: Fix GetDesiredLanguage implementation. | bunnei | 1 | -2/+4 | |
2018-04-29 | set: Fix GetAvailableLanguageCodes implementation. | bunnei | 2 | -6/+45 | |
2018-04-29 | fermi_2d: Fix surface copy block height. | bunnei | 2 | -2/+7 | |
2018-04-29 | gl_shader_decompiler: Partially implement I2I_R, and I2F_R. | bunnei | 2 | -8/+34 | |
2018-04-29 | gl_shader_decompiler: More cleanups, etc. with how we handle register types. | bunnei | 1 | -44/+120 | |
2018-04-29 | GLSLRegister: Simplify register declarations, etc. | bunnei | 1 | -63/+31 | |
2018-04-29 | shader_bytecode: Add decodings for i2i instructions. | bunnei | 1 | -3/+20 | |
2018-04-29 | gl_shader_decompiler: Implement MOV32_IMM instruction. | bunnei | 2 | -2/+7 | |
2018-04-28 | file_util: Remove compiler version checks around is_trivially_copyable() | Lioncash | 1 | -8/+0 | |
The minimum clang/GCC versions we support already support this. We can also remove is_standard_layout(), as fread and fwrite only require the type to be trivially copyable. | |||||
2018-04-27 | log: Remove old logging macros and functions | Lioncash | 2 | -54/+1 | |
Now that the old macros are no longer used, we can remove all functionality related to them. | |||||
2018-04-27 | renderer_opengl: Replace usages of LOG_GENERIC with fmt-capable equivalents | Lioncash | 1 | -6/+7 | |
2018-04-27 | core: Replace usages of LOG_GENERIC with new fmt-capable equivalents | Lioncash | 3 | -6/+4 | |
2018-04-27 | gl_shader_decompiler: Add GLSLRegisterManager class to track register state. | bunnei | 1 | -154/+262 | |
2018-04-27 | general: Convert assertion macros over to be fmt-compatible | Lioncash | 17 | -39/+39 | |
2018-04-27 | Switched to NGLOG_WARNING | David Marcec | 4 | -5/+5 | |
2018-04-27 | common: Move logging macros over to new fmt-capable macros where applicable | Lioncash | 4 | -67/+67 | |
2018-04-27 | frontends: Move logging macros over to new fmt-capable ones | Lioncash | 5 | -27/+26 | |
2018-04-27 | input_common: Move old logging macros over to fmt-capable ones | Lioncash | 1 | -3/+3 | |
2018-04-26 | Added PREPO to logging backend, Removed comments from SaveReportWithUser | David Marcec | 3 | -13/+3 | |
2018-04-26 | core: Replace remaining old non-generic logger usages with fmt-capable equivalents | Lioncash | 6 | -28/+28 | |
LOG_GENERIC usages will be amended in a follow-up to keep API changes separate from interface changes, as it will require removing a parameter from the relevant function in the VMManager class. | |||||
2018-04-26 | common: Remove chunk_file.h and linear_disk_cache.h | Lioncash | 3 | -792/+0 | |
These are unused (and given chunk_file references Dolphin's >SVN< I doubt they were going to be used). | |||||
2018-04-26 | gl_shader_decompiler: Boilerplate for handling integer instructions. | bunnei | 2 | -6/+111 | |
2018-04-26 | gl_shader_decompiler: Move color output to EXIT instruction. | bunnei | 1 | -6/+12 | |
2018-04-26 | core/gdbstub: Move logging macros to new fmt-compatible ones | Lioncash | 1 | -38/+37 | |
2018-04-26 | core/hw: Move logging macros over to fmt-capable ones | Lioncash | 2 | -8/+10 | |
2018-04-26 | kernel/shared_memory: Remove unnecessary semicolon at end of ConvertPermissions() | Lioncash | 1 | -1/+1 | |
Functions don't need to be terminated by semicolons. | |||||
2018-04-26 | kernel: Migrate logging macros to fmt-compatible ones | Lioncash | 11 | -106/+109 | |
2018-04-25 | GPU: Partially implemented the Fermi2D surface copy operation. | Subv | 2 | -0/+59 | |
The hardware allows for some rather complicated operations to be performed on the data during the copy, this is not implemented. Only same-format same-size raw copies are implemented for now. | |||||
2018-04-25 | Shaders: Added bit decodings for the I2I instruction. | Subv | 1 | -0/+6 | |
2018-04-25 | Shaders: Implemented the FSET instruction. | Subv | 1 | -0/+53 | |
This instruction is similar to the FSETP instruction, but it doesn't set a predicate, it sets the destination register to 1.0 if the condition holds, and 0 otherwise. | |||||
2018-04-25 | Memory: Added a missing shortcut for Memory::CopyBlock for the current process. | Subv | 1 | -0/+4 | |
2018-04-25 | GPU: Make the Textures::CopySwizzledData function accessible from the outside of the file. | Subv | 2 | -3/+6 | |
2018-04-25 | GPU: Added a function to retrieve the bytes per pixel of the render target formats. | Subv | 2 | -0/+15 | |
2018-04-25 | GPU: Added surface copy registers to Fermi2D | Subv | 1 | -1/+57 | |
2018-04-25 | GPU: Added boilerplate code for the Fermi2D engine | Subv | 3 | -3/+34 | |
2018-04-25 | GPU: Reduce the number of registers of Maxwell3D to 0xE00. | Subv | 2 | -5/+5 | |
The rest are just macro shim registers. | |||||
2018-04-25 | GPU: Move the Maxwell3D macro uploading code to the inside of the Maxwell3D processor. | Subv | 4 | -40/+23 | |
It doesn't belong in the PFIFO handler. | |||||
2018-04-25 | GPU: Corrected the upper bound of the PFIFO method ids in the command processor. | Subv | 1 | -1/+1 | |
2018-04-25 | file-sys: convert a StringFromFormat call into fmt::format in GetFullPath() | Lioncash | 1 | -4/+1 | |
Lessens the amount to read and gets rid of the PRIX64 macro, allowing us to use a single string for the whole path, making it easier to read. | |||||
2018-04-25 | file-sys: Move logging macros over to the new fmt-capable ones | Lioncash | 8 | -64/+58 | |
2018-04-25 | core/memory: Amend address widths in asserts | Lioncash | 1 | -2/+2 | |
Addresses are 64-bit, these formatting specifiers are simply holdovers from citra. Adjust them to be the correct width. | |||||
2018-04-25 | core/memory: Move logging macros over to new fmt-capable ones | Lioncash | 1 | -22/+24 | |
While we're at it, correct addresses to print all 64 bits where applicable, which were holdovers from citra. | |||||
2018-04-25 | video-core: Move logging macros over to new fmt-capable ones | Lioncash | 5 | -18/+20 | |
2018-04-25 | Service/PCTL: convert to module, add services, stub | mailwl | 7 | -39/+71 | |
PCTL::CreateServiceWithoutInitialize and IParentalControlService::Initialize, required by Kirby Star Allies | |||||
2018-04-25 | Shaders: Added decodings for the FSET instructions. | Subv | 2 | -9/+30 | |
2018-04-25 | renderer_opengl: Use correct byte order for framebuffer pixel format ABGR8. | bunnei | 1 | -2/+1 | |
2018-04-25 | gl_rasterizer_cache: Use CHAR_BIT for bpp conversions instead of 8. | bunnei | 2 | -4/+4 | |
2018-04-25 | gl_rasterizer_cache: Use GPU PAGE_BITS/SIZE, not CPU. | bunnei | 1 | -5/+5 | |
2018-04-25 | gl_rasterizer_cache: Use new logger. | bunnei | 1 | -4/+4 | |
2018-04-25 | gl_rasterizer_cache: Add a function for finding framebuffer GPU address. | bunnei | 3 | -0/+31 | |
2018-04-25 | gl_rasterizer_cache: Handle compressed texture sizes. | bunnei | 2 | -24/+65 | |
2018-04-25 | gl_rasterizer_cache: Update to be based on GPU addresses, not CPU addresses. | bunnei | 10 | -67/+122 | |
2018-04-25 | loader: Move old logging macros over to new fmt-capable ones | Lioncash | 5 | -26/+25 | |
2018-04-24 | memory_manager: Add implement CpuToGpuAddress. | bunnei | 2 | -0/+27 | |
2018-04-24 | memory_manager: Make GpuToCpuAddress return an optional. | bunnei | 7 | -28/+37 | |
2018-04-24 | memory_manager: Use GPUVAdddr, not PAddr, for GPU addresses. | bunnei | 7 | -60/+57 | |
2018-04-24 | service: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -5/+5 | |
2018-04-24 | vi: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -26/+27 | |
2018-04-24 | time: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -12/+12 | |
2018-04-24 | ssl: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -3/+3 | |
2018-04-24 | spl: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -1/+1 | |
2018-04-24 | sockets: Move logging macros over to new fmt-compatible ones | Lioncash | 2 | -7/+8 | |
2018-04-24 | sm: Move logging macros over to new fmt-compatible ones | Lioncash | 2 | -9/+8 | |
2018-04-24 | set: Move logging macros over to new fmt-compatible ones | Lioncash | 2 | -2/+2 | |
2018-04-24 | pctl: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -1/+1 | |
2018-04-24 | nvflinger: Move logging macros over to new fmt-compatible ones | Lioncash | 2 | -3/+3 | |
2018-04-24 | nvdrv: Move logging macros over to new fmt-compatible ones | Lioncash | 7 | -60/+61 | |
2018-04-24 | ns: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -6/+6 | |
2018-04-24 | nifm: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -11/+11 | |
2018-04-24 | nfp: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -1/+1 | |
2018-04-24 | lm: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -6/+6 | |
2018-04-24 | hid: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -25/+25 | |
2018-04-24 | friend: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -1/+1 | |
2018-04-24 | filesystem: Move logging macros over to new fmt-compatible ones | Lioncash | 2 | -30/+29 | |
2018-04-24 | renderer_opengl: Silence a -Wdangling-else warning in DrawScreenTriangles() | Lioncash | 1 | -1/+2 | |
2018-04-24 | fatal: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -2/+2 | |
2018-04-24 | audio: Move logging macros over to new fmt-compatible ones | Lioncash | 2 | -21/+21 | |
2018-04-24 | apm: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -3/+3 | |
2018-04-24 | aoc: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -2/+2 | |
2018-04-24 | am: Move logging macros over to new fmt-compatible ones | Lioncash | 3 | -50/+50 | |
2018-04-24 | acc: Move logging macros over to new fmt-compatible ones | Lioncash | 1 | -10/+10 | |
2018-04-24 | Service/FS: implement IFileSystem::RenameFile | mailwl | 6 | -8/+36 | |
2018-04-24 | GPU: Added asserts to our code for handling the QUERY_GET GPU command. | Subv | 2 | -2/+53 | |
This is based on research from nouveau. Many things are currently unknown and will require hwtests in the future. This commit also stubs QueryMode::Write2 to do the same as Write. Nouveau code treats them interchangeably, it is currently unknown what the difference is. | |||||
2018-04-23 | GPU: Support multiple enabled vertex arrays. | Subv | 3 | -43/+89 | |
The vertex arrays will be copied to the stream buffer one after the other, and the attributes will be set using the ARB_vertex_attrib_binding extension. yuzu now thus requires OpenGL 4.3 or the ARB_vertex_attrib_binding extension. | |||||
2018-04-23 | Kernel: Implemented mutex priority inheritance. | Subv | 4 | -10/+94 | |
Verified with a hwtest and implemented based on reverse engineering. Thread A's priority will get bumped to the highest priority among all the threads that are waiting for a mutex that A holds. Once A releases the mutex and ownership is transferred to B, A's priority will return to normal and B's priority will be bumped. | |||||
2018-04-23 | NvDrv/nvhost-as-gpu: Ensure that the object passed to MapBufferEx has already been allocated. | Subv | 1 | -0/+10 | |
Also added a consistency check and a comment for the case when the object id is different than its handle. The real nvservices doesn't make a distinction between ids and handles, each object gets an unique handle which doubles as its id. | |||||
2018-04-23 | Nvdrv/nvhost-as-gpu: Implemented the ioctl REMAP command. | Subv | 2 | -0/+47 | |
It takes a previously-reserved (AllocateSpace) GPU memory address and maps it to the address of the nvmap object passed to Remap. | |||||
2018-04-23 | Nvdrv: Assert when receiving an unimplemented ioctl in the nv* handlers. | Subv | 5 | -5/+5 | |
2018-04-23 | GPU: Make the GPU virtual memory manager use 16 page bits and 10 page table bits. | Subv | 2 | -34/+25 | |
Also removed some dead code and added memory map consistency asserts. | |||||
2018-04-23 | GPU: Implement the RGB10_A2 RenderTarget format, it will use the same format as the A2BGR10 texture format. | Subv | 2 | -0/+4 | |
2018-04-23 | GetIUserInterface->CreateUserInterface, Added todos and stub logs. Playreport->PlayReport. | David Marcec | 10 | -25/+64 | |
2018-04-22 | lioncash proposed changes | David | 1 | -2/+2 | |
2018-04-22 | Implemented GetIUserInterface properly, Playreport and SSL::SetInterfaceVersion. Fixed ipc issues with IAudioDevice(wrong ids) | David Marcec | 11 | -11/+109 | |
2018-04-22 | GPU: Implement the A2BGR10 texture format. | Subv | 4 | -6/+18 | |
2018-04-21 | SDL2: Implement fullscreen. (Original PR: citra-emu/citra#3607) | adityaruplaha | 3 | -4/+40 | |
2018-04-21 | gl_shader_decompiler: Skip RRO instruction. | bunnei | 1 | -0/+4 | |
2018-04-21 | gl_shader_decompiler: Cleanup error logging. | bunnei | 1 | -14/+6 | |
2018-04-21 | shader_bytecode: Add several more instruction decodings. | bunnei | 1 | -5/+52 | |
2018-04-21 | shader_bytecode: Decode instructions based on bit strings. | bunnei | 2 | -205/+201 | |
2018-04-21 | ShaderGen: Implemented the KIL instruction, which is equivalent to 'discard'. | Subv | 1 | -1/+7 | |
2018-04-21 | ShaderGen: Implemented predicated instruction execution. | Subv | 2 | -1/+40 | |
Each predicated instruction will be wrapped in an `if (predicate) { instruction_body; }` in the GLSL, where `predicate` is one of the predicate boolean variables previously set by fsetp. | |||||
2018-04-21 | ShaderGen: Implemented the fsetp instruction. | Subv | 2 | -3/+112 | |
Predicate variables are now added to the generated shader code in the form of 'pX' where X is the predicate id. These predicate variables are initialized to false on shader startup and are set via the fsetp instructions. TODO: * Not all the comparison types are implemented. * Only the single-predicate version is implemented. | |||||
2018-04-21 | Kernel: Use 0x2C as default main thread priority for homebrew and lone NRO/NSOs | Subv | 3 | -3/+3 | |
2018-04-21 | Qt: Update the WaitTree widget to show info about the current mutex of each thread. | Subv | 5 | -90/+55 | |
2018-04-21 | Kernel: Remove unused ConditionVariable class. | Subv | 6 | -150/+0 | |
2018-04-21 | Kernel: Remove old and unused Mutex code. | Subv | 4 | -209/+3 | |
2018-04-21 | Kernel: Properly implemented svcWaitProcessWideKey and svcSignalProcessWideKey | Subv | 1 | -83/+46 | |
They work in tandem with guest code to provide synchronization primitives along with svcArbitrateLock/Unlock | |||||
2018-04-21 | Kernel: Corrected the implementation of svcArbitrateLock and svcArbitrateUnlock. | Subv | 6 | -22/+126 | |
Switch mutexes are no longer kernel objects, they are managed in userland and only use the kernel to handle the contention case. Mutex addresses store a special flag value (0x40000000) to notify the guest code that there are still some threads waiting for the mutex to be released. This flag is updated when a thread calls ArbitrateUnlock. TODO: * Fix svcWaitProcessWideKey * Fix svcSignalProcessWideKey * Remove the Mutex class. | |||||
2018-04-21 | opengl: Remove unnecessary header inclusions | Lioncash | 4 | -11/+0 | |
2018-04-21 | gl_resource_manager: Add missing noexcept specifiers to move constructors and assignment operators | Lioncash | 1 | -20/+19 | |
Standard library containers may use std::move_if_noexcept to perform move operations. If a move cannot be performed under these circumstances, then a copy is attempted. Given we only intend for these types to be move-only this can be somewhat problematic. By defining these to be noexcept we prevent cases where copies may be attempted. | |||||
2018-04-21 | gl_rasterizer_cache: Make MatchFlags an enum class | Lioncash | 1 | -4/+9 | |
Prevents implicit conversions and scope pollution. | |||||
2018-04-21 | core: Relocate g_service_manager to the System class | Lioncash | 6 | -38/+66 | |
Converts the service manager from a global into an instance-based variable. | |||||
2018-04-21 | resource_limit: Make ResourceTypes an enum class | Lioncash | 3 | -38/+38 | |
Prevents enum identifiers from leaking into the surrounding scope. | |||||
2018-04-20 | ShaderGen: Register id 255 is special and is hardcoded to return 0 (SR_ZERO). | Subv | 2 | -0/+5 | |
2018-04-20 | ShaderGen: Ignore the 'sched' instruction when generating shaders. | Subv | 1 | -0/+16 | |
The 'sched' instruction has a very convoluted encoding, but fortunately it seems to only appear on a fixed interval (once every 4 instructions). | |||||
2018-04-20 | math_util: Remove the Clamp() function | Lioncash | 5 | -24/+22 | |
C++17 adds clamp() to the standard library, so we can remove ours in favor of it. | |||||
2018-04-20 | vector_math: Remove AsArray() and Write() functions from Vec[2,3,4] | Lioncash | 1 | -30/+0 | |
These are all unused and the Write() ones should arguably not even be in the interface. There are better ways to provide this if we ever need it (like iterators). | |||||
2018-04-20 | common: Remove code_block.h | Lioncash | 2 | -86/+0 | |
We use dynarmic, so this is unued. Anything else we need will likely use Xbyak, so this header isn't necessary any more. | |||||
2018-04-20 | common/thread: Remove unnecessary feature checking for thread_local | Lioncash | 1 | -19/+0 | |
Every compiler we require already supports it. | |||||
2018-04-20 | common_funcs: Remove ARRAY_SIZE macro | Lioncash | 3 | -5/+4 | |
C++17 has non-member size() which we can just call where necessary. | |||||
2018-04-20 | common_funcs: Remove check for VS versions that we don't even support | Lioncash | 1 | -5/+0 | |
We don't support any VS versions that don't already have snprintf in the standard library implementation. | |||||
2018-04-20 | common_types: Convert typedefs to using aliases | Lioncash | 1 | -12/+12 | |
May as well while we're making changes to this file. | |||||
2018-04-20 | common_types: Remove unnecessary check for whether or not__func__ is defined | Lioncash | 1 | -6/+0 | |
VS has supported this for quite a while. | |||||
2018-04-20 | service: Use nested namespace specifiers where applicable | Lioncash | 136 | -570/+273 | |
Tidies up namespace declarations | |||||
2018-04-20 | vi: Remove redundant initializers in the constructors | Lioncash | 1 | -9/+5 | |
2018-04-20 | disk_filesystem: Remove unused total_entries_in_directory member from Disk_Directory | Lioncash | 1 | -1/+0 | |
2018-04-20 | disk_filesystem: Remove redundant initializer in Disk_Directory's constructor | Lioncash | 1 | -1/+1 | |
2018-04-20 | disk_filesystem: Make constructors explicit where applicable | Lioncash | 1 | -2/+2 | |
2018-04-20 | renderer_opengl: Add missing header guards | Lioncash | 2 | -0/+4 | |
2018-04-20 | glsl_shader_decompiler: Use std::string_view instead of std::string for AddLine() | Lioncash | 1 | -1/+2 | |
This function doesn't need to take ownership of the string data being given to it, considering all we do is append the characters to the internal string instance. Instead, use a string view to simply reference the string data without any potential heap allocation. Now anything that is a raw const char* won't need to be converted to a std::string before appending. | |||||
2018-04-20 | glsl_shader_decompiler: Add AddNewLine() function to ShaderWriter | Lioncash | 1 | -6/+12 | |
Avoids constructing a std::string just to append a newline character | |||||
2018-04-20 | glsl_shader_decompiler: Add char overload for ShaderWriter's AddLine() | Lioncash | 1 | -4/+11 | |
Avoids constructing a std::string just to append a character. | |||||
2018-04-20 | glsl_shader_decompiler: Append indentation without constructing a separate std::string | Lioncash | 1 | -1/+5 | |
The interface of std::string already lets us append N copies of a character to an existing string. | |||||
2018-04-19 | ShaderGen: Implemented the fmul32i shader instruction. | Subv | 2 | -9/+30 | |
2018-04-19 | ShaderGen: Fixed a case where the TEXS instruction would use the same registers for the input and the output. | Subv | 1 | -2/+9 | |
It will now save the coords before writing the outputs in a subscope. | |||||
2018-04-19 | Implement Pull #3528 from citra: use nvidia graphics automatically on laptops with optimus (with AMD support) (#271) | N00byKing | 2 | -0/+18 | |
* Port 3528: use nvidia graphics automatically on laptops with optimus * Force dedicated AMD Card for switchable Graphics * Ran clang-format | |||||
2018-04-19 | GPU: Add support for the DXT23 and DXT45 compressed texture formats. | Subv | 3 | -28/+35 | |
2018-04-19 | nvflinger: Call MicroProfileFlip on NVFlinger::Compose. | bunnei | 1 | -0/+3 | |
2018-04-19 | GPU: Implemented the B5G6R5 format. | Subv | 4 | -8/+28 | |
2018-04-18 | gl_shader_gen: Support vertical/horizontal viewport flipping. (#347) | bunnei | 4 | -5/+29 | |
* gl_shader_gen: Support vertical/horizontal viewport flipping. * fixup! gl_shader_gen: Support vertical/horizontal viewport flipping. | |||||
2018-04-18 | GLCache: Added boilerplate code to make supporting configurable texture component types. | Subv | 3 | -9/+69 | |
For now only the UNORM type is supported. | |||||
2018-04-18 | GLCache: Unify texture and framebuffer formats when converting to OpenGL. | Subv | 2 | -26/+13 | |
2018-04-18 | GPU: Texture format 8 and framebuffer format 0xD5 are actually ABGR8. | Subv | 2 | -10/+10 | |
2018-04-18 | GPU: Pitch textures are now supported, don't assert when encountering them. | Subv | 1 | -2/+3 | |
2018-04-18 | GLCache: Take into account the texture's block height when caching and unswizzling. | Subv | 3 | -43/+43 | |
2018-04-18 | GLCache: Added a function to convert cached PixelFormats back to texture formats. | Subv | 1 | -0/+12 | |
TODO: The way we handle cached formats must change, framebuffer and texture formats are too different to keep them in the same place. | |||||
2018-04-18 | GPU: Allow using a configurable block height when unswizzling textures. | Subv | 4 | -7/+23 | |
2018-04-18 | GPU/TIC: Added the pitch and block height fields to the TIC structure. | Subv | 1 | -1/+16 | |
2018-04-18 | gl_rasterizer_cache: Add missing LOG statements. | bunnei | 1 | -0/+3 | |
2018-04-18 | texture: Add missing formats. | bunnei | 1 | -1/+3 | |
2018-04-18 | gpu: Add several framebuffer formats to RenderTargetFormat. | bunnei | 1 | -0/+3 | |
2018-04-18 | maxwell3d: Allow Texture2DNoMipmap as Texture2D. | bunnei | 1 | -1/+2 | |
2018-04-18 | shader_bytecode: Make ctor's constexpr and explicit. | bunnei | 1 | -7/+7 | |
2018-04-18 | renderer_opengl: Implement BlendEquation and BlendFunc. | bunnei | 6 | -7/+140 | |
2018-04-18 | bit_field: Remove is_pod check, add is_trivially_copyable_v. | bunnei | 1 | -6/+1 | |
2018-04-17 | gl_shader_decompiler: Fix warnings with MarkAsUsed. | bunnei | 1 | -1/+2 | |
2018-04-17 | gl_shader_decompiler: Cleanup logging, updating to NGLOG_*. | bunnei | 1 | -24/+22 | |
2018-04-17 | gl_shader_decompiler: Implement several MUFU subops and abs_d. | bunnei | 1 | -7/+21 | |
2018-04-17 | gl_shader_decompiler: Fix swizzle in GetRegister. | bunnei | 1 | -1/+1 | |
2018-04-17 | gl_shader_decompiler: Implement FMUL/FADD/FFMA immediate instructions. | bunnei | 2 | -12/+53 | |
2018-04-17 | gl_shader_decompiler: Allow vertex position to be used in fragment shader. | bunnei | 2 | -16/+18 | |
2018-04-17 | gl_shader_decompiler: Implement IPA instruction. | bunnei | 1 | -0/+11 | |
2018-04-17 | gl_shader_decompiler: Add support for TEXS instruction. | bunnei | 2 | -12/+43 | |
2018-04-17 | gl_shader_decompiler: Use fragment output color for GPR 0-3. | bunnei | 1 | -0/+5 | |
2018-04-17 | gl_shader_decompiler: Partially implement MUFU. | bunnei | 1 | -2/+11 | |
2018-04-17 | Service/VI: stub SetLayerVisibility, fix GetDisplayResolution output | mailwl | 1 | -7/+27 | |
both SetLayerVisibility() functions used in Lego games, GetDisplayResolution() fixed according switchbrew.org | |||||
2018-04-17 | file_sys: Use NGLOG | shinyquagsire23 | 1 | -5/+5 | |
2018-04-17 | Various service name fixes - part 2 (rebased) (#322) | Hexagon12 | 13 | -11/+207 | |
* Updated ACC with more service names * Updated SVC with more service names * Updated set with more service names * Updated sockets with more service names * Updated SPL with more service names * Updated time with more service names * Updated vi with more service names | |||||
2018-04-17 | MaxwellToGL: Implemented tex wrap mode 1 (Wrap, GL_REPEAT). | Subv | 1 | -0/+2 | |
2018-04-17 | MaxwellToGL: Added a TODO and partial implementation of maxwell wrap mode 4 (Clamp, GL_CLAMP). | Subv | 1 | -0/+5 | |
This clamp mode was removed from OpenGL as of 3.1, we can emulate it by using GL_CLAMP_TO_BORDER to get the border color of the texture, and then manually sampling the edge to mix them in the fragment shader. | |||||
2018-04-17 | gl_rendering: Use NGLOG* for changed code. | bunnei | 2 | -10/+11 | |
2018-04-17 | gl_rasterizer: Implement indexed vertex mode. | bunnei | 5 | -23/+92 | |
2018-04-16 | file_sys: tweaks | shinyquagsire23 | 2 | -6/+7 | |
2018-04-16 | file_sys: Add HFS/PFS helper component | shinyquagsire23 | 3 | -0/+213 | |
2018-04-15 | pl_u: Use empty shared font if none is available. | bunnei | 1 | -17/+14 | |
- Makes games work in lieu of shared_font.bin. | |||||
2018-04-15 | GPU: Use the same buffer names in the generated GLSL and the buffer uploading code. | Subv | 4 | -17/+24 | |
2018-04-15 | GPU: Don't use explicit binding points when uploading the constbuffers to opengl. | Subv | 3 | -7/+47 | |
The bindpoints will now be dynamically calculated based on the number of buffers used by the previous shader stage. | |||||
2018-04-15 | fsp_srv: Implement DeleteFile. | bunnei | 6 | -9/+27 | |
- Used by Binding of Isaac. | |||||
2018-04-15 | GPU: Don't use GetPointer when uploading the constbuffer data to the GPU. | Subv | 1 | -3/+4 | |
2018-04-15 | GPU: Use the buffer hints from the shader decompiler to upload only the necessary const buffers for each shader stage. | Subv | 3 | -31/+41 | |
2018-04-15 | shaders: Expose hints about used const buffers. | bunnei | 5 | -31/+146 | |
2018-04-15 | GPU: Upload the entirety of each constbuffer for each shader stage as SSBOs. | Subv | 4 | -14/+48 | |
We're going to need the shader generator to give us a mapping of the actual used const buffers to properly bind them to the shader. | |||||
2018-04-15 | GPU: Allow configuring ssbos in the opengl state manager. | Subv | 4 | -0/+30 | |
2018-04-15 | GPU: Added a function to determine whether a shader stage is enabled or not. | Subv | 3 | -3/+27 | |
2018-04-15 | vm_manager: Increase GetTotalMemoryUsage value. | bunnei | 1 | -1/+1 | |
- Gets Binding of Isaac running. | |||||
2018-04-15 | fsp_srv: Implement IFile::Flush. | bunnei | 1 | -1/+9 | |
2018-04-15 | shaders: Add NumTextureSamplers const, remove unused #pragma. | bunnei | 4 | -4/+5 | |
2018-04-14 | shaders: Address PR review feedback. | bunnei | 2 | -7/+9 | |
2018-04-14 | gl_shader_decompiler: Cleanup log statements. | bunnei | 1 | -15/+15 | |
2018-04-14 | shaders: Fix GCC and clang build issues. | bunnei | 3 | -5/+5 | |
2018-04-14 | gl_shader_decompiler: Implement negate, abs, etc. and lots of cleanup. | bunnei | 2 | -40/+96 | |
2018-04-14 | shader_bytecode: Add FSETP and KIL to GetInfo. | bunnei | 1 | -0/+3 | |
2018-04-14 | shader_bytecode: Add SubOp decoding. | bunnei | 1 | -0/+10 | |
2018-04-14 | gl_shader_decompiler: Add shader stage hint. | bunnei | 2 | -5/+12 | |
2018-04-14 | renderer_opengl: Fix Morton copy byteswap, etc. | bunnei | 2 | -6/+6 | |
2018-04-14 | Fix the stuck in fullscreen bug (Original PR: citra-emu/citra#3611) | adityaruplaha | 1 | -2/+4 | |
2018-04-14 | gl_shader_manager: Implement SetShaderSamplerBindings. | bunnei | 1 | -0/+8 | |
2018-04-14 | gl_rasterizer: Generate shaders and upload uniforms. | bunnei | 2 | -32/+77 | |
2018-04-14 | gl_shader_decompiler: Basic impl. for very simple vertex shaders. | bunnei | 2 | -16/+311 | |
- Tested with Puyo Puyo Tetris and Cave Story+ | |||||
2018-04-14 | gl_shader_manager: Cleanup and consolidate uniform handling. | bunnei | 2 | -26/+24 | |
2018-04-14 | maxwell_3d: Make memory_manager public. | bunnei | 1 | -2/+1 | |
2018-04-14 | maxwell_3d: Fix shader_config decodings. | bunnei | 1 | -6/+3 | |
2018-04-14 | gl_rasterizer: Use shader program manager, remove test shader. | bunnei | 2 | -196/+31 | |
2018-04-14 | renderer_opengl: Add gl_shader_manager class. | bunnei | 3 | -0/+209 | |
2018-04-14 | maxwell_to_gl: Add a few types, etc. | bunnei | 1 | -0/+10 | |
2018-04-14 | gl_shader_gen: Add hashable setup/config structs. | bunnei | 2 | -29/+50 | |
2018-04-14 | gl_shader_util: Add missing includes. | bunnei | 1 | -0/+2 | |
2018-04-14 | common: Port cityhash code from Citra. | bunnei | 5 | -147/+502 | |
2018-04-14 | renderer_opengl: Use OGLProgram instead of OGLShader. | bunnei | 6 | -6/+6 | |
2018-04-14 | gl_shader_util: Grab latest upstream. | bunnei | 2 | -149/+74 | |
2018-04-14 | gl_resource_manager: Grab latest upstream. | bunnei | 1 | -30/+86 | |
2018-04-14 | gl_shader_decompiler: Add skeleton code from Citra for shader analysis. | bunnei | 2 | -44/+142 | |
2018-04-14 | shader_bytecode: Add initial module for shader decoding. | bunnei | 2 | -0/+298 | |
2018-04-14 | bit_field: Make all methods constexpr. | bunnei | 1 | -5/+5 | |
2018-04-13 | Fixed normal params in GetDisplayResolution | Hexagon12 | 1 | -1/+1 | |
2018-04-13 | Stubbed out GetPlayerLedPattern | Hexagon12 | 1 | -1/+7 | |
2018-04-11 | Service/SSL: update service according switchbrew | mailwl | 2 | -1/+98 | |
2018-04-11 | Various fixes and clang | Hexagon12 | 6 | -115/+108 | |
2018-04-10 | Decimal change | Hexagon12 | 1 | -4/+4 | |
2018-04-10 | Updated pctl:a with new service names. | Hexagon12 | 1 | -4/+101 | |
2018-04-10 | Updated nvmemp with new service names. | Hexagon12 | 1 | -4/+4 | |
2018-04-10 | Updated nvdrv with more service names. | Hexagon12 | 1 | -0/+7 | |
2018-04-10 | Updated pl:u with more service names. | Hexagon12 | 1 | -1/+3 | |
2018-04-10 | Updated hid with more service names. | Hexagon12 | 1 | -0/+50 | |
2018-04-10 | Updated friend:u with more service names. | Hexagon12 | 1 | -1/+2 | |
2018-04-10 | Updated the unknown name | Hexagon12 | 1 | -1/+1 | |
2018-04-10 | Updated friend:a with more service names. | Hexagon12 | 1 | -1/+2 | |
2018-04-10 | Updated fsp-srv with more service names. | Hexagon12 | 1 | -4/+102 | |
2018-04-10 | Updated CodecCtl with more service names. | Hexagon12 | 1 | -3/+3 | |
2018-04-10 | Updated audren with more service names. | Hexagon12 | 1 | -10/+14 | |
2018-04-10 | Updated audrec with more service names. | Hexagon12 | 1 | -7/+9 | |
2018-04-10 | Updated audout with more service names. | Hexagon12 | 1 | -13/+16 | |
2018-04-10 | Updated audin with more service names. | Hexagon12 | 1 | -9/+16 | |
2018-04-10 | Updated AOC with more service names. | Hexagon12 | 1 | -0/+1 | |
2018-04-10 | Updated AppletOE with more service names. | Hexagon12 | 1 | -0/+1 | |
2018-04-10 | Updated AppletAE with more service names. | Hexagon12 | 1 | -0/+1 | |
2018-04-10 | Updated AM with more service names. | Hexagon12 | 1 | -2/+82 | |
2018-04-10 | Service/ACC: convert to module, add acc:aa, acc:su, acc:u1 services | mailwl | 11 | -127/+342 | |
2018-04-07 | Prevent crash from uninitialized telemetry | James Rowe | 1 | -2/+1 | |
2018-04-07 | Fix spelling of Initialize | James Rowe | 2 | -3/+3 | |
2018-04-07 | Fix clang format issues | James Rowe | 1 | -1/+1 | |
2018-04-07 | GPU: Assert when finding a texture with a format type other than UNORM. | Subv | 2 | -4/+16 | |
2018-04-07 | GL: Set up the textures used for each draw call. | Subv | 2 | -2/+39 | |
Each Maxwell shader stage can have an arbitrary number of textures, but we're limited to a certain number in OpenGL. We try to only use the minimum amount of host textures by not keeping a 1:1 relation between guest texture ids and host texture ids, ie, guest texture id 8 can be host texture id 0 if it's the only texture used in the guest shader program. This mapping will have to be passed to the shader decompiler so it can rewrite the texture accesses. | |||||
2018-04-07 | GL: Bind the textures to the shaders used for drawing. | Subv | 1 | -2/+11 | |
2018-04-07 | GLCache: Specialize the MortonCopy function for the DXT1 texture format. | Subv | 1 | -1/+15 | |
It will now use the UnswizzleTexture function instead of the MortonCopyPixels128, which doesn't seem to work for textures. | |||||
2018-04-07 | GLCache: Implemented GetTextureSurface. | Subv | 1 | -3/+28 | |
2018-04-07 | GLCache: Support uploading compressed textures to the GPU. | Subv | 1 | -5/+17 | |
Compressed texture formats like DXT1, DXT2, DXT3, etc will use this to ease the load on the CPU. | |||||
2018-04-07 | GL: Remove remaining references to 3DS-specific pixel formats | Subv | 1 | -83/+22 | |
2018-04-07 | RasterizerCache: Remove 3DS-specific pixel formats. | Subv | 2 | -71/+32 | |
We're only left with RGB8 and DXT1 for now. More will be added as they are needed. | |||||
2018-04-07 | GL: Create the sampler objects when starting up the GL rasterizer. | Subv | 1 | -0/+6 | |
2018-04-07 | GL: Ported the SamplerInfo struct from citra. | Subv | 2 | -1/+59 | |
2018-04-07 | GL: Rename PicaTexture to MaxwellTexture. | Subv | 2 | -2/+2 | |
2018-04-07 | GL: Added functions to convert Maxwell tex filters and wrap modes to OpenGL. | Subv | 1 | -0/+23 | |
2018-04-07 | Textures: Added a helper function to know if a texture is blocklinear or pitch. | Subv | 1 | -0/+5 | |
2018-04-06 | core, main.h: Abort on 32Bit ROMs (#309) | N00byKing | 5 | -1/+17 | |
* core, main.h: Abort on 32Bit ROMs * main.cpp: Fix Grammar | |||||
2018-04-06 | Update fmtlib to fix msvc warnings | James Rowe | 2 | -5/+8 | |
Additionally, when updating fmtlib, there was a change in fmtlib broke how the old logging macro was overloaded, so this works around that by just naming the fmtlib macro impl something different | |||||
2018-04-04 | rasterizer_interface.h: Update from citra to yuzu | N00byKing | 1 | -3/+3 | |
2018-04-04 | default_ini.h: Update from citra to yuzu | N00byKing | 1 | -1/+1 | |
2018-04-04 | gl_rasterizer_cache.cpp: Update from citra to yuzu | N00byKing | 1 | -1/+1 | |
2018-04-04 | gl_rasterizer_cache.h: Update from citra to yuzu | N00byKing | 1 | -3/+3 | |
2018-04-04 | renderer_opengl.h: Update from citra to yuzu | N00byKing | 1 | -2/+2 | |
2018-04-03 | svc: Stub out SetThreadActivity, GetThreadContext. | bunnei | 2 | -2/+19 | |
2018-04-03 | audren_u: Stub out GetActiveAudioDeviceName. | bunnei | 1 | -1/+13 | |
2018-04-03 | audout_u: Implement GetAudioOutState. | bunnei | 1 | -1/+8 | |
2018-04-03 | nifm: GetResult does not return a data field. | bunnei | 1 | -2/+1 | |
2018-04-03 | vi: Implement GetDisplayResolution. | bunnei | 2 | -0/+26 | |
2018-04-03 | shared_memory: Remove incorrect 3ds-specific check. | bunnei | 1 | -12/+0 | |
2018-04-03 | service: Add friend:u interface. | bunnei | 4 | -0/+41 | |
2018-04-03 | logging: Change FmtLogMessage to use variadic template instead of FMT_VARIADIC | Daniel Lim Wee Soong | 2 | -5/+11 | |
Due to premature merging of #262 I think the build may be failing right now. Should merge this ASAP to fix it. | |||||
2018-04-03 | deconstructed_rom_directory.cpp: Fix Typo | N00byKing | 1 | -1/+1 | |
2018-04-02 | externals: Update fmt to 4d35f94 | Daniel Lim Wee Soong | 1 | -6/+6 | |
Versions prior to this didn't compile on OpenBSD due to unconditional use of the non-standard strtod_l() function. The fmt::MemoryWriter API has been removed in the intervening versions, so replace its use with fmt::memory_buffer and fmt::format_to. The library also no longer provides the fmt::fmt ALIAS, so define it in externals/CMakeLists.txt. | |||||
2018-04-02 | common: fix swap functions on Bitrig and OpenBSD | Daniel Lim Wee Soong | 1 | -1/+13 | |
swap{16,32,64} are defined as macros on the two, but client code tries to invoke them as Common::swap{16,32,64}, which naturally doesn't work. This hack redefines the macros as inline functions in the Common namespace: the bodies of the functions are the same as the original macros, but relying on OS-specific implementation details like this is of course brittle. | |||||
2018-04-01 | GPU: Use the MacroInterpreter class to execute the GPU macros instead of HLEing them. | Subv | 2 | -121/+13 | |
2018-04-01 | GPU: Implemented a gpu macro interpreter. | Subv | 5 | -0/+431 | |
The Ryujinx macro interpreter and envydis were used as reference. Macros are programs that are uploaded by the games during boot and can later be called by writing to their method id in a GPU command buffer. | |||||
2018-04-01 | hid: Write empty touch screen state. | bunnei | 1 | -5/+21 | |
2018-04-01 | hle_ipc, fsp_srv: Cleanup logging. | bunnei | 2 | -3/+3 | |
2018-03-31 | hid: Stub out GetSupportedNpadStyleSet. | bunnei | 1 | -0/+8 | |
2018-03-31 | hle_ipc: Do not ensure write buffer size. | bunnei | 1 | -2/+5 | |
2018-03-31 | fsp_srv: Implement GetSize and SetSize. | bunnei | 2 | -4/+24 | |
2018-03-31 | memory: Fix stack region. | bunnei | 6 | -10/+12 | |
2018-03-30 | Port citra-emu/citra#3610 to yuzu | N00byKing | 2 | -3/+7 | |
2018-03-30 | Remove whitespaces | N00byKing | 1 | -1/+1 | |
2018-03-30 | Add Dark theme, Icon theming | N00byKing | 7 | -0/+75 | |
configure_general.ui: Add UI Option for Themes config.cpp: Save Theme Settings | |||||
2018-03-30 | audren_u: Stub QueryAudioDeviceSystemEvent and GetActiveChannelCount. | bunnei | 1 | -8/+36 | |
2018-03-30 | svc: Stub GetThreadCoreMask. | bunnei | 2 | -3/+26 | |
2018-03-30 | service: Add NFP module interface. | bunnei | 8 | -0/+101 | |
service: Initialize NFP service. Log: Add NFP service as a log subtype. | |||||
2018-03-29 | result: Check against self-assignment in ResultVal's copy assignment operator | Lioncash | 1 | -0/+3 | |
Avoids doing work that doesn't need to be done. | |||||
2018-03-27 | main.h: Add pragma once, remove ifndef | N00byKing | 1 | -5/+2 | |
2018-03-27 | telemetry.h: Reword comment from citra to yuzu | N00byKing | 1 | -1/+1 | |
2018-03-27 | telemetry_session.h: Reword Documentation Comment from citra to yuzu | N00byKing | 1 | -2/+2 | |
2018-03-27 | Remove Links to citra Services | N00byKing | 1 | -2/+2 | |
2018-03-27 | Change Telemetry Names to yuzu | N00byKing | 2 | -5/+5 | |
2018-03-27 | settings: Remove unused CpuCore class. | bunnei | 1 | -5/+0 | |
2018-03-27 | config: Use simplified checkbox (from Citra) for CPU JIT. | bunnei | 8 | -46/+33 | |
2018-03-27 | config: Rename is_docked to use_docked_mode to be consistent with other config bools. | bunnei | 7 | -14/+14 | |
2018-03-27 | configure_general: Cleanup naming. | bunnei | 1 | -14/+14 | |
2018-03-27 | qt: Add config option for is_docked. | bunnei | 2 | -0/+23 | |
2018-03-27 | config: Add setting for whether the system is docked or not. | bunnei | 5 | -2/+24 | |
2018-03-27 | renderer_opengl: Use better naming for DrawScreens and DrawSingleScreen. | bunnei | 2 | -8/+8 | |
2018-03-27 | graphics_surface: Remove superfluous cast. | bunnei | 1 | -2/+1 | |
2018-03-27 | gl_rasterizer: Move code to bind framebuffer surfaces before draw to its own function. | bunnei | 2 | -22/+31 | |
2018-03-27 | gl_rasterizer: Add a SyncViewport method. | bunnei | 3 | -18/+30 | |
2018-03-27 | gl_rasterizer: Move PrimitiveTopology check to MaxwellToGL. | bunnei | 2 | -11/+12 | |
2018-03-27 | graphics_surface: Fix merge conflicts. | bunnei | 2 | -3/+4 | |
2018-03-27 | gl_rasterizer: Use ReadBlock instead of GetPointer for SetupVertexArray. | bunnei | 1 | -1/+1 | |
2018-03-27 | gl_rasterizer: Normalize vertex array data as appropriate. | bunnei | 2 | -1/+5 | |
2018-03-27 | memory: Fix cast for ReadBlock/WriteBlock/ZeroBlock/CopyBlock. | bunnei | 1 | -4/+8 | |
2018-03-27 | maxwel_to_gl: Fix string formatting in log statements. | bunnei | 1 | -2/+2 | |
2018-03-27 | rasterizer: Rename DrawTriangles to DrawArrays. | bunnei | 3 | -5/+5 | |
2018-03-27 | gl_rasterizer: Use passthrough shader for SetupVertexShader. | bunnei | 1 | -1/+2 | |
2018-03-27 | renderer_opengl: Logging, etc. cleanup. | bunnei | 6 | -33/+34 | |
2018-03-27 | renderer_opengl: Remove framebuffer RasterizerFlushVirtualRegion hack. | bunnei | 1 | -5/+0 | |
2018-03-27 | gl_rasterizer_cache: Implement UpdatePagesCachedCount. | bunnei | 2 | -8/+37 | |
2018-03-27 | memory: Add RasterizerMarkRegionCached code and cleanup. | bunnei | 2 | -200/+195 | |
2018-03-27 | gl_rasterizer: Implement SetupVertexArray. | bunnei | 1 | -20/+38 | |
2018-03-27 | gl_rasterizer_cache: Fix an ASSERT_MSG. | bunnei | 1 | -1/+1 | |
2018-03-27 | maxwell_to_gl: Add module and function for decoding VertexType. | bunnei | 2 | -0/+41 | |
2018-03-27 | maxwell_3d: Use names that match envytools for VertexType. | bunnei | 1 | -8/+8 | |
2018-03-27 | maxwell_3d: Add VertexAttribute struct and cleanup. | bunnei | 1 | -121/+160 | |
2018-03-27 | gl_rasterizer: Use 32 texture units instead of 3. | bunnei | 3 | -2/+3 | |
2018-03-27 | gl_rasterizer: Implement DrawTriangles. | bunnei | 1 | -1/+194 | |
2018-03-27 | Maxwell3D: Call AccelerateDrawBatch on DrawArrays. | bunnei | 1 | -1/+8 | |
2018-03-27 | gl_rasterizer: Implement AnalyzeVertexArray. | bunnei | 2 | -1/+56 | |
2018-03-27 | gl_rasterizer_cache: MortonCopy Switch-style. | bunnei | 1 | -72/+32 | |
2018-03-27 | gl_rasterizer_cache: Implement GetFramebufferSurfaces. | bunnei | 2 | -4/+104 | |
2018-03-27 | maxwell: Add RenderTargetFormat enum. | bunnei | 2 | -4/+5 | |
2018-03-27 | renderer_opengl: Only draw the screen if a framebuffer is specified. | bunnei | 1 | -6/+7 | |
2018-03-26 | GPU: Load the sampler info (TSC) when retrieving active textures. | Subv | 2 | -21/+67 | |
2018-03-26 | GPU: Added the TSC structure. It contains information about the sampler. | Subv | 1 | -0/+50 | |
2018-03-26 | GPU: Added more fields to the TIC structure. | Subv | 1 | -4/+30 | |
2018-03-26 | log.h: Change comment from citra to yuzu | N00byKing | 1 | -1/+1 | |
2018-03-26 | file_util.h: Update Comment from citra to yuzu | N00byKing | 1 | -1/+1 | |
2018-03-26 | yuzu.cpp: Update Link from citra to yuzu | N00byKing | 1 | -1/+1 | |
2018-03-26 | cpu_detect.cpp: Change comment from citra to yuzu | N00byKing | 1 | -1/+1 | |
2018-03-25 | main.cpp: Replace Citra with yuzu Wiki Links | N00byKing | 1 | -4/+4 | |
2018-03-25 | main.cpp: Update Dialog from citra to yuzu | N00byKing | 1 | -11/+11 | |
2018-03-25 | Service/sockets: add bsd:s, nsd:a, nsd:u services | mailwl | 8 | -32/+96 | |
2018-03-25 | audren_u: Fix GetAudioDevice. | bunnei | 2 | -7/+48 | |
2018-03-25 | hid: Stub out SetNpadJoyAssignmentModeDual. | bunnei | 1 | -1/+7 | |
2018-03-25 | pl_u: Add RequestLoad. | bunnei | 2 | -0/+11 | |
2018-03-25 | GPU: Make the debug_context variable a member of the frontend instead of a global. | Subv | 7 | -19/+40 | |
2018-03-24 | GPU: Added a function to retrieve the active textures for a shader stage. | Subv | 2 | -50/+59 | |
TODO: A shader may not use all of these textures at the same time, shader analysis should be performed to determine which textures are actually sampled. | |||||
2018-03-24 | Frontend: Updated the surface view debug widget to work with Maxwell surfaces. | Subv | 3 | -19/+38 | |
2018-03-24 | Frontend: Allow opening the Surface View widget in the Qt frontend. | Subv | 2 | -0/+8 | |
2018-03-24 | GPU: Implement the Incoming/FinishedPrimitiveBatch debug breakpoints. | Subv | 1 | -0/+7 | |
2018-03-24 | GPU: Implement the MaxwellCommandLoaded/Processed debug breakpoints. | Subv | 1 | -0/+10 | |
2018-03-24 | Frontend: Ported the GPU breakpoints and surface viewer widgets from citra. | Subv | 15 | -4/+1155 | |
2018-03-24 | GPU: Added a method to unswizzle a texture without decoding it. | Subv | 4 | -5/+95 | |
Allow unswizzling of DXT1 textures. | |||||
2018-03-24 | GPU: Preliminary work for texture decoding. | Subv | 5 | -0/+139 | |
2018-03-24 | arm_dynarmic: Fix timing | MerryMage | 1 | -7/+3 | |
2018-03-24 | GPU: Added viewport registers to Maxwell3D's reg structure. | Subv | 1 | -1/+18 | |
2018-03-24 | gl_rasterizer: Fake render in green, because it's cooler. | bunnei | 1 | -1/+1 | |
2018-03-24 | gl_rasterizer: Log warning instead of sync'ing unimplemented funcs. | bunnei | 1 | -7/+1 | |
2018-03-23 | gl_rasterizer_cache: Add missing include for vm_manager. | bunnei | 1 | -0/+1 | |
2018-03-23 | renderer_opengl: Only invalidate the framebuffer region, not flush. | bunnei | 1 | -4/+3 | |
2018-03-23 | renderer_opengl: Fixes for properly flushing & rendering the framebuffer. | bunnei | 2 | -12/+12 | |
2018-03-23 | memory: Fix typo in RasterizerFlushVirtualRegion. | bunnei | 1 | -3/+3 | |
2018-03-23 | FS: Move the file open mode calculation to a separate function. | Subv | 1 | -7/+14 | |
2018-03-23 | RasterizerCacheOpenGL: FlushAll should flush full memory region. | bunnei | 1 | -1/+1 | |
2018-03-23 | memory: RasterizerFlushVirtualRegion should also check process image region. | bunnei | 1 | -0/+1 | |
2018-03-23 | rasterizer: Flush and invalidate regions should be 64-bit. | bunnei | 5 | -12/+12 | |
2018-03-23 | renderer_opengl: Add framebuffer_transform_flags member variable. | bunnei | 1 | -2/+2 | |
2018-03-23 | renderer_opengl: Better handling of framebuffer transform flags. | bunnei | 4 | -6/+23 | |
2018-03-23 | Remove Option for N/3DS from default.ini | N00byKing | 1 | -4/+0 | |
2018-03-23 | CITRA_ICON -> YUZU_ICON | N00byKing | 1 | -1/+1 | |
2018-03-23 | Service/SSL: add ssl service | mailwl | 6 | -0/+45 | |
2018-03-23 | renderer_opengl: Use accelerated framebuffer load with LoadFBToScreenInfo. | bunnei | 1 | -31/+25 | |
2018-03-23 | nvdisp_disp0: Always flush and invalidate framebuffer region. | bunnei | 1 | -0/+7 | |
- Workaround for texture forwarding until we have a better place. | |||||
2018-03-23 | gl_rasterizer: Implement AccelerateDisplay method from Citra. | bunnei | 2 | -2/+44 | |
2018-03-23 | LoadGLBuffer: Use bytes_per_pixel, not bits. | bunnei | 1 | -1/+2 | |
2018-03-23 | memory: Port RasterizerFlushVirtualRegion from Citra. | bunnei | 2 | -1/+58 | |
2018-03-23 | gl_rasterizer_cache: LoadGLBuffer should do a morton copy. | bunnei | 1 | -16/+5 | |
2018-03-23 | video_core: Move MortonCopyPixels128 to utils header. | bunnei | 2 | -111/+113 | |
2018-03-23 | yuzu_cmd: change default cpu core to dynarmic | Valentin Vanelslande | 1 | -1/+1 | |
2018-03-23 | default_ini: change default cpu core to dynarmic | Valentin Vanelslande | 1 | -1/+1 | |
2018-03-23 | video_core: Remove usage of PAddr and replace with VAddr. | bunnei | 5 | -39/+39 | |
2018-03-23 | video_core: Move FramebufferInfo to FramebufferConfig in GPU. | bunnei | 8 | -69/+77 | |
2018-03-23 | gl_rasterizer: Replace a bunch of UNIMPLEMENTED with ASSERT. | bunnei | 2 | -20/+20 | |
2018-03-23 | gl_rasterizer: Add a simple passthrough shader in lieu of shader generation. | bunnei | 2 | -5/+68 | |
2018-03-23 | gpu: Expose Maxwell3D engine. | bunnei | 1 | -0/+4 | |
2018-03-23 | maxwell_3d: Add some format decodings and string helper functions. | bunnei | 1 | -3/+107 | |
2018-03-23 | renderer: Create rasterizer and cleanup. | bunnei | 4 | -4/+16 | |
2018-03-22 | Remove more N3DS References | N00byKing | 2 | -20/+0 | |
2018-03-22 | Remove dependency chrono | Daniel Lim Wee Soong | 1 | -1/+0 | |
Earlier chrono was included but after some code changed it was no longer needed Forgot to remove it so I'm removing it now | |||||
2018-03-22 | Change "yuzu starting..." to be logged with the new macro | Daniel Lim Wee Soong | 1 | -1/+1 | |
Just as a proof that it works | |||||
2018-03-22 | Logging: Create logging macros based on fmtlib | Daniel Lim Wee Soong | 10 | -67/+112 | |
Add a new set of logging macros based on fmtlib Similar but not exactly the same as https://github.com/citra-emu/citra/pull/3533 Citra currently uses a different version of fmt, which does not support FMT_VARIADIC so make_args is used instead. On the other hand, yuzu uses fmt 4.1.0 which doesn't have make_args yet so FMT_VARIADIC is used. | |||||
2018-03-22 | Service/spl: add module and services | mailwl | 10 | -0/+176 | |
2018-03-21 | CMake: Set EMU_ARCH_BITS in CMakeLists.txt | N00byKing | 3 | -36/+0 | |
2018-03-21 | FS: Implemented IFileSystem::CreateDirectory. | Subv | 6 | -7/+29 | |
2018-03-21 | GPU: Added vertex attribute format registers. | Subv | 1 | -1/+14 | |
2018-03-21 | Service/vi: convert services to module | mailwl | 8 | -212/+160 | |
2018-03-21 | GPU: Added registers for the number of vertices to render. | Subv | 1 | -2/+13 | |
2018-03-20 | Service: add fatal:u, fatal:p services | mailwl | 10 | -0/+146 | |
2018-03-20 | renderer_gl: Port boilerplate rasterizer code over from Citra. | bunnei | 5 | -1/+495 | |
2018-03-20 | gl_shader_util: Sync latest version with Citra. | bunnei | 3 | -46/+116 | |
2018-03-20 | renderer_gl: Port over gl_shader_gen module from Citra. | bunnei | 3 | -0/+88 | |
2018-03-20 | FS: Implemented IFileSystem's OpenDirectory function. | Subv | 1 | -0/+28 | |
Note that the filter parameter is not yet implemented. | |||||
2018-03-20 | FS: Added the IDirectory IPC interface and implemented its two functions. | Subv | 1 | -0/+51 | |
2018-03-20 | FS: Implement DiskFileSystem's OpenDirectory interface. | Subv | 5 | -6/+19 | |
2018-03-20 | FS: Implement DiskFileSystem::GetEntryType for existing files/directories. | Subv | 1 | -2/+4 | |
2018-03-20 | FS: Updated the Directory Entry structure to match the Switch. | Subv | 5 | -30/+84 | |
2018-03-20 | FS: Support the file Append open mode. | Subv | 2 | -2/+23 | |
2018-03-20 | renderer_gl: Port over gl_shader_decompiler module from Citra. | bunnei | 3 | -0/+87 | |
2018-03-20 | renderer_gl: Port over gl_rasterizer_cache module from Citra. | bunnei | 3 | -0/+1714 | |
2018-03-20 | gl_resource_manager: Sync latest version with Citra. | bunnei | 1 | -8/+77 | |
2018-03-20 | renderer_gl: Port over gl_stream_buffer module from Citra. | bunnei | 3 | -0/+218 | |
2018-03-20 | gl_state: Sync latest version with Citra. | bunnei | 2 | -47/+111 | |
2018-03-20 | FS: Implement MountSdCard. | Subv | 1 | -2/+6 | |
2018-03-20 | FS: Added an SDMC archive factory and registered it to the SDMC archive on startup. | Subv | 5 | -0/+79 | |
2018-03-19 | GPU: Added Z buffer registers to Maxwell3D's reg structure. | Subv | 1 | -1/+17 | |
2018-03-19 | GPU: Added the render target (RT) registers to Maxwell3D's reg structure. | Subv | 1 | -1/+32 | |
2018-03-19 | Clang Fixes | N00byKing | 5 | -9/+11 | |
2018-03-19 | oops | N00byKing | 1 | -3/+3 | |
2018-03-19 | More Warning cleanups | N00byKing | 3 | -3/+3 | |
2018-03-19 | Clean Warnings (?) | N00byKing | 15 | -20/+20 | |
2018-03-19 | GPU: Added the TSC registers to the Maxwell3D register structure. | Subv | 1 | -1/+15 | |
2018-03-19 | GPU: Added the TIC registers to the Maxwell3D register structure. | Subv | 1 | -1/+16 | |
2018-03-19 | vi: Remove DequeueBuffer and wait until next available buffer. | bunnei | 3 | -12/+49 | |
2018-03-19 | hle_ipc: Add SleepClientThread to block current thread within HLE routines. | bunnei | 2 | -0/+47 | |
2018-03-19 | hle_ipc: Use shared_ptr instead of unique_ptr to allow copies. | bunnei | 2 | -9/+9 | |
2018-03-19 | hle_ipc: Remove GetPointer(..) usage with WriteToOutgoingCommandBuffer. | bunnei | 3 | -7/+14 | |
2018-03-19 | thread: Add THREADSTATUS_WAIT_HLE_EVENT, remove THREADSTATUS_WAIT_ARB. | bunnei | 4 | -23/+9 | |
2018-03-19 | GPU: Implement macro 0xE1A BindTextureInfoBuffer in HLE. | Subv | 2 | -1/+29 | |
This macro simply sets the current CB_ADDRESS to the texture buffer address for the input shader stage. | |||||
2018-03-18 | GPU: Implement the BindStorageBuffer macro method in HLE. | Subv | 2 | -1/+36 | |
This macro binds the SSBO Info Buffer as the current ConstBuffer. This buffer is usually bound to c0 during shader execution. Games seem to use this macro instead of directly writing the address for some reason. | |||||
2018-03-18 | GPU: Handle writes to the CB_DATA method. | Subv | 2 | -0/+39 | |
Writing to this method will cause the written value to be stored in the currently-set ConstBuffer plus CB_POS. This method is usually used to upload uniforms or other shader-visible data. | |||||
2018-03-18 | GPU: Move the GPU's class constructor and destructors to a cpp file. | Subv | 3 | -10/+30 | |
This should reduce recompile times when editing the Maxwell3D register structure. | |||||
2018-03-18 | GPU: Store uploaded GPU macros and keep track of the number of method parameters. | Subv | 4 | -27/+74 | |
2018-03-18 | GPU: Macros are specific to the Maxwell3D engine, so handle them internally. | Subv | 8 | -63/+55 | |
2018-03-18 | GPU: Renamed ShaderType to ShaderStage as that is less confusing. | Subv | 2 | -19/+19 | |
2018-03-18 | GPU: Store shader constbuffer bindings in the GPU state. | Subv | 2 | -5/+61 | |
2018-03-18 | GPU: Corrected some register offsets and removed superfluous macro registers. | Subv | 1 | -9/+3 | |
2018-03-18 | GPU: Make the SetShader macro call do the same as the real macro's code. | Subv | 2 | -3/+44 | |
It'll now set the CB_SIZE, CB_ADDRESS and CB_BIND registers when it's called. Presumably this SetShader function is binding the constant shader uniforms to buffer 1 (c1[]). | |||||
2018-03-17 | GPU: Corrected the parameter documentation for the SetShader macro call. | Subv | 2 | -11/+12 | |
Register 0xE24 is actually a macro that sets some shader parameters in the register structure. Macros are uploaded to the GPU at startup and have their own ISA, we'll probably write an interpreter for this in the future. | |||||
2018-03-17 | GPU: Handle the SetShader method call (0xE24) and store the shader config. | Subv | 2 | -4/+38 | |
2018-03-17 | GPU: Added the vertex array registers. | Subv | 1 | -2/+33 | |
2018-03-17 | GPU: Process command mode 5 (IncreaseOnce) differently from other commands. | Subv | 9 | -8/+97 | |
Accumulate all arguments before calling the desired method. Note: Maybe we should do the same for the NonIncreasing mode? | |||||
2018-03-17 | GPU: Assert that we get a 0 CODE_ADDRESS register in the 3D engine. | Subv | 1 | -0/+8 | |
Shader address calculation depends on this value to some extent, we do not currently know what it being 0 entails. | |||||
2018-03-17 | GPU: Added Maxwell registers for Shader Program control. | Subv | 1 | -2/+55 | |
2018-03-17 | nvflinger: Remove superfluous buffer format check. | bunnei | 1 | -3/+1 | |
2018-03-17 | process: MirrorMemory should use MemoryState::Mapped. | bunnei | 1 | -1/+1 | |
2018-03-16 | process: Unmap previously allocated heap. | bunnei | 1 | -1/+3 | |
2018-03-16 | arm_interface: Support unmapping previously mapped memory. | bunnei | 6 | -2/+18 | |
2018-03-16 | svc: Use more correct values for GetInfo MapRegion and NewMapRegion. | bunnei | 3 | -29/+5 | |
2018-03-16 | kernel: Move stack region outside of application heap. | bunnei | 6 | -11/+6 | |
2018-03-16 | memory: Add regions for map region, "new" map region, etc. | bunnei | 1 | -19/+29 | |
2018-03-16 | process: Fix stack memory state. | bunnei | 1 | -2/+4 | |
2018-03-16 | MemoryState: Add additional memory states and improve naming. | bunnei | 5 | -18/+45 | |
2018-03-16 | IGeneralService: fix function list | mailwl | 1 | -2/+3 | |
2018-03-16 | Service/NIFM: stub cancel function | mailwl | 1 | -1/+6 | |
2018-03-16 | Service/NIFM: convert to module | mailwl | 8 | -122/+75 | |
2018-03-14 | core: Move process creation out of global state. | bunnei | 22 | -72/+87 | |
2018-03-05 | GPU: Intercept writes to the VERTEX_END_GL register. | Subv | 2 | -1/+18 | |
This is the register that gets written after a game calls DrawArrays(). We should collect all GPU state and draw using our graphics API here. | |||||
2018-03-04 | FS: Use the correct error code when trying to open files that don't exist. | Subv | 2 | -26/+6 | |
2018-03-04 | FS: Stubbed CreateSaveData. It currently does nothing. | Subv | 2 | -0/+15 | |
2018-03-04 | FS: Make EnsureSaveData create the savedata folder when called for the first time. | Subv | 8 | -17/+70 | |
2018-03-04 | CoreTiming: Unschedule the pending events when an Interface is destroyed. | Subv | 3 | -2/+10 | |
2018-03-03 | Vi: Signal the BufferQueue's Native Handle right after ReleaseBuffer is called. | Subv | 1 | -0/+3 | |
This prevents a thread starvation issue in Puyo Puyo Tetris. We should hwtest this behavior and figure out where exactly this event is signaled. | |||||
2018-03-03 | Service/Set: add more services | mailwl | 12 | -10/+348 | |
2018-03-02 | SaveData: Use the current titleid when opening the savedata archive. | Subv | 1 | -2/+3 | |
2018-03-02 | Kernel: Store the program id in the Process class instead of the CodeSet class. | Subv | 9 | -26/+25 | |
There may be many CodeSets per Process, so it's wasteful and overcomplicated to store the program id in each of them. | |||||
2018-03-02 | FS: Implement MountSaveData and some of the IFile interface. | Subv | 2 | -0/+189 | |
2018-03-02 | Filesystem: Added a SaveData Factory and associated Disk_FileSystem. | Subv | 10 | -16/+329 | |
2018-02-27 | thread: Clear the process list on shutdown. | Jules Blok | 1 | -1/+3 | |
2018-02-27 | ResultCode: Mark any error code that isn't 0 as an error. | Subv | 1 | -2/+2 | |
2018-02-27 | Removes the use of QKeySequence::Cancel (#186) | Vishal Sharma | 1 | -1/+2 | |
* Removes the use of QKeySequence::Cancel to remove issues while running make * Corrects characters in a line for travis failure * Corrects space in a line for travis failure | |||||
2018-02-26 | file_sys: Style tweaks | shinyquagsire23 | 2 | -11/+5 | |
Asdf | |||||
2018-02-25 | loader: Check error on NPDM load, use TID for CodeSet | shinyquagsire23 | 3 | -6/+10 | |
2018-02-25 | loader: Use NPDM information when loading NSOs | shinyquagsire23 | 2 | -4/+15 | |
2018-02-25 | file_sys: Add support for parsing NPDM files | shinyquagsire23 | 3 | -0/+276 | |
2018-02-25 | (Hopefully) Fix MinGW Build | N00byKing | 1 | -1/+1 | |
2018-02-25 | Implements citra-emu/citra#3184 | N00byKing | 7 | -41/+41 | |
2018-02-25 | Add UnmapSharedMemory | N00byKing | 2 | -1/+17 | |
C++11 requires spaces on the Identifier Add inttypes include clang | |||||
2018-02-23 | time: Add missing time:s functions, used for libnx | shinyquagsire23 | 1 | -0/+4 | |
2018-02-22 | Stub more functions | mailwl | 7 | -8/+90 | |
2018-02-22 | Stub am::SetScreenShotPermission, and bsd::StartMonitoring functions | mailwl | 5 | -1/+22 | |
2018-02-22 | time: Add GetStandardLocalSystemClock, used by libnx | shinyquagsire23 | 3 | -0/+9 | |
2018-02-21 | dynarmic: Update to 6b4c6b0 | MerryMage | 1 | -2/+18 | |
6b4c6b0 impl: Update PC when raising exception 7a1313a A64: Implement FDIV (vector) b2d781d system: Raise exception for YIELD, WFE, WFI, SEV, SEVL b277bf5 Correct FPSR and FPCR 7673933 A64: Implement USHL 8d0e558 A64: Implement UCVTF (vector, integer), scalar variant da9a4f8 A64: Partially implement FCVTZU (scalar, fixed-point) and FCVTZS (scalar, fixed-point) 7479684 A64: Implement system register TPIDR_EL0 0fd75fd A64: Implement system registers FPCR and FPSR 31e370c A64: Implement system register CNTPCT_EL0 9a88fd3 A64: Implement system register CTR_EL0 1d16896 A64: Implement NEG (vector) 3184edf IR: Add IR instruction ZeroVector 31f8fbc emit_x64_floating_point: Add maybe_unused to preprocess parameter 567eb1a A64: Implement FMINNM (scalar) c6d8fa1 A64: Implement FMAXNM (scalar) 616056d constant_pool: Add frame parameter a3747cb A64: Implement ADDP (scalar) 5cd5d9f reg_alloc: Only exchange GPRs dd0452a A64: Implement DUP (element), scalar variant e5732ea emit_x64_floating_point: Correct FP{Max,Min}{32,64} implementations for -0/+0 40eb9c3 A64: Implement FMAX (scalar), FMIN (scalar) 7cef39b fuzz_with_unicorn: QEMU's implementation of FCVT is incorrect 826dce2 travis: Switch unicorn repository 9605f28 a64/config: Allow NaN emulation accuracy to be set e9435bc a64_emit_x64: Add conf to A64EmitContext 30b596d fuzz_with_unicorn: Explicitly test floating point instructions be292a8 A64: Implement FSQRT (scalar) 3c42d48 backend_x64: Accurately handle NaNs 4aefed0 fuzz_with_unicorn: Print AArch64 disassembly | |||||
2018-02-21 | arm_dynarmic: LOG_INFO on unicorn fallback | MerryMage | 1 | -0/+4 | |
2018-02-21 | memory: LOG_ERROR when falling off end of page table | MerryMage | 1 | -0/+11 | |
2018-02-21 | core: Fix scheduler-shutdown related crash | MerryMage | 1 | -5/+9 | |
2018-02-20 | Add warning if Domain request has no domain message header | mailwl | 1 | -0/+3 | |
2018-02-20 | Fix: change check for domain order and existance of domain message header | mailwl | 3 | -3/+4 | |
2018-02-20 | IPC: add domain header to response if only it exists in request | mailwl | 3 | -6/+8 | |
2018-02-20 | Service/AOC: stub ListAddOnContent function | mailwl | 4 | -2/+28 | |
2018-02-19 | acc_u0: Stub ListOpenUsers service function. | bunnei | 2 | -1/+11 | |
2018-02-19 | service: Add Friend service interface. | bunnei | 6 | -0/+100 | |
2018-02-19 | logging: Add category for Friend service. | bunnei | 2 | -0/+2 | |
2018-02-19 | scheduler: Cleanup based on PR feedback. | bunnei | 3 | -5/+4 | |
2018-02-19 | AM: Corrected the response in EnsureSaveData. | Subv | 1 | -1/+2 | |
The values are still unknown and the function is still considered a stub. Puyo Puyo Tetris now tries to call fsp-srv:MountSaveData. | |||||
2018-02-18 | kernel: Use Scheduler class for threading. | bunnei | 6 | -174/+26 | |
2018-02-18 | kernel: Add Scheduler, which encapsulates the scheduling loading from Thread module. | bunnei | 3 | -0/+210 | |
2018-02-18 | core: Use shared_ptr for cpu_core. | bunnei | 2 | -6/+4 | |
2018-02-18 | kernel: Remove unused address_arbiter code. | bunnei | 5 | -199/+0 | |
2018-02-18 | Kernel/IPC: Add a small delay after each SyncRequest to prevent thread starvation. | Subv | 4 | -50/+63 | |
Ported from citra PR #3091 The delay specified here is from a Nintendo 3DS, and should be measured in a Nintendo Switch. This change is enough to prevent Puyo Puyo Tetris's main thread starvation. | |||||
2018-02-17 | nvmap: Make IocFromId return the same existing handle instead of creating a new one. | Subv | 1 | -5/+2 | |
Games like Puyo Puyo Tetris and BOTW seem to depend on the buffer always having the same handle | |||||
2018-02-17 | Parcel: Ensure we don't read past the end of the parcels in Vi. | Subv | 1 | -0/+5 | |
2018-02-17 | Vi: Mark all fences as NO_FENCE in the DequeueBuffer response parcel. | Subv | 1 | -2/+2 | |
2018-02-17 | Vi: Always write the IGBPBuffer in the RequestBuffer response parcel. | Subv | 1 | -1/+2 | |
This may break libnx homebrew due to a bug in libnx but is required by official games since they always assume that the buffer will be there. | |||||
2018-02-16 | Service/hid: stub some functions | mailwl | 4 | -1/+98 | |
2018-02-15 | nvhost-ctrl: Stub NVHOST_IOCTL_CTRL_EVENT_WAIT. | Subv | 2 | -0/+25 | |
2018-02-15 | Vi: Mark the fences as valid in the DequeueBuffer response parcel. | Subv | 1 | -0/+3 | |
2018-02-15 | Vi: Added a missing u32 in the DequeueBuffer response parcel. | Subv | 1 | -0/+1 | |
2018-02-15 | Vi: Don't write the IGBPBuffer in the IGBPRequestBufferResponseParcel. | Subv | 1 | -4/+2 | |
2018-02-15 | Vi: Properly write the BufferProducerFence object in the DequeueBuffer response parcel. | Subv | 2 | -18/+28 | |
2018-02-15 | shared_memory: Remove some checks. | bunnei | 1 | -13/+0 | |
2018-02-15 | pl_u: Implement basic shared font loading from RAM dump. | bunnei | 6 | -0/+182 | |
2018-02-15 | log: Add logging category for NS services. | bunnei | 2 | -0/+2 | |
2018-02-15 | hid: Stub GetVibrationDeviceInfo and SendVibrationValues. | bunnei | 1 | -0/+15 | |
2018-02-14 | hle_ipc: Remove const from WriteBuffer size. | bunnei | 2 | -2/+2 | |
2018-02-14 | pls, that was easy | Hexagon12 | 1 | -1/+1 | |
2018-02-14 | Fix fps counter to correctly measure frame end when there was no frame to draw | James Rowe | 1 | -0/+2 | |
2018-02-14 | memory: Silence formatting sepecifier warnings | Lioncash | 1 | -21/+30 | |
2018-02-14 | nso: Silence formatting specifier warnings | Lioncash | 1 | -2/+4 | |
2018-02-14 | deconstructed_rom_directory: Silence formatting specifier warnings | Lioncash | 1 | -3/+4 | |
2018-02-14 | nvdrv/interface: Silence formatting specifier warnings | Lioncash | 1 | -1/+2 | |
2018-02-14 | nvmap: Silence formatting specifier warnings | Lioncash | 1 | -1/+2 | |
2018-02-14 | nvhost_gpu: Silence formatting specifier warnings | Lioncash | 1 | -6/+8 | |
2018-02-14 | nvhost_ctrl: Silence formatting specifier warnings | Lioncash | 1 | -2/+2 | |
2018-02-14 | nvhost_ctrl_gpu: Silence formatting specifier warnings | Lioncash | 1 | -3/+4 | |
2018-02-14 | nvhost_as_gpu: Silence formatting specifier warnings | Lioncash | 1 | -5/+7 | |
2018-02-14 | thread: Silence formatting specifier warnings | Lioncash | 1 | -2/+3 | |
2018-02-14 | vm_manager: Silence formatting specifier warnings | Lioncash | 1 | -5/+7 | |
2018-02-14 | gdbstub: Silence formatting specifier warnings | Lioncash | 1 | -6/+9 | |
2018-02-14 | hle_ipc: Add GetReadBufferSize and check write buffer size. | bunnei | 2 | -0/+10 | |
2018-02-14 | debugger: Fix wait_tree crash. | bunnei | 1 | -1/+1 | |
2018-02-14 | service: Remove remaining uses of BufferDescriptor*. | bunnei | 5 | -14/+8 | |
2018-02-14 | audio: Use WriteBuffer instead of BufferDescriptorB. | bunnei | 2 | -9/+3 | |
2018-02-14 | vi: Eliminate direct usage of BufferDescriptorB. | bunnei | 1 | -14/+3 | |
2018-02-14 | nvdrv: Use ReadBuffer/WriteBuffer functions for Ioctl. | bunnei | 1 | -17/+5 | |
2018-02-14 | vi: Use ReadBuffer/WriteBuffer functions for TransactParcel. | bunnei | 1 | -44/+19 | |
2018-02-14 | hle_ipc: Add helper functions for reading and writing buffers. | bunnei | 1 | -4/+2 | |
2018-02-14 | maxwell_3d: Make constructor explicit | Lioncash | 1 | -1/+1 | |
2018-02-14 | hle_ipc: Add helper functions for reading and writing buffers. | bunnei | 3 | -0/+55 | |
2018-02-14 | vi: Fix TransactParcelAuto to support both buffer formats. | bunnei | 1 | -25/+16 | |
2018-02-14 | audren_u: Schedule reoccuring event. (#183) | bunnei | 2 | -6/+36 | |
* audren_u: Schedule reoccuring event. * audren_u: Stub GetAudioRenderersProcessMasterVolume, and misc. changes. | |||||
2018-02-13 | Service/lm: add support to multiline logs | mailwl | 1 | -20/+49 | |
2018-02-13 | vi: Add FENCE_HACK, which is useful for booting BOTW. | bunnei | 1 | -7/+21 | |
2018-02-13 | vi: Stub TransactParcel CancelBuffer. | bunnei | 1 | -0/+2 | |
2018-02-13 | TransactParcel: Move WriteBlock to narrowest scope. | bunnei | 1 | -10/+13 | |
2018-02-12 | arm_dynarmic: Support direct page table access | MerryMage | 2 | -10/+19 | |
2018-02-12 | Add RequestUpdateAudioRenderer, StartAudioRenderer and StopAudioRenderer stubs to audren:u | gdkchan | 1 | -2/+76 | |
2018-02-12 | GPU: Partially implemented the QUERY_* registers in the Maxwell3D engine. | Subv | 3 | -3/+95 | |
Only QueryMode::Write is supported at the moment. | |||||
2018-02-12 | Make a GPU class in VideoCore to contain the GPU state. | Subv | 20 | -76/+125 | |
Also moved the GPU MemoryManager class to video_core since it makes more sense for it to be there. | |||||
2018-02-12 | GPU: Added a command processor to decode the GPU pushbuffers and forward the commands to their respective engines. | Subv | 12 | -3/+285 | |
2018-02-12 | nvdrv: Make the GPU memory manager available to nvhost-gpu. | Subv | 3 | -6/+16 | |
2018-02-12 | renderer_opengl: Support framebuffer flip vertical. | bunnei | 3 | -5/+13 | |
2018-02-12 | vi: Parse IGBPQueueBufferRequestParcel params and expose buffer flip vertical. | bunnei | 6 | -11/+46 | |
2018-02-11 | vi: Fix OpenLayer and CreateStrayLayer. | bunnei | 1 | -6/+8 | |
2018-02-10 | fsp_srv: Stub MountSdCard. | bunnei | 2 | -0/+9 | |
2018-02-10 | apm: Refactor service impl. to support multiple ports. | bunnei | 5 | -58/+102 | |
2018-02-10 | vi: Implement TransactParcelAuto. | bunnei | 1 | -32/+46 | |
2018-02-10 | nvflinger: (Hack) Use first available buffer if none are found. | bunnei | 1 | -1/+5 | |
2018-02-10 | IGBPQueueBufferRequestParcel: Don't enforce buffer length. | bunnei | 1 | -1/+0 | |
- Another fix for libnx. | |||||
2018-02-10 | IGBPRequestBufferResponseParcel: Fix response for libnx. | bunnei | 1 | -7/+4 | |
2018-02-09 | nvdrv: Fix QueryEvent for libnx. | bunnei | 2 | -4/+8 | |
2018-02-09 | IApplicationDisplayService::CloseDisplay: Fix response params size. | bunnei | 1 | -1/+1 | |
2018-02-09 | nvhost_ctrl_gpu: Implement ZCullGetInfo. | bunnei | 1 | -2/+14 | |
2018-02-09 | dynarmic: Update to 41ae12263 | MerryMage | 2 | -31/+45 | |
Changes: Primarily implementing more A64 instructions | |||||
2018-02-09 | acc_u0: Implement ListAllUsers. | bunnei | 2 | -2/+15 | |
2018-02-08 | nvhost_as_gpu: Implement AllocateSpace and MapBufferEx. | bunnei | 2 | -10/+33 | |
2018-02-08 | nvdrv: Add MemoryManager class to track GPU memory. | bunnei | 3 | -0/+162 | |
2018-02-08 | nvmap: Refactor to expose nvmap objects. | bunnei | 2 | -19/+22 | |
2018-02-08 | nvhost_as_gpu: Add nvmap as a class member. | bunnei | 3 | -2/+9 | |
2018-02-07 | Service: stub some functions in am, audio, time, vi services | mailwl | 9 | -6/+191 | |
2018-02-06 | Service/hid: stub SetNpadHandheldActivationMode | mailwl | 1 | -0/+7 | |
2018-02-06 | mutex: Update hasWaiters on release. | bunnei | 1 | -0/+1 | |
2018-02-06 | hid: Stub ActivateTouchScreen and SetNpadJoyHoldType. | bunnei | 1 | -2/+14 | |
2018-02-06 | Extra nvdrv support (#162) | David | 17 | -37/+765 | |
* FinishInitalize needed for 3.0.1+ games * nvdrv:s and nvdrv:t both use NVDRV * Most settings return 0 on hardware, disabled NV_MEMORY_PROFILER for now. NVN_THROUGH_OPENGL & NVRM_GPU_PREVENT_USE are a few interesting settings to look at. Carefully choosing settings can help with drawing graphics later on * Initial /dev/nvhost-gpu support * ZCullBind * Stubbed SetErrorNotifier * Fixed SetErrorNotifier log, Added SetChannelPriority * Allocate GPFIFO Ex2, Allocate Obj Ctx, Submit GPFIFO * oops * Fixed up naming/structs/enums. Used vector instead of array for "gpfifo_entry" * Added missing fixes * /dev/nvhost-ctrl-gpu * unneeded struct * Forgot u32 in enum class * Automatic descriptor swapping for ioctls, fixed nvgpu_gpu_get_tpc_masks_args being incorrect size * nvdrv#QueryEvent * Renamed logs for nvdrv * Refactor ioctl so nv_result isn't needed * /dev/nvhost-as-gpu * Fixed Log service naming, CtxObjects now u32, renamed all structs, added static_asserts to structs, used INSERT_PADDING_WORDS instead of u32s * nvdevices now uses "Ioctl" union, * IoctlGpfifoEntry now uses bit field * final changes | |||||
2018-02-06 | IApplicationFunctions: Stub out EnsureSaveData. | bunnei | 2 | -0/+8 | |
2018-02-05 | Dont call UNIMPLEMENTED for 'empty services', just return error code | David Marcec | 1 | -0/+2 | |
2018-02-05 | Changed .istorage to .romfs | David Marcec | 2 | -5/+5 | |
2018-02-05 | set: GetAvailableLanguageCodes should not return lang_codes size. | bunnei | 1 | -2/+3 | |
2018-02-05 | nvflinger: Signal BufferQueue native handle event. | bunnei | 1 | -0/+1 | |
- This gets BOTW booting. | |||||
2018-02-05 | logger: Add Time service logging category. | bunnei | 3 | -10/+12 | |
2018-02-05 | logger: Add SET service logging category. | bunnei | 3 | -16/+12 | |
2018-02-05 | logger: Add PCTL service logging category. | bunnei | 3 | -1/+3 | |
2018-02-05 | logger: Add LM service logging category. | bunnei | 3 | -2/+4 | |
2018-02-05 | logger: Add APM service logging category. | bunnei | 3 | -2/+5 | |
2018-02-05 | lm: Ensure log string is non-empty before checking back(). | bunnei | 1 | -1/+1 | |
2018-02-05 | logger: Add NIFM service logging category. | bunnei | 6 | -11/+13 | |
2018-02-05 | logger: Add VI service logging category. | bunnei | 6 | -21/+22 | |
2018-02-05 | hid: Stub out several functions. | bunnei | 1 | -1/+39 | |
2018-02-04 | hid: Implement CreateActiveVibrationDeviceList. | bunnei | 1 | -0/+25 | |
2018-02-04 | logger: Use Service_HID category where applicable. | bunnei | 1 | -2/+2 | |
2018-02-04 | logger: Use Service_NVDRV category where applicable. | bunnei | 2 | -10/+10 | |
2018-02-04 | logger: Add AM service logging category. | bunnei | 5 | -42/+44 | |
2018-02-04 | logger: Add "account" service logging category. | bunnei | 3 | -8/+10 | |
2018-02-04 | acc_u0: Stub out GetLastOpenedUser. | bunnei | 2 | -0/+10 | |
2018-02-04 | GetInfo: Implement IsCurrentProcessBeingDebugged. | bunnei | 1 | -0/+3 | |
2018-02-04 | WaitProcessWideKeyAtomic: Handle case where condition variable was already created. | bunnei | 3 | -13/+17 | |
2018-02-04 | acc:u0 : stub GetAccountId | mailwl | 1 | -1/+9 | |
2018-02-03 | svc: SharedMemory size should be 64-bits and cleanup. | bunnei | 3 | -11/+11 | |
2018-02-03 | ArbitrateLock: Assert that requesting_thread is current_thread. | bunnei | 1 | -0/+1 | |
2018-02-03 | controller: DuplicateSession should return a ClientSession. | bunnei | 1 | -4/+9 | |
2018-02-03 | Service:nifm: add nifm:a, nifm:s and nifm:u services | mailwl | 10 | -0/+378 | |
2018-02-02 | Service/am: Add AppletAE service (#153) | mailwl | 7 | -379/+571 | |
* Add AppletAE, step 1: move common interfaces to am.h * Add AppletAE, step 2 | |||||
2018-02-02 | Services/vi: add vi:s and vi:u services | mailwl | 6 | -0/+128 | |
2018-02-02 | vi::CreateStrayLayer : add padding to request | mailwl | 1 | -0/+1 | |
2018-01-30 | shared_memory: Only mark addresses as invalid if they are within the heap | shinyquagsire23 | 1 | -1/+2 | |
2018-01-30 | [WIP] sfdnsres: stub (#146) | mailwl | 5 | -2/+52 | |
sfdnsres: Add several stubs | |||||
2018-01-27 | memory: Replace all memory hooking with Special regions | MerryMage | 11 | -441/+273 | |
2018-01-26 | time: Implement ISteadyClock::GetCurrentTimePoint. | bunnei | 2 | -1/+22 | |
2018-01-25 | audout_u: Various cleanups. | bunnei | 1 | -29/+17 | |
2018-01-25 | ResponseBuilder: Use a bit field for customizing instead of always_move_handles. | bunnei | 3 | -11/+21 | |
2018-01-25 | time: Stub GetSystemClockContext function. | bunnei | 2 | -2/+17 | |
2018-01-25 | server_session: Fix scenario where all domain handlers are closed. | bunnei | 1 | -3/+3 | |
2018-01-25 | hle: Rename RequestBuilder to ResponseBuilder. | bunnei | 19 | -128/+129 | |
2018-01-25 | service: Fix all incorrect IPC response headers. | bunnei | 14 | -82/+42 | |
2018-01-25 | ipc_helpers: Make interface domain agnostic and add header validation. | bunnei | 2 | -25/+58 | |
2018-01-25 | hle: Integrate Domain handling into ServerSession. | bunnei | 7 | -38/+74 | |
2018-01-25 | hle: Remove Domain and SyncObject kernel objects. | bunnei | 10 | -169/+2 | |
2018-01-25 | handle_table: Remove ConvertSessionToDomain. | bunnei | 2 | -17/+0 | |
2018-01-25 | audout:u OpenAudioOut and IAudioOut (#138) | st4rk | 4 | -14/+168 | |
* Updated the audout:u and IAudioOut, now it might work with RetroArch without trigger an assert, however it's not the ideal implementation * Updated the audout:u and IAudioOut, now it might work with RetroArch without trigger an assert, however it's not the ideal implementation * audout:u OpenAudioOut implementation and IAudioOut cmd 1,2,3,4,5 implementation * using an enum for audio_out_state as well as changing its initialize to member initializer list * Minor fixes, added Service_Audio for LOG_*, changed PcmFormat enum to EnumClass * Minor fixes, added Service_Audio for LOG_*, changed PcmFormat enum to EnumClass * added missing Audio loggin subclass, minor fixes, clang comment breakline * Solving backend logging conflict * minor fix * Fixed duplicated Service NVDRV in backend.cpp, my bad | |||||
2018-01-24 | Fix time returning epoch time in milliseconds rather than in seconds | gdkchan | 1 | -1/+1 | |
2018-01-24 | logging: add missing NVDRV subclass to macro list | Rozlette | 1 | -0/+1 | |
2018-01-23 | Correct Spelling | N00byKing | 1 | -2/+2 | |
2018-01-23 | Services: Added a todo about returning interfaces as domain objects in lm, hid and time. | Subv | 3 | -0/+12 | |
2018-01-22 | Time: Don't create unnecessary ports when retrieving the clock service sessions. | Subv | 1 | -33/+27 | |
2018-01-22 | HID: Don't create an unnecessary port in CreateAppletResource. | Subv | 1 | -13/+13 | |
2018-01-22 | LM: Don't create an unnecessary port in Initialize. | Subv | 2 | -15/+10 | |
2018-01-22 | IPC: Don't create an unnecessary port when using PushIpcInterface outside of a domain. | Subv | 1 | -4/+5 | |
2018-01-22 | Stub OpenAudioOut and fix a issue with HID IAppletResource being created more than once | gdkchan | 3 | -2/+21 | |
2018-01-22 | AppletOE: Stubbed CreateManagedDisplayLayer to create a new layer in the Default display. | Subv | 1 | -0/+14 | |
This function is used by libnx to obtain a new layer. | |||||
2018-01-22 | AppletOE: Make ISelfController keep a reference to nvflinger. | Subv | 5 | -10/+32 | |
It'll be needed when we implement CreateManagedDisplayLayer. | |||||
2018-01-22 | Services: Vi shouldn't be responsible for creating nvflinger. | Subv | 5 | -7/+13 | |
It is now created during Service initialization and passed to all the services that need it. | |||||
2018-01-22 | VI: Move BufferQueue and NVFlinger to their own folder/namespace. | Subv | 9 | -363/+452 | |
2018-01-22 | Added stubs for audio services. (#116) | st4rk | 12 | -5/+309 | |
* stubs for audout:u, audin:u, audrec:u, audren:u, codecctl and decoding tables with nullptr for future implementations * fixing the changes requested (remove private, explicit) | |||||
2018-01-21 | Added nvmemp, Added /dev/nvhost-ctrl, SetClientPID now stores pid (#114) | David | 9 | -5/+163 | |
* Added nvmemp, Added /dev/nvhost-ctrl, SetClientPID now stores pid * used clang-format-3.9 instead * lowercase pid * Moved nvmemp handlers to cpp * Removed unnecessary logging for NvOsGetConfigU32. Cleaned up log and changed to LOG_DEBUG * using std::arrays instead of c arrays * nvhost get config now uses std::array completely * added pid logging back * updated cmakelist * missing includes * added array, removed memcpy * clang-format6.0 | |||||
2018-01-21 | nvmap: Add a return 0 underneath the UNIMPLEMENTED macro | Lioncash | 1 | -0/+1 | |
This macro resolves to an empty macro in release builds. | |||||
2018-01-21 | nvmap: Make IoctlCommands an enum class | Lioncash | 2 | -12/+12 | |
Prevents the enum values from polluting the surrounding scope | |||||
2018-01-21 | file_sys: Clang format fixes. | bunnei | 3 | -4/+4 | |
2018-01-21 | fsp_srv: Various improvements to IStorage:Read implementation. | bunnei | 5 | -48/+79 | |
2018-01-21 | deconstructed_rom_directory: Implement istorage loading for RomFS. | bunnei | 2 | -2/+71 | |
2018-01-21 | filesystem: Implement basic IStorage functionality. | David Marcec | 6 | -0/+258 | |
2018-01-21 | file_sys: Cleanup to better match Switch file system constructs. | bunnei | 10 | -63/+136 | |
file_sys: Add factory class for RomFS file system. | |||||
2018-01-21 | file_sys: Remove disk_archive, savedata_archive, and title_metadata. | bunnei | 7 | -835/+0 | |
2018-01-21 | archive_backend: Minor changes to match Switch IFileSystem. | bunnei | 5 | -26/+26 | |
2018-01-21 | file_sys: Repurpose 3DS IVFC code for Switch ROMFS. | bunnei | 3 | -51/+43 | |
2018-01-21 | gdbstub: Update registers and sizes for aarch64 | Rozlette | 1 | -113/+155 | |
This gets gdbstub working at least to the point where clients can communicate with it. What works: - Reading/writing GPRegs - Reading/writing memory - Interrupting the emulated program and continuing What does NOT work: - Breakpoints. Sizes have been updated to u64, but support will need to be added in the interpreter for them to work. - VRegs. Mostly because my gdb was having issues with 128-bit regs for some reason. However, the current u128 representation is a bit awkward to use and should probably be updated first. | |||||
2018-01-21 | VI: Implement the Query transaction of IHOSBinderDriver, and stubbed some results. | Subv | 2 | -0/+58 | |
2018-01-21 | Fix spelling error in CMakeLists | Matthew Brener | 1 | -1/+1 | |
Minor spelling error of its --> it's | |||||
2018-01-21 | service/time: remove accidental #pragmas | tgsm | 2 | -4/+0 | |
2018-01-21 | loader: Minor style fix in deconstructed_rom_directory | Rozlette | 1 | -1/+0 | |
2018-01-21 | Format: Run the new clang format on everything | James Rowe | 74 | -117/+207 | |
2018-01-20 | memory: Return false for large VAddr in IsValidVirtualAddress | Rozlette | 1 | -0/+3 | |
2018-01-20 | loader: Clean up ctors and includes. | bunnei | 10 | -18/+22 | |
2018-01-20 | loader: Add DeconstructedRomDirectory for game dumps. | bunnei | 5 | -0/+156 | |
2018-01-20 | loader: Refactor to also pass filepath into IdentifyType. | bunnei | 8 | -19/+19 | |
2018-01-20 | nso: Remove code specific to directory loading. | bunnei | 2 | -17/+6 | |
2018-01-20 | Port citra #3352 to yuzu (#103) | River City Ransomware | 3 | -4/+25 | |
* Port citra #3352 to yuzu This change allows non x86_64 architectures to compile yuzu by skipping the building of dynarmic * Fixed clang-format errors * fixes more clang-format errors | |||||
2018-01-20 | Added CreateSharedMemory & UNIMPLEMENTED() for non existent services. (#113) | David | 3 | -1/+23 | |
* Added svcCreateSharedMemory * Services which are not implemented now throw UNIMPLEMENTED() * clang-format * changed perms to u32 * removed camelcase | |||||
2018-01-20 | Fixes some cast warnings, partial port of citra #3064 (#106) | River City Ransomware | 6 | -21/+22 | |
* Fixes some cast warnings, partially fixes citra #3064 * Converted casts to uint32_t to u32 * Ran clang-format | |||||
2018-01-19 | acc, set, applet_oe: stub various functions, add set service (#105) | goaaats | 8 | -0/+161 | |
* Stubs for various acc:u0 funcs needed * Stub for GetDesiredLanguage in IApplicationFunctions * Add set service + stubs needed for games * Fix formatting * Implement IProfile, IManagerForApplication, return bool in CheckAvailability, style fixes * Remove IProfile::Get(needs more research), fix IPC response sizes | |||||
2018-01-19 | ISelfController: Stub LockExit and UnlockExit | Rozlette | 1 | -0/+16 | |
2018-01-19 | time: Add new line to ends of files. | bunnei | 4 | -4/+4 | |
2018-01-19 | applet_oe: Clang-format. | bunnei | 1 | -2/+1 | |
2018-01-19 | time: Stub out GetTotalLocationNameCount and some cleanup. | bunnei | 2 | -4/+12 | |
2018-01-19 | nvdrv: Stub SetClientPID. | bunnei | 2 | -0/+13 | |
2018-01-19 | svc: Fix svcGetInfo MapRegionBaseAddr. | bunnei | 3 | -1/+9 | |
2018-01-19 | svc: Add additional fields to MemoryInfo struct. | bunnei | 1 | -0/+4 | |
2018-01-19 | Fix dispdrv typo | gdkchan | 1 | -1/+1 | |
2018-01-19 | qt: Migrate to Qt 5 signal/slot connection syntax where applicable | Lioncash | 5 | -31/+31 | |
2018-01-18 | ui: Rename almost all classes in configuration_input.ui (#99) | Evgeni Danailov | 1 | -66/+66 | |
* Rename verticalLayout_25 to verticalLayout_23. * Rename almost all classes. | |||||
2018-01-18 | Port citra #3336 - Resizes the configuration window to not be so stretched out | River City Ransomware | 1 | -1/+1 | |
2018-01-18 | Fix NRO Entry Point | gdkchan | 1 | -2/+2 | |
2018-01-18 | Stub PopLaunchParameter and implement Buffer C Descriptors reading on hle_ipc (#96) | gdkchan | 5 | -7/+127 | |
* Stub PopLaunchParameter and implement Buffer C Descriptors reading * Address PR feedback * Ensure we push a u64 not a size_t * Fix formatting | |||||
2018-01-18 | Start to implement/stub BSD:U and SFDNSRES services (#78) | flerovium^-^ | 7 | -0/+159 | |
* bsd: start stubbing bsd:u and sfdnsres * bsd: stubbed RegisterClient * bsd: attempt to get past socket() * bsd: fix some wrong assumptions about IPC * bsd: fix format specifiers * bsd: stubbed Connect() * bsd: stubbed SendTo() * made requested changes * sockets: respect alphabetical order at service installation * run clang-format * bsd: start stubbing bsd:u and sfdnsres * bsd: stubbed RegisterClient * bsd: attempt to get past socket() * bsd: fix some wrong assumptions about IPC * bsd: fix format specifiers * bsd: stubbed Connect() * bsd: stubbed SendTo() * made requested changes * sockets: respect alphabetical order at service installation * run clang-format * run clang-format (2) | |||||
2018-01-18 | time: Fix use of CamelCase in ToCalendarTimeWithMyRule | Rozlette | 1 | -6/+6 | |
2018-01-18 | time: Refactor time:* to use a single shared module | Rozlette | 7 | -26/+107 | |
2018-01-18 | lm: Minor logging fix to skip a byte. | bunnei | 1 | -0/+7 | |
2018-01-18 | CMakeLists: Derive the source directory grouping from targets themselves | Lioncash | 7 | -360/+338 | |
Removes the need to store to separate SRC and HEADER variables, and then construct the target in most cases. | |||||
2018-01-18 | controller: Use DuplicateSession for DuplicateSessionEx. | bunnei | 2 | -1/+8 | |
2018-01-18 | svc: Rename some entries to match their analogue on SwitchBrew | Lioncash | 1 | -7/+7 | |
Makes the codebase a little more consistent with regards to available documentation. Also amends the duplicate case where there was a similar entry at 0x72 named ConnectToPort. | |||||
2018-01-18 | svc: Add CreateJitMemory and MapJitMemory svc strings | Lioncash | 1 | -2/+2 | |
Makes the table match SwitchBrew for these entries | |||||
2018-01-18 | vi: Make constructors explicit where applicable | Lioncash | 1 | -13/+14 | |
Prevents implicit conversions. | |||||
2018-01-18 | vi: Add missing override specifiers | Lioncash | 1 | -7/+7 | |
2018-01-18 | vi: Copy data directly into the std::vector within Parcel's ReadBlock function | Lioncash | 1 | -2/+3 | |
Previously this would unnecessarily zero-initialize the vector before copying the actual data into the vector instance. | |||||
2018-01-18 | hotkeys: Add missing <QTreeWidgetItem> include | Lioncash | 1 | -0/+1 | |
2018-01-18 | game_list: Add missing override specifier for KeyReleaseEater's eventFilter function | Lioncash | 1 | -1/+1 | |
2018-01-18 | game_list: Amend doxygen parameter identifiers for containsAllWords() | Lioncash | 1 | -2/+2 | |
2018-01-18 | telemetry: Silence initialization order warnings | Lioncash | 1 | -2/+2 | |
2018-01-18 | input_common/sdl: Silence a -Wpessimizing-move warning | Lioncash | 1 | -1/+1 | |
2018-01-18 | bootmanager: Minor tidiness/correctness changes | Lioncash | 2 | -7/+6 | |
Moved over from #3266 in citra. | |||||
2018-01-18 | Fix NRO loading | gdkchan | 1 | -20/+9 | |
2018-01-17 | Implement Pull #3306 from citra: citra_qt: Drop Qt 5 version checks in code (#41) | N00byKing | 1 | -13/+1 | |
* Update bootmanager.cpp * This *should* fix the clang error | |||||
2018-01-17 | TIME: consolidate time:* interfaces, stub functions and structs | Rozlette | 5 | -85/+164 | |
2018-01-17 | Remove relocation on NSO/NRO | gdkchan | 3 | -19/+2 | |
2018-01-17 | Update CMakeLists.txt | N00byKing | 1 | -0/+1 | |
2018-01-17 | Update title_metadata.h | N00byKing | 1 | -0/+1 | |
2018-01-17 | svc: Clang-format fix. | bunnei | 1 | -6/+4 | |
2018-01-17 | Update core.cpp | N00byKing | 1 | -1/+0 | |
2018-01-17 | Update default_ini.h | N00byKing | 1 | -2/+2 | |
2018-01-17 | hle_ipc: Clang format. | bunnei | 1 | -2/+3 | |
2018-01-17 | Fixed formatting | noah katz | 1 | -2/+2 | |
2018-01-17 | nvdrv: stubbed Close(cmd 2) | Frederic Meyer | 4 | -0/+26 | |
2018-01-17 | Fix gdbstub typo, fixes Citra #3318 | River City Ransomware | 1 | -1/+1 | |
Core::System().GetInstance().IsPoweredOn() -> Core::System::GetInstance().IsPoweredOn() | |||||
2018-01-17 | hid: Adjust timing based on actual hardware | shinyquagsire23 | 1 | -3/+3 | |
2018-01-17 | ipc: Implement domain command CloseVirtualHandle. | bunnei | 3 | -3/+34 | |
2018-01-17 | loggin: Add IPC logging category. | bunnei | 2 | -1/+3 | |
2018-01-17 | UI: Fix frame rate perf stats | James Rowe | 2 | -1/+4 | |
Adds in a missing EndGameFrame when nvdrv swaps buffers | |||||
2018-01-17 | acc_u0: Add IPC interface and stub InitializeApplicationInfo. | bunnei | 6 | -0/+86 | |
2018-01-17 | hid: clang-format | shinyquagsire23 | 1 | -3/+3 | |
2018-01-17 | hid: Adjust for style guide | shinyquagsire23 | 2 | -63/+68 | |
2018-01-17 | applet_oe: Fix GetOperationMode and GetPerformanceMode. | bunnei | 1 | -2/+2 | |
2018-01-17 | Fix non translated string (same as Citra PR 2949) | noah katz | 1 | -1/+1 | |
2018-01-17 | NV: Implemented the nvdrv service, which uses the same interface as nvdrv:a | Subv | 4 | -16/+18 | |
2018-01-17 | NV: Move the nvdrv classes into the Nvidia namespace, and move the functionality to a s single module that services call. | Subv | 13 | -165/+95 | |
2018-01-17 | VI: Stubbed GetNativeHandle, Create/DestroyStrayLayer and CloseDisplay | Subv | 2 | -3/+85 | |
2018-01-17 | Services: Stubbed APM::OpenSession and the ISession interface. | Subv | 3 | -2/+53 | |
# Conflicts: # src/core/hle/service/am/applet_oe.cpp # src/core/hle/service/apm/apm.cpp | |||||
2018-01-17 | AppletOE: Stub a bunch of functions required by libnx homebrew. | Subv | 1 | -4/+62 | |
2018-01-17 | SVC: Correct some return values in svcGetInfo and added TitleId and PrivilegedProcessId stubs. | Subv | 1 | -6/+21 | |
# Conflicts: # src/core/hle/kernel/svc.cpp | |||||
2018-01-17 | SVC: Add 4.0.0+ comment to GetInfoType enum values. | Subv | 1 | -0/+1 | |
2018-01-17 | IPC: Push domain objects as move handles when not in a domain. | Subv | 2 | -2/+28 | |
2018-01-17 | Update memory.h | David | 1 | -2/+2 | |
2018-01-16 | SetThreadCoreMask stub, time to implement fsp | David Marcec | 1 | -1/+6 | |
2018-01-16 | implemented more of ISelfController and IApplicationFunctions | David Marcec | 1 | -0/+53 | |
2018-01-16 | Added more svcGetInfo pairs | David Marcec | 4 | -2/+29 | |
2018-01-16 | Increased heap size and changed tls area vaddr | David Marcec | 1 | -2/+2 | |
2018-01-16 | Use static functions instead of lambdas | muemart | 1 | -49/+46 | |
2018-01-16 | Add translation support for button labels | muemart | 1 | -14/+15 | |
2018-01-16 | Add button labels for sdl joystick mappings | muemart | 1 | -17/+46 | |
2018-01-16 | clang-format | MerryMage | 25 | -63/+54 | |
2018-01-16 | Implement Pull #3030 from Citra | Tobias | 1 | -6/+6 | |
citra-qt: Rename derivative class name | |||||
2018-01-16 | nso: Modify .bss size calculation logic | Rozlette | 1 | -3/+7 | |
2018-01-16 | Update game_list.cpp | N00byKing | 1 | -1/+1 | |
2018-01-16 | Update CMakeLists.txt | N00byKing | 1 | -5/+1 | |
2018-01-16 | Build: Automagically handle unicorn | James Rowe | 1 | -1/+1 | |
On MSVC if unicorn isn't found, fallback to bundled unicorn On everything else, fallback to building unicorn in externals Also fixes loading unicorn in msvc | |||||
2018-01-16 | Implement Pull #3333 from citra: citra_qt: Pause emulation on CoreError (#39) | N00byKing | 2 | -0/+2 | |
2018-01-16 | Merge citra-emu PR#3159 by FearlessTobi(citra-qt : Fix a bug in our fullscreen implementation) | goaaats | 2 | -15/+31 | |
2018-01-16 | Merge citra-emu PR#3001 by Styleoshin(citra-qt : Adding fullscreen mode) | goaaats | 5 | -1/+57 | |
2018-01-16 | hid: Write to all layouts, implement circular buffers, set up controller metadata. | shinyquagsire23 | 2 | -39/+71 | |
2018-01-16 | Build: Add unicorn as a submodule and build it if needed | James Rowe | 1 | -1/+1 | |
Adds a cmake custom target that will build unicorn on first compile and uses this in the build scripts as well. Updates Appveyor and Travis build scripts to work with the new unicorn build, and updates the paths to all of the different artifacts. | |||||
2018-01-16 | Adding meumart's Citra SDL Joystick support. Citra PR #3116 | muemart | 7 | -191/+524 | |
2018-01-15 | nso: Load subsdk4 if available. | bunnei | 1 | -1/+1 | |
2018-01-15 | pctl: Clang format. | bunnei | 1 | -1/+1 | |
2018-01-15 | pctl: GetService should return an IParentalControlService interface. | bunnei | 1 | -3/+8 | |
2018-01-15 | applet_oe: Stub SetFocusHandlingMode, GetCurrentFocusState, SetTerminateResult. | bunnei | 1 | -2/+55 | |
2018-01-15 | settings: Fix button mappings array to have correct entries. | bunnei | 1 | -2/+6 | |
2018-01-15 | Clanggit rebase -i fixes | unknown | 1 | -10/+2 | |
2018-01-15 | Clang format | unknown | 2 | -4/+10 | |
2018-01-15 | Change default log level to info | unknown | 1 | -1/+1 | |
2018-01-15 | Update the internal resolution settings | unknown | 3 | -67/+7 | |
2018-01-15 | yuzu_cmd: Fix default ini, add screenshot button | shinyquagsire23 | 1 | -1/+2 | |
2018-01-15 | hid: Bare-minimum sharedmem input | shinyquagsire23 | 2 | -2/+88 | |
2018-01-15 | hid: Remove redundant HID prefix on structs/enums | shinyquagsire23 | 1 | -73/+73 | |
2018-01-15 | configure_input: update w/ Switch buttons | shinyquagsire23 | 3 | -90/+221 | |
2018-01-15 | settings: Screenshot button | shinyquagsire23 | 1 | -0/+2 | |
2018-01-15 | yuzu_cmd: fix default ini | shinyquagsire23 | 1 | -9/+17 | |
2018-01-15 | settings: adjust button configs for Switch controllers | shinyquagsire23 | 1 | -17/+50 | |
2018-01-15 | hid: Add sharedmem structs | shinyquagsire23 | 1 | -0/+312 | |
2018-01-15 | vi: Add IManagerDisplayService::CloseDisplay function | bsaleil | 1 | -0/+10 | |
2018-01-15 | renderer_gl: Clear screen to black before rendering framebuffer. | bunnei | 2 | -5/+8 | |
2018-01-15 | Games expect 15 for ICommonStateGetter::ReceiveMessage in order to continue execution | David Marcec | 1 | -1/+1 | |
2018-01-15 | renderer: Render previous frame when no new one is available. | bunnei | 4 | -17/+22 | |
2018-01-15 | lm: Fix IPC header for Initialize. | bunnei | 1 | -1/+1 | |
2018-01-15 | time: Implement GetStandardUserSystemClock, GetCurrentTime. | bunnei | 6 | -1/+121 | |
2018-01-15 | audio: Add files to CMake. | bunnei | 2 | -1/+4 | |
2018-01-15 | hid: Remove unused registered_loggers. | bunnei | 1 | -3/+0 | |
2018-01-15 | audio: Stub out AudOutU::ListAudioOuts. | bunnei | 5 | -0/+84 | |
2018-01-15 | hid: Implement IAppletResource::GetSharedMemoryHandle. | bunnei | 3 | -14/+68 | |
2018-01-14 | qt: Update about dialog to show license for GPLv2 only. | bunnei | 1 | -1/+1 | |
Fixes #6. | |||||
2018-01-14 | shared_memory: Minor fixes and cleanup. | bunnei | 1 | -6/+6 | |
2018-01-14 | svc: Implement svcMapSharedMemory. | bunnei | 2 | -1/+38 | |
2018-01-14 | kernel: Increase default stack size to 64K. | bunnei | 1 | -1/+1 | |
2018-01-14 | Remove Surface Viewer stub | Jannik Vogel | 3 | -13/+0 | |
2018-01-14 | Implement "About" dialog | spycrab | 6 | -3/+245 | |
2018-01-14 | Add missing FileType declarations in GuessFromExtension and GetFileTypeString | Thog | 1 | -0/+8 | |
2018-01-14 | yuzu qt copy windows deps renamed | James Rowe | 1 | -2/+2 | |
2018-01-14 | Minor cleanup | MerryMage | 7 | -18/+18 | |
2018-01-14 | macOS: Update Info.plist | MerryMage | 1 | -34/+34 | |
2018-01-13 | Add new icons and fix up the linux paths for install | James Rowe | 1 | -3/+1 | |
2018-01-13 | Update dynarmic to bc73004 | MerryMage | 1 | -12/+17 | |
bc73004 a64_merge_interpret_blocks: Remove debug output 4e656ed tests/A64: Randomize PSTATE.<NZCV> fd9530b A64: Optimization: Merge interpret blocks 3c9eb04 testenv: Use format constants 324f3fc tests/A64: Unicorn interface fixes 98ecbe7 tests/A64: Fuzz against unicorn b1d38e7 tests/A64: Move TestEnvironment to own header 5218ad9 A64/data_processing_pcrel: bug: ADR{,P} instructions sign extend their immediate b1a8c39 A64/data_processing_addsub: bug: {ADD,SUB}S (extended register) instructions write to ZR when d = 31 64827fb a64_emit_x64: bug: A64CallSupervisor trampled callee-save registers 1bfa04d emit_x64: bug: OP m/r64, imm32 form instructions sign-extend their immediate on x64 edadeea A64 inferface: Use two argument static_assert 9ab1304 A64: Add ExceptionRaised IR instruction 6843eed Update readme 7438d07 A64/translate: Add TranslateSingleInstruction function | |||||
2018-01-13 | Fix build on macOS and linux | MerryMage | 4 | -6/+7 | |
2018-01-13 | arm_unicorn: Log unmapped memory access address. | bunnei | 1 | -1/+1 | |
2018-01-13 | config: Default log filter to trace. | bunnei | 3 | -3/+3 | |
2018-01-13 | yuzu: Update license text to be consistent across project. | bunnei | 61 | -61/+61 | |
2018-01-13 | Remove settings issues in sdl and fix a few files that broke in mingw | James Rowe | 4 | -53/+1 | |
2018-01-13 | Removing unused settings and yuzu rebranding | James Rowe | 17 | -485/+69 | |
2018-01-13 | Get yuzu sdl to start compiling | James Rowe | 5 | -12/+12 | |
2018-01-13 | Remove gpu debugger and get yuzu qt to compile | James Rowe | 46 | -3245/+47 | |
2018-01-13 | Remove references to PICA and rasterizers in video_core | James Rowe | 77 | -16444/+4 | |
2018-01-13 | Massive removal of unused modules | James Rowe | 120 | -5227/+21 | |
2018-01-13 | config: Default CPU core to Unicorn. | bunnei | 3 | -3/+3 | |
2018-01-13 | core: Gut out cryptop, since it doesn't compile with C++17. | bunnei | 4 | -126/+7 | |
2018-01-12 | configuration: Add cpu_core configuration option | MerryMage | 8 | -16/+40 | |
2018-01-12 | arm_dynarmic: Implement core | MerryMage | 8 | -65/+166 | |
2018-01-12 | core: Include <algorithm> where used. | bunnei | 3 | -0/+6 | |
2018-01-12 | renderer_opengl: Fix LOG_TRACE in LoadFBToScreenInfo. | bunnei | 1 | -1/+1 | |
2018-01-12 | nv: Fix more broken asserts. | bunnei | 2 | -3/+3 | |
2018-01-12 | nvdisp_disp0: Fix broken assert. | bunnei | 1 | -1/+1 | |
2018-01-12 | core: Fix recent GCC build breaks. | bunnei | 2 | -2/+4 | |
2018-01-12 | svc: Implement GetSystemTick. | bunnei | 2 | -2/+21 | |
2018-01-11 | nvdisp_disp0: Call SwapBuffers to render framebuffer. | bunnei | 1 | -0/+7 | |
2018-01-11 | renderer_opengl: Support rendering Switch framebuffer. | bunnei | 3 | -138/+83 | |
2018-01-11 | render_base: Add a struct describing framebuffer metadata. | bunnei | 1 | -0/+26 | |
2018-01-11 | renderer_opengl: Add MortonCopyPixels function for Switch framebuffer. | bunnei | 1 | -0/+111 | |
2018-01-11 | renderer_opengl: Update DrawScreens for Switch. | bunnei | 2 | -23/+11 | |
2018-01-11 | CMakeLists: Add framebuffer_layout.cpp. | bunnei | 1 | -0/+1 | |
2018-01-11 | frontend: Update for undocked Switch screen layout. | bunnei | 8 | -279/+43 | |
2018-01-11 | NV: Move the nv device nodes to their own directory and namespace. | Subv | 11 | -166/+430 | |
2018-01-11 | VI: Use a Pulse event instead of OneShot for the vblank events. | Subv | 1 | -1/+1 | |
This prevents missing frames if the vblank fires between the DequeueBuffer and Wait(vsync) calls | |||||
2018-01-11 | vi: Use new CoreTiming::EventType | bunnei | 1 | -1/+5 | |
2018-01-11 | NV: Expose the nvdisp_disp0 device and a weak reference to the nvdrv:a service. | Subv | 6 | -172/+252 | |
NVFlinger will call into the nvdisp_disp0 device to perform screen flips, bypassing the ioctl interface. We now have the address of the framebuffer to draw, we just need to actually put it on the screen. | |||||
2018-01-11 | NV: Determine what buffer to draw for each layer of each display. | Subv | 2 | -13/+58 | |
Don't try to draw buffers that the guest application is using, only queued buffers are eligible for drawing. Drawing actual pixels is still not implemented. | |||||
2018-01-11 | NV: Signal all display's vsync event 60 times per second. | Subv | 2 | -1/+32 | |
2018-01-11 | NV: Give each display its own vsync event. | Subv | 2 | -12/+29 | |
2018-01-11 | NV: Keep track of Displays, Layers and BufferQueues in nvflinger. | Subv | 4 | -41/+261 | |
2018-01-11 | IPC: Allow passing arguments to the Interfaces when using PushIpcInterface | Subv | 1 | -3/+3 | |
2018-01-11 | NV: Implemented (with stubs) the vi:m service and some of its subservices. | Subv | 6 | -0/+726 | |
The homebrew display test application now properly writes graphics data to the graphics buffer but we still don't have a way to compose the display layers. | |||||
2018-01-11 | NV: Implemented the nvdrv:a service and the /dev/nvmap device. | Subv | 4 | -0/+354 | |
2018-01-11 | IPC: Corrected some definitions for the buffer C descriptor flags. | Subv | 3 | -3/+10 | |
2018-01-11 | svc: Stub ResetSignal and CreateTransferMemory | Subv | 2 | -3/+28 | |
2018-01-11 | svc: Stub SetMemoryAttribute | Subv | 2 | -0/+11 | |
2018-01-10 | Threads: Added enum values for the Switch's 4 cpu cores and implemented svcGetInfo(AllowedCpuIdBitmask) | Subv | 5 | -16/+28 | |
2018-01-10 | Services: Allow lm to log single-character messages. | Subv | 1 | -7/+3 | |
2018-01-09 | SVC: Fixed WaitSynchronization with multiple handles when none is immediately ready. | Subv | 1 | -7/+18 | |
2018-01-09 | SVC: Implemented CancelSynchronization. | Subv | 2 | -1/+19 | |
2018-01-09 | ErrorCodes: Updated the InvalidHandle and Timeout kernel error codes. | Subv | 1 | -2/+7 | |
2018-01-09 | SVC: Fixed WaitSynchronization with multiple handles when at least one of them is ready. | Subv | 2 | -3/+29 | |
2018-01-09 | kernel: Rename Semaphore to ConditionVariable. | bunnei | 11 | -171/+180 | |
2018-01-09 | mutex: Remove unused call to VerifyGuestState. | bunnei | 1 | -3/+0 | |
2018-01-09 | Kernel: Actually wake up the requested number of threads in Semaphore::Release. | Subv | 4 | -21/+18 | |
Also properly keep track of data in guest memory, this fixes managing the semaphore from userland. It was found that Semaphores are actually Condition Variables, with Release(1) and Release(-1) being equivalent to notify_one and notify_all. We should change the name of the class to reflect this. | |||||
2018-01-09 | Kernel: Properly keep track of mutex lock data in the guest memory. This fixes userland locking/unlocking. | Subv | 4 | -67/+63 | |
2018-01-09 | Kernel: Allow chaining WaitSynchronization calls inside a wakeup callback. | Subv | 4 | -30/+78 | |
2018-01-09 | fix macos build | MerryMage | 2 | -5/+5 | |
2018-01-09 | core_timing: Use 1.020GHz for core clock rate. | bunnei | 1 | -5/+3 | |
2018-01-09 | CoreTiming: Reworked CoreTiming (cherry-picked from Citra #3119) | B3n30 | 12 | -557/+638 | |
* CoreTiming: New CoreTiming; Add Test for CoreTiming | |||||
2018-01-07 | IPC: Make DuplicateSession return the Domain instead of the Session if the request was made on a Domain interface. | Subv | 2 | -2/+7 | |
2018-01-07 | AppletOE: Fixed command buffer structure for ReceiveMessage. | Subv | 1 | -2/+1 | |
2018-01-07 | IPC: Corrected some command headers in the IPC Controller interface. | Subv | 1 | -4/+2 | |
2018-01-07 | IPC: Corrected some command header sizes in appletOE. | Subv | 1 | -12/+21 | |
2018-01-07 | IPC: Take the number of domain objects as a parameter in MakeBuilder. | Subv | 2 | -4/+6 | |
2018-01-07 | SM: Fixed connecting to services with an 8-byte name, like appletOE. | Subv | 1 | -12/+4 | |
2018-01-07 | IPC: Fixed pushing ResultCodes into the command buffer. | Subv | 2 | -7/+9 | |
They should have 32 bits of padding after the error code now. | |||||
2018-01-07 | IPC: Add functions to read the input move/copy objects from an IPC request. | Subv | 3 | -2/+42 | |
2018-01-07 | IPC: Don't attempt to read the command buffer if it holds a Close request. | Subv | 1 | -0/+5 | |
2018-01-07 | IPC Cleanup: Remove 3DS-specific code and translate copy, move and domain objects in IPC requests. | Subv | 8 | -405/+118 | |
Popping objects from the buffer is still not implemented. | |||||
2018-01-07 | IPC: Skip the entire u64 of the command id when receiving an IPC request. | Subv | 2 | -15/+5 | |
Service code now doesn't have to deal with this. | |||||
2018-01-07 | IPC: Use the correct size when pushing raw data to the command buffer and fixed pushing domain objects. | Subv | 4 | -10/+29 | |
Domain object ids are always stored immediately after the raw data. | |||||
2018-01-07 | svc: Implement svcSignalProcessWideKey. | bunnei | 2 | -4/+23 | |
2018-01-07 | audio: Log dropping frames as trace to reduce spam. | bunnei | 1 | -1/+1 | |
2018-01-07 | semaphore: More changes for Switch. | bunnei | 2 | -11/+17 | |
2018-01-07 | wait_object: Refactor to allow waking up a single thread. | bunnei | 2 | -15/+28 | |
2018-01-07 | nso: Always load the filepath specified by the user. | bunnei | 1 | -1/+3 | |
2018-01-07 | core_timing: Increase clock speed for Switch docked. | bunnei | 3 | -3/+3 | |
2018-01-06 | svc: Implement svcWaitProcessWideKeyAtomic. | bunnei | 2 | -1/+54 | |
2018-01-06 | semaphore: Updates for Switch. | bunnei | 2 | -21/+31 | |
2018-01-06 | lm: Assert on unsupported multi-message. | bunnei | 1 | -0/+9 | |
2018-01-06 | svc: Implement WaitSynchronization for a single handle. | bunnei | 1 | -4/+24 | |
2018-01-06 | svc: Refactor LockMutex code to use WaitSynchronization1. | bunnei | 1 | -13/+45 | |
2018-01-05 | lm: Improve Log() to format a useful string. | bunnei | 1 | -10/+75 | |
2018-01-05 | svc: Add missing string_util include. | bunnei | 1 | -0/+1 | |
2018-01-04 | cmake: Don't compile Dynarmic as it's unused. | bunnei | 1 | -1/+1 | |
2018-01-04 | core: Increase tight_loop 100x for speed. | bunnei | 1 | -1/+1 | |
2018-01-04 | citra_qt: Remove VFP registers, since this isn't used anyways and caused an assert. | bunnei | 1 | -4/+0 | |
2018-01-04 | arm_unicorn: Load/release unicorn DLL. | bunnei | 1 | -0/+16 | |
2018-01-04 | externals: Use unicorn DLL instead of static lib. | bunnei | 2 | -0/+4 | |
2018-01-04 | unicorn: Use for arm interface on Windows. | bunnei | 4 | -9/+242 | |
2018-01-04 | arm_dynarmic: More cleanup. | bunnei | 1 | -6/+0 | |
2018-01-04 | core: Remove unicorn_dynload. | bunnei | 1 | -2/+0 | |
2018-01-04 | arm_dynarmic: Gut interface until dynarmic is ready for general use. | bunnei | 2 | -142/+44 | |
2018-01-03 | arm: Remove SkyEye/Dyncom code that is ARMv6-only. | bunnei | 37 | -28101/+23 | |
2018-01-03 | vm_manager: Use a more reasonable MAX_ADDRESS size. | bunnei | 1 | -5/+4 | |
2018-01-03 | svc: Remove unnecessary "svc" prefix to naming scheme. | bunnei | 1 | -106/+106 | |
2018-01-03 | pctl: Remove duplicate InstallInterfaces function. | bunnei | 1 | -4/+0 | |
2018-01-03 | hle: Move SVC code to kernel namespace. | bunnei | 4 | -134/+121 | |
2018-01-01 | svc: Improve svcGetInfo. | bunnei | 2 | -35/+41 | |
2018-01-01 | vm_manager: Stub out a bunch of interfaces used by svcGetInfo. | bunnei | 2 | -1/+51 | |
2018-01-01 | svc: Fix string formatting for CreateThread. | bunnei | 1 | -1/+1 | |
2018-01-01 | cmake: Add missing object_address_table. | bunnei | 1 | -0/+2 | |
2018-01-01 | core/video_core: Fix a bunch of u64 -> u32 warnings. | bunnei | 8 | -26/+26 | |
2018-01-01 | svc: Stub out svcWaitSynchronization. | bunnei | 1 | -1/+9 | |
- This does not matter until we implement other kernel objects, mutexes use svcLockMutex for waiting. | |||||
2018-01-01 | svc: Implement svcExitProcess. | bunnei | 3 | -11/+77 | |
2018-01-01 | svc: Implement svcUnlockMutex. | bunnei | 1 | -1/+11 | |
2018-01-01 | svc: Implement svcLockMutex. | bunnei | 3 | -24/+134 | |
2018-01-01 | kernel: Add ObjectAddressTable class. | bunnei | 3 | -2/+101 | |
2017-12-31 | thread: Keep track of the initially created handle. | bunnei | 3 | -2/+7 | |
This is kinda crufty, but we need it for now to update guest state variables. | |||||
2017-12-31 | svc: Implement svcExitThread. | bunnei | 1 | -1/+9 | |
2017-12-31 | svc: Implement svcCreateThread. | bunnei | 1 | -2/+57 | |
2017-12-31 | svc: Cleanup svcGetThreadPriority. | bunnei | 1 | -3/+5 | |
2017-12-31 | svc: Stub out svcGetCurrentProcessorNumber. | bunnei | 1 | -1/+7 | |
2017-12-31 | errors: Define missing kernel error codes. | bunnei | 1 | -0/+3 | |
2017-12-31 | svc: Implement svcSetThreadPriority. | bunnei | 1 | -1/+30 | |
2017-12-31 | svc: Change SignalProcessWideKey to a stub. | bunnei | 1 | -2/+2 | |
2017-12-31 | function_wrappers: Cleanup, fix warnings, remove unused code. | bunnei | 1 | -187/+35 | |
2017-12-31 | svc: Implement svcUnmapMemory. | bunnei | 3 | -1/+15 | |
2017-12-30 | svc: Minor cleanups. | bunnei | 1 | -8/+9 | |
2017-12-30 | svc: Implement svcStartThread. | bunnei | 1 | -0/+16 | |
2017-12-30 | thread: Main thread should set thread handle to reg 1. | bunnei | 1 | -1/+4 | |
2017-12-30 | thread: Remove THUMB mode flag. | bunnei | 1 | -1/+1 | |
2017-12-30 | thread: Main thread should be ready by default, all others dormant. | bunnei | 1 | -4/+3 | |
2017-12-29 | kernel: Various 64-bit fixes in memory/process/thread | bunnei | 5 | -14/+14 | |
2017-12-29 | applet_oe: Stub out a bunch of interfaces necessary for boot. | bunnei | 2 | -1/+159 | |
2017-12-29 | controller: Implement DuplicateSession. | bunnei | 2 | -9/+11 | |
2017-12-29 | kernel: Fix implementation of ConvertSessionToDomain. | bunnei | 10 | -54/+90 | |
2017-12-29 | ap, aoc_u: Minor cleanup. | bunnei | 3 | -4/+1 | |
2017-12-29 | service: Add empty interface for pctl:a. | bunnei | 6 | -0/+90 | |
2017-12-29 | kernel: Add basic support for Domain object. | bunnei | 5 | -4/+112 | |
2017-12-29 | kernel: Add SyncObject primitive, use it for ClientSession. | bunnei | 4 | -10/+41 | |
2017-12-29 | svc: Implement MapMemory. | bunnei | 3 | -4/+17 | |
2017-12-29 | process: Add method to mirror a memory region. | bunnei | 2 | -0/+27 | |
2017-12-28 | svc: Implement SetHeapSize. | bunnei | 2 | -3/+19 | |
2017-12-28 | service: Clean up apm/lm/applet_oe/controller/sm ctor/dtor. | bunnei | 10 | -20/+10 | |
2017-12-28 | service: Halt on ReportUnimplementedFunction and improve output log. | bunnei | 1 | -4/+2 | |
2017-12-28 | service: Add empty interface for aoc:u. | bunnei | 4 | -0/+44 | |
2017-11-01 | service: Return proper result code for IPC::CommandType::Close. | bunnei | 4 | -9/+12 | |
2017-11-01 | hle: Use Switch formatted result codes. | bunnei | 8 | -346/+110 | |
2017-10-23 | svc: Implement GetThreadId and GetProcessId. | bunnei | 2 | -2/+37 | |
2017-10-23 | logging: Rename category "Core_ARM11" to "Core_ARM". | bunnei | 10 | -89/+89 | |
2017-10-23 | nso: Load more common submodules. | bunnei | 1 | -15/+11 | |
2017-10-23 | memory: Support 32-bit paging, move heap address space up. | bunnei | 2 | -3/+3 | |
2017-10-20 | hle: Fix QueryMemory response for MemoryInfo. | bunnei | 7 | -149/+31 | |
2017-10-19 | lm: Implement lm::Initialize and Logger::log. | bunnei | 2 | -3/+67 | |
2017-10-19 | hle_ipc: Only copy necessary fields for outgoing command buffer. | bunnei | 1 | -1/+1 | |
2017-10-19 | hle_ipc: Parse out buffer X/A/B/B descriptors from incoming command buffer. | bunnei | 2 | -14/+19 | |
2017-10-19 | service: Add CreatePort function (that does not register/install). | bunnei | 2 | -0/+12 | |
2017-10-19 | memory: Print addresses as 64-bit. | bunnei | 1 | -2/+2 | |
2017-10-18 | ipc_helpers: Fix alignment (was wrong as a result of a dynarmic bug). | bunnei | 1 | -3/+4 | |
2017-10-18 | service: Print correct command ID on unimplemented function. | bunnei | 1 | -1/+1 | |
2017-10-15 | hle: Implement ConvertSessionToDomain, various cleanups. | bunnei | 10 | -33/+82 | |
2017-10-15 | core: Refactor MakeMagic usage and remove dead code. | bunnei | 11 | -885/+18 | |
2017-10-15 | hle: Add service stubs for apm and appletOE. | bunnei | 10 | -2/+136 | |
2017-10-15 | hle: Initial implementation of NX service framework and IPC. | bunnei | 21 | -859/+574 | |
2017-10-14 | nso: Add a log for loading submodules. | bunnei | 1 | -0/+1 | |
2017-10-14 | svc: Some logging cleanup. | bunnei | 1 | -7/+5 | |
2017-10-14 | svc: Update MemoryInfo flags for 64-bit. | bunnei | 1 | -5/+5 | |
2017-10-14 | svc: Initial nx impl. for QueryMemory, ConnectToPort, SendSyncRequest, etc. | bunnei | 1 | -1185/+185 | |
2017-10-13 | Remove more 3DS-specific code. | bunnei | 5 | -48/+3 | |
2017-10-13 | Remove more 3DS-specific code. | bunnei | 7 | -1414/+2 | |
2017-10-13 | Remove more 3DS-specific code. | bunnei | 3 | -55/+0 | |
2017-10-13 | Remove lots more 3DS-specific code. | bunnei | 50 | -6976/+8 | |
2017-10-10 | hle: Remove a large amount of 3ds-specific service code. | bunnei | 200 | -22393/+2 | |
2017-10-10 | loader: Various improvements for NSO/NRO loaders. | bunnei | 8 | -58/+40 | |
2017-10-09 | Change command header in nwm::UDS Initialize function | Dragios | 1 | -1/+1 | |
2017-10-06 | loader: Add support for NRO, as well as various fixes and shared linker. | bunnei | 9 | -146/+434 | |
2017-10-04 | SVC: Removed GetPointer usage in the GetResourceLimit functions. | Subv | 1 | -10/+16 | |
2017-10-04 | SVC: Remove GetPointer usage in CreatePort. | Subv | 2 | -6/+4 | |
2017-10-04 | SVC: Replace GetPointer usage with ReadCString in ConnectToPort. | Subv | 2 | -20/+9 | |
2017-10-04 | SVC: Replace GetPointer usage with ReadBlock in OutputDebugString. | Subv | 2 | -4/+6 | |
2017-10-04 | SVC: Replace GetPointer usage with Read32 in ReplyAndReceive. | Subv | 2 | -7/+6 | |
2017-10-04 | SVC: Replace GetPointer usage with Read32 in WaitSynchronizationN. | Subv | 2 | -8/+8 | |
2017-10-04 | Memory: Remove all GetPointer usages from the GDB stub. | Subv | 1 | -8/+12 | |
2017-10-04 | Extracted the attribute setup and draw commands into their own functions | Huw Pascoe | 1 | -217/+222 | |
2017-10-04 | nso: Fixes to support homebrew NSOs without a MOD header. | bunnei | 2 | -17/+23 | |
2017-10-02 | Kernel/SharedMemory: Don't take over and unmap the source memory block when creating a shared memory, just reference it. | Subv | 1 | -15/+12 | |
Also reference the right offset into the backing block for the requested address. | |||||
2017-10-01 | Memory: Make WriteBlock take a Process parameter on which to operate | Subv | 2 | -10/+19 | |
2017-10-01 | Memory: Make ReadBlock take a Process parameter on which to operate | Subv | 2 | -12/+30 | |
2017-10-01 | Kernel/Thread: Added a helper function to get a thread's command buffer VAddr. | Subv | 2 | -0/+12 | |
2017-10-01 | file_sys, loader: add support for reading TMDs to determine app paths | shinyquagsire23 | 2 | -5/+27 | |
2017-10-01 | file_sys: add class for Title Metadata (TMD) | shinyquagsire23 | 3 | -0/+338 | |
2017-10-01 | file_sys/ncch_container: add RomFS, ExeFS override to allow for backward compatibility with existing .romfs system archive dumps | shinyquagsire23 | 2 | -69/+206 | |
2017-10-01 | file_sys/archive_ncch: use NCCHContainer instead of loading .romfs files | shinyquagsire23 | 1 | -6/+12 | |
2017-09-30 | arm_interface: Set TLS address for dynarmic core. | bunnei | 5 | -0/+32 | |
2017-09-30 | nso: Refactor and allocate .bss section. | bunnei | 9 | -132/+162 | |
2017-09-30 | process: Support loading multiple codesets. | bunnei | 2 | -20/+27 | |
2017-09-30 | loader: Add support for loading an NSO. | bunnei | 5 | -0/+342 | |
2017-09-30 | externals: Add lz4. | bunnei | 1 | -1/+1 | |
2017-09-30 | memory: Log with 64-bit values. | bunnei | 1 | -8/+8 | |
2017-09-30 | kernel: Various threading fixes to support 64-bit addressing. | bunnei | 2 | -8/+8 | |
2017-09-30 | core: Various changes to support 64-bit addressing. | bunnei | 5 | -54/+54 | |
2017-09-30 | arm: Use 64-bit addressing in a bunch of places. | bunnei | 9 | -80/+113 | |
2017-09-30 | elf: Check if machine is ARM. | bunnei | 1 | -2/+9 | |
2017-09-30 | Services/NIM: Implement CheckForSysUpdateEvent. | Subv | 3 | -2/+29 | |
Implementation verified by reverse engineering. This lets the Home Menu boot without crashing on startup. | |||||
2017-09-30 | Moved down_count to CoreTiming | Huw Pascoe | 9 | -43/+33 | |
2017-09-30 | Services/UDS: Handle the rest of the connection sequence. (#2963) | B3n30 | 3 | -19/+250 | |
Services/UDS: Handle the rest of the connection sequence. | |||||
2017-09-30 | Fixed type conversion ambiguity | Huw Pascoe | 32 | -91/+97 | |
2017-09-28 | Kernel/Threads: When putting a thread to wait, specify a function to execute when it is awoken. | Subv | 4 | -17/+91 | |
This change makes for a clearer (less confusing) path of execution in the scheduler, now the code to execute when a thread awakes is closer to the code that puts the thread to sleep (WaitSynch1, WaitSynchN). It also allows us to implement the special wake up behavior of ReplyAndReceive without hacking up WaitObject::WakeupAllWaitingThreads. If savestates are desired in the future, we can change this implementation to one similar to the CoreTiming event system, where we first register the callback functions at startup and assign their identifiers to the Thread callback variable instead of directly assigning a lambda to the wake up callback variable. | |||||
2017-09-27 | Disable unary operator- on Math::Vec2/Vec3/Vec4 for unsigned types. | Subv | 2 | -5/+9 | |
It is unlikely we will ever use this without first doing a Cast to a signed type. Fixes 9 "unary minus operator applied to unsigned type, result still unsigned" warnings on MSVC2017.3 | |||||
2017-09-27 | Loaders: Don't automatically set the current process every time we load an application. | Subv | 8 | -37/+40 | |
The loaders will now just create a Kernel::Process, construct it and return it to the caller, which is responsible for setting it as the current process and configuring the global page table. | |||||
2017-09-27 | Kernel/Thread: Allow specifying which process a thread belongs to when creating it. | Subv | 4 | -17/+22 | |
Don't automatically assume that Thread::Create will only be called when the parent process is currently scheduled. This assumption will be broken when applets or system modules are loaded. | |||||
2017-09-27 | Tests: Added Memory::IsValidVirtualAddress tests. | Subv | 2 | -0/+57 | |
2017-09-27 | Tests: Fixed ARM VFP tests | Subv | 1 | -9/+13 | |
2017-09-27 | Memory: Allow IsValidVirtualAddress to be called with a specific process parameter. | Subv | 2 | -7/+25 | |
There is still an overload of IsValidVirtualAddress that only takes the VAddr and will default to the current process. | |||||
2017-09-26 | HLE/APT: Always set up the APT parameter when starting a library applet. | Subv | 2 | -30/+47 | |
Only use the HLE interface if an HLE applet with the desired id was started. This commit reorganizes the APT code surrounding parameter creation and delivery to make it easier to support LLE applets in the future. As future work, the HLE applet interface can be reworked to utilize the same facilities as the LLE interface. | |||||
2017-09-26 | Memory/RasterizerCache: Ignore unmapped memory regions when caching physical regions. | Subv | 1 | -1/+16 | |
Not all physical regions need to be mapped into the address space of every process, for example, system modules do not have a VRAM mapping. This fixes a crash when loading applets and system modules. | |||||
2017-09-26 | Audio: Use std::deque instead of std::vector for the audio buffer type (StereoBuffer16). | Subv | 5 | -7/+9 | |
The current code inserts and deletes elements from the beginning of the audio buffer, which is very inefficient in an std::vector. Profiling was done using VisualStudio2017's Performance Analyzer in Super Mario 3D Land. Before this change: AudioInterp::Linear had 14.14% of the runtime (inclusive) and most of that time was spent in std::vector's insert implementation. After this change: AudioInterp::Linear has 0.36% of the runtime (inclusive) | |||||
2017-09-25 | HLE/Archives: Allow multiple loaded applications to access their SelfNCCH archive independently. | Subv | 6 | -18/+65 | |
The loaders now register each loaded ROM with the SelfNCCH factory, which keeps the data around for the duration of the emulation session. When opening the SelfNCCH archive, the factory queries the current program's programid and uses that as a key to the map that contains the NCCHData structure (RomFS, Icon, Banner, etc). 3dsx files do not have a programid and will use a default of 0 for this value, thus, only 1 3dsx file with RomFS is loadable at the same time. | |||||
2017-09-25 | Loader/NCCH: Add support for loading application updates (#2927) | Max Thomas | 8 | -439/+670 | |
* loader/ncch: split NCCH parsing into its own file * loader/ncch: add support for loading update NCCHs from the SD card * loader/ncch: fix formatting * file_sys/ncch_container: Return a value for OpenFile * loader/ncch: cleanup, always instantiate overlay_ncch to base_ncch * file_sys/ncch_container: better encryption checks, allow non-app NCCHs to load properly and for the existence of NCCH structures to be checked * file_sys/ncch_container: pass filepath as a const reference | |||||
2017-09-25 | Services/UDS: Added a function to send EAPoL-Start packets (#2920) | B3n30 | 5 | -88/+250 | |
* Services/UDS: Added a function to generate the EAPoL-Start packet body. * Services/UDS: Added filter for beacons. * Services/UDS: Lock a mutex when accessing connection_status from both the emulation and network thread. * Services/UDS: Handle the Association Response frame and respond with the EAPoL-Start frame. * fixup: make use of current_node, changed received_beacons into a list, mutex and assert corrections * fixup: fix damn clang-format | |||||
2017-09-25 | Optimized Float<M,E> multiplication | Huw Pascoe | 1 | -11/+7 | |
Before: ucomiss xmm1, xmm1 jp .L9 pxor xmm2, xmm2 mov edx, 1 ucomiss xmm0, xmm2 setp al cmovne eax, edx test al, al jne .L9 .L3: movaps xmm0, xmm2 ret .L9: ucomiss xmm0, xmm0 jp .L10 pxor xmm2, xmm2 mov edx, 1 ucomiss xmm1, xmm2 setp al cmovne eax, edx test al, al je .L3 After: movaps xmm2, xmm1 mulss xmm2, xmm0 ucomiss xmm2, xmm2 jnp .L3 ucomiss xmm1, xmm0 jnp .L11 .L3: movaps xmm0, xmm2 ret .L11: pxor xmm2, xmm2 jmp .L3 | |||||
2017-09-25 | ARM_Interface: Implement PageTableChanged | MerryMage | 6 | -6/+39 | |
2017-09-24 | memory: Remove GetCurrentPageTablePointers | MerryMage | 2 | -10/+0 | |
2017-09-24 | memory: Add GetCurrentPageTable/SetCurrentPageTable | MerryMage | 7 | -13/+19 | |
Don't expose Memory::current_page_table as a global. | |||||
2017-09-24 | Optimized Morton | Huw Pascoe | 1 | -10/+4 | |
2017-09-24 | citra-qt: fix some untranslated strings | wwylele | 3 | -21/+22 | |
2017-09-24 | HLE/APT: Always return an error from PrepareToStartNewestHomeMenu so that the Home Menu doesn't try to reboot the system. | Subv | 3 | -2/+26 | |
As per 3dbrew: "During Home Menu start-up it uses APT:PrepareToStartNewestHomeMenu. If that doesn't return an error(normally NS returns 0xC8A0CFFC for that), Home Menu starts a hardware reboot with APT:StartNewestHomeMenu etc. " | |||||
2017-09-24 | HLE/APT: Prepare the APT Wakeup parameter when the game calls Initialize | Subv | 1 | -6/+19 | |
We need to know what is being run so we can set the APT parameter destination AppId correctly. Delaying the preparation of the parameter until we know which AppId is running lets us support booting both the Home Menu and normal game Applications. | |||||
2017-09-24 | HLE/SRV: Implemented RegisterService. | Subv | 4 | -1/+33 | |
Now system modules can do more than just crash immediately on startup. | |||||
2017-09-23 | Remove pipeline.gpu_mode and fix minor issues | James Rowe | 1 | -12/+2 | |
2017-09-19 | WebService: Verify username and token (#2930) | B3n30 | 15 | -38/+316 | |
* WebService: Verify username and token; Log errors in PostJson * Fixup: added docstrings to the functions * Webservice: Added Icons to the verification, imrpved error detection in cpr, fixup nits * fixup: fmt warning | |||||
2017-09-17 | Improved performance of FromAttributeBuffer | Huw Pascoe | 1 | -1/+2 | |
Ternary operator is optimized by the compiler whereas std::min() is meant to return a value. I've noticed a 5%-10% emulation speed increase. | |||||
2017-09-17 | Fixed framebuffer warning | Huw Pascoe | 1 | -7/+18 | |
2017-09-16 | Services/NS: Port ns:s to the new service framework. | Subv | 7 | -42/+77 | |
2017-09-15 | CPU/Dynarmic: Disable the fast page-table access in dynarmic until it supports switching page tables at runtime. | Subv | 1 | -1/+3 | |
2017-09-15 | Tests/VFP: Use a standalone pagetable for the TestEnvironment memory operations. | Subv | 1 | -4/+14 | |
This fixes building the tests | |||||
2017-09-15 | Kernel/Memory: Make IsValidPhysicalAddress not go through the current process' virtual memory mapping. | Subv | 1 | -2/+1 | |
2017-09-15 | Kernel/Threads: Don't clear the CPU instruction cache when performing a context switch from an idle thread into a thread in the same process. | Subv | 1 | -1/+3 | |
We were unnecessarily clearing the cache when going from Process A -> Idle -> Process A, this caused extreme performance regressions. | |||||
2017-09-15 | Kernel/Memory: Changed GetPhysicalPointer so that it doesn't go through the current process' page table to obtain a pointer. | Subv | 4 | -30/+69 | |
2017-09-11 | GPU: Add draw for immediate and batch modes | James Rowe | 1 | -2/+17 | |
PR #1461 introduced a regression where some games would change configuration even while in the poorly named "drawing" mode, which broke the heuristic citra was using to determine when to draw the batch. This change adds back in a draw call for batching, and also adds in a draw call in immediate mode each time it adds a triangle. | |||||
2017-09-10 | Kernel/Memory: Switch the current page table when a new process is scheduled. | Subv | 1 | -0/+10 | |
2017-09-10 | Kernel/Memory: Give each Process its own page table. | Subv | 9 | -87/+93 | |
The loader is in charge of setting the newly created process's page table as the main one during the loading process. | |||||
2017-09-04 | Remove _flag in var names | mailwl | 1 | -6/+6 | |
2017-09-04 | Mii Selector Applet: update Mii structures | mailwl | 2 | -34/+29 | |
2017-09-03 | Fix icon for citra qt | James Rowe | 1 | -1/+3 | |
2017-09-03 | APT: load different shared font depending on the region | wwylele | 3 | -135/+155 | |
2017-09-03 | pica/lighting: only apply Fresnel factor for the last light | wwylele | 2 | -7/+9 | |
2017-09-03 | Add manifest | DaMan | 2 | -0/+16 | |
2017-08-31 | video_core: report telemetry for gas mode | wwylele | 1 | -0/+6 | |
2017-08-29 | Use recursive_mutex instead of mutex to fix #2902 | danzel | 4 | -5/+5 | |
2017-08-28 | interpolate: Interpolate on a frame-by-frame basis | MerryMage | 3 | -88/+74 | |
2017-08-27 | Services/UDS: Remove an old duplicated declaration of WifiPacket. | Subv | 2 | -22/+0 | |
2017-08-27 | Services/UDS: Handle the connection sequence packets. | Subv | 1 | -17/+83 | |
There is currently no stage tracking, a client is considered "Connected" when it receives the EAPoL Logoff packet from the server, this is not yet implemented. | |||||
2017-08-27 | Services/UDS: Store the received beacon frames until RecvBeaconBroadcastData is called, up to 15 beacons at the same time, removing any older beacon frames when the limit is exceeded. | Subv | 1 | -3/+62 | |
2017-08-27 | Services/UDS: Add functions to generate 802.11 auth and assoc response frames. | Subv | 5 | -11/+144 | |
2017-08-27 | web_backend: Fix CPR bug where Winsock is not properly initializing. | bunnei | 1 | -15/+27 | |
2017-08-26 | Warnings: Fixed a few missing-return warnings in video_core. | Subv | 3 | -6/+10 | |
2017-08-26 | web_backend: Fix asynchronous JSON post by spawning new thread. | bunnei | 1 | -9/+18 | |
2017-08-26 | web_services: Refactor to remove dependency on Core. | bunnei | 5 | -20/+35 | |
2017-08-26 | qt: Add an option to view/regenerate telemetry ID. | bunnei | 4 | -7/+40 | |
2017-08-26 | default_ini: Use correct telemetry endpoint URL. | bunnei | 1 | -1/+1 | |
2017-08-26 | # This is a combination of 2 commits. | bunnei | 1 | -3/+30 | |
# This is the 1st commit message: qt: Add web configuration tab. # The commit message #2 will be skipped: # fixup! qt: Add web configuration tab. | |||||
2017-08-26 | qt: Add web configuration tab. | bunnei | 6 | -2/+217 | |
2017-08-26 | web_backend: User config for username and token, support anonymous post. | bunnei | 2 | -40/+17 | |
2017-08-26 | telemetry: Log frontend type. | bunnei | 2 | -0/+4 | |
2017-08-26 | settings: Add enable_telemetry, citra_username, and citra_token. | bunnei | 4 | -0/+20 | |
2017-08-26 | telemetry_session: Log telemetry ID. | bunnei | 1 | -0/+36 | |
2017-08-26 | citra_qt: Show one-time callout messages to user. | bunnei | 4 | -0/+50 | |
2017-08-25 | SidebySide Layout (#2859) | ThaMighty90 | 6 | -7/+61 | |
* added a SidebySide Layout * Reworked, so both screen have the same height and cleaned up screen translates. * added the option in the UI, hope this is the right way to do it. formated framebuffer_layout.cpp * delete the x64 files * deleted ui_configure_graphics.h * added Option for the Layout in the xml * got rid of SIDE_BY_SIDE_ASPECT_RATIO because it was useless. pulled translate into variables * changed shift variables to u32 and moved them in their respective branch. remove notr="true" for the Screen layout drop down * reworked intends :). changed function description for SideFrameLayout * some description reworking | |||||
2017-08-25 | SwRasterizer/Clipper: flip the sign convention to match PICA and OpenGL | wwylele | 1 | -9/+9 | |
2017-08-25 | gl_rasterizer: implement custom clip plane | wwylele | 3 | -34/+83 | |
2017-08-24 | SwRasterizer: implement custom clip plane | wwylele | 2 | -4/+25 | |
2017-08-24 | EmuWindow: refactor touch input into a TouchDevice | wwylele | 5 | -39/+72 | |
2017-08-24 | HID: use TouchDevice for touch pad | wwylele | 3 | -4/+15 | |
2017-08-22 | Kernel/Memory: Acquire the global HLE lock when a memory read/write operation falls outside of the fast path, for it might perform an MMIO operation. | Subv | 1 | -1/+8 | |
2017-08-22 | Kernel/HLE: Use a mutex to synchronize access to the HLE kernel state between the cpu thread and any other possible threads that might touch the kernel (network thread, etc). | Subv | 5 | -3/+38 | |
This mutex is acquired in SVC::CallSVC, ie, as soon as the guest application enters the HLE kernel, and should be acquired by the aforementioned threads before modifying kernel structures. | |||||
2017-08-22 | motion_emu: fix initialization order | wwylele | 1 | -1/+4 | |
2017-08-22 | gl_rasterizer/lighting: more accurate CP formula | wwylele | 1 | -2/+2 | |
2017-08-22 | SwRasterizer/Lighting: implement LUT input CP | wwylele | 1 | -0/+11 | |
2017-08-22 | SwRasterizer/Lighting: implement bump mapping | wwylele | 3 | -8/+27 | |
2017-08-22 | Kernel/Threads: Don't immediately switch to the new main thread when loading a new process. | Subv | 1 | -5/+1 | |
This is necessary for loading multiple processes at the same time. The main thread will be automatically scheduled when necessary once the scheduler runs. | |||||
2017-08-21 | GPU/Warnings: Explicitly cast the screen refresh ticks to u64. | Subv | 1 | -1/+1 | |
2017-08-21 | Warnings: Add UNREACHABLE macros to switches that contemplate all possible values. | Subv | 3 | -2/+7 | |
2017-08-21 | HLE/Applets: Fixed some conversion warnings when creating the framebuffer shared memory objects. | Subv | 4 | -8/+8 | |
2017-08-21 | CPU/Dynarmic: Fixed a warning when incrementing the number of ticks in ExecuteInstructions. | Subv | 1 | -1/+1 | |
2017-08-21 | Dyncom: Use size_t instead of int to store the instruction offsets in the instruction cache. | Subv | 2 | -4/+4 | |
Fixes a few warnings. | |||||
2017-08-21 | Dyncom: Fixed a conversion warning when decoding thumb instructions. | Subv | 1 | -1/+1 | |
2017-08-21 | swrasterizer: remove invalid TODO | wwylele | 1 | -4/+2 | |
This function is called in clipping, before the pespective divide, and is not used in later rasterization. Thus it doesn't need perspective correction. | |||||
2017-08-21 | swrasterizer/clipper: remove tested TODO | wwylele | 1 | -4/+0 | |
hwtested. Current implementation is the correct behavior | |||||
2017-08-21 | gl_shader_gen: simplify and clarify the depth transformation between vertex shader and fragment shader | wwylele | 1 | -2/+5 | |
2017-08-21 | gl_rasterizer: add clipping plane z<=0 defined in PICA | wwylele | 4 | -0/+21 | |
2017-08-20 | HID: fix a comment and a warning | wwylele | 1 | -2/+2 | |
2017-08-19 | Added missing parts in libnetwork (#2838) | B3n30 | 9 | -37/+310 | |
* Network: Set and send the game information over enet Added Callbacks for RoomMember and GetMemberList to Room in preparation for web_services. | |||||
2017-08-19 | pica/command_processor: build geometry pipeline and run geometry shader | wwylele | 6 | -28/+383 | |
The geometry pipeline manages data transfer between VS, GS and primitive assembler. It has known four modes: - no GS mode: sends VS output directly to the primitive assembler (what citra currently does) - GS mode 0: sends VS output to GS input registers, and sends GS output to primitive assembler - GS mode 1: sends VS output to GS uniform registers, and sends GS output to primitive assembler. It also takes an index from the index buffer at the beginning of each primitive for determine the primitive size. - GS mode 2: similar to mode 1, but doesn't take the index and uses a fixed primitive size. hwtest shows that immediate mode also supports GS (at least for mode 0), so the geometry pipeline gets refactored into its own class for supporting both drawing mode. In the immediate mode, some games don't set the pipeline registers to a valid value until the first attribute input, so a geometry pipeline reset flag is set in `pipeline.vs_default_attributes_setup.index` trigger, and the actual pipeline reconfigure is triggered in the first attribute input. In the normal drawing mode with index buffer, the vertex cache is a little bit modified to support the geometry pipeline. Instead of OutputVertex, it now holds AttributeBuffer, which is the input to the geometry pipeline. The AttributeBuffer->OutputVertex conversion is done inside the pipeline vertex handler. The actual hardware vertex cache is believed to be implemented in a similar way (because this is the only way that makes sense). Both geometry pipeline and GS unit rely on states preservation across drawing call, so they are put into the global state. In the future, the other three vertex shader units should be also placed in the global state, and a scheduler should be implemented on top of the four units. Note that the current gs_unit already allows running VS on it in the future. | |||||
2017-08-19 | pica/shader/jit: implement SETEMIT and EMIT | wwylele | 2 | -2/+49 | |
2017-08-19 | pica/primitive_assembly: Handle winding for GS primitive | wwylele | 2 | -3/+19 | |
hwtest shows that, although GS always emit a group of three vertices as one primitive, it still respects to the topology type, as if the three vertices are input into the primitive assembler independently and sequentially. It is also shown that the winding flag in SETEMIT only takes effect for Shader topology type, which is believed to be the actual difference between List and Shader (hence removed the TODO). However, only Shader topology type is observed in official games when GS is in use, so the other mode seems to be just unintended usage. | |||||
2017-08-19 | correct constness | wwylele | 2 | -2/+4 | |
2017-08-19 | pica/shader/interpreter: implement SETEMIT and EMIT | wwylele | 1 | -0/+16 | |
2017-08-19 | pica/shader: extend UnitState for GS | wwylele | 2 | -0/+84 | |
Among four shader units in pica, a special unit can be configured to run both VS and GS program. GSUnitState represents this unit, which extends UnitState (which represents the other three normal units) with extra state for primitive emitting. It uses lots of raw pointers to represent internal structure in order to keep it standard layout type for JIT to access. This unit doesn't handle triangle winding (inverting) itself; instead, it calls a WindingSetter handler. This will be explained in the following commits | |||||
2017-08-19 | motion_emu: no need to include thread in header | wwylele | 2 | -2/+7 | |
2017-08-15 | dsp_dsp: Remove size assertion in LoadComponent | MerryMage | 1 | -3/+4 | |
2017-08-13 | Fix Spelling/English mistakes | Dave Leaver | 1 | -1/+1 | |
2017-08-11 | gl_shader_gen: don't call SampleTexture when bump map is not used | wwylele | 1 | -4/+5 | |
2017-08-11 | move MotionEmu from core/frontend to input_common as a InputDevice | wwylele | 17 | -244/+221 | |
2017-08-11 | HID: use MotionDevice for Accelerometer and Gyroscope | wwylele | 3 | -5/+48 | |
2017-08-11 | Fix some spelling mistakes | danzel | 2 | -4/+4 | |
2017-08-11 | SwRasterizer/Lighting: implement spot light | wwylele | 1 | -3/+19 | |
2017-08-11 | SwRasterizer/Lighting: implement geometric factor | wwylele | 1 | -4/+16 | |
2017-08-10 | HID: zero unused PadState bits | wwylele | 2 | -2/+2 | |
2017-08-10 | SwRasterizer/Lighting: use make_tuple instead of constructor | wwylele | 1 | -1/+1 | |
implicit tuple constructor is a c++17 thing, which is not supported by some not-so-old libraries. Play safe for now | |||||
2017-08-10 | pica/regs: layout geometry shader configuration regs | wwylele | 2 | -2/+39 | |
All the register meanings are derived from ctrulib (3dbrew is outdated for most of them) | |||||
2017-08-09 | Service/dlp: Update function tables according 3dbrew | mailwl | 3 | -4/+44 | |
2017-08-08 | Update cryptopp | James | 1 | -1/+1 | |
2017-08-07 | Services/APT: Use the AppletAttributes union directly when dealing with applet attrs. | Subv | 1 | -19/+15 | |
2017-08-07 | Services/APT: Use an array to hold data about the 4 possible concurrent applet types (Application, Library, HomeMenu, System). | Subv | 2 | -35/+204 | |
This gives each applet type its own set of events as per the real NS module. | |||||
2017-08-07 | pica: upload shared shader code to both unit | wwylele | 2 | -26/+45 | |
2017-08-05 | Quickfix typo in OpenGL 3.3 error message | Andrea Pascal | 1 | -1/+1 | |
User pointed out on the Discord server that "nothave" is erroneously concatenated. Added a space to prevent it. | |||||
2017-08-04 | telemetry: Add field for OsPlatform. | bunnei | 1 | -0/+9 | |
2017-08-04 | telemetry: Add field for BuildName. | bunnei | 1 | -0/+1 | |
2017-08-04 | telemetry: Add field for RequiresSharedFont. | bunnei | 1 | -0/+4 | |
2017-08-04 | telemetry_session: Log BuildDate and ProgramName fields. | bunnei | 1 | -0/+7 | |
2017-08-04 | common: Add build timestamp to scm_rev. | bunnei | 2 | -0/+3 | |
2017-08-04 | core: Expose AppLoader as a public interface. | bunnei | 1 | -4/+5 | |
2017-08-04 | loader: Expose program title. | bunnei | 3 | -12/+31 | |
2017-08-03 | SwRasterizer/Lighting: shorten file name | wwylele | 4 | -4/+4 | |
2017-08-02 | SwRasterizer/Lighting: move to its own file | wwylele | 4 | -240/+271 | |
2017-08-02 | SwRasterizer/Lighting: reduce confusion | wwylele | 1 | -1/+1 | |
2017-08-02 | SwRasterizer/Lighting: move quaternion normalization to the caller | wwylele | 1 | -3/+3 | |
2017-07-31 | Handle invalid filenames when renaming files/directories | James | 2 | -4/+78 | |
2017-07-27 | pica/shader_interpreter: fix off-by-one in LOOP | wwylele | 1 | -1/+1 | |
2017-07-26 | Network: Moved NintendoOUI initalization to RoomMember constructor | B3n30 | 2 | -3/+4 | |
2017-07-23 | tests: Add tests for vadd | MerryMage | 5 | -2/+13510 | |
2017-07-23 | tests: Arm testing framework | MerryMage | 3 | -0/+208 | |
2017-07-21 | Service/APT: Log Send/Cancel/Receive/GlanceParameter calls even if they return an error. | Subv | 1 | -7/+9 | |
2017-07-21 | Services/APT: Return the proper error code when calling SendParameter with an outstanding parameter already in memory. | Subv | 2 | -4/+17 | |
2017-07-21 | Services/APT: Reset the APT parameter inside CancelParameter if the conditions are met. | Subv | 1 | -6/+23 | |
2017-07-21 | Services/APT: Properly clear the apt parameter after a successful ReceiveParameter call. | Subv | 1 | -2/+8 | |
2017-07-21 | Services/APT: Use the right error codes in ReceiveParameter and GlanceParameter when the parameter doesn't exist. | Subv | 1 | -0/+28 | |
2017-07-21 | Services/APT: Use boost::optional for the APT parameter structure. | Subv | 1 | -20/+26 | |
2017-07-20 | debugger/shader: display LOOP | wwylele | 1 | -1/+3 | |
2017-07-20 | debugger/shader: print the invert flag for JMPU | wwylele | 1 | -0/+4 | |
2017-07-20 | debugger/shader: fix address register for reverted arithmetic op | wwylele | 1 | -20/+9 | |
2017-07-20 | debugger/shader: fix inverted uniform flow control | wwylele | 1 | -2/+2 | |
2017-07-18 | telemetry: Log performance, configuration, and system data. | bunnei | 5 | -18/+96 | |
2017-07-17 | stubbed frd::UnscrambleLocalFriendCode (#2827) | B3n30 | 3 | -1/+57 | |
2017-07-16 | Network: Changed timeout for receiving packets to 100ms | B3n30 | 5 | -43/+50 | |