diff options
| author | 2023-05-24 03:55:45 +0200 | |
|---|---|---|
| committer | 2023-05-24 03:55:45 +0200 | |
| commit | 76f63889692a0836dafd626841aa050ef26b407b (patch) | |
| tree | 442b586dc2ead257e4411101b05a06298c97e423 /src/video_core/vulkan_common | |
| parent | Merge pull request #10388 from GPUCode/fence-wait (diff) | |
| parent | textures: add BC1 and BC3 compressors and recompression setting (diff) | |
| download | yuzu-76f63889692a0836dafd626841aa050ef26b407b.tar.gz yuzu-76f63889692a0836dafd626841aa050ef26b407b.tar.xz yuzu-76f63889692a0836dafd626841aa050ef26b407b.zip | |
Merge pull request #10398 from liamwhite/bcn
video_core: add ASTC recompression
Diffstat (limited to 'src/video_core/vulkan_common')
| -rw-r--r-- | src/video_core/vulkan_common/vulkan_device.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/src/video_core/vulkan_common/vulkan_device.cpp b/src/video_core/vulkan_common/vulkan_device.cpp index c0b2b3e17..3a7c2dedf 100644 --- a/src/video_core/vulkan_common/vulkan_device.cpp +++ b/src/video_core/vulkan_common/vulkan_device.cpp | |||
| @@ -1001,6 +1001,11 @@ u64 Device::GetDeviceMemoryUsage() const { | |||
| 1001 | } | 1001 | } |
| 1002 | 1002 | ||
| 1003 | void Device::CollectPhysicalMemoryInfo() { | 1003 | void Device::CollectPhysicalMemoryInfo() { |
| 1004 | // Account for resolution scaling in memory limits | ||
| 1005 | const size_t normal_memory = 6_GiB; | ||
| 1006 | const size_t scaler_memory = 1_GiB * Settings::values.resolution_info.ScaleUp(1); | ||
| 1007 | |||
| 1008 | // Calculate limits using memory budget | ||
| 1004 | VkPhysicalDeviceMemoryBudgetPropertiesEXT budget{}; | 1009 | VkPhysicalDeviceMemoryBudgetPropertiesEXT budget{}; |
| 1005 | budget.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_BUDGET_PROPERTIES_EXT; | 1010 | budget.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_BUDGET_PROPERTIES_EXT; |
| 1006 | const auto mem_info = | 1011 | const auto mem_info = |
| @@ -1030,6 +1035,7 @@ void Device::CollectPhysicalMemoryInfo() { | |||
| 1030 | if (!is_integrated) { | 1035 | if (!is_integrated) { |
| 1031 | const u64 reserve_memory = std::min<u64>(device_access_memory / 8, 1_GiB); | 1036 | const u64 reserve_memory = std::min<u64>(device_access_memory / 8, 1_GiB); |
| 1032 | device_access_memory -= reserve_memory; | 1037 | device_access_memory -= reserve_memory; |
| 1038 | device_access_memory = std::min<u64>(device_access_memory, normal_memory + scaler_memory); | ||
| 1033 | return; | 1039 | return; |
| 1034 | } | 1040 | } |
| 1035 | const s64 available_memory = static_cast<s64>(device_access_memory - device_initial_usage); | 1041 | const s64 available_memory = static_cast<s64>(device_access_memory - device_initial_usage); |