diff options
| author | 2020-03-13 16:33:47 -0400 | |
|---|---|---|
| committer | 2020-03-14 09:43:57 -0400 | |
| commit | 27cbb75e7c2818c073bd65a000d7ff7f28d391d4 (patch) | |
| tree | 1f8ff16d5202fde0e15f8a8f7c5d50045efb9341 /src/common/page_table.cpp | |
| parent | Merge pull request #3491 from ReinUsesLisp/polygon-modes (diff) | |
| download | yuzu-27cbb75e7c2818c073bd65a000d7ff7f28d391d4.tar.gz yuzu-27cbb75e7c2818c073bd65a000d7ff7f28d391d4.tar.xz yuzu-27cbb75e7c2818c073bd65a000d7ff7f28d391d4.zip | |
PageTable: move backing addresses to a children class as the CPU page table does not need them.
This PR aims to reduce the memory usage in the CPU page table by moving
GPU specific parameters into a child class. This saves 1Gb of Memory for
most games.
Diffstat (limited to 'src/common/page_table.cpp')
| -rw-r--r-- | src/common/page_table.cpp | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/src/common/page_table.cpp b/src/common/page_table.cpp index 69b7abc54..566b57b62 100644 --- a/src/common/page_table.cpp +++ b/src/common/page_table.cpp | |||
| @@ -16,7 +16,6 @@ void PageTable::Resize(std::size_t address_space_width_in_bits) { | |||
| 16 | 16 | ||
| 17 | pointers.resize(num_page_table_entries); | 17 | pointers.resize(num_page_table_entries); |
| 18 | attributes.resize(num_page_table_entries); | 18 | attributes.resize(num_page_table_entries); |
| 19 | backing_addr.resize(num_page_table_entries); | ||
| 20 | 19 | ||
| 21 | // The default is a 39-bit address space, which causes an initial 1GB allocation size. If the | 20 | // The default is a 39-bit address space, which causes an initial 1GB allocation size. If the |
| 22 | // vector size is subsequently decreased (via resize), the vector might not automatically | 21 | // vector size is subsequently decreased (via resize), the vector might not automatically |
| @@ -25,6 +24,17 @@ void PageTable::Resize(std::size_t address_space_width_in_bits) { | |||
| 25 | 24 | ||
| 26 | pointers.shrink_to_fit(); | 25 | pointers.shrink_to_fit(); |
| 27 | attributes.shrink_to_fit(); | 26 | attributes.shrink_to_fit(); |
| 27 | } | ||
| 28 | |||
| 29 | BackingPageTable::BackingPageTable(std::size_t page_size_in_bits) : PageTable{page_size_in_bits} {} | ||
| 30 | |||
| 31 | BackingPageTable::~BackingPageTable() = default; | ||
| 32 | |||
| 33 | void BackingPageTable::Resize(std::size_t address_space_width_in_bits) { | ||
| 34 | PageTable::Resize(address_space_width_in_bits); | ||
| 35 | const std::size_t num_page_table_entries = 1ULL | ||
| 36 | << (address_space_width_in_bits - page_size_in_bits); | ||
| 37 | backing_addr.resize(num_page_table_entries); | ||
| 28 | backing_addr.shrink_to_fit(); | 38 | backing_addr.shrink_to_fit(); |
| 29 | } | 39 | } |
| 30 | 40 | ||