summaryrefslogtreecommitdiffstats
path: root/src/common
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2020-03-14 21:50:27 +0100
committerGitHub <noreply@github.com>2020-03-14 21:50:27 +0100
commit4dfd5c84ea00cb3c2d5772f6951af93779b6d70e (patch)
tree9b9235159a9ef45e5fdbfb6bc60587e370cda8b7 /src/common
parentMerge pull request #3500 from ReinUsesLisp/incompatible-types (diff)
parentPageTable: move backing addresses to a children class as the CPU page table does not need them. (diff)
downloadyuzu-4dfd5c84ea00cb3c2d5772f6951af93779b6d70e.tar
yuzu-4dfd5c84ea00cb3c2d5772f6951af93779b6d70e.tar.gz
yuzu-4dfd5c84ea00cb3c2d5772f6951af93779b6d70e.tar.bz2
yuzu-4dfd5c84ea00cb3c2d5772f6951af93779b6d70e.tar.lz
yuzu-4dfd5c84ea00cb3c2d5772f6951af93779b6d70e.tar.xz
yuzu-4dfd5c84ea00cb3c2d5772f6951af93779b6d70e.tar.zst
yuzu-4dfd5c84ea00cb3c2d5772f6951af93779b6d70e.zip
Diffstat (limited to 'src/common')
-rw-r--r--src/common/page_table.cpp12
-rw-r--r--src/common/page_table.h15
2 files changed, 24 insertions, 3 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) {
pointers.resize(num_page_table_entries);
attributes.resize(num_page_table_entries);
- backing_addr.resize(num_page_table_entries);
// The default is a 39-bit address space, which causes an initial 1GB allocation size. If the
// 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) {
pointers.shrink_to_fit();
attributes.shrink_to_fit();
+}
+
+BackingPageTable::BackingPageTable(std::size_t page_size_in_bits) : PageTable{page_size_in_bits} {}
+
+BackingPageTable::~BackingPageTable() = default;
+
+void BackingPageTable::Resize(std::size_t address_space_width_in_bits) {
+ PageTable::Resize(address_space_width_in_bits);
+ const std::size_t num_page_table_entries = 1ULL
+ << (address_space_width_in_bits - page_size_in_bits);
+ backing_addr.resize(num_page_table_entries);
backing_addr.shrink_to_fit();
}
diff --git a/src/common/page_table.h b/src/common/page_table.h
index 8b8ff0bb8..dbc272ab7 100644
--- a/src/common/page_table.h
+++ b/src/common/page_table.h
@@ -76,9 +76,20 @@ struct PageTable {
*/
std::vector<PageType> attributes;
- std::vector<u64> backing_addr;
-
const std::size_t page_size_in_bits{};
};
+/**
+ * A more advanced Page Table with the ability to save a backing address when using it
+ * depends on another MMU.
+ */
+struct BackingPageTable : PageTable {
+ explicit BackingPageTable(std::size_t page_size_in_bits);
+ ~BackingPageTable();
+
+ void Resize(std::size_t address_space_width_in_bits);
+
+ std::vector<u64> backing_addr;
+};
+
} // namespace Common