version 1.22.8.5, 2013/10/13 21:31:59
|
version 1.23, 2013/10/13 22:46:58
|
|
|
// Pegasus CIM_StatisticalData | // Pegasus CIM_StatisticalData |
// message type | // message type |
// -------------- ------------------- | // -------------- ------------------- |
"Unknown", // 0 default |
//"Unknown", // 0 default |
"Other", // 1 mapped |
//"Other", // 1 mapped |
"Batched", // 2 not used |
//"Batched", // 2 not used |
"GetClass", // 1 3 | "GetClass", // 1 3 |
"GetInstance", // 2 4 | "GetInstance", // 2 4 |
"IndicationDelivery", // 3 26 | "IndicationDelivery", // 3 26 |
|
|
"AssociatorNames", // 17 17 | "AssociatorNames", // 17 17 |
"References", // 18 18 | "References", // 18 18 |
"ReferenceNames", // 19 20 | "ReferenceNames", // 19 20 |
"SetProperty", // 20 21 |
"GetProperty", // 20 20 |
"GetQualifier", // 21 22 |
"SetProperty", // 21 21 |
"SetQualifier", // 22 23 |
"GetQualifier", // 22 22 |
"DeleteQualifier", // 23 24 |
"SetQualifier", // 23 23 |
"EnumerateQualifiers", // 24 25 |
"DeleteQualifier", // 24 24 |
|
"EnumerateQualifiers", // 25 25 |
// Entries below this point are not part of the CIM Class and are treated | // Entries below this point are not part of the CIM Class and are treated |
// as OtherOperationTypes in the instance. |
// as OtherOperationTypes in the CIM_CIMOMStatisticalData instance. |
"InvokeMethod" // 25 Not Present index = 26 |
"InvokeMethod" // 26 Not Present index = 26 |
//EXP_PULL_BEGIN |
|
//// TODO these are not defined in CIM_StatisticalData class and are |
|
/// represented by the Other groping with supplementary property |
|
"OpenEnumerateInstances", // 71 27 |
|
"OpenEnumerateInstancePaths", // 72 |
|
"OpenReferences", // 73 |
|
"OpenReferenceNames", // 74 |
|
"OpenAssociators", // 75 |
|
"OpenAssociatorPaths", // 76 |
|
"PullInstancesWithPath", // 77 |
|
"PullInstancePaths", // 77 |
|
"CloseEnumeration" , // 79 |
|
//EXP_PULL_END |
|
| |
}; | }; |
| |
const Uint32 StatisticalData::length = NUMBER_OF_TYPES; | const Uint32 StatisticalData::length = NUMBER_OF_TYPES; |
| |
StatisticalData* StatisticalData::cur = NULL; |
// Pointer to StatisticalData table if it exists. |
|
StatisticalData* StatisticalData::table = NULL; |
| |
// If first call, create the statistical data array | // If first call, create the statistical data array |
StatisticalData* StatisticalData::current() | StatisticalData* StatisticalData::current() |
{ | { |
if (cur == NULL) |
if (table == NULL) |
{ | { |
cur = new StatisticalData(); |
table = new StatisticalData(); |
} | } |
return cur; |
return table; |
} | } |
| |
// Clear the statisticalData Array |
// Constructor clears the statisticalData Array and sets the gatherint |
|
// flag to zero |
StatisticalData::StatisticalData() | StatisticalData::StatisticalData() |
{ | { |
copyGSD = 0; | copyGSD = 0; |
|
clear(); |
|
} |
| |
|
void StatisticalData::clear() |
|
{ |
|
AutoMutex autoMut(_mutex); |
for (unsigned int i=0; i<StatisticalData::length; i++) | for (unsigned int i=0; i<StatisticalData::length; i++) |
{ | { |
numCalls[i] = 0; | numCalls[i] = 0; |
|
|
} | } |
} | } |
| |
|
|
|
String StatisticalData::getRequestName(Uint16 i) |
|
{ |
|
return requestName[i]; |
|
} |
|
|
void StatisticalData::addToValue(Sint64 value, | void StatisticalData::addToValue(Sint64 value, |
MessageType msgType, | MessageType msgType, |
StatDataType t) | StatDataType t) |
{ | { |
// Map MessageType to statistic type |
// Map MessageType to statistic type. Requires multiple tests because |
|
// mapping request and responses to the request types. |
Uint16 type; | Uint16 type; |
if ((msgType) >= CIM_OPEN_ENUMERATE_INSTANCES_RESPONSE_MESSAGE) |
|
{ |
// if is response type, substract starting point of responses. |
type = msgType - CIM_SET_QUALIFIER_RESPONSE_MESSAGE; |
if (msgType >= CIM_GET_CLASS_RESPONSE_MESSAGE) |
} |
|
else if (msgType >= CIM_ENUMERATE_CLASSES_RESPONSE_MESSAGE) |
|
{ |
|
type = msgType - CIM_OPEN_ENUMERATE_INSTANCES_REQUEST_MESSAGE; |
|
} |
|
else if (msgType >= CIM_GET_CLASS_RESPONSE_MESSAGE) |
|
{ | { |
type = msgType - CIM_GET_CLASS_RESPONSE_MESSAGE; | type = msgType - CIM_GET_CLASS_RESPONSE_MESSAGE; |
} | } |
else | else |
{ | { |
type = msgType; |
type = msgType - 1; |
} | } |
| |
//// KS_TODO diagnostic to confirm that the above if statements are correct |
|
//// KS_DELETE when we get bug 9786 completely integrated. |
|
PEG_TRACE((TRC_STATISTICAL_DATA, Tracer::LEVEL4, |
|
"StatisticalData::addToValue msgType %s %u. stat type %u", |
|
MessageTypeToString(msgType), |
|
msgType, type )); |
|
|
|
// Test if valid statistic type | // Test if valid statistic type |
if (type >= NUMBER_OF_TYPES) | if (type >= NUMBER_OF_TYPES) |
{ | { |