|
|
/*++
Copyright (c) 1991-1998 Microsoft Corporation
Module Name:
amlitest
Abstract:
Environment:
kernel mode only
Notes:
--*/
/*
#include "wdm.h"
#include "stdarg.h"
#include "stdio.h" */
#include "pch.h"
//#include "amlihook.h"
//#include "amlitest.h"
#define AMLIHOOK_DEBUG_ASYNC_AMLI ((ULONG)0x1)
#ifdef DBG
ULONG AmliTestDebugFlags=0x00;
#define AmliTest_DebugPrint(x) AmliTestDebugPrintFunc x
CHAR AmliTestDebugBuffer[200];
//
// Internal functions.
//
VOID AmliTestDebugPrintFunc( ULONG DebugPrintLevel, PCCHAR DebugMessage, ...) { va_list ap; va_start(ap, DebugMessage);
if(DebugPrintLevel & AmliTestDebugFlags) {
if(_vsnprintf(AmliTestDebugBuffer, 200, DebugMessage, ap) < 0) { //
// _vsnprintf failed, don't print out anything.
//
AmliTestDebugBuffer[0] = '\0'; } AmliTestDebugBuffer[199] = '\0';
DbgPrint(AmliTestDebugBuffer); } }
#endif
//
// AMLITest_Post_Generic
//
NTSTATUS AMLITest_Post_Generic( PAMLIHOOK_DATA * ppData, NTSTATUS _Status) {
//
//--- Notify test driver off call status
//
NTSTATUS Status = AmliHook_TestNotifyRet( *ppData, _Status);
ExFreePool(*ppData); *ppData = NULL; return(Status); }
//
// Exported functions.
//
//
// Pre/Post GetNameSpaceObject
//
NTSTATUS AMLITest_Pre_GetNameSpaceObject( IN PSZ pszObjPath, IN PNSOBJ pnsScope, OUT PPNSOBJ ppns, IN ULONG dwfFlags, PAMLIHOOK_DATA * ppData) { //
// Alocate and init AMLIHOOK_DATA
//
*ppData = AmliHook_AllocAndInitTestData(); if(!(*ppData)) { AmliHook_ProcessInternalError(); return(STATUS_INSUFFICIENT_RESOURCES); } //
//--- Notify test driver off call
//
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_GET_NAME_SPACE_OBJECT; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_CALL; (*ppData)->Arg1 = (ULONG_PTR)pszObjPath; (*ppData)->Arg2 = (ULONG_PTR)pnsScope; (*ppData)->Arg3 = (ULONG_PTR)ppns; (*ppData)->Arg4 = (ULONG_PTR)dwfFlags;
return(AmliHook_TestNotify(*ppData)); }
NTSTATUS AMLITest_Post_GetNameSpaceObject( PAMLIHOOK_DATA * ppData, NTSTATUS Status) { return(AMLITest_Post_Generic(ppData,Status)); }
//
// Pre/Post GetFieldUnitRegionObj
//
NTSTATUS AMLITest_Pre_GetFieldUnitRegionObj( IN PFIELDUNITOBJ pfu, OUT PPNSOBJ ppns, PAMLIHOOK_DATA * ppData) {
//
// Allocate and init AMLIHOOK_DATA
//
*ppData = AmliHook_AllocAndInitTestData(); if(!(*ppData)) return(STATUS_INSUFFICIENT_RESOURCES);
//
//--- Notify test driver off call
//
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_GET_FIELD_UNIT_REGION_OP; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_CALL; (*ppData)->Arg1 = (ULONG_PTR)pfu; (*ppData)->Arg2 = (ULONG_PTR)ppns;
return(AmliHook_TestNotify(*ppData)); }
NTSTATUS AMLITest_Post_GetFieldUnitRegionObj( PAMLIHOOK_DATA * ppData, NTSTATUS _Status) { return(AMLITest_Post_Generic(ppData,_Status)); }
//
// Pre/Post EvalNameSpaceObject
//
NTSTATUS AMLITest_Pre_EvalNameSpaceObject( IN PNSOBJ pns, OUT POBJDATA pdataResult, IN int icArgs, IN POBJDATA pdataArgs, PAMLIHOOK_DATA * ppData) {
//
// Alocate and init AMLIHOOK_DATA
//
*ppData = AmliHook_AllocAndInitTestData(); if(!(*ppData)) return(STATUS_INSUFFICIENT_RESOURCES);
//
//--- Notify test driver off call
//
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_EVAL_NAME_SPACE_OBJECT; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_CALL; (*ppData)->Arg1 = (ULONG_PTR)pns; (*ppData)->Arg2 = (ULONG_PTR)pdataResult; (*ppData)->Arg3 = (ULONG_PTR)icArgs; (*ppData)->Arg4 = (ULONG_PTR)pdataArgs;
return(AmliHook_TestNotify(*ppData)); } NTSTATUS AMLITest_Post_EvalNameSpaceObject( PAMLIHOOK_DATA * Data, NTSTATUS _Status) { return(AMLITest_Post_Generic(Data,_Status)); }
//
// CallBack Pre/Post AsyncEvalObject
//
VOID EXPORT AMLITest_AsyncEvalObjectCallBack( IN PNSOBJ pns, IN NTSTATUS status, IN POBJDATA pdataResult, IN PVOID Context) {
PAMLIHOOK_DATA pData = (PAMLIHOOK_DATA)Context; NTSTATUS RetStatus ; PFNACB AcpiAsyncCallBack; PVOID AcpiContext;
AcpiAsyncCallBack = (PFNACB)pData->Arg5; AcpiContext = (PVOID)pData->Arg6;
if( (VOID*)(pData->Arg2) != (VOID*)pdataResult) AmliHook_ProcessInternalError();
//
//--- Notify test driver off call status
//
RetStatus = AmliHook_TestNotifyRet( pData, status);
AmliTest_DebugPrint(( AMLIHOOK_DEBUG_ASYNC_AMLI, "DEBUG: AMLITest_AsyncEvalObjectCallBack Data=%lx\n", pData));
ExFreePool(pData);
if(AcpiAsyncCallBack) { AcpiAsyncCallBack( pns, RetStatus, pdataResult, AcpiContext); } }
NTSTATUS AMLITest_Pre_AsyncEvalObject( IN PNSOBJ pns, OUT POBJDATA pdataResult, IN int icArgs, IN POBJDATA pdataArgs, IN PFNACB * pfnAsyncCallBack, IN PVOID * pvContext, PAMLIHOOK_DATA * Data) {
//
// Alocate and init AMLIHOOK_DATA
//
*Data = AmliHook_AllocAndInitTestData(); if(!Data) return(STATUS_INSUFFICIENT_RESOURCES);
//
//--- Notify test driver off call
//
(*Data)->Type = ACPIVER_DATA_TYPE_AMLI; (*Data)->SubType = ACPIVER_DATA_SUBTYPE_ASYNC_EVAL_OBJECT; (*Data)->State = AMLIHOOK_TEST_DATA_STATE_CALL; (*Data)->Arg1 = (ULONG_PTR)pns; (*Data)->Arg2 = (ULONG_PTR)pdataResult; (*Data)->Arg3 = (ULONG_PTR)icArgs; (*Data)->Arg4 = (ULONG_PTR)pdataArgs; (*Data)->Arg5 = (ULONG_PTR)*pfnAsyncCallBack; (*Data)->Arg6 = (ULONG_PTR)*pvContext;
//
// Hook my callback function , and conext.
//
*pfnAsyncCallBack = AMLITest_AsyncEvalObjectCallBack; *pvContext = *Data;
return(AmliHook_TestNotify(*Data)); }
NTSTATUS AMLITest_Post_AsyncEvalObject( PAMLIHOOK_DATA * ppData, NTSTATUS Status) {
AmliTest_DebugPrint(( AMLIHOOK_DEBUG_ASYNC_AMLI, "DEBUG: AMLITest_Post_AsyncEvalObject Data=%lx Pending=%s\n", *ppData, (Status == STATUS_PENDING)? "TRUE" : "FALSE"));
if(Status == STATUS_PENDING) return(Status);
//
//--- Call back will not be called.
//
return(AMLITest_Post_Generic(ppData,Status)); }
//
// Pre/Post NestAsyncEvalObject
//
NTSTATUS AMLITest_Pre_NestAsyncEvalObject( PNSOBJ pns, POBJDATA pdataResult, int icArgs, POBJDATA pdataArgs, PFNACB * pfnAsyncCallBack, PVOID * pvContext, PAMLIHOOK_DATA * ppData) {
//
// Alocate and init AMLIHOOK_DATA
//
*ppData = AmliHook_AllocAndInitTestData(); if(!(*ppData)) return(STATUS_INSUFFICIENT_RESOURCES);
//
//--- Notify test driver off call
//
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_NEST_ASYNC_EVAL_OBJECT; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_CALL; (*ppData)->Arg1 = (ULONG_PTR)pns; (*ppData)->Arg2 = (ULONG_PTR)pdataResult; (*ppData)->Arg3 = (ULONG_PTR)icArgs; (*ppData)->Arg4 = (ULONG_PTR)pdataArgs; (*ppData)->Arg5 = (ULONG_PTR)pfnAsyncCallBack; (*ppData)->Arg6 = (ULONG_PTR)pvContext;
//
// Hook my callback function , and conext.
//
*pfnAsyncCallBack = AMLITest_AsyncEvalObjectCallBack; *pvContext = *ppData;
return(AmliHook_TestNotify(*ppData)); }
NTSTATUS AMLITest_Post_NestAsyncEvalObject( PAMLIHOOK_DATA * ppData, NTSTATUS Status) {
if(Status == STATUS_PENDING) return(Status);
//
//--- Work is done.
//--- AMLITest_AsyncEvalObjectCallBack will not be called.
//
return(AMLITest_Post_Generic(ppData,Status)); }
//
// Pre/Post EvalPackageElement
//
NTSTATUS AMLITest_Pre_EvalPackageElement( PNSOBJ pns, int iPkgIndex, POBJDATA pdataResult, PAMLIHOOK_DATA * ppData) {
//
// Alocate and init AMLIHOOK_DATA
//
*ppData = AmliHook_AllocAndInitTestData(); if(!(*ppData)) return(STATUS_INSUFFICIENT_RESOURCES);
//
//--- Notify test driver off call
//
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_EVAL_PACKAGE_ELEMENT; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_CALL; (*ppData)->Arg1 = (ULONG_PTR)pns; (*ppData)->Arg2 = (ULONG_PTR)iPkgIndex; (*ppData)->Arg3 = (ULONG_PTR)pdataResult;
return(AmliHook_TestNotify(*ppData)); }
NTSTATUS AMLITest_Post_EvalPackageElement( PAMLIHOOK_DATA * Data, NTSTATUS Status) { return(AMLITest_Post_Generic(Data,Status)); }
//
// Pre/Post EvalPkgDataElement
//
NTSTATUS AMLITest_Pre_EvalPkgDataElement( POBJDATA pdataPkg, int iPkgIndex, POBJDATA pdataResult, PAMLIHOOK_DATA * ppData) {
//
// Alocate and init AMLIHOOK_DATA
//
*ppData = AmliHook_AllocAndInitTestData(); if(!(*ppData)) return(STATUS_INSUFFICIENT_RESOURCES);
//
//--- Notify test driver off call
//
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_EVAL_PKG_DATA_ELEMENT; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_CALL; (*ppData)->Arg1 = (ULONG_PTR)pdataPkg; (*ppData)->Arg2 = (ULONG_PTR)iPkgIndex; (*ppData)->Arg3 = (ULONG_PTR)pdataResult;
return(AmliHook_TestNotify(*ppData)); }
NTSTATUS AMLITest_Post_EvalPkgDataElement( PAMLIHOOK_DATA * ppData, NTSTATUS Status) { return(AMLITest_Post_Generic(ppData,Status)); }
//
// Pre/Post FreeDataBuffs
//
NTSTATUS AMLITest_Pre_FreeDataBuffs( POBJDATA pdata, int icData, PAMLIHOOK_DATA * ppData) {
//
// Alocate and init AMLIHOOK_DATA
//
*ppData = AmliHook_AllocAndInitTestData(); if(!(*ppData)) return(STATUS_INSUFFICIENT_RESOURCES); //
//--- Notify test driver off call
//
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_FREE_DATA_BUFFS; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_CALL; (*ppData)->Arg1 = (ULONG_PTR)pdata; (*ppData)->Arg2 = (ULONG_PTR)icData;
return(AmliHook_TestNotify(*ppData)); }
NTSTATUS AMLITest_Post_FreeDataBuffs( PAMLIHOOK_DATA * ppData, NTSTATUS Status) { return(AMLITest_Post_Generic(ppData,Status)); }
//
// Pre/Post RegEventHandler.
//
NTSTATUS AMLIHook_Pre_RegEventHandler( ULONG dwEventType, ULONG_PTR uipEventData, PFNHND * pfnHandler, ULONG_PTR * uipParam, PAMLIHOOK_DATA * ppData) { NTSTATUS Status; PFNHND EventHandler; ULONG_PTR EventParam;
//
// Alocate and init AMLIHOOK_DATA
//
*ppData = AmliHook_AllocAndInitTestData(); if(!(*ppData)) return(STATUS_INSUFFICIENT_RESOURCES);
//
//--- Querry the test driver for Event handler to
//--- register.
//
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_REG_EVENT_HANDLER; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_QUERY; (*ppData)->Arg1 = (ULONG_PTR)dwEventType; (*ppData)->Arg2 = (ULONG_PTR)uipEventData; (*ppData)->Arg3 = (ULONG_PTR)*pfnHandler; (*ppData)->Arg4 = (ULONG_PTR)*uipParam;
AmliHook_TestNotify(*ppData);
if((*ppData)->Ret != STATUS_SUCCESS) DbgBreakPoint();
EventHandler = (PFNHND)(*ppData)->Arg3; EventParam = (ULONG_PTR)(*ppData)->Arg4;
if(EventHandler != *pfnHandler) { //
// Test driver will hook this call
// I will need values for both
// params.
//
if(!EventHandler) AmliHook_ProcessInternalError();
if(!EventParam) AmliHook_ProcessInternalError();
*pfnHandler = EventHandler; *uipParam = EventParam;
}
//
//--- Notify test driver off call
//
AmliHook_InitTestData(*ppData);
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_REG_EVENT_HANDLER; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_CALL; (*ppData)->Arg1 = (ULONG_PTR)dwEventType; (*ppData)->Arg2 = (ULONG_PTR)uipEventData;
return(AmliHook_TestNotify(*ppData)); }
NTSTATUS AMLIHook_Post_RegEventHandler( PAMLIHOOK_DATA * ppData, NTSTATUS Status) { return(AMLITest_Post_Generic(ppData,Status)); }
//
// CallBack , Pre/Post PauseInterpreter
//
VOID EXPORT AMLITest_PauseInterpreterCallBack( PVOID Context) { NTSTATUS Status; PFNAA AcpiCallBack=NULL; PVOID AcpiContext=NULL; PAMLIHOOK_DATA Data = (PAMLIHOOK_DATA)Context;
//
//--- Notify test driver off call status
//
Status = AmliHook_TestNotifyRet( Data, STATUS_SUCCESS);
AcpiCallBack = (PFNAA)Data->Arg1; AcpiContext = (PVOID)Data->Arg2;
ExFreePool(Data);
if(AcpiCallBack) { AcpiCallBack(AcpiContext); }
}
NTSTATUS AMLITest_Pre_PauseInterpreter( PFNAA * pfnCallBack, PVOID * Context, PAMLIHOOK_DATA * ppData) {
//
// Alocate and init AMLIHOOK_DATA
//
*ppData = AmliHook_AllocAndInitTestData(); if(!(*ppData)) return(STATUS_INSUFFICIENT_RESOURCES);
//
//--- Notify test driver off call
//
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_PAUSE_INTERPRETER; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_CALL; (*ppData)->Arg1 = (ULONG_PTR)*pfnCallBack; (*ppData)->Arg2 = (ULONG_PTR)*Context;
//
// Hook my Callback context
//
*pfnCallBack = AMLITest_PauseInterpreterCallBack; *Context = *ppData;
return(AmliHook_TestNotify(*ppData)); }
NTSTATUS AMLITest_Post_PauseInterpreter( PAMLIHOOK_DATA * ppData, NTSTATUS Status) {
if(Status == STATUS_PENDING) return(Status);
//
//--- Call back will not be called.
//
Status = AmliHook_TestNotifyRet( *ppData, Status);
ExFreePool(*ppData); *ppData = NULL;
return(Status); }
//
// Pre/Post ResumeInterpreter
//
NTSTATUS AMLITest_Pre_ResumeInterpreter( PAMLIHOOK_DATA * ppData) {
//
// Alocate and init AMLIHOOK_DATA
//
*ppData = AmliHook_AllocAndInitTestData(); if(!(*ppData)) return(STATUS_INSUFFICIENT_RESOURCES);
//
//--- Notify test driver off call
//
(*ppData)->Type = ACPIVER_DATA_TYPE_AMLI; (*ppData)->SubType = ACPIVER_DATA_SUBTYPE_RESUME_INTERPRETER; (*ppData)->State = AMLIHOOK_TEST_DATA_STATE_CALL;
return(AmliHook_TestNotify(*ppData)); }
NTSTATUS AMLITest_Post_ResumeInterpreter( PAMLIHOOK_DATA * ppData, NTSTATUS Status) { return(AMLITest_Post_Generic(ppData,Status)); }
|