- Feb 19, 2019
-
-
Markus Wick authored
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.
-
Markus Wick authored
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.
-
- Feb 16, 2019
-
-
Lioncash authored
This way proper const/non-const selection can occur.
-
Lioncash authored
A fairly trivial change. Other sections of the codebase use nested namespaces instead of separate namespaces here. This one must have just been overlooked.
-
Lioncash authored
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.
-
- Feb 15, 2019
-
-
B3n30 authored
-
B3n30 authored
-
fearlessTobi authored
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.
-
- Feb 14, 2019
-
-
ReinUsesLisp authored
-
ReinUsesLisp authored
Handles a pool of resources protected by fences. Manages resource overflow allocating more resources. This class is intended to be used through inheritance.
-
ReinUsesLisp authored
CommitFence iterates a pool of fences until one is found. If all fences are being used at the same time, allocate more.
-
ReinUsesLisp authored
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.
-
ReinUsesLisp authored
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.
-
ReinUsesLisp authored
VKResource is an interface that gets signaled by a fence when it is free to be reused.
-
- Feb 13, 2019
-
-
Lioncash authored
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.
-
Lioncash authored
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.
-
Lioncash authored
Given this is only used in one place, it can be moved closest to its usage site.
-
ReinUsesLisp authored
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).
-
Lioncash authored
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()
-
- Feb 12, 2019
-
-
Lioncash authored
-
Lioncash authored
Avoids shadowing the members of the struct itself, which results in a -Wshadow warning.
-
ReinUsesLisp authored
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).
-
ReinUsesLisp authored
-
ReinUsesLisp authored
-
Lioncash authored
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.
-
- Feb 11, 2019
-
-
Fernando Sahmkow authored
-
Fernando Sahmkow authored
-
- Feb 10, 2019
-
-
ReinUsesLisp authored
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.
-
- Feb 09, 2019
-
-
greggameplayer authored
-
- Feb 08, 2019
-
-
Fernando Sahmkow authored
-
ReinUsesLisp authored
These parameters were declared as constants and passed to glTextureView but then they were removed on a rabase. This addresses that mistake.
-
Tobias authored
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.
-
- Feb 07, 2019
-
-
ReinUsesLisp authored
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.
-
ReinUsesLisp authored
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.
-
bunnei authored
-
bunnei authored
- This is a blit, use the blit registers.
-
ReinUsesLisp authored
-
Frederic L authored
Co-Authored-By:
ReinUsesLisp <reinuseslisp@airmail.cc>
-
Frederic L authored
Co-Authored-By:
ReinUsesLisp <reinuseslisp@airmail.cc>
-
Frederic L authored
Co-Authored-By:
ReinUsesLisp <reinuseslisp@airmail.cc>
-