analyzetool/dynamicmemoryhook/src/threadstack.cpp
author hgs
Mon, 06 Sep 2010 15:00:47 +0300
changeset 50 827f48a8fbdf
parent 20 a71a3e32a2ae
permissions -rw-r--r--
201035
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:  Definitions for the class TThreadStack.
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
#include "threadstack.h"
hgs
parents:
diff changeset
    20
#include "atlog.h"
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    23
// TThreadStack::TThreadStack()
hgs
parents:
diff changeset
    24
// C++ default constructor.
hgs
parents:
diff changeset
    25
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    26
//
hgs
parents:
diff changeset
    27
TThreadStack::TThreadStack( TThreadId aId, TUint32 aStackStart ) :
hgs
parents:
diff changeset
    28
    iId( aId ),
hgs
parents:
diff changeset
    29
    iStackStart( aStackStart )
hgs
parents:
diff changeset
    30
    {
hgs
parents:
diff changeset
    31
    LOGSTR2( "ATMH TThreadStack::TThreadStack() aStackStart: %i", aStackStart );
hgs
parents:
diff changeset
    32
    }
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    35
// TThreadStack::ThreadStackStart()
hgs
parents:
diff changeset
    36
// Checks if this is the current thread and if this is the current
hgs
parents:
diff changeset
    37
// thread assings value to the given parameter
hgs
parents:
diff changeset
    38
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    39
//
hgs
parents:
diff changeset
    40
TBool TThreadStack::ThreadStackStart( TUint32& aStackStart )
hgs
parents:
diff changeset
    41
    {
hgs
parents:
diff changeset
    42
    LOGSTR1( "ATMH TThreadStack::ThreadStackStart");
hgs
parents:
diff changeset
    43
    
hgs
parents:
diff changeset
    44
    if ( RThread().Id() == iId )
hgs
parents:
diff changeset
    45
        {
hgs
parents:
diff changeset
    46
        aStackStart = iStackStart;
hgs
parents:
diff changeset
    47
        return ETrue;
hgs
parents:
diff changeset
    48
        }
hgs
parents:
diff changeset
    49
    else
hgs
parents:
diff changeset
    50
        {
hgs
parents:
diff changeset
    51
        aStackStart = 0;
hgs
parents:
diff changeset
    52
        return EFalse;
hgs
parents:
diff changeset
    53
        }
hgs
parents:
diff changeset
    54
    }
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    57
// TThreadStack::Match()
hgs
parents:
diff changeset
    58
// Checks if this is the the current thread.
hgs
parents:
diff changeset
    59
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    60
//
hgs
parents:
diff changeset
    61
TBool TThreadStack::Match( const TUint aThreadId )
hgs
parents:
diff changeset
    62
    {
hgs
parents:
diff changeset
    63
    LOGSTR2( "ATMH TThreadStack::Match( %d )", aThreadId );
hgs
parents:
diff changeset
    64
    
hgs
parents:
diff changeset
    65
    if ( aThreadId != 0 )
hgs
parents:
diff changeset
    66
    	{
hgs
parents:
diff changeset
    67
    	LOGSTR2( "ATMH > iId.operator TUint() = %d", iId.operator TUint() );
hgs
parents:
diff changeset
    68
    	return ( aThreadId == iId.operator TUint() ) ? ETrue : EFalse;
hgs
parents:
diff changeset
    69
    	}
hgs
parents:
diff changeset
    70
    else
hgs
parents:
diff changeset
    71
    	{
hgs
parents:
diff changeset
    72
    	return ( RThread().Id() == iId ) ? ETrue : EFalse;
hgs
parents:
diff changeset
    73
    	}
hgs
parents:
diff changeset
    74
    }
hgs
parents:
diff changeset
    75
    
hgs
parents:
diff changeset
    76
// End of File