Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

213 lines
3.4 KiB

//---------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation 1993-1995
//
// File: dll.c
//
// This file contains the library entry points
//
// History:
// 12-23-93 ScottH Created
// 9-22-95 ScottH Ported to NT
//
//---------------------------------------------------------------------------
#include "proj.h"
#include <rovdbg.h> // debug assertion code
// Global data
//
BOOL g_bAdminUser;
#ifdef WIN32
CRITICAL_SECTION g_csDll = { 0 };
#endif // WIN32
/*----------------------------------------------------------
Purpose: Initialize the DLL
Returns:
Cond: --
*/
BOOL PRIVATE Dll_Initialize(void)
{
BOOL bRet = TRUE;
InitCommonControls();
return bRet;
}
/*----------------------------------------------------------
Purpose: Attach a process to this DLL
Returns: --
Cond: --
*/
BOOL PRIVATE Dll_ProcessAttach(HINSTANCE hDll)
{
BOOL bSuccess = TRUE;
__try {
InitializeCriticalSection(&g_csDll);
} __except (EXCEPTION_EXECUTE_HANDLER ) {
return FALSE;
}
g_bAdminUser = IsAdminUser();
if (bSuccess)
{
g_hinst = hDll;
DEBUG_MEMORY_PROCESS_ATTACH("serialui");
#ifdef DEBUG
// We do this simply to load the debug .ini flags
//
RovComm_ProcessIniFile();
TRACE_MSG(TF_GENERAL, "Process Attach (hDll = %lx)", hDll);
DEBUG_BREAK(BF_ONPROCESSATT);
#endif
bSuccess = Dll_Initialize();
}
return bSuccess;
}
/*----------------------------------------------------------
Purpose: Detach a process from the DLL
Returns: --
Cond: --
*/
BOOL PRIVATE Dll_ProcessDetach(HINSTANCE hDll)
{
BOOL bSuccess = TRUE;
ASSERT(hDll == g_hinst);
DEBUG_CODE( TRACE_MSG(TF_GENERAL, "Process Detach (hDll = %lx)",
hDll); )
DEBUG_CODE( DEBUG_BREAK(BF_ONPROCESSDET); )
DEBUG_MEMORY_PROCESS_DETACH();
DeleteCriticalSection(&g_csDll);
return bSuccess;
}
HINSTANCE g_hinst = 0;
// **************************************************************************
// WIN32 specific code
// **************************************************************************
#ifdef WIN32
#ifdef DEBUG
BOOL g_bExclusive=FALSE;
#endif
/*----------------------------------------------------------
Purpose: Enter an exclusive section
Returns: --
Cond: --
*/
void PUBLIC Dll_EnterExclusive(void)
{
EnterCriticalSection(&g_csDll);
#ifdef DEBUG
g_bExclusive = TRUE;
#endif
}
/*----------------------------------------------------------
Purpose: Leave an exclusive section
Returns: --
Cond: --
*/
void PUBLIC Dll_LeaveExclusive(void)
{
#ifdef DEBUG
g_bExclusive = FALSE;
#endif
LeaveCriticalSection(&g_csDll);
}
/*----------------------------------------------------------
Purpose: Win32 Libmain
Returns: --
Cond: --
*/
BOOL APIENTRY LibMain(
HANDLE hDll,
DWORD dwReason,
LPVOID lpReserved)
{
switch(dwReason)
{
case DLL_PROCESS_ATTACH:
Dll_ProcessAttach(hDll);
break;
case DLL_PROCESS_DETACH:
Dll_ProcessDetach(hDll);
break;
case DLL_THREAD_ATTACH:
#ifdef DEBUG
DEBUG_BREAK(BF_ONTHREADATT);
#endif
break;
case DLL_THREAD_DETACH:
#ifdef DEBUG
DEBUG_BREAK(BF_ONTHREADDET);
#endif
break;
default:
break;
}
return TRUE;
}
#else // WIN32
#endif // WIN32