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.
 
 
 
 
 
 

408 lines
8.2 KiB

#include "precomp.h"
const ULONG guFatalExceptions[] =
{
STATUS_ACCESS_VIOLATION,
STATUS_POSSIBLE_DEADLOCK,
STATUS_INSTRUCTION_MISALIGNMENT,
STATUS_DATATYPE_MISALIGNMENT,
STATUS_PRIVILEGED_INSTRUCTION,
STATUS_ILLEGAL_INSTRUCTION,
STATUS_BREAKPOINT,
STATUS_STACK_OVERFLOW
};
const int FATAL_EXCEPTIONS_ARRAY_SIZE =
sizeof(guFatalExceptions) / sizeof(guFatalExceptions[0]);
#define BAIL_ON_WIN32_ERROR(dwError) \
if (dwError) { \
goto error; \
}
DWORD
TranslateExceptionCode(
DWORD dwExceptionCode
)
{
return (dwExceptionCode);
}
int
RPC_ENTRY
I_RpcExceptionFilter(
unsigned long uExceptionCode
)
{
int i = 0;
for (i = 0; i < FATAL_EXCEPTIONS_ARRAY_SIZE; i ++) {
if (uExceptionCode == guFatalExceptions[i]) {
return EXCEPTION_CONTINUE_SEARCH;
}
}
return EXCEPTION_EXECUTE_HANDLER;
}
DWORD
WZCDestroyClientContextHandle(
DWORD dwStatus,
HANDLE hFilter
)
{
DWORD dwError = 0;
switch (dwStatus) {
case RPC_S_SERVER_UNAVAILABLE:
case RPC_S_CALL_FAILED:
case RPC_S_CALL_FAILED_DNE:
case RPC_S_UNKNOWN_IF:
RpcTryExcept {
RpcSsDestroyClientContext(&hFilter);
} RpcExcept(I_RpcExceptionFilter(RpcExceptionCode())) {
dwError = TranslateExceptionCode(RpcExceptionCode());
BAIL_ON_WIN32_ERROR(dwError);
} RpcEndExcept
break;
default:
dwError = dwStatus;
break;
}
error:
return (dwError);
}
DWORD
OpenWZCDbLogSession(
LPWSTR pServerName,
DWORD dwVersion,
PHANDLE phSession
)
{
DWORD dwError = 0;
if (dwVersion) {
return (ERROR_INVALID_LEVEL);
}
if (!phSession) {
return (ERROR_INVALID_PARAMETER);
}
RpcTryExcept {
dwError = RpcOpenWZCDbLogSession(
pServerName,
phSession
);
BAIL_ON_WIN32_ERROR(dwError);
} RpcExcept(I_RpcExceptionFilter(RpcExceptionCode())) {
dwError = TranslateExceptionCode(RpcExceptionCode());
BAIL_ON_WIN32_ERROR(dwError);
} RpcEndExcept
error:
return (dwError);
}
DWORD
CloseWZCDbLogSession(
HANDLE hSession
)
{
DWORD dwError = 0;
if (!hSession) {
return (ERROR_INVALID_PARAMETER);
}
RpcTryExcept {
dwError = RpcCloseWZCDbLogSession(
&hSession
);
BAIL_ON_WIN32_ERROR(dwError);
} RpcExcept(I_RpcExceptionFilter(RpcExceptionCode())) {
dwError = TranslateExceptionCode(RpcExceptionCode());
BAIL_ON_WIN32_ERROR(dwError);
} RpcEndExcept
error:
if (dwError) {
dwError = WZCDestroyClientContextHandle(
dwError,
hSession
);
}
return (dwError);
}
DWORD
AddWZCDbLogRecord(
LPWSTR pServerName,
DWORD dwVersion,
PWZC_DB_RECORD pWZCRecord,
LPVOID pvReserved
)
{
DWORD dwError = 0;
WZC_DB_RECORD_CONTAINER RecordContainer;
PWZC_DB_RECORD_CONTAINER pRecordContainer = &RecordContainer;
if (dwVersion || pvReserved != NULL) {
return (ERROR_INVALID_LEVEL);
}
if (!pWZCRecord) {
return (ERROR_INVALID_PARAMETER);
}
pRecordContainer->dwNumRecords = 1;
pRecordContainer->pWZCRecords = pWZCRecord;
RpcTryExcept {
dwError = RpcAddWZCDbLogRecord(
pServerName,
pRecordContainer
);
BAIL_ON_WIN32_ERROR(dwError);
} RpcExcept(I_RpcExceptionFilter(RpcExceptionCode())) {
dwError = TranslateExceptionCode(RpcExceptionCode());
BAIL_ON_WIN32_ERROR(dwError);
} RpcEndExcept
error:
return (dwError);
}
DWORD
EnumWZCDbLogRecords(
HANDLE hSession,
PWZC_DB_RECORD pTemplateRecord,
PBOOL pbEnumFromStart,
DWORD dwPreferredNumEntries,
PWZC_DB_RECORD * ppWZCRecords,
LPDWORD pdwNumRecords,
LPVOID pvReserved
)
{
DWORD dwError = 0;
WZC_DB_RECORD_CONTAINER RecordContainer;
PWZC_DB_RECORD_CONTAINER pRecordContainer = &RecordContainer;
WZC_DB_RECORD_CONTAINER TemplateRecordContainer;
PWZC_DB_RECORD_CONTAINER pTemplateRecordContainer = &TemplateRecordContainer;
if (pvReserved != NULL) {
return (ERROR_INVALID_LEVEL);
}
memset(pRecordContainer, 0, sizeof(WZC_DB_RECORD_CONTAINER));
memset(pTemplateRecordContainer, 0, sizeof(WZC_DB_RECORD_CONTAINER));
if (!hSession || !pbEnumFromStart) {
return (ERROR_INVALID_PARAMETER);
}
if (!ppWZCRecords || !pdwNumRecords) {
return (ERROR_INVALID_PARAMETER);
}
if (pTemplateRecord) {
pTemplateRecordContainer->dwNumRecords = 1;
pTemplateRecordContainer->pWZCRecords = pTemplateRecord;
}
RpcTryExcept {
dwError = RpcEnumWZCDbLogRecords(
hSession,
pTemplateRecordContainer,
pbEnumFromStart,
dwPreferredNumEntries,
&pRecordContainer
);
if (dwError != ERROR_NO_MORE_ITEMS) {
BAIL_ON_WIN32_ERROR(dwError);
}
} RpcExcept(I_RpcExceptionFilter(RpcExceptionCode())) {
dwError = TranslateExceptionCode(RpcExceptionCode());
BAIL_ON_WIN32_ERROR(dwError);
} RpcEndExcept
*ppWZCRecords = pRecordContainer->pWZCRecords;
*pdwNumRecords = pRecordContainer->dwNumRecords;
return (dwError);
error:
*ppWZCRecords = NULL;
*pdwNumRecords = 0;
return (dwError);
}
DWORD
FlushWZCDbLog(
HANDLE hSession
)
{
DWORD dwError = 0;
if (!hSession) {
return (ERROR_INVALID_PARAMETER);
}
RpcTryExcept {
dwError = RpcFlushWZCDbLog(
hSession
);
BAIL_ON_WIN32_ERROR(dwError);
} RpcExcept(I_RpcExceptionFilter(RpcExceptionCode())) {
dwError = TranslateExceptionCode(RpcExceptionCode());
BAIL_ON_WIN32_ERROR(dwError);
} RpcEndExcept
error:
return (dwError);
}
/*
GetSpecificLogRecord: Wrapper for the RPC call to get a specific record
Arguments:
[in] hSession - Handle to the database session
[in] pwzcTemplate - Type of record to locate
[out] ppWZCRecords - List of records retrieved
pvReserved - Reserved
Returns:
ERROR_SUCCESS on success
*/
DWORD GetSpecificLogRecord(HANDLE hSession,
PWZC_DB_RECORD pTemplateRecord,
PWZC_DB_RECORD *ppWZCRecords,
LPDWORD pdwNumRecords,
LPVOID pvReserved)
{
DWORD dwError = 0;
WZC_DB_RECORD_CONTAINER RecordContainer;
PWZC_DB_RECORD_CONTAINER pRecordContainer = &RecordContainer;
WZC_DB_RECORD_CONTAINER TemplateRecordContainer;
PWZC_DB_RECORD_CONTAINER pTemplateRecordContainer=&TemplateRecordContainer;
if (pvReserved != NULL)
{
return (ERROR_INVALID_LEVEL);
}
memset(pRecordContainer, 0, sizeof(WZC_DB_RECORD_CONTAINER));
memset(pTemplateRecordContainer, 0, sizeof(WZC_DB_RECORD_CONTAINER));
if (!hSession)
{
return (ERROR_INVALID_PARAMETER);
}
if (!ppWZCRecords || !pdwNumRecords)
{
return (ERROR_INVALID_PARAMETER);
}
if (pTemplateRecord)
{
pTemplateRecordContainer->dwNumRecords = 1;
pTemplateRecordContainer->pWZCRecords = pTemplateRecord;
}
RpcTryExcept
{
dwError = RpcGetWZCDbLogRecord(hSession,
pTemplateRecordContainer,
&pRecordContainer);
if (dwError != ERROR_NO_MORE_ITEMS)
{
BAIL_ON_WIN32_ERROR(dwError);
}
}
RpcExcept(I_RpcExceptionFilter(RpcExceptionCode()))
{
dwError = TranslateExceptionCode(RpcExceptionCode());
BAIL_ON_WIN32_ERROR(dwError);
} RpcEndExcept
*ppWZCRecords = pRecordContainer->pWZCRecords;
*pdwNumRecords = pRecordContainer->dwNumRecords;
return (dwError);
error:
*ppWZCRecords = NULL;
*pdwNumRecords = 0;
return (dwError);
}