Converting more kernel methods to the new style.

This commit is contained in:
Ben Vanik 2013-05-26 22:04:12 -07:00
parent 6e8828f843
commit b87b17f51e
8 changed files with 149 additions and 74 deletions

View File

@ -24,22 +24,32 @@ namespace kernel {
namespace xboxkrnl { namespace xboxkrnl {
SHIM_CALL HalReturnToFirmware_shim( void xeHalReturnToFirmware(uint32_t routine) {
xe_ppc_state_t* ppc_state, KernelState* state) { KernelState* state = shared_kernel_state_;
XEASSERTNOTNULL(state);
// void // void
// IN FIRMWARE_REENTRY Routine // IN FIRMWARE_REENTRY Routine
// Routine must be 1 'HalRebootRoutine' // Routine must be 1 'HalRebootRoutine'
XEASSERT(routine == 1);
// TODO(benvank): diediedie much more gracefully
// Not sure how to blast back up the stack in LLVM without exceptions, though.
XELOGE("Game requested shutdown via HalReturnToFirmware");
exit(0);
}
SHIM_CALL HalReturnToFirmware_shim(
xe_ppc_state_t* ppc_state, KernelState* state) {
uint32_t routine = SHIM_GET_ARG_32(0); uint32_t routine = SHIM_GET_ARG_32(0);
XELOGD( XELOGD(
"HalReturnToFirmware(%d)", "HalReturnToFirmware(%d)",
routine); routine);
// TODO(benvank): diediedie much more gracefully xeHalReturnToFirmware(routine);
// Not sure how to blast back up the stack in LLVM without exceptions, though.
XELOGE("Game requested shutdown via HalReturnToFirmware");
exit(0);
} }

View File

@ -21,6 +21,7 @@ namespace kernel {
namespace xboxkrnl { namespace xboxkrnl {
void xeHalReturnToFirmware(uint32_t routine);
} // namespace xboxkrnl } // namespace xboxkrnl

View File

@ -85,6 +85,7 @@ X_STATUS xeNtAllocateVirtualMemory(
return X_STATUS_SUCCESS; return X_STATUS_SUCCESS;
} }
// TODO(benvanik): remove state parameter. // TODO(benvanik): remove state parameter.
SHIM_CALL NtAllocateVirtualMemory_shim( SHIM_CALL NtAllocateVirtualMemory_shim(
xe_ppc_state_t* ppc_state, KernelState* state) { xe_ppc_state_t* ppc_state, KernelState* state) {
@ -113,6 +114,7 @@ SHIM_CALL NtAllocateVirtualMemory_shim(
SHIM_SET_RETURN(result); SHIM_SET_RETURN(result);
} }
X_STATUS xeNtFreeVirtualMemory( X_STATUS xeNtFreeVirtualMemory(
uint32_t* base_addr_ptr, uint32_t* region_size_ptr, uint32_t* base_addr_ptr, uint32_t* region_size_ptr,
uint32_t free_type, uint32_t unknown) { uint32_t free_type, uint32_t unknown) {
@ -145,6 +147,7 @@ X_STATUS xeNtFreeVirtualMemory(
return X_STATUS_SUCCESS; return X_STATUS_SUCCESS;
} }
SHIM_CALL NtFreeVirtualMemory_shim( SHIM_CALL NtFreeVirtualMemory_shim(
xe_ppc_state_t* ppc_state, KernelState* state) { xe_ppc_state_t* ppc_state, KernelState* state) {
uint32_t base_addr_ptr = SHIM_GET_ARG_32(0); uint32_t base_addr_ptr = SHIM_GET_ARG_32(0);

View File

@ -33,25 +33,20 @@ namespace xboxkrnl {
// } // }
SHIM_CALL XexCheckExecutablePrivilege_shim( int xeXexCheckExecutablePriviledge(uint32_t privilege) {
xe_ppc_state_t* ppc_state, KernelState* state) { KernelState* state = shared_kernel_state_;
XEASSERTNOTNULL(state);
// BOOL // BOOL
// DWORD Privilege // DWORD Privilege
uint32_t privilege = SHIM_GET_ARG_32(0);
XELOGD(
"XexCheckExecutablePrivilege(%.8X)",
privilege);
// Privilege is bit position in xe_xex2_system_flags enum - so: // Privilege is bit position in xe_xex2_system_flags enum - so:
// Privilege=6 -> 0x00000040 -> XEX_SYSTEM_INSECURE_SOCKETS // Privilege=6 -> 0x00000040 -> XEX_SYSTEM_INSECURE_SOCKETS
uint32_t mask = 1 << privilege; uint32_t mask = 1 << privilege;
XModule* module = state->GetExecutableModule(); XModule* module = state->GetExecutableModule();
if (!module) { if (!module) {
SHIM_SET_RETURN(0); return 0;
return;
} }
xe_xex2_ref xex = module->xex(); xe_xex2_ref xex = module->xex();
@ -61,16 +56,49 @@ SHIM_CALL XexCheckExecutablePrivilege_shim(
xe_xex2_release(xex); xe_xex2_release(xex);
module->Release(); module->Release();
return result;
}
SHIM_CALL XexCheckExecutablePrivilege_shim(
xe_ppc_state_t* ppc_state, KernelState* state) {
uint32_t privilege = SHIM_GET_ARG_32(0);
XELOGD(
"XexCheckExecutablePrivilege(%.8X)",
privilege);
int result = xeXexCheckExecutablePriviledge(privilege);
SHIM_SET_RETURN(result); SHIM_SET_RETURN(result);
} }
int xeXexGetModuleHandle(const char* module_name,
X_HANDLE* module_handle_ptr) {
KernelState* state = shared_kernel_state_;
XEASSERTNOTNULL(state);
// BOOL
// LPCSZ ModuleName
// LPHMODULE ModuleHandle
XModule* module = state->GetModule(module_name);
if (!module) {
return 0;
}
// NOTE: we don't retain the handle for return.
*module_handle_ptr = module->handle();
module->Release();
return 1;
}
SHIM_CALL XexGetModuleHandle_shim( SHIM_CALL XexGetModuleHandle_shim(
xe_ppc_state_t* ppc_state, KernelState* state) { xe_ppc_state_t* ppc_state, KernelState* state) {
// BOOL
// LPCSZ ModuleName
// LPHMODULE ModuleHandle
uint32_t module_name_ptr = SHIM_GET_ARG_32(0); uint32_t module_name_ptr = SHIM_GET_ARG_32(0);
const char* module_name = (const char*)SHIM_MEM_ADDR(module_name_ptr); const char* module_name = (const char*)SHIM_MEM_ADDR(module_name_ptr);
uint32_t module_handle_ptr = SHIM_GET_ARG_32(1); uint32_t module_handle_ptr = SHIM_GET_ARG_32(1);
@ -79,17 +107,13 @@ SHIM_CALL XexGetModuleHandle_shim(
"XexGetModuleHandle(%s, %.8X)", "XexGetModuleHandle(%s, %.8X)",
module_name, module_handle_ptr); module_name, module_handle_ptr);
XModule* module = state->GetModule(module_name); X_HANDLE module_handle = 0;
if (!module) { int result = xeXexGetModuleHandle(module_name, &module_handle);
SHIM_SET_RETURN(0); if (result) {
return; SHIM_SET_MEM_32(module_handle_ptr, module_handle);
} }
// NOTE: we don't retain the handle for return. SHIM_SET_RETURN(result);
SHIM_SET_MEM_32(module_handle_ptr, module->handle());
SHIM_SET_RETURN(1);
module->Release();
} }

View File

@ -21,7 +21,10 @@ namespace kernel {
namespace xboxkrnl { namespace xboxkrnl {
int xeXexCheckExecutablePriviledge(uint32_t privilege);
int xeXexGetModuleHandle(const char* module_name,
X_HANDLE* module_handle_ptr);
} // namespace xboxkrnl } // namespace xboxkrnl

View File

@ -28,23 +28,18 @@ namespace xboxkrnl {
// http://msdn.microsoft.com/en-us/library/ff561778 // http://msdn.microsoft.com/en-us/library/ff561778
SHIM_CALL RtlCompareMemory_shim( uint32_t xeRtlCompareMemory(uint32_t source1_ptr, uint32_t source2_ptr,
xe_ppc_state_t* ppc_state, KernelState* state) { uint32_t length) {
KernelState* state = shared_kernel_state_;
XEASSERTNOTNULL(state);
// SIZE_T // SIZE_T
// _In_ const VOID *Source1, // _In_ const VOID *Source1,
// _In_ const VOID *Source2, // _In_ const VOID *Source2,
// _In_ SIZE_T Length // _In_ SIZE_T Length
uint32_t source1 = SHIM_GET_ARG_32(0); uint8_t* p1 = IMPL_MEM_ADDR(source1_ptr);
uint32_t source2 = SHIM_GET_ARG_32(1); uint8_t* p2 = IMPL_MEM_ADDR(source2_ptr);
uint32_t length = SHIM_GET_ARG_32(2);
XELOGD(
"RtlCompareMemory(%.8X, %.8X, %d)",
source1, source2, length);
uint8_t* p1 = SHIM_MEM_ADDR(source1);
uint8_t* p2 = SHIM_MEM_ADDR(source2);
// Note that the return value is the number of bytes that match, so it's best // Note that the return value is the number of bytes that match, so it's best
// we just do this ourselves vs. using memcmp. // we just do this ourselves vs. using memcmp.
@ -57,31 +52,41 @@ SHIM_CALL RtlCompareMemory_shim(
} }
} }
SHIM_SET_RETURN(c); return c;
} }
// http://msdn.microsoft.com/en-us/library/ff552123
SHIM_CALL RtlCompareMemoryUlong_shim( SHIM_CALL RtlCompareMemory_shim(
xe_ppc_state_t* ppc_state, KernelState* state) { xe_ppc_state_t* ppc_state, KernelState* state) {
uint32_t source1 = SHIM_GET_ARG_32(0);
uint32_t source2 = SHIM_GET_ARG_32(1);
uint32_t length = SHIM_GET_ARG_32(2);
XELOGD(
"RtlCompareMemory(%.8X, %.8X, %d)",
source1, source2, length);
uint32_t result = xeRtlCompareMemory(source1, source2, length);
SHIM_SET_RETURN(result);
}
// http://msdn.microsoft.com/en-us/library/ff552123
uint32_t xeRtlCompareMemoryUlong(uint32_t source_ptr, uint32_t length,
uint32_t pattern) {
KernelState* state = shared_kernel_state_;
XEASSERTNOTNULL(state);
// SIZE_T // SIZE_T
// _In_ PVOID Source, // _In_ PVOID Source,
// _In_ SIZE_T Length, // _In_ SIZE_T Length,
// _In_ ULONG Pattern // _In_ ULONG Pattern
uint32_t source = SHIM_GET_ARG_32(0); if ((source_ptr % 4) || (length % 4)) {
uint32_t length = SHIM_GET_ARG_32(1); return 0;
uint32_t pattern = SHIM_GET_ARG_32(2);
XELOGD(
"RtlCompareMemoryUlong(%.8X, %d, %.8X)",
source, length, pattern);
if ((source % 4) || (length % 4)) {
SHIM_SET_RETURN(0);
return;
} }
uint8_t* p = SHIM_MEM_ADDR(source); uint8_t* p = IMPL_MEM_ADDR(source_ptr);
// Swap pattern. // Swap pattern.
// TODO(benvanik): ensure byte order of pattern is correct. // TODO(benvanik): ensure byte order of pattern is correct.
@ -97,17 +102,50 @@ SHIM_CALL RtlCompareMemoryUlong_shim(
} }
} }
SHIM_SET_RETURN(c); return c;
} }
// http://msdn.microsoft.com/en-us/library/ff552263
SHIM_CALL RtlFillMemoryUlong_shim( SHIM_CALL RtlCompareMemoryUlong_shim(
xe_ppc_state_t* ppc_state, KernelState* state) { xe_ppc_state_t* ppc_state, KernelState* state) {
uint32_t source = SHIM_GET_ARG_32(0);
uint32_t length = SHIM_GET_ARG_32(1);
uint32_t pattern = SHIM_GET_ARG_32(2);
XELOGD(
"RtlCompareMemoryUlong(%.8X, %d, %.8X)",
source, length, pattern);
uint32_t result = xeRtlCompareMemoryUlong(source, length, pattern);
SHIM_SET_RETURN(result);
}
// http://msdn.microsoft.com/en-us/library/ff552263
void xeRtlFillMemoryUlong(uint32_t destination_ptr, uint32_t length,
uint32_t pattern) {
KernelState* state = shared_kernel_state_;
XEASSERTNOTNULL(state);
// VOID // VOID
// _Out_ PVOID Destination, // _Out_ PVOID Destination,
// _In_ SIZE_T Length, // _In_ SIZE_T Length,
// _In_ ULONG Pattern // _In_ ULONG Pattern
// NOTE: length must be % 4, so we can work on uint32s.
uint32_t* p = (uint32_t*)IMPL_MEM_ADDR(destination_ptr);
// TODO(benvanik): ensure byte order is correct - we're writing back the
// swapped arg value.
for (uint32_t n = 0; n < length / 4; n++, p++) {
*p = pattern;
}
}
SHIM_CALL RtlFillMemoryUlong_shim(
xe_ppc_state_t* ppc_state, KernelState* state) {
uint32_t destination = SHIM_GET_ARG_32(0); uint32_t destination = SHIM_GET_ARG_32(0);
uint32_t length = SHIM_GET_ARG_32(1); uint32_t length = SHIM_GET_ARG_32(1);
uint32_t pattern = SHIM_GET_ARG_32(2); uint32_t pattern = SHIM_GET_ARG_32(2);
@ -116,15 +154,7 @@ SHIM_CALL RtlFillMemoryUlong_shim(
"RtlFillMemoryUlong(%.8X, %d, %.8X)", "RtlFillMemoryUlong(%.8X, %d, %.8X)",
destination, length, pattern); destination, length, pattern);
// NOTE: length must be % 4, so we can work on uint32s. xeRtlFillMemoryUlong(destination, length, pattern);
uint32_t* p = (uint32_t*)SHIM_MEM_ADDR(destination);
// TODO(benvanik): ensure byte order is correct - we're writing back the
// swapped arg value.
for (uint32_t n = 0; n < length / 4; n++, p++) {
*p = pattern;
}
} }

View File

@ -21,7 +21,14 @@ namespace kernel {
namespace xboxkrnl { namespace xboxkrnl {
uint32_t xeRtlCompareMemory(uint32_t source1_ptr, uint32_t source2_ptr,
uint32_t length);
uint32_t xeRtlCompareMemoryUlong(uint32_t source_ptr, uint32_t length,
uint32_t pattern);
void xeRtlFillMemoryUlong(uint32_t destination_ptr, uint32_t length,
uint32_t pattern);
} // namespace xboxkrnl } // namespace xboxkrnl

View File

@ -29,12 +29,6 @@ namespace kernel {
shim_data, \ shim_data, \
(xe_kernel_export_shim_fn)export_name##_shim, \ (xe_kernel_export_shim_fn)export_name##_shim, \
NULL); NULL);
#define SHIM_SET_MAPPING_WITH_IMPL(library_name, export_name, shim_data) \
export_resolver->SetFunctionMapping( \
library_name, ordinals::##export_name, \
shim_data, \
(xe_kernel_export_shim_fn)export_name##_shim, \
(xe_kernel_export_impl_fn)export_name##_impl);
#define SHIM_MEM_ADDR(a) (ppc_state->membase + a) #define SHIM_MEM_ADDR(a) (ppc_state->membase + a)
@ -53,6 +47,9 @@ namespace kernel {
#define SHIM_SET_RETURN(v) SHIM_SET_GPR_64(3, v) #define SHIM_SET_RETURN(v) SHIM_SET_GPR_64(3, v)
#define IMPL_MEM_ADDR(a) xe_memory_addr(state->memory(), a)
} // namespace kernel } // namespace kernel
} // namespace xe } // namespace xe