From f3552ff9a51b8f111242093fa5021b476fbf3671 Mon Sep 17 00:00:00 2001 From: Ben Vanik Date: Sat, 25 May 2013 00:08:01 -0700 Subject: [PATCH] Implementing RtlImageXexHeaderField better. --- .../kernel/modules/xboxkrnl/xboxkrnl_rtl.cc | 32 +++++++------------ 1 file changed, 12 insertions(+), 20 deletions(-) diff --git a/src/xenia/kernel/modules/xboxkrnl/xboxkrnl_rtl.cc b/src/xenia/kernel/modules/xboxkrnl/xboxkrnl_rtl.cc index 7e6af6cab..bae5ca45a 100644 --- a/src/xenia/kernel/modules/xboxkrnl/xboxkrnl_rtl.cc +++ b/src/xenia/kernel/modules/xboxkrnl/xboxkrnl_rtl.cc @@ -12,6 +12,7 @@ #include #include #include +#include #include @@ -276,29 +277,20 @@ SHIM_CALL RtlImageXexHeaderField_shim( return; } - // TODO(benvanik): pull from xex header - // module = GetExecutableModule() || (user defined one) - // header = module->xex_header() - // for (n = 0; n < header->header_count; n++) { - // if (header->headers[n].key == ImageField) { - // return value? or offset? - // } - // } + XModule* module = NULL; + + // TODO(benvanik): use xex_header_base to dereference this. + // Right now we are only concerned with games making this call on their main + // module, so this hack is fine. + module = state->GetExecutableModule(); uint32_t return_value = 0; - switch (image_field) { - case XEX_HEADER_DEFAULT_HEAP_SIZE: - // TODO(benvanik): pull from running module - // This is header->exe_heap_size. - //SHIM_SET_MEM_32(0x80101104, [some value]); - //return_value = 0x80101104; - return_value = 0; + const xe_xex2_header_t* xex_header = module->xex_header(); + for (size_t n = 0; n < xex_header->header_count; n++) { + if (xex_header->headers[n].key == image_field) { + return_value = xex_header->headers[n].value; break; - default: - XELOGE("RtlImageXexHeaderField header field %.8X NOT IMPLEMENTED", - image_field); - SHIM_SET_RETURN(0); - return; + } } SHIM_SET_RETURN(return_value);