/*++ Copyright (c) 1987-1993 Microsoft Corporation Module Name: debug.cxx Abstract: Support routines allowing the NtLmSsp DLL side use the common routines shared between the DLL and the SERVICE. These routines exist in the DLL side. They are different implementations of the same routines that exist on the SERVICE side. These implementations are significantly simpler because they run in the address space of the caller. Author: Cliff Van Dyke (CliffV) 22-Sep-1993 Environment: User mode only. Contains NT-specific code. Requires ANSI C extensions: slash-slash comments, long external names. Revision History: ChandanS 03-Aug-1996 Stolen from net\svcdlls\ntlmssp\client\support.c --*/ // // Common include files. // #include #if DBG #include #define MAX_PRINTF_LEN 1024 // Arbitrary. VOID SspPrintRoutine( IN DWORD DebugFlag, IN LPSTR Format, ... ) { va_list arglist; char OutputBuffer[MAX_PRINTF_LEN]; ULONG length; int cbUsed = 0; static BeginningOfLine = TRUE; static LineCount = 0; // // If we aren't debugging this functionality, just return. // if ( DebugFlag != 0 && (SspGlobalDbflag & DebugFlag) == 0 ) { return; } // // vsprintf isn't multithreaded + we don't want to intermingle output // from different threads. // EnterCriticalSection( &SspGlobalLogFileCritSect ); length = 0; // // make sure it is null terminated // OutputBuffer[sizeof(OutputBuffer) - 1] = '\0'; // // Handle the beginning of a new line. // // if ( BeginningOfLine ) { // // If we're writing to the debug terminal, // indicate this is an NtLmSsp message. // cbUsed = _snprintf(&OutputBuffer[length], sizeof(OutputBuffer) - 1 - length, "[MSV1_0.dll] "); if (cbUsed <= 0) { goto Done; } length += cbUsed; // // Put the timestamp at the begining of the line. // IF_DEBUG( TIMESTAMP ) { SYSTEMTIME SystemTime; GetLocalTime( &SystemTime ); cbUsed = _snprintf( &OutputBuffer[length], sizeof(OutputBuffer) - 1 - length, "%02u/%02u %02u:%02u:%02u ", SystemTime.wMonth, SystemTime.wDay, SystemTime.wHour, SystemTime.wMinute, SystemTime.wSecond ); if (cbUsed <= 0) { goto Done; } length += cbUsed; } // // Indicate the type of message on the line // { char *Text; switch (DebugFlag) { case SSP_INIT: Text = "INIT"; break; case SSP_MISC: Text = "MISC"; break; case SSP_LOGON_SESS: Text = "LOGON_SESS"; break; case SSP_CRITICAL: Text = "CRITICAL"; break; case SSP_LEAK_TRACK: Text = "LEAK_TRACK"; break; case SSP_WARNING: Text = "WARNING"; break; case SSP_LPC: case SSP_LPC_MORE: Text = "LPC"; break; case SSP_API: Text = "API"; break; case SSP_API_MORE: Text = "APIMORE"; break; case SSP_SESSION_KEYS: Text = "SESSION_KEYS"; break; case SSP_NEGOTIATE_FLAGS: Text = "NEGOTIATE_FLAGS"; break; case SSP_UPDATES: Text = "UPDATES"; break; case SSP_NTLM_V2: Text = "NTLM_V2"; break; case SSP_CRED: Text = "CRED"; break; case SSP_VERSION: Text = "VER"; break; default: Text = "UNKNOWN"; break; case 0: Text = NULL; } if ( Text != NULL ) { cbUsed = _snprintf( &OutputBuffer[length], sizeof(OutputBuffer) - 1 - length, "[%s] ", Text ); if (cbUsed <= 0) { goto Done; } length += cbUsed; } } } // // Put a the information requested by the caller onto the line // va_start(arglist, Format); cbUsed = _vsnprintf(&OutputBuffer[length], sizeof(OutputBuffer) - 1 - length, Format, arglist); va_end(arglist); if (cbUsed <= 0) { goto Done; } length += cbUsed; Done: BeginningOfLine = (length > 0 && OutputBuffer[length - 1] == '\n' ); // // just output to the debug terminal // (void) DbgPrint( (PCH) OutputBuffer); LeaveCriticalSection( &SspGlobalLogFileCritSect ); } // SspPrintRoutine #endif // DBG