[RTL]
Merge from amd64 branch
35738,37004,37308,37324,37330,37331,37332,37370,37419,37424,37425,37428,37473,37492,37844,37911,37987,40604,41006,43686,43951,43953,43980,43993,44001,44289,44295,44296,44428,44966,44967,44968
- Implement amd64 specific RTL functions: RtlLookupFunctionTable, RtlLookupFunctionEntry, RtlCaptureContext, RtlVirtualUnwind, RtlWalkFrameChain, RtlGetCallersAddress, RtlRaiseException (Timo Kreuzer)
- Implement amd64 asm functions: RtlCompareMemory, DebugService, RtlInterlockedPopEntrySList, RtlInterlockedPushEntrySList and RtlInterlockedFlushSList (Timo Kreuzer)
- Don't use double in rtl's sprintf / swprintf, use double_t union instead. (Stefan Ginsberg)
svn path=/trunk/; revision=44970
2010-01-06 00:39:07 +00:00
|
|
|
/*
|
|
|
|
* COPYRIGHT: See COPYING in the top level directory
|
|
|
|
* PROJECT: ReactOS Run-Time Library
|
|
|
|
* PURPOSE: AMD64 stubs
|
|
|
|
* FILE: lib/rtl/amd64/stubs.c
|
|
|
|
* PROGRAMMERS: Stefan Ginsberg (stefan.ginsberg@reactos.org)
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* INCLUDES *****************************************************************/
|
|
|
|
|
|
|
|
#include <rtl.h>
|
|
|
|
#define NDEBUG
|
|
|
|
#include <debug.h>
|
2012-02-04 18:35:56 +00:00
|
|
|
#include "amd64/ketypes.h"
|
[RTL]
Merge from amd64 branch
35738,37004,37308,37324,37330,37331,37332,37370,37419,37424,37425,37428,37473,37492,37844,37911,37987,40604,41006,43686,43951,43953,43980,43993,44001,44289,44295,44296,44428,44966,44967,44968
- Implement amd64 specific RTL functions: RtlLookupFunctionTable, RtlLookupFunctionEntry, RtlCaptureContext, RtlVirtualUnwind, RtlWalkFrameChain, RtlGetCallersAddress, RtlRaiseException (Timo Kreuzer)
- Implement amd64 asm functions: RtlCompareMemory, DebugService, RtlInterlockedPopEntrySList, RtlInterlockedPushEntrySList and RtlInterlockedFlushSList (Timo Kreuzer)
- Don't use double in rtl's sprintf / swprintf, use double_t union instead. (Stefan Ginsberg)
svn path=/trunk/; revision=44970
2010-01-06 00:39:07 +00:00
|
|
|
|
|
|
|
/* PUBLIC FUNCTIONS **********************************************************/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @unimplemented
|
|
|
|
*/
|
|
|
|
VOID
|
|
|
|
NTAPI
|
2020-01-06 09:46:01 +00:00
|
|
|
RtlInitializeContext(
|
|
|
|
_Reserved_ HANDLE ProcessHandle,
|
|
|
|
_Out_ PCONTEXT ThreadContext,
|
2022-07-23 11:31:27 +00:00
|
|
|
_In_opt_ PVOID ThreadStartParam,
|
2020-01-06 09:46:01 +00:00
|
|
|
_In_ PTHREAD_START_ROUTINE ThreadStartAddress,
|
|
|
|
_In_ PINITIAL_TEB StackBase)
|
[RTL]
Merge from amd64 branch
35738,37004,37308,37324,37330,37331,37332,37370,37419,37424,37425,37428,37473,37492,37844,37911,37987,40604,41006,43686,43951,43953,43980,43993,44001,44289,44295,44296,44428,44966,44967,44968
- Implement amd64 specific RTL functions: RtlLookupFunctionTable, RtlLookupFunctionEntry, RtlCaptureContext, RtlVirtualUnwind, RtlWalkFrameChain, RtlGetCallersAddress, RtlRaiseException (Timo Kreuzer)
- Implement amd64 asm functions: RtlCompareMemory, DebugService, RtlInterlockedPopEntrySList, RtlInterlockedPushEntrySList and RtlInterlockedFlushSList (Timo Kreuzer)
- Don't use double in rtl's sprintf / swprintf, use double_t union instead. (Stefan Ginsberg)
svn path=/trunk/; revision=44970
2010-01-06 00:39:07 +00:00
|
|
|
{
|
2020-01-06 09:46:01 +00:00
|
|
|
/* Initialize everything to 0 */
|
|
|
|
RtlZeroMemory(ThreadContext, sizeof(*ThreadContext));
|
2012-02-04 18:35:56 +00:00
|
|
|
|
2020-01-06 09:46:01 +00:00
|
|
|
/* Initialize StartAddress and Stack */
|
|
|
|
ThreadContext->Rip = (ULONG64)ThreadStartAddress;
|
|
|
|
ThreadContext->Rsp = (ULONG64)StackBase - 6 * sizeof(PVOID);
|
|
|
|
|
|
|
|
/* Align stack by 16 and substract 8 (unaligned on function entry) */
|
|
|
|
ThreadContext->Rsp &= ~15;
|
|
|
|
ThreadContext->Rsp -= 8;
|
|
|
|
|
|
|
|
/* Enable Interrupts */
|
|
|
|
ThreadContext->EFlags = EFLAGS_INTERRUPT_MASK;
|
|
|
|
|
|
|
|
/* Set start parameter */
|
2012-02-04 18:35:56 +00:00
|
|
|
ThreadContext->Rcx = (ULONG64)ThreadStartParam;
|
|
|
|
|
|
|
|
/* Set the Selectors */
|
|
|
|
if ((LONG64)ThreadStartAddress < 0)
|
|
|
|
{
|
|
|
|
/* Initialize kernel mode segments */
|
|
|
|
ThreadContext->SegCs = KGDT64_R0_CODE;
|
|
|
|
ThreadContext->SegDs = KGDT64_R3_DATA;
|
|
|
|
ThreadContext->SegEs = KGDT64_R3_DATA;
|
|
|
|
ThreadContext->SegFs = KGDT64_R3_CMTEB;
|
|
|
|
ThreadContext->SegGs = KGDT64_R3_DATA;
|
|
|
|
ThreadContext->SegSs = KGDT64_R0_DATA;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Initialize user mode segments */
|
|
|
|
ThreadContext->SegCs = KGDT64_R3_CODE | RPL_MASK;
|
|
|
|
ThreadContext->SegDs = KGDT64_R3_DATA | RPL_MASK;
|
|
|
|
ThreadContext->SegEs = KGDT64_R3_DATA | RPL_MASK;
|
|
|
|
ThreadContext->SegFs = KGDT64_R3_CMTEB | RPL_MASK;
|
|
|
|
ThreadContext->SegGs = KGDT64_R3_DATA | RPL_MASK;
|
|
|
|
ThreadContext->SegSs = KGDT64_R3_DATA | RPL_MASK;
|
|
|
|
}
|
|
|
|
|
2022-07-23 11:31:27 +00:00
|
|
|
ThreadContext->MxCsr = INITIAL_MXCSR;
|
|
|
|
|
2012-02-04 18:35:56 +00:00
|
|
|
/* Only the basic Context is initialized */
|
|
|
|
ThreadContext->ContextFlags = CONTEXT_CONTROL |
|
|
|
|
CONTEXT_INTEGER |
|
2022-07-23 11:31:27 +00:00
|
|
|
CONTEXT_SEGMENTS |
|
|
|
|
CONTEXT_FLOATING_POINT;
|
2012-02-04 18:35:56 +00:00
|
|
|
|
[RTL]
Merge from amd64 branch
35738,37004,37308,37324,37330,37331,37332,37370,37419,37424,37425,37428,37473,37492,37844,37911,37987,40604,41006,43686,43951,43953,43980,43993,44001,44289,44295,44296,44428,44966,44967,44968
- Implement amd64 specific RTL functions: RtlLookupFunctionTable, RtlLookupFunctionEntry, RtlCaptureContext, RtlVirtualUnwind, RtlWalkFrameChain, RtlGetCallersAddress, RtlRaiseException (Timo Kreuzer)
- Implement amd64 asm functions: RtlCompareMemory, DebugService, RtlInterlockedPopEntrySList, RtlInterlockedPushEntrySList and RtlInterlockedFlushSList (Timo Kreuzer)
- Don't use double in rtl's sprintf / swprintf, use double_t union instead. (Stefan Ginsberg)
svn path=/trunk/; revision=44970
2010-01-06 00:39:07 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-09-21 10:46:01 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
RtlQueueApcWow64Thread(
|
|
|
|
_In_ HANDLE ThreadHandle,
|
|
|
|
_In_ PKNORMAL_ROUTINE ApcRoutine,
|
|
|
|
_In_opt_ PVOID NormalContext,
|
|
|
|
_In_opt_ PVOID SystemArgument1,
|
|
|
|
_In_opt_ PVOID SystemArgument2)
|
|
|
|
{
|
|
|
|
UNIMPLEMENTED;
|
|
|
|
return STATUS_NOT_IMPLEMENTED;
|
|
|
|
}
|
2011-08-20 19:04:55 +00:00
|
|
|
|