Removing 64bit return type and cleaning up some SHIM* stuff pre-refactor.
This commit is contained in:
parent
0a83b49744
commit
a4edb7f9e1
|
@ -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))
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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_;
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
Loading…
Reference in New Issue