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