windows-nt/Source/XPSP1/NT/base/fs/mup/log.c

174 lines
5 KiB
C
Raw Normal View History

2020-09-26 03:20:57 -05:00
//+----------------------------------------------------------------------------
//
// Copyright (C) 1992, Microsoft Corporation
//
// File: log.c
//
// Contents: Module to log messages from the driver to the NT event logging
// system.
//
// Classes:
//
// Functions: LogWriteMessage()
//
// History: 3/30/93 Milans created
// 04/18/93 SudK modified to use a MessageFile. and some
// cleanup to the function below.
//
//-----------------------------------------------------------------------------
#include "dfsprocs.h"
#define Dbg DEBUG_TRACE_EVENTLOG
VOID LogpPutString(
IN PUNICODE_STRING pustrString,
IN OUT PCHAR *ppStringBuffer,
IN OUT UCHAR *pcbBuffer);
#ifdef ALLOC_PRAGMA
#pragma alloc_text( PAGE, LogWriteMessage )
#pragma alloc_text( PAGE, LogpPutString )
#endif // ALLOC_PRAGMA
//+----------------------------------------------------------------------------
//
// Function: LogWriteMessage
//
// Synopsis: Logs a message to the NT event logging system.
//
// Arguments: [UniqueErrCode] -- The code that identifes the message.
// [NtStatusCode] -- Status code from some error.
// [nStrings] -- Number of strings being passed in.
// [pustrArg] -- The Array of insertion strings.
//
// Returns: Nothing at all.
//
// History: 04/18/93 SudK Created.
//
//-----------------------------------------------------------------------------
VOID LogWriteMessage(
IN ULONG UniqueErrorCode,
IN NTSTATUS NtStatusCode,
IN ULONG nStrings,
IN PUNICODE_STRING pustrArg OPTIONAL)
{
PIO_ERROR_LOG_PACKET pErrorLog;
UCHAR cbSize;
UCHAR *pStringBuffer;
ULONG i;
//
// Compute the size of the Error Log Packet that we need to start with.
//
cbSize = sizeof(IO_ERROR_LOG_PACKET);
for (i = 0; i < nStrings; i++) {
cbSize = (UCHAR)( cbSize + pustrArg[i].Length + sizeof(WCHAR));
}
if (cbSize > ERROR_LOG_MAXIMUM_SIZE) {
cbSize = ERROR_LOG_MAXIMUM_SIZE;
}
pErrorLog = (PIO_ERROR_LOG_PACKET) IoAllocateErrorLogEntry(
DfsData.DriverObject,
cbSize);
if (!pErrorLog) {
//
// Well, I guess we won't be logging this one.
//
return;
}
//
// Zero out all fields, then set the ones we want.
//
RtlZeroMemory((PVOID) pErrorLog, sizeof(IO_ERROR_LOG_PACKET));
pErrorLog->FinalStatus = NtStatusCode;
pErrorLog->ErrorCode = UniqueErrorCode;
pErrorLog->NumberOfStrings = (USHORT) nStrings;
pErrorLog->StringOffset = sizeof(IO_ERROR_LOG_PACKET);
pStringBuffer = ((PCHAR) pErrorLog) + sizeof(IO_ERROR_LOG_PACKET);
//
// Copy the strings into the buffer, making sure we truncate if and when
// we need to.
//
cbSize -= sizeof(IO_ERROR_LOG_PACKET);
for (i = 0; i < nStrings; i++) {
LogpPutString(&pustrArg[i], &pStringBuffer, &cbSize);
}
//
// And finally, write out the log
//
IoWriteErrorLogEntry(pErrorLog);
}
//+----------------------------------------------------------------------------
//
// Function: LogpPutString
//
// Synopsis: Copies a string into the buffer part of an IO_ERROR_LOG_PACKET.
// Takes care of truncating if the whole string won't fit.
//
// Arguments: [pustrString] -- Pointer to unicode string to copy.
// [ppStringBuffer] -- On input, pointer to beginning of buffer
// to copy to. On exit, will point one past the
// end of the copied string.
// [pcbBuffer] -- On input, max size of buffer. On output,
// remaining size after string has been copied.
//
// Returns: Nothing
//
// History: 04/18/93 SudK Created.
//
//-----------------------------------------------------------------------------
VOID LogpPutString(
IN PUNICODE_STRING pustrString,
IN OUT PCHAR *ppStringBuffer,
IN OUT UCHAR *pcbBuffer)
{
ULONG len;
PWCHAR pwch;
if ((*pcbBuffer == 0) || (pustrString->Length == 0)) {
return;
}
if ( *pcbBuffer >= (pustrString->Length + sizeof(WCHAR)) ) {
RtlMoveMemory(*ppStringBuffer, pustrString->Buffer, pustrString->Length);
(*pcbBuffer) -= pustrString->Length;
(*ppStringBuffer) += pustrString->Length;
} else {
RtlMoveMemory(*ppStringBuffer, pustrString->Buffer, (*pcbBuffer)-sizeof(WCHAR));
*pcbBuffer = sizeof(WCHAR);
(*ppStringBuffer) += (*pcbBuffer - sizeof(WCHAR));
}
//
// Null Terminate the String Now if necessary.
//
if (*((PWCHAR) *ppStringBuffer - 1) != L'\0') {
*((PWCHAR) *ppStringBuffer) = L'\0';
*ppStringBuffer += sizeof(WCHAR);
(*pcbBuffer) -= sizeof(WCHAR);
}
}