tracesrv/tracecore/btrace_handler/src/TraceCoreSubscriber.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
// Trace Core
hgs
parents:
diff changeset
    15
hgs
parents:
diff changeset
    16
hgs
parents:
diff changeset
    17
#include "TraceCore.h"
hgs
parents:
diff changeset
    18
#include "TraceCoreSubscriber.h"
hgs
parents:
diff changeset
    19
#include "TraceCoreRouter.h"
hgs
parents:
diff changeset
    20
#include "TraceCoreDebug.h"
hgs
parents:
diff changeset
    21
#include "OstTraceDefinitions.h"
hgs
parents:
diff changeset
    22
#ifdef OST_TRACE_COMPILER_IN_USE
hgs
parents:
diff changeset
    23
#include "TraceCoreSubscriberTraces.h"
hgs
parents:
diff changeset
    24
#endif
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
/**
hgs
parents:
diff changeset
    29
 * Constructor
hgs
parents:
diff changeset
    30
 */
hgs
parents:
diff changeset
    31
EXPORT_C DTraceCoreSubscriber::DTraceCoreSubscriber()
hgs
parents:
diff changeset
    32
: iMessageSender( NULL )
hgs
parents:
diff changeset
    33
    {
hgs
parents:
diff changeset
    34
    }
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
/**
hgs
parents:
diff changeset
    38
 * Destructor
hgs
parents:
diff changeset
    39
 */
hgs
parents:
diff changeset
    40
EXPORT_C DTraceCoreSubscriber::~DTraceCoreSubscriber()
hgs
parents:
diff changeset
    41
    {
hgs
parents:
diff changeset
    42
    iMessageSender = NULL;
hgs
parents:
diff changeset
    43
    Unsubscribe();
hgs
parents:
diff changeset
    44
    }
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
/**
hgs
parents:
diff changeset
    47
 * Subscribes to a message by message ID / protocol ID
hgs
parents:
diff changeset
    48
 * depending of the header format. First byte of aMessageID is always used
hgs
parents:
diff changeset
    49
 * for header format.
hgs
parents:
diff changeset
    50
 * 
hgs
parents:
diff changeset
    51
 * @param aMessageId The message ID to be subscribed
hgs
parents:
diff changeset
    52
 * @param aMsgFormat Message format e.g. EMessageHeaderFormatOst
hgs
parents:
diff changeset
    53
 * 
hgs
parents:
diff changeset
    54
 */
hgs
parents:
diff changeset
    55
EXPORT_C TInt DTraceCoreSubscriber::Subscribe( TUint32 aMessageID, TMessageHeaderFormat aHeaderFormat )
hgs
parents:
diff changeset
    56
    {
hgs
parents:
diff changeset
    57
    TInt ret(KErrNone);
hgs
parents:
diff changeset
    58
    // Use MSByte only for header format
hgs
parents:
diff changeset
    59
    TUint32 combined = aHeaderFormat << 24 | (aMessageID & 0x00FFFFFF); // CodForChk_Dis_Magic
hgs
parents:
diff changeset
    60
    DTraceCoreSubscriber::Subscribe( combined );
hgs
parents:
diff changeset
    61
    return ret;
hgs
parents:
diff changeset
    62
    }
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
/**
hgs
parents:
diff changeset
    65
 * Subscribes to a message by message ID
hgs
parents:
diff changeset
    66
 * 
hgs
parents:
diff changeset
    67
 * @param aMessageId The message ID to be subscribed
hgs
parents:
diff changeset
    68
 */
hgs
parents:
diff changeset
    69
EXPORT_C TInt DTraceCoreSubscriber::Subscribe( TUint32 aMessageID )
hgs
parents:
diff changeset
    70
    {
hgs
parents:
diff changeset
    71
    OstTrace1( TRACE_BORDER, DTRACECORESUBSCRIBER_SUBSCRIBE_ENTRY, "> DTraceCoreSubscriber::Subscribe 0x%x", aMessageID );
hgs
parents:
diff changeset
    72
    TInt ret = KErrGeneral;
hgs
parents:
diff changeset
    73
    DTraceCore* traceCore = DTraceCore::GetInstance();
hgs
parents:
diff changeset
    74
    if ( traceCore != NULL )
hgs
parents:
diff changeset
    75
        {
hgs
parents:
diff changeset
    76
        TRoutingItem routingItem;
hgs
parents:
diff changeset
    77
        
hgs
parents:
diff changeset
    78
        // If MSByte is empty it is Proprietary message -> Add Proprietary header format id
hgs
parents:
diff changeset
    79
        // Otherwise take it from aMessageId (MSByte)
hgs
parents:
diff changeset
    80
        if( !(aMessageID & 0xFF000000) ) // CodForChk_Dis_Magic explained in comment
hgs
parents:
diff changeset
    81
            {
hgs
parents:
diff changeset
    82
            routingItem.iMsgFormat = EMessageHeaderFormatProprietary;
hgs
parents:
diff changeset
    83
            }
hgs
parents:
diff changeset
    84
        else
hgs
parents:
diff changeset
    85
            {
hgs
parents:
diff changeset
    86
            // Extract Header Format from aMessageID
hgs
parents:
diff changeset
    87
            routingItem.iMsgFormat = (aMessageID >> 24) & 0x000000FF; // CodForChk_Dis_Magic
hgs
parents:
diff changeset
    88
            }
hgs
parents:
diff changeset
    89
        
hgs
parents:
diff changeset
    90
        // Remove Header format
hgs
parents:
diff changeset
    91
        aMessageID = (aMessageID & 0x00FFFFFF); // CodForChk_Dis_Magic
hgs
parents:
diff changeset
    92
        
hgs
parents:
diff changeset
    93
        routingItem.iMessageID = aMessageID;
hgs
parents:
diff changeset
    94
        routingItem.iSubscriber = this;
hgs
parents:
diff changeset
    95
           
hgs
parents:
diff changeset
    96
        ret = traceCore->GetRouter().Subscribe( routingItem );
hgs
parents:
diff changeset
    97
        }
hgs
parents:
diff changeset
    98
    OstTrace1( TRACE_API, DTRACECORESUBSCRIBER_SUBSCRIBE_EXIT, "DTraceCoreSubscriber::Subscribe. Return code:%d", ret );
hgs
parents:
diff changeset
    99
    return ret;
hgs
parents:
diff changeset
   100
    }
hgs
parents:
diff changeset
   101
    
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
/**
hgs
parents:
diff changeset
   104
 * Unsubscribes a message ID
hgs
parents:
diff changeset
   105
 * 
hgs
parents:
diff changeset
   106
 * @param aMessageId The message ID to be unsubscribed
hgs
parents:
diff changeset
   107
 */
hgs
parents:
diff changeset
   108
EXPORT_C void DTraceCoreSubscriber::Unsubscribe( TUint32 aMessageID )
hgs
parents:
diff changeset
   109
    {
hgs
parents:
diff changeset
   110
    OstTrace1( TRACE_BORDER, DTRACECORESUBSCRIBER_UNSUBSCRIBE_ENTRY, "> DTraceCoreSubscriber::Unsubscribe. MsgId:%d", aMessageID );
hgs
parents:
diff changeset
   111
    DTraceCore* traceCore = DTraceCore::GetInstance();
hgs
parents:
diff changeset
   112
    if ( traceCore != NULL )
hgs
parents:
diff changeset
   113
        {
hgs
parents:
diff changeset
   114
        TRoutingItem routingItem;
hgs
parents:
diff changeset
   115
        routingItem.iMessageID = aMessageID;
hgs
parents:
diff changeset
   116
        routingItem.iSubscriber = this;
hgs
parents:
diff changeset
   117
        traceCore->GetRouter().Unsubscribe( routingItem );
hgs
parents:
diff changeset
   118
        }
hgs
parents:
diff changeset
   119
    }
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
/**
hgs
parents:
diff changeset
   123
 * Called by router to set the message sender interface
hgs
parents:
diff changeset
   124
 */
hgs
parents:
diff changeset
   125
void DTraceCoreSubscriber::SetMessageSender( MTraceCoreMessageSender& aMessageSender )
hgs
parents:
diff changeset
   126
    {
hgs
parents:
diff changeset
   127
    iMessageSender = &aMessageSender;
hgs
parents:
diff changeset
   128
    }
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
/**
hgs
parents:
diff changeset
   132
 * Unsubscribes all message ID's of this subscriber
hgs
parents:
diff changeset
   133
 */
hgs
parents:
diff changeset
   134
void DTraceCoreSubscriber::Unsubscribe()
hgs
parents:
diff changeset
   135
    {
hgs
parents:
diff changeset
   136
    DTraceCore* traceCore = DTraceCore::GetInstance();
hgs
parents:
diff changeset
   137
    
hgs
parents:
diff changeset
   138
    // Unsubsribe if TraceCore exists
hgs
parents:
diff changeset
   139
    if ( traceCore != NULL )
hgs
parents:
diff changeset
   140
        {
hgs
parents:
diff changeset
   141
        traceCore->GetRouter().Unsubscribe( *this );
hgs
parents:
diff changeset
   142
        }
hgs
parents:
diff changeset
   143
    }
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
// End of File