khronosfws/openmax_al/inc/profileutilmacro.h
author hgs
Fri, 11 Jun 2010 19:59:23 -0500
changeset 25 6f7ceef7b1d1
parent 19 4a629bc82c5e
permissions -rw-r--r--
201023
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
19
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
*
25
hgs
parents: 19
diff changeset
    14
* Description:  Internal Header to define Performance Profiling macros.
hgs
parents: 19
diff changeset
    15
*               The MACROS can be defined in the MMP file to enable profiling.
19
hgs
parents:
diff changeset
    16
*
hgs
parents:
diff changeset
    17
*/
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#ifndef PROFILEUTILMACRO_H
hgs
parents:
diff changeset
    20
#define PROFILEUTILMACRO_H
hgs
parents:
diff changeset
    21
/*
hgs
parents:
diff changeset
    22
// MACROS to be defined to use profiling
hgs
parents:
diff changeset
    23
PROFILE_TIME
hgs
parents:
diff changeset
    24
PROFILE_RAM_USAGE
hgs
parents:
diff changeset
    25
PROFILE_HEAP_USAGE
hgs
parents:
diff changeset
    26
PRINT_TO_CONSOLE_TIME_DIFF
hgs
parents:
diff changeset
    27
PRINT_TO_CONSOLE_RAM_DIFF
hgs
parents:
diff changeset
    28
PRINT_TO_CONSOLE_HEAP_DIFF
hgs
parents:
diff changeset
    29
*/
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
#if defined(PROFILE_TIME) || defined(PROFILE_RAM_USAGE) || defined(PROFILE_HEAP_USAGE)
hgs
parents:
diff changeset
    32
#include <e32debug.h>
hgs
parents:
diff changeset
    33
#include <hal.h>
hgs
parents:
diff changeset
    34
#endif
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
#ifdef PROFILE_TIME
hgs
parents:
diff changeset
    37
#define TAG_TIME_PROFILING_BEGIN \
hgs
parents:
diff changeset
    38
    TTime beginProfilingTime; \
hgs
parents:
diff changeset
    39
    beginProfilingTime.HomeTime()
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
#define TAG_TIME_PROFILING_BEGIN_NO_VAR_DEF \
hgs
parents:
diff changeset
    42
    beginProfilingTime.HomeTime()
hgs
parents:
diff changeset
    43
hgs
parents:
diff changeset
    44
#define TAG_TIME_PROFILING_END \
hgs
parents:
diff changeset
    45
    TTime endProfilingTime; \
hgs
parents:
diff changeset
    46
    endProfilingTime.HomeTime(); \
hgs
parents:
diff changeset
    47
    TTimeIntervalMicroSeconds diffInMicroSecs = endProfilingTime.MicroSecondsFrom(beginProfilingTime)
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
#define TAG_TIME_PROFILING_END_NO_VAR_DEF \
hgs
parents:
diff changeset
    50
    endProfilingTime.HomeTime(); \
hgs
parents:
diff changeset
    51
    diffInMicroSecs = endProfilingTime.MicroSecondsFrom(beginProfilingTime)
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
#define PRINT_TO_CONSOLE_TIME_DIFF \
hgs
parents:
diff changeset
    54
    RDebug::Printf("VPROFILEDAT: %s : Time taken[%u]microseconds ", __PRETTY_FUNCTION__, diffInMicroSecs.Int64())
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
#define PRINT_TO_CONSOLE_HOME_TIME \
hgs
parents:
diff changeset
    57
    TTime homeTime; \
hgs
parents:
diff changeset
    58
    homeTime.HomeTime(); \
hgs
parents:
diff changeset
    59
    RDebug::Printf("VPROFILEDAT: %s : Home Time [%u]microseconds ", __PRETTY_FUNCTION__, homeTime.Int64())
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
#define PRINT_TO_CONSOLE_HOME_TIME_NO_VAR_DEF \
hgs
parents:
diff changeset
    62
    homeTime.HomeTime(); \
hgs
parents:
diff changeset
    63
    RDebug::Printf("VPROFILEDAT: %s : Home Time [%u]microseconds ", __PRETTY_FUNCTION__, homeTime.Int64())
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
#else /* Empty macros */
hgs
parents:
diff changeset
    66
#define TAG_TIME_PROFILING_BEGIN
hgs
parents:
diff changeset
    67
#define TAG_TIME_PROFILING_BEGIN_NO_VAR_DEF
hgs
parents:
diff changeset
    68
#define TAG_TIME_PROFILING_END
hgs
parents:
diff changeset
    69
#define TAG_TIME_PROFILING_END_NO_VAR_DEF
hgs
parents:
diff changeset
    70
#define PRINT_TO_CONSOLE_TIME_DIFF
hgs
parents:
diff changeset
    71
#define PRINT_TO_CONSOLE_HOME_TIME
hgs
parents:
diff changeset
    72
#define PRINT_TO_CONSOLE_HOME_TIME_NO_VAR_DEF
hgs
parents:
diff changeset
    73
#endif /*PROFILE_TIME*/
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
#ifdef PROFILE_RAM_USAGE
hgs
parents:
diff changeset
    76
#define TAG_RAM_PROFILING_BEGIN \
hgs
parents:
diff changeset
    77
    TInt beginProfilingRAM; \
hgs
parents:
diff changeset
    78
    TInt err1 = HAL::Get(HALData::EMemoryRAMFree, beginProfilingRAM)
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
#define TAG_RAM_PROFILING_END \
hgs
parents:
diff changeset
    81
    TInt endProfilingRAM; \
hgs
parents:
diff changeset
    82
    TInt err2 = HAL::Get(HALData::EMemoryRAMFree, endProfilingRAM)
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
#define PRINT_TO_CONSOLE_RAM_DIFF \
hgs
parents:
diff changeset
    85
    if ((err1 == KErrNone) && (err2 == KErrNone)) \
hgs
parents:
diff changeset
    86
        { \
hgs
parents:
diff changeset
    87
        TInt diffRAM = (beginProfilingRAM - endProfilingRAM); \
hgs
parents:
diff changeset
    88
        if ( diffRAM > 0 ) \
hgs
parents:
diff changeset
    89
            { \
hgs
parents:
diff changeset
    90
            RDebug::Printf("VPROFILEDAT: %s : RAM used[%u]bytes ", __PRETTY_FUNCTION__, diffRAM); \
hgs
parents:
diff changeset
    91
            } \
hgs
parents:
diff changeset
    92
        else \
hgs
parents:
diff changeset
    93
            { \
hgs
parents:
diff changeset
    94
            RDebug::Printf("VPROFILEDAT: %s : RAM freed[%u]bytes ", __PRETTY_FUNCTION__, (-diffRAM)); \
hgs
parents:
diff changeset
    95
            } \
hgs
parents:
diff changeset
    96
        } \
hgs
parents:
diff changeset
    97
    else \
hgs
parents:
diff changeset
    98
        { \
hgs
parents:
diff changeset
    99
        RDebug::Printf("VPROFILEDAT: %s : Error1[%d] Error2[%d] ", __PRETTY_FUNCTION__, err1, err2); \
hgs
parents:
diff changeset
   100
        }
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
#else /* Empty macros */
hgs
parents:
diff changeset
   103
#define TAG_RAM_PROFILING_BEGIN
hgs
parents:
diff changeset
   104
#define TAG_RAM_PROFILING_END
hgs
parents:
diff changeset
   105
#define PRINT_TO_CONSOLE_RAM_DIFF
hgs
parents:
diff changeset
   106
#endif /*PROFILE_RAM_USAGE*/
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
#ifdef PROFILE_HEAP_USAGE
hgs
parents:
diff changeset
   109
#define TAG_DEFAULT_HEAP_PROFILING_BEGIN \
hgs
parents:
diff changeset
   110
    TInt beginProfilingHEAPBiggestBlock; \
hgs
parents:
diff changeset
   111
    TInt beginProfilingHEAP = User::Available(beginProfilingHEAPBiggestBlock) \
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
#define TAG_DEFAULT_HEAP_PROFILING_END \
hgs
parents:
diff changeset
   114
    TInt endProfilingHEAPBiggestBlock; \
hgs
parents:
diff changeset
   115
    TInt endProfilingHEAP = User::Available(endProfilingHEAPBiggestBlock) \
hgs
parents:
diff changeset
   116
hgs
parents:
diff changeset
   117
#define PRINT_TO_CONSOLE_HEAP_DIFF \
hgs
parents:
diff changeset
   118
    TInt diffHEAP = beginProfilingHEAP - endProfilingHEAP; \
hgs
parents:
diff changeset
   119
    if ( diffHEAP > 0 ) \
hgs
parents:
diff changeset
   120
        { \
hgs
parents:
diff changeset
   121
        RDebug::Printf("VPROFILEDAT: %s : HEAP used[%u]bytes ", __PRETTY_FUNCTION__, diffHEAP); \
hgs
parents:
diff changeset
   122
        } \
hgs
parents:
diff changeset
   123
    else \
hgs
parents:
diff changeset
   124
        { \
hgs
parents:
diff changeset
   125
        RDebug::Printf("VPROFILEDAT: %s : HEAP freed[%u]bytes ", __PRETTY_FUNCTION__, (-diffHEAP)); \
hgs
parents:
diff changeset
   126
        }
hgs
parents:
diff changeset
   127
#else /* Empty macros */
hgs
parents:
diff changeset
   128
#define TAG_DEFAULT_HEAP_PROFILING_BEGIN
hgs
parents:
diff changeset
   129
#define TAG_DEFAULT_HEAP_PROFILING_END
hgs
parents:
diff changeset
   130
#define PRINT_TO_CONSOLE_HEAP_DIFF
hgs
parents:
diff changeset
   131
#endif /*PROFILE_HEAP_USAGE*/
hgs
parents:
diff changeset
   132
hgs
parents:
diff changeset
   133
#endif /* PROFILEUTILMACRO_H */