From 447b5bf316def4740d6d7d7ef43e8cc8dfb90a0f Mon Sep 17 00:00:00 2001 From: Ben Vanik Date: Sat, 13 Sep 2014 19:32:37 -0700 Subject: [PATCH] Fixing xex loading into 4k pages. --- src/xenia/cpu/xex_module.cc | 28 +++++++++++------------- src/xenia/kernel/objects/xuser_module.cc | 9 ++++---- src/xenia/kernel/util/xex2.cc | 2 ++ src/xenia/kernel/util/xex2_info.h | 5 ++--- src/xenia/memory.cc | 3 ++- src/xenia/memory.h | 3 ++- 6 files changed, 25 insertions(+), 25 deletions(-) diff --git a/src/xenia/cpu/xex_module.cc b/src/xenia/cpu/xex_module.cc index 9532ef16f..43ff90b83 100644 --- a/src/xenia/cpu/xex_module.cc +++ b/src/xenia/cpu/xex_module.cc @@ -52,10 +52,9 @@ int XexModule::Load(const std::string& name, const std::string& path, xe_xex2_re high_address_ = 0; for (size_t n = 0, i = 0; n < header->section_count; n++) { const xe_xex2_section_t* section = &header->sections[n]; - const size_t start_address = - header->exe_address + (i * xe_xex2_section_length); + const size_t start_address = header->exe_address + (i * section->page_size); const size_t end_address = - start_address + (section->info.page_count * xe_xex2_section_length); + start_address + (section->info.page_count * section->page_size); if (section->info.type == XEX_SECTION_CODE) { low_address_ = static_cast(std::min(low_address_, start_address)); @@ -391,25 +390,24 @@ int XexModule::FindSaveRest() { const xe_xex2_header_t* header = xe_xex2_get_header(xex_); for (size_t n = 0, i = 0; n < header->section_count; n++) { const xe_xex2_section_t* section = &header->sections[n]; - const size_t start_address = - header->exe_address + (i * xe_xex2_section_length); + const size_t start_address = header->exe_address + (i * section->page_size); const size_t end_address = - start_address + (section->info.page_count * xe_xex2_section_length); + start_address + (section->info.page_count * section->page_size); if (section->info.type == XEX_SECTION_CODE) { if (!gplr_start) { - gplr_start = memory_->SearchAligned( - start_address, end_address, - gprlr_code_values, poly::countof(gprlr_code_values)); + gplr_start = memory_->SearchAligned(start_address, end_address, + gprlr_code_values, + poly::countof(gprlr_code_values)); } if (!fpr_start) { - fpr_start = memory_->SearchAligned( - start_address, end_address, - fpr_code_values, poly::countof(fpr_code_values)); + fpr_start = + memory_->SearchAligned(start_address, end_address, fpr_code_values, + poly::countof(fpr_code_values)); } if (!vmx_start) { - vmx_start = memory_->SearchAligned( - start_address, end_address, - vmx_code_values, poly::countof(vmx_code_values)); + vmx_start = + memory_->SearchAligned(start_address, end_address, vmx_code_values, + poly::countof(vmx_code_values)); } if (gplr_start && fpr_start && vmx_start) { break; diff --git a/src/xenia/kernel/objects/xuser_module.cc b/src/xenia/kernel/objects/xuser_module.cc index ad6b9aa41..03ccd998b 100644 --- a/src/xenia/kernel/objects/xuser_module.cc +++ b/src/xenia/kernel/objects/xuser_module.cc @@ -233,13 +233,12 @@ void XUserModule::Dump() { type = "RODATA "; break; } - const size_t start_address = - header->exe_address + (i * xe_xex2_section_length); + const size_t start_address = header->exe_address + (i * section->page_size); const size_t end_address = - start_address + (section->info.page_count * xe_xex2_section_length); + start_address + (section->info.page_count * section->page_size); printf(" %3d %s %3d pages %.8X - %.8X (%d bytes)\n", (int)n, type, section->info.page_count, (int)start_address, (int)end_address, - section->info.page_count * xe_xex2_section_length); + section->info.page_count * section->page_size); i += section->info.page_count; } printf("\n"); @@ -292,7 +291,7 @@ void XUserModule::Dump() { unimpl_count++; } } - printf(" Total: %4zu\n", import_info_count); + printf(" Total: %4u\n", uint32_t(import_info_count)); printf(" Known: %3d%% (%d known, %d unknown)\n", (int)(known_count / (float)import_info_count * 100.0f), known_count, unknown_count); diff --git a/src/xenia/kernel/util/xex2.cc b/src/xenia/kernel/util/xex2.cc index b0a2526db..979706a82 100644 --- a/src/xenia/kernel/util/xex2.cc +++ b/src/xenia/kernel/util/xex2.cc @@ -399,6 +399,8 @@ int xe_xex2_read_header(const uint8_t *addr, const size_t length, XEEXPECTNOTNULL(header->sections); for (size_t n = 0; n < header->section_count; n++) { xe_xex2_section_t *section = &header->sections[n]; + section->page_size = + header->exe_address <= 0x90000000 ? 64 * 1024 : 4 * 1024; section->info.value = poly::load_and_swap(ps); ps += 4; memcpy(section->digest, ps, sizeof(section->digest)); diff --git a/src/xenia/kernel/util/xex2_info.h b/src/xenia/kernel/util/xex2_info.h index 16313a23c..6ebdb8674 100644 --- a/src/xenia/kernel/util/xex2_info.h +++ b/src/xenia/kernel/util/xex2_info.h @@ -410,18 +410,17 @@ typedef enum { } xe_xex2_section_type; typedef struct { + size_t page_size; union { struct { xe_xex2_section_type type : 4; - uint32_t page_count : 28; // # of 64kb pages + uint32_t page_count : 28; // # of pages }; uint32_t value; // To make uint8_t swapping easier } info; uint8_t digest[20]; } xe_xex2_section_t; -#define xe_xex2_section_length 0x00010000 - typedef struct { uint32_t xex2; xe_xex2_module_flags module_flags; diff --git a/src/xenia/memory.cc b/src/xenia/memory.cc index bd216231a..f87a8bb62 100644 --- a/src/xenia/memory.cc +++ b/src/xenia/memory.cc @@ -218,7 +218,8 @@ const static struct { } map_info[] = { 0x00000000, 0x3FFFFFFF, 0x00000000, // (1024mb) - virtual 4k pages 0x40000000, 0x7FFFFFFF, 0x40000000, // (1024mb) - virtual 64k pages - 0x80000000, 0x9FFFFFFF, 0x80000000, // (512mb) - xex pages + 0x80000000, 0x8FFFFFFF, 0x80000000, // (256mb) - xex 64k pages + 0x90000000, 0x9FFFFFFF, 0x80000000, // (256mb) - xex 4k pages 0xA0000000, 0xBFFFFFFF, 0x00000000, // (512mb) - physical 64k pages 0xC0000000, 0xDFFFFFFF, 0x00000000, // - physical 16mb pages 0xE0000000, 0xFFFFFFFF, 0x00000000, // - physical 4k pages diff --git a/src/xenia/memory.h b/src/xenia/memory.h index 91c87c6a9..4d102b797 100644 --- a/src/xenia/memory.h +++ b/src/xenia/memory.h @@ -87,11 +87,12 @@ class Memory : public alloy::Memory { uint8_t* v00000000; uint8_t* v40000000; uint8_t* v80000000; + uint8_t* v90000000; uint8_t* vA0000000; uint8_t* vC0000000; uint8_t* vE0000000; }; - uint8_t* all_views[6]; + uint8_t* all_views[7]; } views_; std::unique_ptr mmio_handler_;