Finishing off the kernel method conversion.
This commit is contained in:
parent
64eb2aa2b3
commit
fe6df31280
|
@ -58,8 +58,13 @@ namespace xboxkrnl {
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
|
||||||
SHIM_CALL ExCreateThread_shim(
|
X_STATUS xeExCreateThread(
|
||||||
xe_ppc_state_t* ppc_state, KernelState* state) {
|
uint32_t* handle_ptr, uint32_t stack_size, uint32_t* thread_id_ptr,
|
||||||
|
uint32_t xapi_thread_startup,
|
||||||
|
uint32_t start_address, uint32_t start_context, uint32_t creation_flags) {
|
||||||
|
KernelState* state = shared_kernel_state_;
|
||||||
|
XEASSERTNOTNULL(state);
|
||||||
|
|
||||||
// DWORD
|
// DWORD
|
||||||
// LPHANDLE Handle,
|
// LPHANDLE Handle,
|
||||||
// DWORD StackSize,
|
// DWORD StackSize,
|
||||||
|
@ -69,6 +74,30 @@ SHIM_CALL ExCreateThread_shim(
|
||||||
// LPVOID StartContext,
|
// LPVOID StartContext,
|
||||||
// DWORD CreationFlags // 0x80?
|
// DWORD CreationFlags // 0x80?
|
||||||
|
|
||||||
|
XThread* thread = new XThread(
|
||||||
|
state, stack_size, xapi_thread_startup, start_address, start_context,
|
||||||
|
creation_flags);
|
||||||
|
|
||||||
|
X_STATUS result_code = thread->Create();
|
||||||
|
if (XFAILED(result_code)) {
|
||||||
|
// Failed!
|
||||||
|
thread->Release();
|
||||||
|
XELOGE("Thread creation failed: %.8X", result_code);
|
||||||
|
return result_code;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (handle_ptr) {
|
||||||
|
*handle_ptr = thread->handle();
|
||||||
|
}
|
||||||
|
if (thread_id_ptr) {
|
||||||
|
*thread_id_ptr = thread->thread_id();
|
||||||
|
}
|
||||||
|
return result_code;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
SHIM_CALL ExCreateThread_shim(
|
||||||
|
xe_ppc_state_t* ppc_state, KernelState* state) {
|
||||||
uint32_t handle_ptr = SHIM_GET_ARG_32(0);
|
uint32_t handle_ptr = SHIM_GET_ARG_32(0);
|
||||||
uint32_t stack_size = SHIM_GET_ARG_32(1);
|
uint32_t stack_size = SHIM_GET_ARG_32(1);
|
||||||
uint32_t thread_id_ptr = SHIM_GET_ARG_32(2);
|
uint32_t thread_id_ptr = SHIM_GET_ARG_32(2);
|
||||||
|
@ -87,37 +116,44 @@ SHIM_CALL ExCreateThread_shim(
|
||||||
start_context,
|
start_context,
|
||||||
creation_flags);
|
creation_flags);
|
||||||
|
|
||||||
XThread* thread = new XThread(
|
uint32_t handle;
|
||||||
state, stack_size, xapi_thread_startup, start_address, start_context,
|
uint32_t thread_id;
|
||||||
creation_flags);
|
X_STATUS result = xeExCreateThread(
|
||||||
|
&handle, stack_size, &thread_id, xapi_thread_startup,
|
||||||
|
start_address, start_context, creation_flags);
|
||||||
|
|
||||||
X_STATUS result_code = thread->Create();
|
if (XSUCCEEDED(result)) {
|
||||||
if (XFAILED(result_code)) {
|
if (handle_ptr) {
|
||||||
// Failed!
|
SHIM_SET_MEM_32(handle_ptr, handle);
|
||||||
thread->Release();
|
}
|
||||||
XELOGE("Thread creation failed: %.8X", result_code);
|
if (thread_id_ptr) {
|
||||||
SHIM_SET_RETURN(result_code);
|
SHIM_SET_MEM_32(thread_id_ptr, thread_id);
|
||||||
return;
|
}
|
||||||
}
|
}
|
||||||
|
SHIM_SET_RETURN(result);
|
||||||
if (handle_ptr) {
|
|
||||||
SHIM_SET_MEM_32(handle_ptr, thread->handle());
|
|
||||||
}
|
|
||||||
if (thread_id_ptr) {
|
|
||||||
SHIM_SET_MEM_32(thread_id_ptr, thread->thread_id());
|
|
||||||
}
|
|
||||||
SHIM_SET_RETURN(result_code);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
SHIM_CALL KeGetCurrentProcessType_shim(
|
uint32_t xeKeGetCurrentProcessType() {
|
||||||
xe_ppc_state_t* ppc_state, KernelState* state) {
|
KernelState* state = shared_kernel_state_;
|
||||||
|
XEASSERTNOTNULL(state);
|
||||||
|
|
||||||
// DWORD
|
// DWORD
|
||||||
|
|
||||||
XELOGD(
|
XELOGD(
|
||||||
"KeGetCurrentProcessType()");
|
"KeGetCurrentProcessType()");
|
||||||
|
|
||||||
SHIM_SET_RETURN(X_PROCTYPE_USER);
|
return X_PROCTYPE_USER;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
SHIM_CALL KeGetCurrentProcessType_shim(
|
||||||
|
xe_ppc_state_t* ppc_state, KernelState* state) {
|
||||||
|
XELOGD(
|
||||||
|
"KeGetCurrentProcessType()");
|
||||||
|
|
||||||
|
int result = xeKeGetCurrentProcessType();
|
||||||
|
SHIM_SET_RETURN(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -128,12 +164,11 @@ SHIM_CALL KeGetCurrentProcessType_shim(
|
||||||
|
|
||||||
|
|
||||||
// http://msdn.microsoft.com/en-us/library/ms686801
|
// http://msdn.microsoft.com/en-us/library/ms686801
|
||||||
SHIM_CALL KeTlsAlloc_shim(
|
uint32_t xeKeTlsAlloc() {
|
||||||
xe_ppc_state_t* ppc_state, KernelState* state) {
|
KernelState* state = shared_kernel_state_;
|
||||||
// DWORD
|
XEASSERTNOTNULL(state);
|
||||||
|
|
||||||
XELOGD(
|
// DWORD
|
||||||
"KeTlsAlloc()");
|
|
||||||
|
|
||||||
uint32_t tls_index;
|
uint32_t tls_index;
|
||||||
|
|
||||||
|
@ -148,25 +183,30 @@ SHIM_CALL KeTlsAlloc_shim(
|
||||||
}
|
}
|
||||||
#endif // WIN32
|
#endif // WIN32
|
||||||
|
|
||||||
SHIM_SET_RETURN(tls_index);
|
return tls_index;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
SHIM_CALL KeTlsAlloc_shim(
|
||||||
|
xe_ppc_state_t* ppc_state, KernelState* state) {
|
||||||
|
XELOGD(
|
||||||
|
"KeTlsAlloc()");
|
||||||
|
|
||||||
|
uint32_t result = xeKeTlsAlloc();
|
||||||
|
SHIM_SET_RETURN(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// http://msdn.microsoft.com/en-us/library/ms686804
|
// http://msdn.microsoft.com/en-us/library/ms686804
|
||||||
SHIM_CALL KeTlsFree_shim(
|
int KeTlsFree(uint32_t tls_index) {
|
||||||
xe_ppc_state_t* ppc_state, KernelState* state) {
|
KernelState* state = shared_kernel_state_;
|
||||||
|
XEASSERTNOTNULL(state);
|
||||||
|
|
||||||
// BOOL
|
// BOOL
|
||||||
// _In_ DWORD dwTlsIndex
|
// _In_ DWORD dwTlsIndex
|
||||||
|
|
||||||
uint32_t tls_index = SHIM_GET_ARG_32(0);
|
|
||||||
|
|
||||||
XELOGD(
|
|
||||||
"KeTlsFree(%.8X)",
|
|
||||||
tls_index);
|
|
||||||
|
|
||||||
if (tls_index == X_TLS_OUT_OF_INDEXES) {
|
if (tls_index == X_TLS_OUT_OF_INDEXES) {
|
||||||
SHIM_SET_RETURN(0);
|
return 0;
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int result_code = 0;
|
int result_code = 0;
|
||||||
|
@ -177,22 +217,31 @@ SHIM_CALL KeTlsFree_shim(
|
||||||
result_code = pthread_key_delete(tls_index) == 0;
|
result_code = pthread_key_delete(tls_index) == 0;
|
||||||
#endif // WIN32
|
#endif // WIN32
|
||||||
|
|
||||||
SHIM_SET_RETURN(result_code);
|
return result_code;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
SHIM_CALL KeTlsFree_shim(
|
||||||
|
xe_ppc_state_t* ppc_state, KernelState* state) {
|
||||||
|
uint32_t tls_index = SHIM_GET_ARG_32(0);
|
||||||
|
|
||||||
|
XELOGD(
|
||||||
|
"KeTlsFree(%.8X)",
|
||||||
|
tls_index);
|
||||||
|
|
||||||
|
int result = xeKeTlsAlloc();
|
||||||
|
SHIM_SET_RETURN(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// http://msdn.microsoft.com/en-us/library/ms686812
|
// http://msdn.microsoft.com/en-us/library/ms686812
|
||||||
SHIM_CALL KeTlsGetValue_shim(
|
uint32_t xeKeTlsGetValue(uint32_t tls_index) {
|
||||||
xe_ppc_state_t* ppc_state, KernelState* state) {
|
KernelState* state = shared_kernel_state_;
|
||||||
|
XEASSERTNOTNULL(state);
|
||||||
|
|
||||||
// LPVOID
|
// LPVOID
|
||||||
// _In_ DWORD dwTlsIndex
|
// _In_ DWORD dwTlsIndex
|
||||||
|
|
||||||
uint32_t tls_index = SHIM_GET_ARG_32(0);
|
|
||||||
|
|
||||||
XELOGD(
|
|
||||||
"KeTlsGetValue(%.8X)",
|
|
||||||
tls_index);
|
|
||||||
|
|
||||||
uint32_t value = 0;
|
uint32_t value = 0;
|
||||||
|
|
||||||
#if XE_PLATFORM(WIN32)
|
#if XE_PLATFORM(WIN32)
|
||||||
|
@ -206,24 +255,32 @@ SHIM_CALL KeTlsGetValue_shim(
|
||||||
// TODO(benvanik): SetLastError
|
// TODO(benvanik): SetLastError
|
||||||
}
|
}
|
||||||
|
|
||||||
SHIM_SET_RETURN(value);
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
SHIM_CALL KeTlsGetValue_shim(
|
||||||
|
xe_ppc_state_t* ppc_state, KernelState* state) {
|
||||||
|
uint32_t tls_index = SHIM_GET_ARG_32(0);
|
||||||
|
|
||||||
|
XELOGD(
|
||||||
|
"KeTlsGetValue(%.8X)",
|
||||||
|
tls_index);
|
||||||
|
|
||||||
|
uint32_t result = xeKeTlsGetValue(tls_index);
|
||||||
|
SHIM_SET_RETURN(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// http://msdn.microsoft.com/en-us/library/ms686818
|
// http://msdn.microsoft.com/en-us/library/ms686818
|
||||||
SHIM_CALL KeTlsSetValue_shim(
|
int xeKeTlsSetValue(uint32_t tls_index, uint32_t tls_value) {
|
||||||
xe_ppc_state_t* ppc_state, KernelState* state) {
|
KernelState* state = shared_kernel_state_;
|
||||||
|
XEASSERTNOTNULL(state);
|
||||||
|
|
||||||
// BOOL
|
// BOOL
|
||||||
// _In_ DWORD dwTlsIndex,
|
// _In_ DWORD dwTlsIndex,
|
||||||
// _In_opt_ LPVOID lpTlsValue
|
// _In_opt_ LPVOID lpTlsValue
|
||||||
|
|
||||||
uint32_t tls_index = SHIM_GET_ARG_32(0);
|
|
||||||
uint32_t tls_value = SHIM_GET_ARG_32(1);
|
|
||||||
|
|
||||||
XELOGD(
|
|
||||||
"KeTlsSetValue(%.8X, %.8X)",
|
|
||||||
tls_index, tls_value);
|
|
||||||
|
|
||||||
int result_code = 0;
|
int result_code = 0;
|
||||||
|
|
||||||
#if XE_PLATFORM(WIN32)
|
#if XE_PLATFORM(WIN32)
|
||||||
|
@ -232,7 +289,21 @@ SHIM_CALL KeTlsSetValue_shim(
|
||||||
result_code = pthread_setspecific(tls_index, (void*)tls_value) == 0;
|
result_code = pthread_setspecific(tls_index, (void*)tls_value) == 0;
|
||||||
#endif // WIN32
|
#endif // WIN32
|
||||||
|
|
||||||
SHIM_SET_RETURN(result_code);
|
return result_code;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
SHIM_CALL KeTlsSetValue_shim(
|
||||||
|
xe_ppc_state_t* ppc_state, KernelState* state) {
|
||||||
|
uint32_t tls_index = SHIM_GET_ARG_32(0);
|
||||||
|
uint32_t tls_value = SHIM_GET_ARG_32(1);
|
||||||
|
|
||||||
|
XELOGD(
|
||||||
|
"KeTlsSetValue(%.8X, %.8X)",
|
||||||
|
tls_index, tls_value);
|
||||||
|
|
||||||
|
int result = xeKeTlsSetValue(tls_index, tls_value);
|
||||||
|
SHIM_SET_RETURN(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,17 @@ namespace kernel {
|
||||||
namespace xboxkrnl {
|
namespace xboxkrnl {
|
||||||
|
|
||||||
|
|
||||||
|
X_STATUS xeExCreateThread(
|
||||||
|
uint32_t* handle_ptr, uint32_t stack_size, uint32_t* thread_id_ptr,
|
||||||
|
uint32_t xapi_thread_startup,
|
||||||
|
uint32_t start_address, uint32_t start_context, uint32_t creation_flags);
|
||||||
|
|
||||||
|
uint32_t xeKeGetCurrentProcessType();
|
||||||
|
|
||||||
|
uint32_t xeKeTlsAlloc();
|
||||||
|
int KeTlsFree(uint32_t tls_index);
|
||||||
|
uint32_t xeKeTlsGetValue(uint32_t tls_index);
|
||||||
|
int xeKeTlsSetValue(uint32_t tls_index, uint32_t tls_value);
|
||||||
|
|
||||||
|
|
||||||
} // namespace xboxkrnl
|
} // namespace xboxkrnl
|
||||||
|
|
|
@ -30,7 +30,7 @@ namespace kernel {
|
||||||
(xe_kernel_export_shim_fn)export_name##_shim, \
|
(xe_kernel_export_shim_fn)export_name##_shim, \
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
#define SHIM_MEM_ADDR(a) (a==NULL?NULL:(ppc_state->membase + a))
|
#define SHIM_MEM_ADDR(a) (a ? (ppc_state->membase + a) : NULL)
|
||||||
|
|
||||||
#define SHIM_MEM_16(a) (uint16_t)XEGETUINT16BE(SHIM_MEM_ADDR(a));
|
#define SHIM_MEM_16(a) (uint16_t)XEGETUINT16BE(SHIM_MEM_ADDR(a));
|
||||||
#define SHIM_MEM_32(a) (uint32_t)XEGETUINT32BE(SHIM_MEM_ADDR(a));
|
#define SHIM_MEM_32(a) (uint32_t)XEGETUINT32BE(SHIM_MEM_ADDR(a));
|
||||||
|
@ -47,7 +47,7 @@ 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) (a==0?NULL:xe_memory_addr(state->memory(), a))
|
#define IMPL_MEM_ADDR(a) (a ? xe_memory_addr(state->memory(), a) : NULL)
|
||||||
|
|
||||||
#define IMPL_MEM_16(a) (uint16_t)XEGETUINT16BE(IMPL_MEM_ADDR(a));
|
#define IMPL_MEM_16(a) (uint16_t)XEGETUINT16BE(IMPL_MEM_ADDR(a));
|
||||||
#define IMPL_MEM_32(a) (uint32_t)XEGETUINT32BE(IMPL_MEM_ADDR(a));
|
#define IMPL_MEM_32(a) (uint32_t)XEGETUINT32BE(IMPL_MEM_ADDR(a));
|
||||||
|
|
Loading…
Reference in New Issue