Removing 64bit return type and cleaning up some SHIM* stuff pre-refactor.

This commit is contained in:
Ben Vanik 2015-05-29 17:12:30 -07:00
parent 0a83b49744
commit a4edb7f9e1
11 changed files with 71 additions and 79 deletions

View File

@ -18,7 +18,7 @@ namespace kernel {
using PPCContext = xe::cpu::frontend::PPCContext; using PPCContext = xe::cpu::frontend::PPCContext;
#define SHIM_CALL void _cdecl #define SHIM_CALL void _cdecl
#define SHIM_SET_MAPPING(library_name, export_name, shim_data) \ #define SHIM_SET_MAPPING(library_name, export_name, shim_data) \
export_resolver->SetFunctionMapping( \ export_resolver->SetFunctionMapping( \
library_name, ordinals::##export_name, shim_data, \ library_name, ordinals::##export_name, shim_data, \
@ -35,22 +35,12 @@ using PPCContext = xe::cpu::frontend::PPCContext;
#define SHIM_SET_MEM_16(a, v) xe::store_and_swap<uint16_t>(SHIM_MEM_ADDR(a), v) #define SHIM_SET_MEM_16(a, v) xe::store_and_swap<uint16_t>(SHIM_MEM_ADDR(a), v)
#define SHIM_SET_MEM_32(a, v) xe::store_and_swap<uint32_t>(SHIM_MEM_ADDR(a), v) #define SHIM_SET_MEM_32(a, v) xe::store_and_swap<uint32_t>(SHIM_MEM_ADDR(a), v)
#define SHIM_SET_MEM_64(a, v) xe::store_and_swap<uint64_t>(SHIM_MEM_ADDR(a), v) #define SHIM_SET_MEM_64(a, v) xe::store_and_swap<uint64_t>(SHIM_MEM_ADDR(a), v)
#define SHIM_SET_MEM_F32(a, v) xe::store_and_swap<float>(SHIM_MEM_ADDR(a), v)
#define SHIM_SET_MEM_F64(a, v) xe::store_and_swap<double>(SHIM_MEM_ADDR(a), v)
#define SHIM_GPR_8(n) (uint8_t)(ppc_state->r[n]) #define SHIM_GET_ARG_8(n) (uint8_t)(ppc_state->r[3 + n])
#define SHIM_GPR_16(n) (uint16_t)(ppc_state->r[n]) #define SHIM_GET_ARG_16(n) (uint16_t)(ppc_state->r[3 + n])
#define SHIM_GPR_32(n) (uint32_t)(ppc_state->r[n]) #define SHIM_GET_ARG_32(n) (uint32_t)(ppc_state->r[3 + n])
#define SHIM_SET_GPR_32(n, v) ppc_state->r[n] = (uint64_t)((v) & UINT32_MAX) #define SHIM_GET_ARG_64(n) ppc_state->r[3 + n]
#define SHIM_GPR_64(n) ppc_state->r[n] #define SHIM_SET_RETURN_32(v) ppc_state->r[3] = (uint64_t)((int32_t)v)
#define SHIM_SET_GPR_64(n, v) ppc_state->r[n] = (uint64_t)(v)
#define SHIM_GET_ARG_8(n) SHIM_GPR_8(3 + n)
#define SHIM_GET_ARG_16(n) SHIM_GPR_16(3 + n)
#define SHIM_GET_ARG_32(n) SHIM_GPR_32(3 + n)
#define SHIM_GET_ARG_64(n) SHIM_GPR_64(3 + n)
#define SHIM_SET_RETURN_32(v) SHIM_SET_GPR_64(3, (uint64_t)(int32_t)v)
#define SHIM_SET_RETURN_64(v) SHIM_SET_GPR_64(3, v)
#define SHIM_STRUCT(type, address) \ #define SHIM_STRUCT(type, address) \
reinterpret_cast<type*>(SHIM_MEM_ADDR(address)) reinterpret_cast<type*>(SHIM_MEM_ADDR(address))

View File

@ -26,7 +26,7 @@ SHIM_CALL XamGetSystemVersion_shim(PPCContext* ppc_state, KernelState* state) {
// we pretend to be old we have less to worry with implementing. // we pretend to be old we have less to worry with implementing.
// 0x200A3200 // 0x200A3200
// 0x20096B00 // 0x20096B00
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
SHIM_CALL XGetAVPack_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL XGetAVPack_shim(PPCContext* ppc_state, KernelState* state) {
@ -35,13 +35,13 @@ SHIM_CALL XGetAVPack_shim(PPCContext* ppc_state, KernelState* state) {
// Other likely values are 3/4/8 for HDMI or something. // Other likely values are 3/4/8 for HDMI or something.
// Games seem to use this as a PAL check - if the result is not 3/4/6/8 // Games seem to use this as a PAL check - if the result is not 3/4/6/8
// they explode with errors if not in PAL mode. // they explode with errors if not in PAL mode.
SHIM_SET_RETURN_64(6); SHIM_SET_RETURN_32(6);
} }
SHIM_CALL XGetGameRegion_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL XGetGameRegion_shim(PPCContext* ppc_state, KernelState* state) {
XELOGD("XGetGameRegion()"); XELOGD("XGetGameRegion()");
SHIM_SET_RETURN_64(0xFFFF); SHIM_SET_RETURN_32(0xFFFF);
} }
SHIM_CALL XGetLanguage_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL XGetLanguage_shim(PPCContext* ppc_state, KernelState* state) {
@ -59,7 +59,7 @@ SHIM_CALL XGetLanguage_shim(PPCContext* ppc_state, KernelState* state) {
} }
// Add more overrides? // Add more overrides?
SHIM_SET_RETURN_64(desired_language); SHIM_SET_RETURN_32(desired_language);
} }
SHIM_CALL XamVoiceIsActiveProcess_shim(PPCContext* ppc_state, SHIM_CALL XamVoiceIsActiveProcess_shim(PPCContext* ppc_state,

View File

@ -26,7 +26,7 @@ SHIM_CALL XamResetInactivity_shim(PPCContext* ppc_state, KernelState* state) {
XELOGD("XamResetInactivity(%d)", unk); XELOGD("XamResetInactivity(%d)", unk);
// Result ignored. // Result ignored.
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
SHIM_CALL XamEnableInactivityProcessing_shim(PPCContext* ppc_state, SHIM_CALL XamEnableInactivityProcessing_shim(PPCContext* ppc_state,
@ -37,7 +37,7 @@ SHIM_CALL XamEnableInactivityProcessing_shim(PPCContext* ppc_state,
XELOGD("XamEnableInactivityProcessing(%d, %d)", zero, unk); XELOGD("XamEnableInactivityProcessing(%d, %d)", zero, unk);
// Expects 0. // Expects 0.
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
// http://msdn.microsoft.com/en-us/library/windows/desktop/microsoft.directx_sdk.reference.xinputgetcapabilities(v=vs.85).aspx // http://msdn.microsoft.com/en-us/library/windows/desktop/microsoft.directx_sdk.reference.xinputgetcapabilities(v=vs.85).aspx

View File

@ -32,7 +32,7 @@ SHIM_CALL XamNotifyCreateListener_shim(PPCContext* ppc_state,
// Handle ref is incremented, so return that. // Handle ref is incremented, so return that.
uint32_t handle = listener->handle(); uint32_t handle = listener->handle();
SHIM_SET_RETURN_64(handle); SHIM_SET_RETURN_32(handle);
} }
// http://ffplay360.googlecode.com/svn/Test/Common/AtgSignIn.cpp // http://ffplay360.googlecode.com/svn/Test/Common/AtgSignIn.cpp
@ -46,14 +46,14 @@ SHIM_CALL XNotifyGetNext_shim(PPCContext* ppc_state, KernelState* state) {
param_ptr); param_ptr);
if (!handle) { if (!handle) {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
// Grab listener. // Grab listener.
auto listener = state->object_table()->LookupObject<XNotifyListener>(handle); auto listener = state->object_table()->LookupObject<XNotifyListener>(handle);
if (!listener) { if (!listener) {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
@ -74,7 +74,7 @@ SHIM_CALL XNotifyGetNext_shim(PPCContext* ppc_state, KernelState* state) {
SHIM_SET_MEM_32(param_ptr, param); SHIM_SET_MEM_32(param_ptr, param);
} }
SHIM_SET_RETURN_64(dequeued ? 1 : 0); SHIM_SET_RETURN_32(dequeued ? 1 : 0);
} }
SHIM_CALL XNotifyDelayUI_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL XNotifyDelayUI_shim(PPCContext* ppc_state, KernelState* state) {

View File

@ -48,9 +48,9 @@ SHIM_CALL XamUserGetSigninState_shim(PPCContext* ppc_state,
if (user_index == 0 || (user_index & 0xFF) == 0xFF) { if (user_index == 0 || (user_index & 0xFF) == 0xFF) {
const auto& user_profile = state->user_profile(); const auto& user_profile = state->user_profile();
auto signin_state = user_profile->signin_state(); auto signin_state = user_profile->signin_state();
SHIM_SET_RETURN_64(signin_state); SHIM_SET_RETURN_32(signin_state);
} else { } else {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
} }

View File

@ -56,7 +56,7 @@ SHIM_CALL XAudioGetVoiceCategoryVolume_shim(PPCContext* ppc_state,
XELOGD("XAudioGetVoiceCategoryVolume(%.8X, %.8X)", unk, out_ptr); XELOGD("XAudioGetVoiceCategoryVolume(%.8X, %.8X)", unk, out_ptr);
// Expects a floating point single. Volume %? // Expects a floating point single. Volume %?
SHIM_SET_MEM_F32(out_ptr, 1.0f); xe::store_and_swap<float>(SHIM_MEM_ADDR(out_ptr), 1.0f);
SHIM_SET_RETURN_32(X_ERROR_SUCCESS); SHIM_SET_RETURN_32(X_ERROR_SUCCESS);
} }

View File

@ -17,11 +17,13 @@
namespace xe { namespace xe {
namespace kernel { namespace kernel {
#define SHIM_GPR_32(n) (uint32_t)(ppc_state->r[n])
// TODO: clean me up! // TODO: clean me up!
SHIM_CALL DbgPrint_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL DbgPrint_shim(PPCContext* ppc_state, KernelState* state) {
uint32_t format_ptr = SHIM_GET_ARG_32(0); uint32_t format_ptr = SHIM_GET_ARG_32(0);
if (format_ptr == 0) { if (format_ptr == 0) {
SHIM_SET_RETURN_64(-1); SHIM_SET_RETURN_32(-1);
return; return;
} }

View File

@ -321,7 +321,7 @@ SHIM_CALL MmAllocatePhysicalMemoryEx_shim(PPCContext* ppc_state,
} }
XELOGD("MmAllocatePhysicalMemoryEx = %.8X", base_address); XELOGD("MmAllocatePhysicalMemoryEx = %.8X", base_address);
SHIM_SET_RETURN_64(base_address); SHIM_SET_RETURN_32(base_address);
} }
SHIM_CALL MmFreePhysicalMemory_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL MmFreePhysicalMemory_shim(PPCContext* ppc_state, KernelState* state) {
@ -440,7 +440,7 @@ SHIM_CALL MmGetPhysicalAddress_shim(PPCContext* ppc_state, KernelState* state) {
physical_address += 0x1000; physical_address += 0x1000;
} }
SHIM_SET_RETURN_64(physical_address); SHIM_SET_RETURN_32(physical_address);
} }
SHIM_CALL MmMapIoSpace_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL MmMapIoSpace_shim(PPCContext* ppc_state, KernelState* state) {
@ -458,7 +458,7 @@ SHIM_CALL MmMapIoSpace_shim(PPCContext* ppc_state, KernelState* state) {
assert_true(size == 0x40); assert_true(size == 0x40);
assert_true(flags == 0x404); assert_true(flags == 0x404);
SHIM_SET_RETURN_64(src_address); SHIM_SET_RETURN_32(src_address);
} }
SHIM_CALL ExAllocatePoolTypeWithTag_shim(PPCContext* ppc_state, SHIM_CALL ExAllocatePoolTypeWithTag_shim(PPCContext* ppc_state,
@ -479,7 +479,7 @@ SHIM_CALL ExAllocatePoolTypeWithTag_shim(PPCContext* ppc_state,
uint32_t addr = state->memory()->SystemHeapAlloc(adjusted_size, alignment); uint32_t addr = state->memory()->SystemHeapAlloc(adjusted_size, alignment);
SHIM_SET_RETURN_64(addr); SHIM_SET_RETURN_32(addr);
} }
SHIM_CALL ExFreePool_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL ExFreePool_shim(PPCContext* ppc_state, KernelState* state) {

View File

@ -51,7 +51,7 @@ SHIM_CALL RtlCompareMemory_shim(PPCContext* ppc_state, KernelState* state) {
} }
} }
SHIM_SET_RETURN_64(c); SHIM_SET_RETURN_32(c);
} }
// http://msdn.microsoft.com/en-us/library/ff552123 // http://msdn.microsoft.com/en-us/library/ff552123
@ -69,7 +69,7 @@ SHIM_CALL RtlCompareMemoryUlong_shim(PPCContext* ppc_state,
// _In_ ULONG Pattern // _In_ ULONG Pattern
if ((source_ptr % 4) || (length % 4)) { if ((source_ptr % 4) || (length % 4)) {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
@ -89,7 +89,7 @@ SHIM_CALL RtlCompareMemoryUlong_shim(PPCContext* ppc_state,
} }
} }
SHIM_SET_RETURN_64(c); SHIM_SET_RETURN_32(c);
} }
// http://msdn.microsoft.com/en-us/library/ff552263 // http://msdn.microsoft.com/en-us/library/ff552263
@ -406,12 +406,12 @@ SHIM_CALL RtlImageXexHeaderField_shim(PPCContext* ppc_state,
for (size_t n = 0; n < xex_header->header_count; n++) { for (size_t n = 0; n < xex_header->header_count; n++) {
if (xex_header->headers[n].key == image_field) { if (xex_header->headers[n].key == image_field) {
uint32_t value = xex_header->headers[n].value; uint32_t value = xex_header->headers[n].value;
SHIM_SET_RETURN_64(value); SHIM_SET_RETURN_32(value);
return; return;
} }
} }
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
// Unfortunately the Windows RTL_CRITICAL_SECTION object is bigger than the one // Unfortunately the Windows RTL_CRITICAL_SECTION object is bigger than the one
@ -576,7 +576,7 @@ SHIM_CALL RtlTryEnterCriticalSection_shim(PPCContext* ppc_state,
++cs->recursion_count; ++cs->recursion_count;
result = 1; result = 1;
} }
SHIM_SET_RETURN_64(result); SHIM_SET_RETURN_32(result);
} }
SHIM_CALL RtlLeaveCriticalSection_shim(PPCContext* ppc_state, SHIM_CALL RtlLeaveCriticalSection_shim(PPCContext* ppc_state,
@ -646,13 +646,13 @@ SHIM_CALL RtlTimeFieldsToTime_shim(PPCContext* ppc_state, KernelState* state) {
FILETIME ft; FILETIME ft;
if (!SystemTimeToFileTime(&st, &ft)) { if (!SystemTimeToFileTime(&st, &ft)) {
// set last error = ERROR_INVALID_PARAMETER // set last error = ERROR_INVALID_PARAMETER
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
uint64_t time = (uint64_t(ft.dwHighDateTime) << 32) | ft.dwLowDateTime; uint64_t time = (uint64_t(ft.dwHighDateTime) << 32) | ft.dwLowDateTime;
SHIM_SET_MEM_64(time_ptr, time); SHIM_SET_MEM_64(time_ptr, time);
SHIM_SET_RETURN_64(1); SHIM_SET_RETURN_32(1);
} }
} // namespace kernel } // namespace kernel

View File

@ -293,7 +293,7 @@ SHIM_CALL KeGetCurrentProcessType_shim(PPCContext* ppc_state,
// DWORD // DWORD
SHIM_SET_RETURN_64(state->process_type()); SHIM_SET_RETURN_32(state->process_type());
} }
SHIM_CALL KeSetCurrentProcessType_shim(PPCContext* ppc_state, SHIM_CALL KeSetCurrentProcessType_shim(PPCContext* ppc_state,
@ -314,7 +314,7 @@ SHIM_CALL KeQueryPerformanceFrequency_shim(PPCContext* ppc_state,
// "KeQueryPerformanceFrequency()"); // "KeQueryPerformanceFrequency()");
uint64_t result = Clock::guest_tick_frequency(); uint64_t result = Clock::guest_tick_frequency();
SHIM_SET_RETURN_64(result); SHIM_SET_RETURN_32(result);
} }
SHIM_CALL KeDelayExecutionThread_shim(PPCContext* ppc_state, SHIM_CALL KeDelayExecutionThread_shim(PPCContext* ppc_state,
@ -338,7 +338,7 @@ SHIM_CALL NtYieldExecution_shim(PPCContext* ppc_state, KernelState* state) {
// XELOGD("NtYieldExecution()"); // XELOGD("NtYieldExecution()");
XThread* thread = XThread::GetCurrentThread(); XThread* thread = XThread::GetCurrentThread();
X_STATUS result = thread->Delay(0, 0, 0); X_STATUS result = thread->Delay(0, 0, 0);
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
SHIM_CALL KeQuerySystemTime_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL KeQuerySystemTime_shim(PPCContext* ppc_state, KernelState* state) {
@ -375,7 +375,7 @@ SHIM_CALL KeTlsAlloc_shim(PPCContext* ppc_state, KernelState* state) {
} }
#endif // WIN32 #endif // WIN32
SHIM_SET_RETURN_64(tls_index); SHIM_SET_RETURN_32(tls_index);
} }
// http://msdn.microsoft.com/en-us/library/ms686804 // http://msdn.microsoft.com/en-us/library/ms686804
@ -385,7 +385,7 @@ SHIM_CALL KeTlsFree_shim(PPCContext* ppc_state, KernelState* state) {
XELOGD("KeTlsFree(%.8X)", tls_index); XELOGD("KeTlsFree(%.8X)", tls_index);
if (tls_index == X_TLS_OUT_OF_INDEXES) { if (tls_index == X_TLS_OUT_OF_INDEXES) {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
@ -397,7 +397,7 @@ SHIM_CALL KeTlsFree_shim(PPCContext* ppc_state, KernelState* state) {
result = pthread_key_delete(tls_index) == 0; result = pthread_key_delete(tls_index) == 0;
#endif // WIN32 #endif // WIN32
SHIM_SET_RETURN_64(result); SHIM_SET_RETURN_32(result);
} }
// http://msdn.microsoft.com/en-us/library/ms686812 // http://msdn.microsoft.com/en-us/library/ms686812
@ -422,7 +422,7 @@ SHIM_CALL KeTlsGetValue_shim(PPCContext* ppc_state, KernelState* state) {
// TODO(benvanik): SetLastError // TODO(benvanik): SetLastError
} }
SHIM_SET_RETURN_64(value); SHIM_SET_RETURN_32(value);
} }
// http://msdn.microsoft.com/en-us/library/ms686818 // http://msdn.microsoft.com/en-us/library/ms686818
@ -441,7 +441,7 @@ SHIM_CALL KeTlsSetValue_shim(PPCContext* ppc_state, KernelState* state) {
result = pthread_setspecific(tls_index, (void*)tls_value) == 0; result = pthread_setspecific(tls_index, (void*)tls_value) == 0;
#endif // WIN32 #endif // WIN32
SHIM_SET_RETURN_64(result); SHIM_SET_RETURN_32(result);
} }
SHIM_CALL NtCreateEvent_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL NtCreateEvent_shim(PPCContext* ppc_state, KernelState* state) {
@ -482,12 +482,12 @@ SHIM_CALL KeSetEvent_shim(PPCContext* ppc_state, KernelState* state) {
auto ev = XObject::GetNativeObject<XEvent>(state, event_ptr); auto ev = XObject::GetNativeObject<XEvent>(state, event_ptr);
if (!ev) { if (!ev) {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
auto result = ev->Set(increment, !!wait); auto result = ev->Set(increment, !!wait);
SHIM_SET_RETURN_64(result); SHIM_SET_RETURN_32(result);
} }
SHIM_CALL NtSetEvent_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL NtSetEvent_shim(PPCContext* ppc_state, KernelState* state) {
@ -526,7 +526,7 @@ SHIM_CALL KePulseEvent_shim(PPCContext* ppc_state, KernelState* state) {
result = ev->Pulse(increment, !!wait); result = ev->Pulse(increment, !!wait);
} }
SHIM_SET_RETURN_64(result); SHIM_SET_RETURN_32(result);
} }
SHIM_CALL NtPulseEvent_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL NtPulseEvent_shim(PPCContext* ppc_state, KernelState* state) {
@ -558,12 +558,12 @@ SHIM_CALL KeResetEvent_shim(PPCContext* ppc_state, KernelState* state) {
void* event_ptr = SHIM_MEM_ADDR(event_ref); void* event_ptr = SHIM_MEM_ADDR(event_ref);
auto ev = XObject::GetNativeObject<XEvent>(state, event_ptr); auto ev = XObject::GetNativeObject<XEvent>(state, event_ptr);
if (!ev) { if (!ev) {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
auto result = ev->Reset(); auto result = ev->Reset();
SHIM_SET_RETURN_64(result); SHIM_SET_RETURN_32(result);
} }
SHIM_CALL NtClearEvent_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL NtClearEvent_shim(PPCContext* ppc_state, KernelState* state) {
@ -643,7 +643,7 @@ SHIM_CALL KeReleaseSemaphore_shim(PPCContext* ppc_state, KernelState* state) {
void* semaphore_ptr = SHIM_MEM_ADDR(semaphore_ref); void* semaphore_ptr = SHIM_MEM_ADDR(semaphore_ref);
auto sem = XObject::GetNativeObject<XSemaphore>(state, semaphore_ptr); auto sem = XObject::GetNativeObject<XSemaphore>(state, semaphore_ptr);
if (!sem) { if (!sem) {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
@ -651,7 +651,7 @@ SHIM_CALL KeReleaseSemaphore_shim(PPCContext* ppc_state, KernelState* state) {
// TODO(benvanik): wait? // TODO(benvanik): wait?
int32_t result = sem->ReleaseSemaphore(adjustment); int32_t result = sem->ReleaseSemaphore(adjustment);
SHIM_SET_RETURN_64(result); SHIM_SET_RETURN_32(result);
} }
SHIM_CALL NtReleaseSemaphore_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL NtReleaseSemaphore_shim(PPCContext* ppc_state, KernelState* state) {
@ -992,7 +992,7 @@ SHIM_CALL KfAcquireSpinLock_shim(PPCContext* ppc_state, KernelState* state) {
XThread* thread = XThread::GetCurrentThread(); XThread* thread = XThread::GetCurrentThread();
auto old_irql = thread->RaiseIrql(2); auto old_irql = thread->RaiseIrql(2);
SHIM_SET_RETURN_64(old_irql); SHIM_SET_RETURN_32(old_irql);
} }
SHIM_CALL KfReleaseSpinLock_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL KfReleaseSpinLock_shim(PPCContext* ppc_state, KernelState* state) {
@ -1133,7 +1133,7 @@ SHIM_CALL KeInsertQueueApc_shim(PPCContext* ppc_state, KernelState* state) {
auto thread = auto thread =
XObject::GetNativeObject<XThread>(state, SHIM_MEM_ADDR(thread_ptr)); XObject::GetNativeObject<XThread>(state, SHIM_MEM_ADDR(thread_ptr));
if (!thread) { if (!thread) {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
@ -1143,7 +1143,7 @@ SHIM_CALL KeInsertQueueApc_shim(PPCContext* ppc_state, KernelState* state) {
// Fail if already inserted. // Fail if already inserted.
if (SHIM_MEM_32(apc_ptr + 40) & 0xFF00) { if (SHIM_MEM_32(apc_ptr + 40) & 0xFF00) {
thread->UnlockApc(); thread->UnlockApc();
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
@ -1161,7 +1161,7 @@ SHIM_CALL KeInsertQueueApc_shim(PPCContext* ppc_state, KernelState* state) {
// Unlock thread. // Unlock thread.
thread->UnlockApc(); thread->UnlockApc();
SHIM_SET_RETURN_64(1); SHIM_SET_RETURN_32(1);
} }
SHIM_CALL KeRemoveQueueApc_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL KeRemoveQueueApc_shim(PPCContext* ppc_state, KernelState* state) {
@ -1175,7 +1175,7 @@ SHIM_CALL KeRemoveQueueApc_shim(PPCContext* ppc_state, KernelState* state) {
auto thread = auto thread =
XObject::GetNativeObject<XThread>(state, SHIM_MEM_ADDR(thread_ptr)); XObject::GetNativeObject<XThread>(state, SHIM_MEM_ADDR(thread_ptr));
if (!thread) { if (!thread) {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
@ -1183,7 +1183,7 @@ SHIM_CALL KeRemoveQueueApc_shim(PPCContext* ppc_state, KernelState* state) {
if (!(SHIM_MEM_32(apc_ptr + 40) & 0xFF00)) { if (!(SHIM_MEM_32(apc_ptr + 40) & 0xFF00)) {
thread->UnlockApc(); thread->UnlockApc();
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
return; return;
} }
@ -1196,7 +1196,7 @@ SHIM_CALL KeRemoveQueueApc_shim(PPCContext* ppc_state, KernelState* state) {
thread->UnlockApc(); thread->UnlockApc();
SHIM_SET_RETURN_64(result ? 1 : 0); SHIM_SET_RETURN_32(result ? 1 : 0);
} }
SHIM_CALL KiApcNormalRoutineNop_shim(PPCContext* ppc_state, SHIM_CALL KiApcNormalRoutineNop_shim(PPCContext* ppc_state,
@ -1206,7 +1206,7 @@ SHIM_CALL KiApcNormalRoutineNop_shim(PPCContext* ppc_state,
XELOGD("KiApcNormalRoutineNop(%.8X, %.8X)", unk0, unk1); XELOGD("KiApcNormalRoutineNop(%.8X, %.8X)", unk0, unk1);
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
SHIM_CALL KeInitializeDpc_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL KeInitializeDpc_shim(PPCContext* ppc_state, KernelState* state) {
@ -1248,7 +1248,7 @@ SHIM_CALL KeInsertQueueDpc_shim(PPCContext* ppc_state, KernelState* state) {
// If already in a queue, abort. // If already in a queue, abort.
if (dpc_list->IsQueued(list_entry_ptr)) { if (dpc_list->IsQueued(list_entry_ptr)) {
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
dispatcher->Unlock(); dispatcher->Unlock();
return; return;
} }
@ -1261,7 +1261,7 @@ SHIM_CALL KeInsertQueueDpc_shim(PPCContext* ppc_state, KernelState* state) {
dispatcher->Unlock(); dispatcher->Unlock();
SHIM_SET_RETURN_64(1); SHIM_SET_RETURN_32(1);
} }
SHIM_CALL KeRemoveQueueDpc_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL KeRemoveQueueDpc_shim(PPCContext* ppc_state, KernelState* state) {
@ -1284,7 +1284,7 @@ SHIM_CALL KeRemoveQueueDpc_shim(PPCContext* ppc_state, KernelState* state) {
dispatcher->Unlock(); dispatcher->Unlock();
SHIM_SET_RETURN_64(result ? 1 : 0); SHIM_SET_RETURN_32(result ? 1 : 0);
} }
xe::mutex global_list_mutex_; xe::mutex global_list_mutex_;

View File

@ -44,7 +44,7 @@ SHIM_CALL VdGetCurrentDisplayGamma_shim(PPCContext* ppc_state,
XELOGD("VdGetCurrentDisplayGamma(%.8X, %.8X)", arg0_ptr, arg1_ptr); XELOGD("VdGetCurrentDisplayGamma(%.8X, %.8X)", arg0_ptr, arg1_ptr);
SHIM_SET_MEM_32(arg0_ptr, 2); SHIM_SET_MEM_32(arg0_ptr, 2);
SHIM_SET_MEM_F32(arg1_ptr, 2.22222233f); xe::store_and_swap<float>(SHIM_MEM_ADDR(arg1_ptr), 2.22222233f);
} }
SHIM_CALL VdGetCurrentDisplayInformation_shim(PPCContext* ppc_state, SHIM_CALL VdGetCurrentDisplayInformation_shim(PPCContext* ppc_state,
@ -128,7 +128,7 @@ SHIM_CALL VdSetDisplayMode_shim(PPCContext* ppc_state, KernelState* state) {
// 40000000 // 40000000
XELOGD("VdSetDisplayMode(%.8X)", mode); XELOGD("VdSetDisplayMode(%.8X)", mode);
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
SHIM_CALL VdSetDisplayModeOverride_shim(PPCContext* ppc_state, SHIM_CALL VdSetDisplayModeOverride_shim(PPCContext* ppc_state,
@ -143,7 +143,7 @@ SHIM_CALL VdSetDisplayModeOverride_shim(PPCContext* ppc_state,
XELOGD("VdSetDisplayModeOverride(%.8X, %.8X, %g, %.8X, %.8X)", unk0, unk1, XELOGD("VdSetDisplayModeOverride(%.8X, %.8X, %g, %.8X, %.8X)", unk0, unk1,
refresh_rate, unk3, unk4); refresh_rate, unk3, unk4);
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
SHIM_CALL VdInitializeEngines_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL VdInitializeEngines_shim(PPCContext* ppc_state, KernelState* state) {
@ -177,7 +177,7 @@ SHIM_CALL VdGetGraphicsAsicID_shim(PPCContext* ppc_state, KernelState* state) {
// Games compare for < 0x10 and do VdInitializeEDRAM, else other // Games compare for < 0x10 and do VdInitializeEDRAM, else other
// (retrain/etc). // (retrain/etc).
SHIM_SET_RETURN_64(0x11); SHIM_SET_RETURN_32(0x11);
} }
SHIM_CALL VdEnableDisableClockGating_shim(PPCContext* ppc_state, SHIM_CALL VdEnableDisableClockGating_shim(PPCContext* ppc_state,
@ -188,7 +188,7 @@ SHIM_CALL VdEnableDisableClockGating_shim(PPCContext* ppc_state,
// Ignored, as it really doesn't matter. // Ignored, as it really doesn't matter.
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
SHIM_CALL VdSetGraphicsInterruptCallback_shim(PPCContext* ppc_state, SHIM_CALL VdSetGraphicsInterruptCallback_shim(PPCContext* ppc_state,
@ -326,7 +326,7 @@ SHIM_CALL VdInitializeScalerCommandBuffer_shim(PPCContext* ppc_state,
} }
// returns memcpy size >> 2 for memcpy(...,...,ret << 2) // returns memcpy size >> 2 for memcpy(...,...,ret << 2)
SHIM_SET_RETURN_64(total_words >> 2); SHIM_SET_RETURN_32(total_words >> 2);
} }
// We use these to shuffle data to VdSwap. // We use these to shuffle data to VdSwap.
@ -356,7 +356,7 @@ SHIM_CALL VdCallGraphicsNotificationRoutines_shim(PPCContext* ppc_state,
last_frontbuffer_width_ = fb_width; last_frontbuffer_width_ = fb_width;
last_frontbuffer_height_ = fb_height; last_frontbuffer_height_ = fb_height;
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
SHIM_CALL VdIsHSIOTrainingSucceeded_shim(PPCContext* ppc_state, SHIM_CALL VdIsHSIOTrainingSucceeded_shim(PPCContext* ppc_state,
@ -365,7 +365,7 @@ SHIM_CALL VdIsHSIOTrainingSucceeded_shim(PPCContext* ppc_state,
// Not really sure what this should be - code does weird stuff here: // Not really sure what this should be - code does weird stuff here:
// (cntlzw r11, r3 / extrwi r11, r11, 1, 26) // (cntlzw r11, r3 / extrwi r11, r11, 1, 26)
SHIM_SET_RETURN_64(1); SHIM_SET_RETURN_32(1);
} }
SHIM_CALL VdPersistDisplay_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL VdPersistDisplay_shim(PPCContext* ppc_state, KernelState* state) {
@ -385,7 +385,7 @@ SHIM_CALL VdPersistDisplay_shim(PPCContext* ppc_state, KernelState* state) {
} }
// ? // ?
SHIM_SET_RETURN_64(1); SHIM_SET_RETURN_32(1);
} }
SHIM_CALL VdRetrainEDRAMWorker_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL VdRetrainEDRAMWorker_shim(PPCContext* ppc_state, KernelState* state) {
@ -393,7 +393,7 @@ SHIM_CALL VdRetrainEDRAMWorker_shim(PPCContext* ppc_state, KernelState* state) {
XELOGD("VdRetrainEDRAMWorker(%.8X)", unk0); XELOGD("VdRetrainEDRAMWorker(%.8X)", unk0);
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
SHIM_CALL VdRetrainEDRAM_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL VdRetrainEDRAM_shim(PPCContext* ppc_state, KernelState* state) {
@ -407,7 +407,7 @@ SHIM_CALL VdRetrainEDRAM_shim(PPCContext* ppc_state, KernelState* state) {
XELOGD("VdRetrainEDRAM(%.8X, %.8X, %.8X, %.8X, %.8X, %.8X)", unk0, unk1, unk2, XELOGD("VdRetrainEDRAM(%.8X, %.8X, %.8X, %.8X, %.8X, %.8X)", unk0, unk1, unk2,
unk3, unk4, unk5); unk3, unk4, unk5);
SHIM_SET_RETURN_64(0); SHIM_SET_RETURN_32(0);
} }
SHIM_CALL VdSwap_shim(PPCContext* ppc_state, KernelState* state) { SHIM_CALL VdSwap_shim(PPCContext* ppc_state, KernelState* state) {