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.
|
|
/*++
Copyright (C) Microsoft Corporation, 1992 - 1999
Module Name:
ntutil.c
Abstract:
This is provides basic utilities for the NT DLL.
Author:
Steven Zeck (stevez) 03/04/92
--*/
#include <nsi.h>
#include <string.h>
void AsciiToUnicodeNT( OUT unsigned short *String, IN unsigned char *AsciiString ) /*++
Routine Description:
Convert a ASCII string to unicode via the NT librarys
Arguments:
String - place to put result
AsciiString - string to convert
--*/ { while(*String++ = RtlAnsiCharToUnicodeChar ((PUCHAR *) &AsciiString)) ; }
int UnicodeToAscii( unsigned short *WideCharString ) /*++
Routine Description:
Make a ASCII string from an UNICODE string. This is done in place so the string becomes ASCII.
Arguments:
UnicodeString - unicode string to convert
Returns:
RPC_S_OK, RPC_S_OUT_OF_MEMORY
--*/ { NTSTATUS NtStatus; UNICODE_STRING UnicodeString; ANSI_STRING AnsiString;
RtlInitUnicodeString(&UnicodeString, WideCharString); NtStatus = RtlUnicodeStringToAnsiString(&AnsiString,&UnicodeString,TRUE);
if (!NT_SUCCESS(NtStatus)) return(RPC_S_OUT_OF_MEMORY);
strcpy((char *)WideCharString, AnsiString.Buffer); RtlFreeAnsiString(&AnsiString);
return(RPC_S_OK); }
static RTL_CRITICAL_SECTION GlobalMutex;
extern "C" { int InitializeDLL ( IN void * DllHandle, IN ULONG Reason, IN PCONTEXT Context OPTIONAL ) /*++
Routine Description:
NT DLL initialization function. Allocate/free the global MUTEX.
Arguments:
DllHandle - my module handle
Reason - why this funciton is being called
Context - the context pointer.
Returns:
0 if there were no error during initialization, non 0 otherwise.
--*/ { NTSTATUS Status;
UNUSED(Context);
if (Reason == DLL_PROCESS_ATTACH) { #ifndef RPC_NT31
// API added for NT 3.11, don't call when building for NT 3.1
DisableThreadLibraryCalls((HMODULE)DllHandle); #endif
Status = RtlInitializeCriticalSection(&GlobalMutex);
if (! NT_SUCCESS(Status) ) return(FALSE);
}
if (Reason == DLL_PROCESS_DETACH) { Status = RtlDeleteCriticalSection(&GlobalMutex); }
return(TRUE); }
}
void GlobalMutexRequest ( void ) /*++
Routine Description:
Request the global mutex.
--*/ { NTSTATUS Status;
Status = RtlEnterCriticalSection(&GlobalMutex); }
void GlobalMutexClear ( void ) /*++
Routine Description:
Clear the global mutex.
--*/ { NTSTATUS Status;
Status = RtlLeaveCriticalSection(&GlobalMutex); }
|