forked from eden-emu/eden
		
	Merge pull request #6385 from degasus/save_memory_access
core/memory: Check our memory fallbacks for out-of-bound behavior.
This commit is contained in:
		
						commit
						89c77a6b91
					
				
					 5 changed files with 77 additions and 33 deletions
				
			
		|  | @ -14,6 +14,7 @@ void PageTable::Resize(size_t address_space_width_in_bits, size_t page_size_in_b | |||
|     const size_t num_page_table_entries{1ULL << (address_space_width_in_bits - page_size_in_bits)}; | ||||
|     pointers.resize(num_page_table_entries); | ||||
|     backing_addr.resize(num_page_table_entries); | ||||
|     current_address_space_width_in_bits = address_space_width_in_bits; | ||||
| } | ||||
| 
 | ||||
| } // namespace Common
 | ||||
|  |  | |||
|  | @ -98,6 +98,10 @@ struct PageTable { | |||
|      */ | ||||
|     void Resize(size_t address_space_width_in_bits, size_t page_size_in_bits); | ||||
| 
 | ||||
|     size_t GetAddressSpaceBits() const { | ||||
|         return current_address_space_width_in_bits; | ||||
|     } | ||||
| 
 | ||||
|     /**
 | ||||
|      * Vector of memory pointers backing each page. An entry can only be non-null if the | ||||
|      * corresponding attribute element is of type `Memory`. | ||||
|  | @ -105,6 +109,8 @@ struct PageTable { | |||
|     VirtualBuffer<PageInfo> pointers; | ||||
| 
 | ||||
|     VirtualBuffer<u64> backing_addr; | ||||
| 
 | ||||
|     size_t current_address_space_width_in_bits; | ||||
| }; | ||||
| 
 | ||||
| } // namespace Common
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei