diff options
author | riperiperi <rhy3756547@hotmail.com> | 2024-01-25 18:29:53 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-01-25 19:29:53 +0100 |
commit | 795539bc821dd51ff7fb2b1f2c851881b168b03d (patch) | |
tree | 8a995ea3e9173c221ce1f4650b26f99c43c38341 /src/Ryujinx.Graphics.Vulkan/BitMap.cs | |
parent | dd2e851e95e586bf65829da7cdb9e82014db36de (diff) |
Vulkan: Use staging buffer for temporary constants (#6168)1.1.1127
* Vulkan: Use staging buffer for temporary constants
Helper shaders and post processing effects typically need some parameters to tell them what to do, which we pass via constant buffers that are created and destroyed each time.
This can vary in cost between different Vulkan drivers. It shows up on profiles on mesa and MoltenVK, so it's worth avoiding. Some games only do it once (BlitColor for present), others multiple times. It's also done for post processing filters and FSR upscaling, which creates two buffers.
For mirrors, I added the ability to reserve a range on the staging buffer for use as any type of binding. This PR allows these constant buffers to be instead temporarily allocated on the staging buffer, skipping allocation and buffer management costs entirely.
Two temporary allocations do remain:
- DrawTexture, because it doesn't have access to the command buffer scope
- Index buffer indirect conversion, because one of them is a storage buffer and thus is a little more complicated.
There's a small cost in that the uniform buffer takes up more space due to alignment requirements. At worst that's 256 bytes (on a GTX 1070) but more modern GPUs should have a better time.
Worth testing across different games and post effects to make sure they still work.
* Use temporary buffer for ConvertIndexBufferIndirect
* Simplify alignment passing for now
* Fix shader params length for CopyIncompatibleFormats
* Set data for helpershaders without overlap checks
The data is in the staging buffer, so its usage range is guarded using that.
Diffstat (limited to 'src/Ryujinx.Graphics.Vulkan/BitMap.cs')
0 files changed, 0 insertions, 0 deletions