(file) Return to StatisticalData.cpp CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Common

Diff for /pegasus/src/Pegasus/Common/StatisticalData.cpp between version 1.14 and 1.22.22.1

version 1.14, 2006/02/07 23:53:45 version 1.22.22.1, 2013/10/15 05:10:36
Line 1 
Line 1 
 //%2006////////////////////////////////////////////////////////////////////////  //%LICENSE////////////////////////////////////////////////////////////////
 // //
 // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development  // Licensed to The Open Group (TOG) under one or more contributor license
 // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.  // agreements.  Refer to the OpenPegasusNOTICE.txt file distributed with
 // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;  // this work for additional information regarding copyright ownership.
 // IBM Corp.; EMC Corporation, The Open Group.  // Each contributor licenses this file to you under the OpenPegasus Open
 // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;  // Source License; you may not use this file except in compliance with the
 // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.  // License.
 // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;  //
 // EMC Corporation; VERITAS Software Corporation; The Open Group.  // Permission is hereby granted, free of charge, to any person obtaining a
 // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;  // copy of this software and associated documentation files (the "Software"),
 // EMC Corporation; Symantec Corporation; The Open Group.  // to deal in the Software without restriction, including without limitation
 //  // the rights to use, copy, modify, merge, publish, distribute, sublicense,
 // Permission is hereby granted, free of charge, to any person obtaining a copy  // and/or sell copies of the Software, and to permit persons to whom the
 // of this software and associated documentation files (the "Software"), to  // Software is furnished to do so, subject to the following conditions:
 // deal in the Software without restriction, including without limitation the  //
 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or  // The above copyright notice and this permission notice shall be included
 // sell copies of the Software, and to permit persons to whom the Software is  // in all copies or substantial portions of the Software.
 // furnished to do so, subject to the following conditions:  //
 //  // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN  // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED  // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT  // IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
 // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR  // CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT  // TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN  // SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION  //
 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.  //////////////////////////////////////////////////////////////////////////
 //  
 //==============================================================================  
 //  
 // Author: Arthur Pichlkostner  
 //             (checked in: Markus Mueller sedgewick_de@yahoo.de)  
 // Modified By: Amit K Arora, IBM (amita@in.ibm.com) for Bug#1090  
 // //
 //%///////////////////////////////////////////////////////////////////////////// //%/////////////////////////////////////////////////////////////////////////////
  
Line 43 
Line 37 
  
 // The table on the right represents the mapping from the enumerated types // The table on the right represents the mapping from the enumerated types
 // in the CIM_CIMOMStatisticalDate class ValueMap versus the internal // in the CIM_CIMOMStatisticalDate class ValueMap versus the internal
 // message type defined in Message.cpp. This conversion is performed by  // message type defined in Message.h. This conversion is performed by
 // getOpType() in CIMOMStatDataProvider.cpp. // getOpType() in CIMOMStatDataProvider.cpp.
 // //
  
Line 51 
Line 45 
 { {
                                     // Enumerated     ValueMap Value                                     // Enumerated     ValueMap Value
                                     // value from     from class                                     // value from     from class
                                     // internal       CIM_StatisticalData                                      // Pegasus        CIM_StatisticalData
                                     // message type                                     // message type
                                     // -------------- -------------------                                     // -------------- -------------------
   //"Unknown",                        //                 0   default
   //"Other",                          //                 1   mapped
   //"Batched",                        //                 2   not used
   "GetClass",                       //     1           3   "GetClass",                       //     1           3
   "GetInstance",                    //     2           4   "GetInstance",                    //     2           4
   "IndicationDelivery",             //     3           26   "IndicationDelivery",             //     3           26
Line 64 
Line 61 
   "ModifyClass",                    //     8           9   "ModifyClass",                    //     8           9
   "ModifyInstance",                 //     9          10   "ModifyInstance",                 //     9          10
   "EnumerateClasses",               //    10          11   "EnumerateClasses",               //    10          11
   "EnumerateClassNames",            //    11          12    "EnumerateClassNames",            //    12          12
   "EnumerateInstances",             //    12          13    "EnumerateInstances",             //    13          13
   "EnumerateInstanceNames",         //    13          14    "EnumerateInstanceNames",         //    14          14
   "ExecQuery",                      //    14          15    "ExecQuery",                      //    15          15
   "Associators",                    //    15          16    "Associators",                    //    16          16
   "AssociatorNames",                //    16          17    "AssociatorNames",                //    17          17
   "References",                     //    17          18    "References",                     //    18          18
   "ReferenceNames",                 //    18          19    "ReferenceNames",                 //    19          20
   "GetProperty",                    //    19          20    "GetProperty",                    //    20          20
   "SetProperty",                    //    20          21    "SetProperty",                    //    21          21
   "GetQualifier",                   //    21          22    "GetQualifier",                   //    22          22
   "SetQualifier",                   //    22          23    "SetQualifier",                   //    23          23
   "DeleteQualifier",                //    23          24    "DeleteQualifier",                //    24          24
   "EnumerateQualifiers",            //    24          25    "EnumerateQualifiers",            //    25          25
   "InvokeMethod"                    //    25          Not Present  // Entries below this point are not part of the CIM Class and are treated
   // as OtherOperationTypes in the CIM_CIMOMStatisticalData instance.
     "InvokeMethod"                    //    26          Not Present index = 26
   
 }; };
  
 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
 StatisticalData* StatisticalData::current() StatisticalData* StatisticalData::current()
 { {
     if (cur == NULL)      if (table == NULL)
     {     {
         cur = new StatisticalData();          table = new StatisticalData();
     }     }
     return cur;      return table;
 } }
  
   // 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;
Line 108 
Line 117 
     }     }
 } }
  
 void StatisticalData::addToValue(Sint64 value, Uint16 type, Uint32 t)  
   String StatisticalData::getRequestName(Uint16 i)
   {
       return requestName[i];
   }
   
   void StatisticalData::addToValue(Sint64 value,
       MessageType msgType,
       StatDataType t)
   {
       // Map MessageType to statistic type. Requires multiple tests because
       // mapping request and responses to the request types.
       Uint16 type;
   
       // if is response type, substract starting point of responses.
       if (msgType >= CIM_GET_CLASS_RESPONSE_MESSAGE)
       {
           type = msgType - CIM_GET_CLASS_RESPONSE_MESSAGE;
       }
       else
 { {
           type = msgType - 1;
       }
   
       // Test if valid statistic type
     if (type >= NUMBER_OF_TYPES)     if (type >= NUMBER_OF_TYPES)
     {     {
          Tracer::trace(TRC_DISCARDED_DATA, Tracer::LEVEL2,           PEG_TRACE((TRC_DISCARDED_DATA, Tracer::LEVEL2,
              "StatData: Statistical Data Discarded.  "              "StatData: Statistical Data Discarded.  "
                  "Invalid Request Type =  %u", type);                   "Invalid Request Type =  %u", type));
          return;          return;
     }     }
  
Line 126 
Line 158 
             case PEGASUS_STATDATA_SERVER:             case PEGASUS_STATDATA_SERVER:
                 numCalls[type] += 1;                 numCalls[type] += 1;
                 cimomTime[type] += value;                 cimomTime[type] += value;
                 Tracer::trace(TRC_STATISTICAL_DATA, Tracer::LEVEL2,                  PEG_TRACE((TRC_STATISTICAL_DATA, Tracer::LEVEL4,
                     "StatData: SERVER: %s(%d): count = %"                     "StatData: SERVER: %s(%d): count = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d; value = %"                         PEGASUS_64BIT_CONVERSION_WIDTH "d; value = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d; total = %"                         PEGASUS_64BIT_CONVERSION_WIDTH "d; total = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d",                         PEGASUS_64BIT_CONVERSION_WIDTH "d",
                     (const char *)requestName[type].getCString(), type,                     (const char *)requestName[type].getCString(), type,
                     numCalls[type], value, cimomTime[type]);                      numCalls[type], value, cimomTime[type]));
                 break;                 break;
             case PEGASUS_STATDATA_PROVIDER:             case PEGASUS_STATDATA_PROVIDER:
                 providerTime[type] += value;                 providerTime[type] += value;
                 Tracer::trace(TRC_STATISTICAL_DATA, Tracer::LEVEL2,                  PEG_TRACE((TRC_STATISTICAL_DATA, Tracer::LEVEL4,
                     "StatData: PROVIDER: %s(%d): count = %"                     "StatData: PROVIDER: %s(%d): count = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d; value = %"                         PEGASUS_64BIT_CONVERSION_WIDTH "d; value = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d; total = %"                         PEGASUS_64BIT_CONVERSION_WIDTH "d; total = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d",                         PEGASUS_64BIT_CONVERSION_WIDTH "d",
                     (const char *)requestName[type].getCString(), type,                     (const char *)requestName[type].getCString(), type,
                     numCalls[type], value, providerTime[type]);                      numCalls[type], value, providerTime[type]));
                 break;                 break;
         case PEGASUS_STATDATA_BYTES_SENT:         case PEGASUS_STATDATA_BYTES_SENT:
                 responseSize[type] += value;                 responseSize[type] += value;
                 Tracer::trace(TRC_STATISTICAL_DATA, Tracer::LEVEL2,                  PEG_TRACE((TRC_STATISTICAL_DATA, Tracer::LEVEL4,
                     "StatData: BYTES_SENT: %s(%d): count = %"                     "StatData: BYTES_SENT: %s(%d): count = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d; value = %"                         PEGASUS_64BIT_CONVERSION_WIDTH "d; value = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d; total = %"                         PEGASUS_64BIT_CONVERSION_WIDTH "d; total = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d",                         PEGASUS_64BIT_CONVERSION_WIDTH "d",
                     (const char *)requestName[type].getCString(), type,                     (const char *)requestName[type].getCString(), type,
                     numCalls[type], value, responseSize[type]);                      numCalls[type], value, responseSize[type]));
                 break;                 break;
         case PEGASUS_STATDATA_BYTES_READ:         case PEGASUS_STATDATA_BYTES_READ:
                 requestSize[type] += value;                 requestSize[type] += value;
                 Tracer::trace(TRC_STATISTICAL_DATA, Tracer::LEVEL2,                  PEG_TRACE((TRC_STATISTICAL_DATA, Tracer::LEVEL4,
                     "StatData: BYTES_READ: %s(%d): count = %"                     "StatData: BYTES_READ: %s(%d): count = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d; value = %"                         PEGASUS_64BIT_CONVERSION_WIDTH "d; value = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d; total = %"                         PEGASUS_64BIT_CONVERSION_WIDTH "d; total = %"
                         PEGASUS_64BIT_CONVERSION_WIDTH "d",                         PEGASUS_64BIT_CONVERSION_WIDTH "d",
                     (const char *)requestName[type].getCString(), type,                     (const char *)requestName[type].getCString(), type,
                     numCalls[type], value, requestSize[type]);                      numCalls[type], value, requestSize[type]));
                 break;                 break;
         }         }
     }     }
Line 170 
Line 202 
  
  void StatisticalData::setCopyGSD(Boolean flag)  void StatisticalData::setCopyGSD(Boolean flag)
 { {
   
         copyGSD = flag;         copyGSD = flag;
 } }
  


Legend:
Removed from v.1.14  
changed lines
  Added in v.1.22.22.1

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2