analyzetool/storageserver/server/inc/atmemoryentry.h
author hgs
Thu, 13 May 2010 23:59:27 +0300
changeset 20 a71a3e32a2ae
permissions -rw-r--r--
201019
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
20
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Declaration of the class CATMemoryEntry
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#ifndef ATMEMORYENTRY_H
hgs
parents:
diff changeset
    20
#define ATMEMORYENTRY_H
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
//  INCLUDES
hgs
parents:
diff changeset
    24
#include <e32base.h>
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
// CLASS DECLARATION
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
/**
hgs
parents:
diff changeset
    30
*  A class for storing memory entries when the server is informed that memory has been
hgs
parents:
diff changeset
    31
*  allocated. The class stores the memory address of a new allocation and a pointer to
hgs
parents:
diff changeset
    32
*  a buffer including the current call stack. It also stores a time stamp, and the size
hgs
parents:
diff changeset
    33
*  of the allocation. 
hgs
parents:
diff changeset
    34
*     The class has member methods for evaluating two different objects of this class
hgs
parents:
diff changeset
    35
*  with each other. In the construction the class takes a pointer to the call stack
hgs
parents:
diff changeset
    36
*  buffer, but it does not create the buffer itself. However, it is responsible for
hgs
parents:
diff changeset
    37
*  deleting the buffer in the destruction.
hgs
parents:
diff changeset
    38
*/
hgs
parents:
diff changeset
    39
class CATMemoryEntry : public CBase
hgs
parents:
diff changeset
    40
    {
hgs
parents:
diff changeset
    41
    public: // Constructor
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
        /**
hgs
parents:
diff changeset
    44
        * Constructor.
hgs
parents:
diff changeset
    45
        * @param aMemAddress An address to allocated memory.
hgs
parents:
diff changeset
    46
        * @param aCallstackBuf A pointer to a buffer containing call stack's memory
hgs
parents:
diff changeset
    47
        *   addresses.
hgs
parents:
diff changeset
    48
        * @param aAllocTime The current time in a 64-bit form.
hgs
parents:
diff changeset
    49
        * @param aAllocSize The size of an allocated memory chunk.
hgs
parents:
diff changeset
    50
        */ 
hgs
parents:
diff changeset
    51
        CATMemoryEntry( TUint32 aMemAddress, const CBufFlat* aCallstackBuf,
hgs
parents:
diff changeset
    52
                        const TInt64& aAllocTime, TInt aAllocSize );
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
        /**
hgs
parents:
diff changeset
    55
        * Destructor
hgs
parents:
diff changeset
    56
        */
hgs
parents:
diff changeset
    57
        virtual ~CATMemoryEntry();
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
    public:
hgs
parents:
diff changeset
    60
        /**
hgs
parents:
diff changeset
    61
        * Compares two objects of this class based on the allocation time.
hgs
parents:
diff changeset
    62
        * @param aFirst The first object of this class to be compared.
hgs
parents:
diff changeset
    63
        * @param aSecond The second object of this class to be compared.
hgs
parents:
diff changeset
    64
        * @return  Zero, if the two objects are equal. A negative value,
hgs
parents:
diff changeset
    65
        *   if the first object is less than the second. A positive value,
hgs
parents:
diff changeset
    66
        *   if the first object is greater than the second.
hgs
parents:
diff changeset
    67
        */
hgs
parents:
diff changeset
    68
        static TInt Compare( const CATMemoryEntry& aFirst,
hgs
parents:
diff changeset
    69
                             const CATMemoryEntry& aSecond );
hgs
parents:
diff changeset
    70
hgs
parents:
diff changeset
    71
        /**
hgs
parents:
diff changeset
    72
        * Checks if two objects of this class match based on the objects's
hgs
parents:
diff changeset
    73
        * saved memory allocation addresses.
hgs
parents:
diff changeset
    74
        * @param aFirst The first object of this class to be evaluated.
hgs
parents:
diff changeset
    75
        * @param aSecond The second object of this class to be evaluated.
hgs
parents:
diff changeset
    76
        * @return ETrue, if the two objects match. EFalse otherwise.
hgs
parents:
diff changeset
    77
        */
hgs
parents:
diff changeset
    78
        static TBool Match( const CATMemoryEntry& aFirst,
hgs
parents:
diff changeset
    79
                            const CATMemoryEntry& aSecond );
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
    public:
hgs
parents:
diff changeset
    82
hgs
parents:
diff changeset
    83
        /** For storing an address of a memory allocation. */
hgs
parents:
diff changeset
    84
        const TUint32 iMemAddress;
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
        /** A pointer to an array for storing the current call stack. */
hgs
parents:
diff changeset
    87
        const CBufFlat* const iCallstackBuf;
hgs
parents:
diff changeset
    88
        
hgs
parents:
diff changeset
    89
        /** For storing the time when an allocation has occured. */
hgs
parents:
diff changeset
    90
        const TInt64 iAllocTime;
hgs
parents:
diff changeset
    91
        
hgs
parents:
diff changeset
    92
        /** For storing the size of an allocation. */
hgs
parents:
diff changeset
    93
        const TInt iAllocSize;
hgs
parents:
diff changeset
    94
        
hgs
parents:
diff changeset
    95
    };
hgs
parents:
diff changeset
    96
  
hgs
parents:
diff changeset
    97
  
hgs
parents:
diff changeset
    98
#endif      // ATMEMORYENTRY_H