Leaked source code of windows server 2003
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.
 
 
 
 
 
 

217 lines
8.8 KiB

/********************************************************************
Copyright (c) 1999 Microsoft Corporation
Module Name:
PCH_ResourceMemRange.CPP
Abstract:
WBEM provider class implementation for PCH_ResourceMemRange class
Revision History:
Ghim-Sim Chua (gschua) 04/27/99
- Created
********************************************************************/
#include "pchealth.h"
#include "PCH_ResourceMemRange.h"
#include "confgmgr.h"
/////////////////////////////////////////////////////////////////////////////
// tracing stuff
#ifdef THIS_FILE
#undef THIS_FILE
#endif
static char __szTraceSourceFile[] = __FILE__;
#define THIS_FILE __szTraceSourceFile
#define TRACE_ID DCID_RESOURCEMEMRANGE
CPCH_ResourceMemRange MyPCH_ResourceMemRangeSet (PROVIDER_NAME_PCH_RESOURCEMEMRANGE, PCH_NAMESPACE) ;
// Property names
//===============
const static WCHAR* pBase = L"Base" ;
const static WCHAR* pCategory = L"Category" ;
const static WCHAR* pTimeStamp = L"TimeStamp" ;
const static WCHAR* pChange = L"Change" ;
const static WCHAR* pEnd = L"End" ;
const static WCHAR* pMax = L"Max" ;
const static WCHAR* pMin = L"Min" ;
const static WCHAR* pName = L"Name" ;
/*****************************************************************************
*
* FUNCTION : CPCH_ResourceMemRange::EnumerateInstances
*
* DESCRIPTION : Returns all the instances of this class.
*
* INPUTS : A pointer to the MethodContext for communication with WinMgmt.
* A long that contains the flags described in
* IWbemServices::CreateInstanceEnumAsync. Note that the following
* flags are handled by (and filtered out by) WinMgmt:
* WBEM_FLAG_DEEP
* WBEM_FLAG_SHALLOW
* WBEM_FLAG_RETURN_IMMEDIATELY
* WBEM_FLAG_FORWARD_ONLY
* WBEM_FLAG_BIDIRECTIONAL
*
* RETURNS : WBEM_S_NO_ERROR if successful
*
* COMMENTS : TO DO: All instances on the machine should be returned here.
* If there are no instances, return WBEM_S_NO_ERROR.
* It is not an error to have no instances.
*
*****************************************************************************/
HRESULT CPCH_ResourceMemRange::EnumerateInstances(
MethodContext* pMethodContext,
long lFlags
)
{
TraceFunctEnter("CPCH_ResourceIRQ::EnumerateInstances");
CConfigManager cfgManager;
CDeviceCollection deviceList;
HRESULT hRes = WBEM_S_NO_ERROR;
//
// Get the date and time
//
SYSTEMTIME stUTCTime;
GetSystemTime(&stUTCTime);
// get the device list
if (cfgManager.GetDeviceList(deviceList))
{
REFPTR_POSITION pos;
// Initialize device enumerator
if (deviceList.BeginEnum(pos))
{
CConfigMgrDevice* pDevice = NULL;
try
{
// Walk the list of devices
while ((NULL != (pDevice = deviceList.GetNext(pos))))
{
CDeviceMemoryCollection memList;
try
{
// Get DMAChannel list for this device
if (pDevice->GetDeviceMemoryResources(memList))
{
REFPTR_POSITION pos2;
// Initialize DMA enumerator
if (memList.BeginEnum(pos2))
{
CDeviceMemoryDescriptor *pMem = NULL;
// Walk the list of DMA
while (( NULL != (pMem = memList.GetNext(pos2))))
{
try
{
// Create a new instance based on the passed-in MethodContext
CInstancePtr pInstance(CreateNewInstance(pMethodContext), false);
CHString chstrVar;
CComVariant varValue;
TCHAR strTemp[64];
// Timestamp
if (!pInstance->SetDateTime(pTimeStamp, WBEMTime(stUTCTime)))
ErrorTrace(TRACE_ID, "SetDateTime on Timestamp Field failed.");
// Snapshot
if (!pInstance->SetCHString(pChange, L"Snapshot"))
ErrorTrace(TRACE_ID, "SetCHString on Change Field failed.");
// Name
if (pDevice->GetDeviceID(chstrVar))
if (!pInstance->SetCHString(pName, chstrVar))
ErrorTrace(TRACE_ID, "SetCHString on Name field failed.");
// Category
if (pDevice->GetClass(chstrVar))
if (!pInstance->SetCHString(pCategory, chstrVar))
ErrorTrace(TRACE_ID, "SetCHString on Category field failed.");
// Base
_stprintf(strTemp, "x%I64X", pMem->GetBaseAddress());
varValue = strTemp;
if (!pInstance->SetVariant(pBase, varValue))
ErrorTrace(TRACE_ID, "SetVariant on Base field failed.");
// End
_stprintf(strTemp, "x%I64X", pMem->GetEndAddress());
varValue = strTemp;
if (!pInstance->SetVariant(pEnd, varValue))
ErrorTrace(TRACE_ID, "SetVariant on End field failed.");
/*
// Alias
varValue = (long)pMem->GetAlias();
if (!pInstance->SetVariant(pAlias, varValue))
ErrorTrace(TRACE_ID, "SetVariant on Alias field failed.");
// Decode
varValue = (long)pMem->GetDecode();
if (!pInstance->SetVariant(pDecode, varValue))
ErrorTrace(TRACE_ID, "SetVariant on Decode field failed.");
*/
// Commit this
hRes = pInstance->Commit();
if (FAILED(hRes))
ErrorTrace(TRACE_ID, "Commit on Instance failed.");
}
catch (...)
{
pMem->Release();
throw;
}
// release the DMA object
pMem->Release();
}
}
}
}
catch (...)
{
pDevice->Release();
memList.EndEnum();
throw;
}
// GetNext() AddRefs
pDevice->Release();
// Always call EndEnum(). For all Beginnings, there must be an End
memList.EndEnum();
}
}
catch (...)
{
deviceList.EndEnum();
throw;
}
// Always call EndEnum(). For all Beginnings, there must be an End
deviceList.EndEnum();
}
}
TraceFunctLeave();
return hRes ;
// pInstance->SetVariant(pBase, <Property Value>);
// pInstance->SetVariant(pCategory, <Property Value>);
// pInstance->SetVariant(pTimeStamp, <Property Value>);
// pInstance->SetVariant(pChange, <Property Value>);
// pInstance->SetVariant(pEnd, <Property Value>);
// pInstance->SetVariant(pMax, <Property Value>);
// pInstance->SetVariant(pMin, <Property Value>);
// pInstance->SetVariant(pName, <Property Value>);
}