tracesrv/tracecore/btrace_handler/src/TraceCoreActivationBase.cpp
author hgs
Fri, 08 Oct 2010 14:56:39 +0300
changeset 56 aa2539c91954
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56
hgs
parents:
diff changeset
     1
// Copyright (c) 2007-2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     2
// All rights reserved.
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     7
//
hgs
parents:
diff changeset
     8
// Initial Contributors:
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    10
//
hgs
parents:
diff changeset
    11
// Contributors:
hgs
parents:
diff changeset
    12
//
hgs
parents:
diff changeset
    13
// Description:
hgs
parents:
diff changeset
    14
// Base class for activation objects
hgs
parents:
diff changeset
    15
//
hgs
parents:
diff changeset
    16
#ifdef __SMP__
hgs
parents:
diff changeset
    17
#include <nkernsmp/nkern.h>
hgs
parents:
diff changeset
    18
#endif
hgs
parents:
diff changeset
    19
#include "TraceCoreActivationBase.h"
hgs
parents:
diff changeset
    20
#include "TraceCore.h"
hgs
parents:
diff changeset
    21
#include "TraceCoreDebug.h"
hgs
parents:
diff changeset
    22
#include "TraceCoreMessageSender.h"
hgs
parents:
diff changeset
    23
#include "OstTraceDefinitions.h"
hgs
parents:
diff changeset
    24
#ifdef OST_TRACE_COMPILER_IN_USE
hgs
parents:
diff changeset
    25
#include "TraceCoreActivationBaseTraces.h"
hgs
parents:
diff changeset
    26
#endif
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
/**
hgs
parents:
diff changeset
    31
 * Constructor
hgs
parents:
diff changeset
    32
 */
hgs
parents:
diff changeset
    33
DTraceCoreActivationBase::DTraceCoreActivationBase()
hgs
parents:
diff changeset
    34
#if defined(__SMP__)
hgs
parents:
diff changeset
    35
: iActivationReadLock(TSpinLock::EOrderBTrace-1)
hgs
parents:
diff changeset
    36
#endif 
hgs
parents:
diff changeset
    37
    {
hgs
parents:
diff changeset
    38
    }
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
/**
hgs
parents:
diff changeset
    42
 * Destructor
hgs
parents:
diff changeset
    43
 */
hgs
parents:
diff changeset
    44
DTraceCoreActivationBase::~DTraceCoreActivationBase()
hgs
parents:
diff changeset
    45
    {
hgs
parents:
diff changeset
    46
    }
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
/**
hgs
parents:
diff changeset
    50
 * Subscribes to message ID and registers to activation interface list
hgs
parents:
diff changeset
    51
 * 
hgs
parents:
diff changeset
    52
 * @param aMessageID the message id to be subscribed
hgs
parents:
diff changeset
    53
 */         
hgs
parents:
diff changeset
    54
TInt DTraceCoreActivationBase::Init( TUint32 aMessageId )
hgs
parents:
diff changeset
    55
    {
hgs
parents:
diff changeset
    56
    // Subscribes to a message by message ID
hgs
parents:
diff changeset
    57
    TInt err = Subscribe( aMessageId );
hgs
parents:
diff changeset
    58
    if ( err == KErrNone )
hgs
parents:
diff changeset
    59
        {
hgs
parents:
diff changeset
    60
        // If subscribe succeeds, GetInstance will not return NULL
hgs
parents:
diff changeset
    61
        err = DTraceCore::GetInstance()->RegisterActivation( *this );
hgs
parents:
diff changeset
    62
        }
hgs
parents:
diff changeset
    63
 
hgs
parents:
diff changeset
    64
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "<DTraceCoreActivationBase::Init() - %d", err ) );
hgs
parents:
diff changeset
    65
    return err;
hgs
parents:
diff changeset
    66
    }
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
    
hgs
parents:
diff changeset
    69
/**
hgs
parents:
diff changeset
    70
 * Subscribes to message ID and registers to activation interface list
hgs
parents:
diff changeset
    71
 * 
hgs
parents:
diff changeset
    72
 * @param aMessageID the message id to be subscribed
hgs
parents:
diff changeset
    73
 * @param aMsgFormat Message format e.g. EMessageHeaderFormatOst
hgs
parents:
diff changeset
    74
 */
hgs
parents:
diff changeset
    75
TInt DTraceCoreActivationBase::SubscribeMessage(TUint32 aMessageId, TMessageHeaderFormat aMsgFormat)
hgs
parents:
diff changeset
    76
    {
hgs
parents:
diff changeset
    77
    return Subscribe(aMessageId, aMsgFormat) ;
hgs
parents:
diff changeset
    78
    }
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
/**
hgs
parents:
diff changeset
    82
 * Registers an activation notification interface
hgs
parents:
diff changeset
    83
 * 
hgs
parents:
diff changeset
    84
 * @param aNotification the notification interface
hgs
parents:
diff changeset
    85
 */
hgs
parents:
diff changeset
    86
TInt DTraceCoreActivationBase::RegisterActivationNotification( MTraceCoreActivationNotification& aNotification )
hgs
parents:
diff changeset
    87
    {
hgs
parents:
diff changeset
    88
    OstTrace1( TRACE_FLOW, DBTRACECOREACTIVATIONBASE_REGISTERACTIVATIONNOTIFICATION_ENTRY, "> DBTraceCoreActivationBase::RegisterActivationNotification 0x%x", ( TUint )&( aNotification ) );
hgs
parents:
diff changeset
    89
    
hgs
parents:
diff changeset
    90
    TInt retval = iActivationNotification.Append( &aNotification );
hgs
parents:
diff changeset
    91
    
hgs
parents:
diff changeset
    92
    OstTrace1( TRACE_FLOW, DBTRACECOREACTIVATIONBASE_REGISTERACTIVATIONNOTIFICATION_EXIT, "< DBTraceCoreActivationBase::RegisterActivationNotification Ret:%d", retval );
hgs
parents:
diff changeset
    93
    return retval;
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
 * Sends notification to TraceCore internal activation notification interfaces.
hgs
parents:
diff changeset
    99
 * 
hgs
parents:
diff changeset
   100
 * @pre Method should be called with writer lock (iActivationWriteLock) held.
hgs
parents:
diff changeset
   101
 * 
hgs
parents:
diff changeset
   102
 * @param aFromSettings ETrue if activation was due to settings read, EFalse if from some other source
hgs
parents:
diff changeset
   103
 * @param aComponentId Component ID of the activation 
hgs
parents:
diff changeset
   104
 */
hgs
parents:
diff changeset
   105
void DTraceCoreActivationBase::NotifyInternalActivation( TBool aFromSettings, TUint32 aComponentId )
hgs
parents:
diff changeset
   106
    {
hgs
parents:
diff changeset
   107
    OstTraceExt2( TRACE_FLOW, DBTRACECOREACTIVATIONBASE_NOTIFYINTERNALACTIVATION_ENTRY, "> DBTraceCoreActivationBase::NotifyInternalActivation. FromSettings:%d, ComponentID:%x", (TUint32)aFromSettings, (TUint32) aComponentId );
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
    for ( int i = 0; i < iActivationNotification.Count(); i++ )
hgs
parents:
diff changeset
   110
        {
hgs
parents:
diff changeset
   111
        iActivationNotification[ i ]->ActivationChanged( *this, aFromSettings, aComponentId );
hgs
parents:
diff changeset
   112
        }
hgs
parents:
diff changeset
   113
    }
hgs
parents:
diff changeset
   114
    
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
/**
hgs
parents:
diff changeset
   117
 * Send response
hgs
parents:
diff changeset
   118
 * 
hgs
parents:
diff changeset
   119
 * @param aMessage Response message
hgs
parents:
diff changeset
   120
 */
hgs
parents:
diff changeset
   121
void DTraceCoreActivationBase::SendResponse( TTraceMessage& aMessage )
hgs
parents:
diff changeset
   122
    {
hgs
parents:
diff changeset
   123
    iMessageSender->SendMessage( aMessage );
hgs
parents:
diff changeset
   124
    }
hgs
parents:
diff changeset
   125