devsound/a3ftrace/src/a3f_trace_heap.cpp
author hgs
Thu, 07 Oct 2010 22:34:12 +0100
changeset 0 b8ed18f6c07b
permissions -rw-r--r--
2010wk40
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     1
// Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     2
// All rights reserved.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     7
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     8
// Initial Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    10
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    11
// Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    12
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    13
// Description:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    14
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    15
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    16
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
// INCLUDE FILES
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
#include <e32std.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
#include <e32svr.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
#include "a3f_trace_heap.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
// EXTERNAL DATA STRUCTURES
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
//extern  ?external_data;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
TUint32* 	TraceHeap::iTraceMask = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
TUint32* 	TraceHeap::iTraceLevel = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
TBool*      TraceHeap::iApiOnly = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
RHeap* 		TraceHeap::iTraceHeap = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
// EXTERNAL FUNCTION PROTOTYPES  
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
//extern ?external_function( ?arg_type,?arg_type );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
// CONSTANTS
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
//const ?type ?constant_var = ?constant;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
// MACROS
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
//#define ?macro ?macro_def
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
// LOCAL CONSTANTS AND MACROS
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
//const ?type ?constant_var = ?constant;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
//#define ?macro_name ?macro_def
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
// MODULE DATA STRUCTURES
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
//enum ?declaration
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
//typedef ?declaration
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
// LOCAL FUNCTION PROTOTYPES
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
//?type ?function_name( ?arg_type, ?arg_type );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
// FORWARD DECLARATIONS
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
//class ?FORWARD_CLASSNAME;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
// ============================ MEMBER FUNCTIONS ===============================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
// ?classname::?member_function
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
// ?implementation_description
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
EXPORT_C void TraceHeap::CreateL(const TUint aDefaultMask)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
    // check that the heap is not already created
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
	if ( TraceHeap::iTraceHeap )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
	    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
	    return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
	    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
	    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
	// create a heap private to the owning process (heap can also be created as global)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
	TraceHeap::iTraceHeap = UserHeap::ChunkHeap( NULL, KMinHeapSize, KMinHeapSize, KMinHeapGrowBy );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
	__ASSERT_ALWAYS( TraceHeap::iTraceHeap, User::Leave(KErrGeneral));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
	// create iTrace... variables
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
	TraceHeap::iTraceMask = (TUint32*)TraceHeap::iTraceHeap->AllocL( sizeof(TUint32) );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
	*TraceHeap::iTraceMask = aDefaultMask;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
    TraceHeap::iTraceLevel = (TUint32*)TraceHeap::iTraceHeap->AllocL( sizeof(TUint32) );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
	*TraceHeap::iTraceLevel = 0;		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
    TraceHeap::iApiOnly = (TBool*)TraceHeap::iTraceHeap->AllocL( sizeof(TBool) );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
	*TraceHeap::iApiOnly = EFalse;		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
// ?classname::?member_function
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
// ?implementation_description
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
EXPORT_C TUint32 TraceHeap::TraceMask()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
	return *TraceHeap::iTraceMask;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
// ?classname::?member_function
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
// ?implementation_description
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
EXPORT_C void TraceHeap::SetTraceMask(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
	const TUint32 aTraceMask )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
    if ( !TraceHeap::iTraceHeap )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
        TRAP_IGNORE(TraceHeap::CreateL());   
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
	*TraceHeap::iTraceMask = aTraceMask;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
// ?classname::?member_function
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
// ?implementation_description
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
EXPORT_C TBool TraceHeap::IsMaskOn(
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
	const TUint32 aMask )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
	return ( *TraceHeap::iTraceMask & aMask );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
// ?classname::?member_function
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
// ?implementation_description
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
EXPORT_C void TraceHeap::SetLevel( const TUint32 aTraceLevel )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
    *TraceHeap::iTraceLevel = aTraceLevel;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
// ?classname::?member_function
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
// ?implementation_description
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
//    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
EXPORT_C TBool TraceHeap::IsBelowLevel( const TUint32 aLevel )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
    return (*TraceHeap::iTraceLevel > aLevel);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
// ?classname::?member_function
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
// ?implementation_description
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
//    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
EXPORT_C TUint32 TraceHeap::TraceLevel()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
    return *TraceHeap::iTraceLevel;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
// ?classname::?member_function
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
// ?implementation_description
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
//    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
EXPORT_C TBool TraceHeap::IsApiOnly()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
    return *iApiOnly;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
// ?classname::?member_function
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
// ?implementation_description
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
// (other items were commented in a header).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
// -----------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
//    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
EXPORT_C void TraceHeap::SetApiOnly( const TBool aApiOnly)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
    *iApiOnly = aApiOnly;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
//  End of File  
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179