mirror of
https://github.com/reactos/reactos.git
synced 2025-01-06 06:20:13 +00:00
254 lines
8 KiB
C
254 lines
8 KiB
C
/*
|
|
* COPYRIGHT: See COPYING in the top level directory
|
|
* PROJECT: ReactOS system libraries
|
|
* FILE: dll/win32/kernel32/client/dllmain.c
|
|
* PURPOSE: Initialization
|
|
* PROGRAMMERS: Ariadne (ariadne@xs4all.nl)
|
|
* Aleksey Bragin (aleksey@reactos.org)
|
|
*/
|
|
|
|
/* INCLUDES ******************************************************************/
|
|
|
|
#include <k32.h>
|
|
|
|
#define NDEBUG
|
|
#include <debug.h>
|
|
|
|
/* GLOBALS *******************************************************************/
|
|
|
|
PBASE_STATIC_SERVER_DATA BaseStaticServerData;
|
|
BOOLEAN BaseRunningInServerProcess = FALSE;
|
|
|
|
WCHAR BaseDefaultPathBuffer[6140];
|
|
|
|
HANDLE BaseNamedObjectDirectory;
|
|
HMODULE hCurrentModule = NULL;
|
|
HMODULE kernel32_handle = NULL;
|
|
PPEB Peb;
|
|
ULONG SessionId;
|
|
static BOOL DllInitialized = FALSE;
|
|
|
|
/* Critical section for various kernel32 data structures */
|
|
RTL_CRITICAL_SECTION BaseDllDirectoryLock;
|
|
|
|
extern BOOL FASTCALL NlsInit(VOID);
|
|
extern VOID FASTCALL NlsUninit(VOID);
|
|
|
|
#define WIN_OBJ_DIR L"\\Windows"
|
|
#define SESSION_DIR L"\\Sessions"
|
|
|
|
/* FUNCTIONS *****************************************************************/
|
|
|
|
NTSTATUS
|
|
NTAPI
|
|
BaseCreateThreadPoolThread(IN PTHREAD_START_ROUTINE Function,
|
|
IN PVOID Parameter,
|
|
OUT PHANDLE ThreadHandle)
|
|
{
|
|
NTSTATUS Status;
|
|
|
|
/* Create a Win32 thread */
|
|
*ThreadHandle = CreateRemoteThread(NtCurrentProcess(),
|
|
NULL,
|
|
0,
|
|
Function,
|
|
Parameter,
|
|
CREATE_SUSPENDED,
|
|
NULL);
|
|
if (!(*ThreadHandle))
|
|
{
|
|
/* Get the status value if we couldn't get a handle */
|
|
Status = NtCurrentTeb()->LastStatusValue;
|
|
if (NT_SUCCESS(Status)) Status = STATUS_UNSUCCESSFUL;
|
|
}
|
|
else
|
|
{
|
|
/* Set success code */
|
|
Status = STATUS_SUCCESS;
|
|
}
|
|
|
|
/* All done */
|
|
return Status;
|
|
}
|
|
|
|
NTSTATUS
|
|
NTAPI
|
|
BaseExitThreadPoolThread(IN NTSTATUS ExitStatus)
|
|
{
|
|
/* Exit the thread */
|
|
ExitThread(ExitStatus);
|
|
return STATUS_SUCCESS;
|
|
}
|
|
|
|
BOOL
|
|
WINAPI
|
|
DllMain(HANDLE hDll,
|
|
DWORD dwReason,
|
|
LPVOID lpReserved)
|
|
{
|
|
NTSTATUS Status;
|
|
BASESRV_API_CONNECTINFO ConnectInfo;
|
|
ULONG ConnectInfoSize = sizeof(ConnectInfo);
|
|
WCHAR SessionDir[256];
|
|
|
|
DPRINT("DllMain(hInst %p, dwReason %lu)\n",
|
|
hDll, dwReason);
|
|
|
|
Basep8BitStringToUnicodeString = RtlAnsiStringToUnicodeString;
|
|
|
|
/* Cache the PEB and Session ID */
|
|
Peb = NtCurrentPeb();
|
|
SessionId = Peb->SessionId;
|
|
|
|
switch (dwReason)
|
|
{
|
|
case DLL_PROCESS_ATTACH:
|
|
{
|
|
/* Set no filter initially */
|
|
GlobalTopLevelExceptionFilter = RtlEncodePointer(NULL);
|
|
|
|
/* Enable the Rtl thread pool and timer queue to use proper Win32 thread */
|
|
RtlSetThreadPoolStartFunc(BaseCreateThreadPoolThread, BaseExitThreadPoolThread);
|
|
|
|
/* Register the manifest prober routine */
|
|
LdrSetDllManifestProber(BasepProbeForDllManifest);
|
|
|
|
/* Don't bother us for each thread */
|
|
LdrDisableThreadCalloutsForDll((PVOID)hDll);
|
|
|
|
/* Initialize default path to NULL */
|
|
RtlInitUnicodeString(&BaseDefaultPath, NULL);
|
|
|
|
/* Setup the Object Directory path */
|
|
if (!SessionId)
|
|
{
|
|
/* Use the raw path */
|
|
wcscpy(SessionDir, WIN_OBJ_DIR);
|
|
}
|
|
else
|
|
{
|
|
/* Use the session path */
|
|
swprintf(SessionDir,
|
|
L"%ws\\%ld%ws",
|
|
SESSION_DIR,
|
|
SessionId,
|
|
WIN_OBJ_DIR);
|
|
}
|
|
|
|
/* Connect to the Base Server */
|
|
Status = CsrClientConnectToServer(SessionDir,
|
|
BASESRV_SERVERDLL_INDEX,
|
|
&ConnectInfo,
|
|
&ConnectInfoSize,
|
|
&BaseRunningInServerProcess);
|
|
if (!NT_SUCCESS(Status))
|
|
{
|
|
DPRINT1("Failed to connect to CSR (Status %lx)\n", Status);
|
|
NtTerminateProcess(NtCurrentProcess(), Status);
|
|
return FALSE;
|
|
}
|
|
|
|
/* Get the server data */
|
|
ASSERT(Peb->ReadOnlyStaticServerData);
|
|
BaseStaticServerData = Peb->ReadOnlyStaticServerData[BASESRV_SERVERDLL_INDEX];
|
|
ASSERT(BaseStaticServerData);
|
|
|
|
/* Check if we are running a CSR Server */
|
|
if (!BaseRunningInServerProcess)
|
|
{
|
|
/* Set the termination port for the thread */
|
|
DPRINT("Creating new thread for CSR\n");
|
|
CsrNewThread();
|
|
}
|
|
|
|
/* Initialize heap handle table */
|
|
BaseDllInitializeMemoryManager();
|
|
|
|
/* Set HMODULE for our DLL */
|
|
kernel32_handle = hCurrentModule = hDll;
|
|
|
|
/* Set the directories */
|
|
BaseWindowsDirectory = BaseStaticServerData->WindowsDirectory;
|
|
BaseWindowsSystemDirectory = BaseStaticServerData->WindowsSystemDirectory;
|
|
|
|
/* Construct the default path (using the static buffer) */
|
|
Status = RtlStringCbPrintfW(BaseDefaultPathBuffer,
|
|
sizeof(BaseDefaultPathBuffer),
|
|
L".;%wZ;%wZ\\system;%wZ;",
|
|
&BaseWindowsSystemDirectory,
|
|
&BaseWindowsDirectory,
|
|
&BaseWindowsDirectory);
|
|
if (!NT_SUCCESS(Status))
|
|
{
|
|
DPRINT1("NLS Init failed\n");
|
|
return FALSE;
|
|
}
|
|
|
|
BaseDefaultPath.Buffer = BaseDefaultPathBuffer;
|
|
BaseDefaultPath.Length = (USHORT)wcslen(BaseDefaultPathBuffer) * sizeof(WCHAR);
|
|
BaseDefaultPath.MaximumLength = sizeof(BaseDefaultPathBuffer);
|
|
|
|
/* Use remaining part of the default path buffer for the append path */
|
|
BaseDefaultPathAppend.Buffer = (PWSTR)((ULONG_PTR)BaseDefaultPathBuffer + BaseDefaultPath.Length);
|
|
BaseDefaultPathAppend.Length = 0;
|
|
BaseDefaultPathAppend.MaximumLength = BaseDefaultPath.MaximumLength - BaseDefaultPath.Length;
|
|
|
|
/* Initialize command line */
|
|
InitCommandLines();
|
|
|
|
/* Initialize the DLL critical section */
|
|
RtlInitializeCriticalSection(&BaseDllDirectoryLock);
|
|
|
|
/* Initialize the National Language Support routines */
|
|
if (!NlsInit())
|
|
{
|
|
DPRINT1("NLS Init failed\n");
|
|
return FALSE;
|
|
}
|
|
|
|
/* Initialize Console Support */
|
|
if (!ConDllInitialize(dwReason, SessionDir))
|
|
{
|
|
DPRINT1("Failed to set up console\n");
|
|
return FALSE;
|
|
}
|
|
|
|
/* Initialize application certification globals */
|
|
InitializeListHead(&BasepAppCertDllsList);
|
|
RtlInitializeCriticalSection(&gcsAppCert);
|
|
|
|
/* Insert more dll attach stuff here! */
|
|
DllInitialized = TRUE;
|
|
break;
|
|
}
|
|
|
|
case DLL_PROCESS_DETACH:
|
|
{
|
|
if (DllInitialized != FALSE)
|
|
{
|
|
/* Uninitialize console support */
|
|
ConDllInitialize(dwReason, NULL);
|
|
|
|
/* Insert more dll detach stuff here! */
|
|
NlsUninit();
|
|
|
|
/* Delete DLL critical section */
|
|
RtlDeleteCriticalSection(&BaseDllDirectoryLock);
|
|
}
|
|
break;
|
|
}
|
|
|
|
case DLL_THREAD_ATTACH:
|
|
{
|
|
/* ConDllInitialize sets the current console locale for the new thread */
|
|
return ConDllInitialize(dwReason, NULL);
|
|
}
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
/* EOF */
|