[Memory] Removed redundant BaseHeap::IsGuestPhysicalHeap
This commit is contained in:
parent
26b0aa0cc4
commit
a6868d1f8a
|
@ -122,14 +122,14 @@ X_STATUS XFile::Read(uint32_t buffer_guest_address, uint32_t buffer_length,
|
|||
const xe::BaseHeap* buffer_end_heap =
|
||||
memory()->LookupHeap(buffer_guest_high_address);
|
||||
if (!buffer_start_heap || !buffer_end_heap ||
|
||||
buffer_start_heap->IsGuestPhysicalHeap() !=
|
||||
buffer_end_heap->IsGuestPhysicalHeap() ||
|
||||
(buffer_start_heap->IsGuestPhysicalHeap() &&
|
||||
(buffer_start_heap->heap_type() == HeapType::kGuestPhysical) !=
|
||||
(buffer_end_heap->heap_type() == HeapType::kGuestPhysical) ||
|
||||
(buffer_start_heap->heap_type() == HeapType::kGuestPhysical &&
|
||||
buffer_start_heap != buffer_end_heap)) {
|
||||
result = X_STATUS_ACCESS_VIOLATION;
|
||||
} else {
|
||||
xe::PhysicalHeap* buffer_physical_heap =
|
||||
buffer_start_heap->IsGuestPhysicalHeap()
|
||||
buffer_start_heap->heap_type() == HeapType::kGuestPhysical
|
||||
? static_cast<xe::PhysicalHeap*>(buffer_start_heap)
|
||||
: nullptr;
|
||||
if (buffer_physical_heap &&
|
||||
|
|
|
@ -375,7 +375,7 @@ uint32_t Memory::HostToGuestVirtualThunk(const void* context,
|
|||
|
||||
uint32_t Memory::GetPhysicalAddress(uint32_t address) const {
|
||||
const BaseHeap* heap = LookupHeap(address);
|
||||
if (!heap || !heap->IsGuestPhysicalHeap()) {
|
||||
if (!heap || heap->heap_type() != HeapType::kGuestPhysical) {
|
||||
return UINT32_MAX;
|
||||
}
|
||||
return static_cast<const PhysicalHeap*>(heap)->GetPhysicalAddress(address);
|
||||
|
@ -451,7 +451,7 @@ bool Memory::AccessViolationCallback(
|
|||
}
|
||||
uint32_t virtual_address = HostToGuestVirtual(host_address);
|
||||
BaseHeap* heap = LookupHeap(virtual_address);
|
||||
if (!heap->IsGuestPhysicalHeap()) {
|
||||
if (heap->heap_type() != HeapType::kGuestPhysical) {
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -477,7 +477,7 @@ bool Memory::TriggerPhysicalMemoryCallbacks(
|
|||
uint32_t virtual_address, uint32_t length, bool is_write,
|
||||
bool unwatch_exact_range, bool unprotect) {
|
||||
BaseHeap* heap = LookupHeap(virtual_address);
|
||||
if (heap->IsGuestPhysicalHeap()) {
|
||||
if (heap->heap_type() == HeapType::kGuestPhysical) {
|
||||
auto physical_heap = static_cast<PhysicalHeap*>(heap);
|
||||
return physical_heap->TriggerCallbacks(std::move(global_lock_locked_once),
|
||||
virtual_address, length, is_write,
|
||||
|
|
|
@ -187,9 +187,6 @@ class BaseHeap {
|
|||
xe::memory::PageAccess QueryRangeAccess(uint32_t low_address,
|
||||
uint32_t high_address);
|
||||
|
||||
// Whether the heap is a guest virtual memory mapping of the physical memory.
|
||||
virtual bool IsGuestPhysicalHeap() const { return false; }
|
||||
|
||||
bool Save(ByteStream* stream);
|
||||
bool Restore(ByteStream* stream);
|
||||
|
||||
|
@ -264,7 +261,6 @@ class PhysicalHeap : public BaseHeap {
|
|||
uint32_t virtual_address, uint32_t length, bool is_write,
|
||||
bool unwatch_exact_range, bool unprotect = true);
|
||||
|
||||
bool IsGuestPhysicalHeap() const override { return true; }
|
||||
uint32_t GetPhysicalAddress(uint32_t address) const;
|
||||
|
||||
protected:
|
||||
|
|
Loading…
Reference in New Issue