diff options
| author | 2024-02-01 12:42:11 +0100 | |
|---|---|---|
| committer | 2024-02-01 13:00:36 +0100 | |
| commit | f740d8b9be1b42dae9ac6d7311a55b0c34b5a8e1 (patch) | |
| tree | 9338fba6a364f7f0eafcfb949183df85b4e0cdad /src/core | |
| parent | Merge pull request #12870 from liamwhite/mac-ci (diff) | |
| download | yuzu-f740d8b9be1b42dae9ac6d7311a55b0c34b5a8e1.tar.gz yuzu-f740d8b9be1b42dae9ac6d7311a55b0c34b5a8e1.tar.xz yuzu-f740d8b9be1b42dae9ac6d7311a55b0c34b5a8e1.zip | |
MemoryManager: Reduce the page table size based on last big page address.
Diffstat (limited to 'src/core')
| -rw-r--r-- | src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp b/src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp index e6646ba04..68fe38874 100644 --- a/src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp +++ b/src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp | |||
| @@ -123,6 +123,8 @@ NvResult nvhost_as_gpu::AllocAsEx(IoctlAllocAsEx& params) { | |||
| 123 | vm.va_range_end = params.va_range_end; | 123 | vm.va_range_end = params.va_range_end; |
| 124 | } | 124 | } |
| 125 | 125 | ||
| 126 | const u64 max_big_page_bits = Common::Log2Ceil64(vm.va_range_end); | ||
| 127 | |||
| 126 | const auto start_pages{static_cast<u32>(vm.va_range_start >> VM::PAGE_SIZE_BITS)}; | 128 | const auto start_pages{static_cast<u32>(vm.va_range_start >> VM::PAGE_SIZE_BITS)}; |
| 127 | const auto end_pages{static_cast<u32>(vm.va_range_split >> VM::PAGE_SIZE_BITS)}; | 129 | const auto end_pages{static_cast<u32>(vm.va_range_split >> VM::PAGE_SIZE_BITS)}; |
| 128 | vm.small_page_allocator = std::make_shared<VM::Allocator>(start_pages, end_pages); | 130 | vm.small_page_allocator = std::make_shared<VM::Allocator>(start_pages, end_pages); |
| @@ -132,8 +134,8 @@ NvResult nvhost_as_gpu::AllocAsEx(IoctlAllocAsEx& params) { | |||
| 132 | static_cast<u32>((vm.va_range_end - vm.va_range_split) >> vm.big_page_size_bits)}; | 134 | static_cast<u32>((vm.va_range_end - vm.va_range_split) >> vm.big_page_size_bits)}; |
| 133 | vm.big_page_allocator = std::make_unique<VM::Allocator>(start_big_pages, end_big_pages); | 135 | vm.big_page_allocator = std::make_unique<VM::Allocator>(start_big_pages, end_big_pages); |
| 134 | 136 | ||
| 135 | gmmu = std::make_shared<Tegra::MemoryManager>(system, 40, vm.big_page_size_bits, | 137 | gmmu = std::make_shared<Tegra::MemoryManager>(system, max_big_page_bits, vm.va_range_split, |
| 136 | VM::PAGE_SIZE_BITS); | 138 | vm.big_page_size_bits, VM::PAGE_SIZE_BITS); |
| 137 | system.GPU().InitAddressSpace(*gmmu); | 139 | system.GPU().InitAddressSpace(*gmmu); |
| 138 | vm.initialised = true; | 140 | vm.initialised = true; |
| 139 | 141 | ||