tracesrv/tracecore/btrace_handler/src/TraceCoreSendReceive.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 "TraceCoreSendReceive.h"
hgs
parents:
diff changeset
    18
#include "TraceCorePluginIf.h"
hgs
parents:
diff changeset
    19
#include "TraceCoreRouter.h"
hgs
parents:
diff changeset
    20
#include "TraceCoreDebug.h"
hgs
parents:
diff changeset
    21
#include "TraceCoreOstLddIf.h"
hgs
parents:
diff changeset
    22
#include "OstTraceDefinitions.h"
hgs
parents:
diff changeset
    23
#ifdef OST_TRACE_COMPILER_IN_USE
hgs
parents:
diff changeset
    24
#include "TraceCoreSendReceiveTraces.h"
hgs
parents:
diff changeset
    25
#endif
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
DTraceCoreSendReceive::DTraceCoreSendReceive()
hgs
parents:
diff changeset
    32
: iPluginInterface( NULL )
hgs
parents:
diff changeset
    33
, iSendInterface( NULL )
hgs
parents:
diff changeset
    34
, iMediaWriterInterface( NULL )
hgs
parents:
diff changeset
    35
, iReceiver( NULL )
hgs
parents:
diff changeset
    36
    {
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
 * Destructor
hgs
parents:
diff changeset
    42
 */                                       
hgs
parents:
diff changeset
    43
DTraceCoreSendReceive::~DTraceCoreSendReceive()
hgs
parents:
diff changeset
    44
    {
hgs
parents:
diff changeset
    45
    DeleteInterfaces();
hgs
parents:
diff changeset
    46
    iReceiver = NULL;
hgs
parents:
diff changeset
    47
    }
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
/**
hgs
parents:
diff changeset
    51
 * Initializer creates the ISA IF and router
hgs
parents:
diff changeset
    52
 */
hgs
parents:
diff changeset
    53
TInt DTraceCoreSendReceive::Init( MTraceCoreMessageReceiver& aReceiver )
hgs
parents:
diff changeset
    54
    {
hgs
parents:
diff changeset
    55
    // Create interfaces
hgs
parents:
diff changeset
    56
    TInt ret = CreateInterfaces();
hgs
parents:
diff changeset
    57
    if ( ret == KErrNone )
hgs
parents:
diff changeset
    58
        {        
hgs
parents:
diff changeset
    59
        // Initialize all Media interfaces
hgs
parents:
diff changeset
    60
        for ( int i = 0; i < iMediaInterfaces.Count() && ret == KErrNone; i++ )
hgs
parents:
diff changeset
    61
            {
hgs
parents:
diff changeset
    62
            DTraceCoreMediaIf* mediaIf = iMediaInterfaces[ i ];
hgs
parents:
diff changeset
    63
            ret = InitMediaInterface( mediaIf );
hgs
parents:
diff changeset
    64
            }
hgs
parents:
diff changeset
    65
        if ( ret == KErrNone )
hgs
parents:
diff changeset
    66
            {
hgs
parents:
diff changeset
    67
            iReceiver = &aReceiver;
hgs
parents:
diff changeset
    68
            }
hgs
parents:
diff changeset
    69
        else
hgs
parents:
diff changeset
    70
            {
hgs
parents:
diff changeset
    71
            DeleteInterfaces();
hgs
parents:
diff changeset
    72
            }
hgs
parents:
diff changeset
    73
        }
hgs
parents:
diff changeset
    74
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "<DTraceCoreSendReceive::Init() - %d", ret ) )
hgs
parents:
diff changeset
    75
    return ret;
hgs
parents:
diff changeset
    76
    }
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
/**
hgs
parents:
diff changeset
    80
 * Initializes a media interface
hgs
parents:
diff changeset
    81
 */
hgs
parents:
diff changeset
    82
TInt DTraceCoreSendReceive::InitMediaInterface( DTraceCoreMediaIf* aMediaIf )
hgs
parents:
diff changeset
    83
    {
hgs
parents:
diff changeset
    84
    TInt ret = aMediaIf->Init( *this );
hgs
parents:
diff changeset
    85
    if ( ret == KErrNone )
hgs
parents:
diff changeset
    86
        {
hgs
parents:
diff changeset
    87
        TUint32 flags = aMediaIf->GetFlags();
hgs
parents:
diff changeset
    88
        // First interface that supports sending is stored as the send interface.
hgs
parents:
diff changeset
    89
        // TODO: Add a TraceCore message which can select the interface used for sending
hgs
parents:
diff changeset
    90
        if ( iSendInterface == NULL && ( flags & KMediaIfSendSupported ) )
hgs
parents:
diff changeset
    91
            {
hgs
parents:
diff changeset
    92
            iSendInterface = aMediaIf;
hgs
parents:
diff changeset
    93
            }
hgs
parents:
diff changeset
    94
        // First interface that can write traces is stored to iMediaWriterInterface
hgs
parents:
diff changeset
    95
        // TODO: Add a TraceCore message which can select the interface used by the writer
hgs
parents:
diff changeset
    96
        if ( iMediaWriterInterface == NULL && ( flags & KMediaIfSendTraceSupported ) )
hgs
parents:
diff changeset
    97
            {
hgs
parents:
diff changeset
    98
            iMediaWriterInterface = aMediaIf;
hgs
parents:
diff changeset
    99
            }
hgs
parents:
diff changeset
   100
        // If the plug-in interface is present, it is stored to iPluginInterface
hgs
parents:
diff changeset
   101
        if ( iPluginInterface == NULL && ( flags & KMediaIfPluginSupported ) )
hgs
parents:
diff changeset
   102
            {
hgs
parents:
diff changeset
   103
            iPluginInterface = static_cast< DTraceCorePluginIf* >( aMediaIf );
hgs
parents:
diff changeset
   104
            }
hgs
parents:
diff changeset
   105
        }
hgs
parents:
diff changeset
   106
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "<DTraceCoreSendReceive::InitMediaInterface() - %d", ret ) );
hgs
parents:
diff changeset
   107
    return ret;
hgs
parents:
diff changeset
   108
    }
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
/**
hgs
parents:
diff changeset
   112
 * Creates the media interfaces. This is platform-specific code
hgs
parents:
diff changeset
   113
 */
hgs
parents:
diff changeset
   114
TInt DTraceCoreSendReceive::CreateInterfaces()
hgs
parents:
diff changeset
   115
    {
hgs
parents:
diff changeset
   116
    TInt ret( KErrNoMemory );
hgs
parents:
diff changeset
   117
#ifdef __WINS__
hgs
parents:
diff changeset
   118
    DTraceCoreMediaIf* pluginIf = new DTraceCorePluginIf();
hgs
parents:
diff changeset
   119
    if ( pluginIf != NULL )
hgs
parents:
diff changeset
   120
        {
hgs
parents:
diff changeset
   121
        ret = iMediaInterfaces.Append( pluginIf );
hgs
parents:
diff changeset
   122
        }
hgs
parents:
diff changeset
   123
    // this is a bit of a hack here for now
hgs
parents:
diff changeset
   124
    // we create a DTraceCoreOstLddIf as the writer interface
hgs
parents:
diff changeset
   125
    if( ret == KErrNone)
hgs
parents:
diff changeset
   126
        {
hgs
parents:
diff changeset
   127
        DTraceCoreMediaIf* ostLddIf = new DTraceCoreOstLddIf();
hgs
parents:
diff changeset
   128
        if ( ostLddIf != NULL)
hgs
parents:
diff changeset
   129
            {
hgs
parents:
diff changeset
   130
            ret = iMediaInterfaces.Append( ostLddIf );
hgs
parents:
diff changeset
   131
            }
hgs
parents:
diff changeset
   132
        }
hgs
parents:
diff changeset
   133
#else
hgs
parents:
diff changeset
   134
    //  - Plug-in API for media plug-in's. Incoming / outgoing messages.
hgs
parents:
diff changeset
   135
    //  - ISA for incoming messages and media writer output
hgs
parents:
diff changeset
   136
    DTraceCoreMediaIf* pluginIf = new DTraceCorePluginIf();
hgs
parents:
diff changeset
   137
    DTraceCoreMediaIf* usbIf = new DTraceCoreOstLddIf();
hgs
parents:
diff changeset
   138
   
hgs
parents:
diff changeset
   139
    if ( pluginIf != NULL && usbIf!= NULL )
hgs
parents:
diff changeset
   140
        {
hgs
parents:
diff changeset
   141
        ret = iMediaInterfaces.Append( pluginIf );
hgs
parents:
diff changeset
   142
        ret = ( ret == KErrNone ) ? iMediaInterfaces.Append( usbIf ) : ret;
hgs
parents:
diff changeset
   143
        }
hgs
parents:
diff changeset
   144
#endif // __WINS__
hgs
parents:
diff changeset
   145
hgs
parents:
diff changeset
   146
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "<DTraceCoreSendReceive::CreateInterfaces()" ) );
hgs
parents:
diff changeset
   147
    return ret;
hgs
parents:
diff changeset
   148
    }
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
/**
hgs
parents:
diff changeset
   152
 * Deletes the media interfaces
hgs
parents:
diff changeset
   153
 */
hgs
parents:
diff changeset
   154
void DTraceCoreSendReceive::DeleteInterfaces()
hgs
parents:
diff changeset
   155
    {
hgs
parents:
diff changeset
   156
    // Delete all interfaces
hgs
parents:
diff changeset
   157
    iMediaInterfaces.ResetAndDestroy();
hgs
parents:
diff changeset
   158
    iSendInterface = NULL;
hgs
parents:
diff changeset
   159
    iMediaWriterInterface = NULL;
hgs
parents:
diff changeset
   160
    iPluginInterface = NULL;
hgs
parents:
diff changeset
   161
    }
hgs
parents:
diff changeset
   162
hgs
parents:
diff changeset
   163
hgs
parents:
diff changeset
   164
/**
hgs
parents:
diff changeset
   165
 * Delegates the incoming message to the router
hgs
parents:
diff changeset
   166
 *
hgs
parents:
diff changeset
   167
 * @param aMsg The message that was received
hgs
parents:
diff changeset
   168
 * @return KErrNotFound if the message id was not found (not subscribed), KErrNone if found
hgs
parents:
diff changeset
   169
 */
hgs
parents:
diff changeset
   170
TInt DTraceCoreSendReceive::MessageReceived( TTraceMessage &aMsg )
hgs
parents:
diff changeset
   171
    {
hgs
parents:
diff changeset
   172
    OstTrace1( TRACE_FLOW, DTRACECORESENDRECEIVE_MESSAGERECEIVED_ENTRY, "> DTraceCoreSendReceive::MessageReceived - %d", &aMsg);
hgs
parents:
diff changeset
   173
    TInt ret( KErrNotFound );
hgs
parents:
diff changeset
   174
    if ( iReceiver != NULL )
hgs
parents:
diff changeset
   175
        {
hgs
parents:
diff changeset
   176
        ret = iReceiver->MessageReceived( aMsg );
hgs
parents:
diff changeset
   177
        }
hgs
parents:
diff changeset
   178
    OstTrace1( TRACE_FLOW, DTRACECORESENDRECEIVE_MESSAGERECEIVED_EXIT, "< DTraceCoreSendReceive::MessageReceived - %d",ret);
hgs
parents:
diff changeset
   179
    return ret;
hgs
parents:
diff changeset
   180
    }
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
/**
hgs
parents:
diff changeset
   183
 * Set Sender Media
hgs
parents:
diff changeset
   184
 *
hgs
parents:
diff changeset
   185
 * @param Sender media
hgs
parents:
diff changeset
   186
 */
hgs
parents:
diff changeset
   187
TInt DTraceCoreSendReceive::SetSenderMedia(DTraceCoreMediaIf* aSenderMedia)
hgs
parents:
diff changeset
   188
    {
hgs
parents:
diff changeset
   189
    if (aSenderMedia != NULL)
hgs
parents:
diff changeset
   190
        {
hgs
parents:
diff changeset
   191
        TUint32 flags = aSenderMedia->GetFlags();
hgs
parents:
diff changeset
   192
        if (flags & KMediaIfSendSupported)
hgs
parents:
diff changeset
   193
            {
hgs
parents:
diff changeset
   194
            iSendInterface = aSenderMedia;
hgs
parents:
diff changeset
   195
            }
hgs
parents:
diff changeset
   196
        if (flags & KMediaIfSendTraceSupported)
hgs
parents:
diff changeset
   197
            {
hgs
parents:
diff changeset
   198
            iMediaWriterInterface = aSenderMedia;
hgs
parents:
diff changeset
   199
            }
hgs
parents:
diff changeset
   200
        }
hgs
parents:
diff changeset
   201
    return KErrNone;
hgs
parents:
diff changeset
   202
    }
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
/**
hgs
parents:
diff changeset
   206
 * Sends a message to media interface
hgs
parents:
diff changeset
   207
 *
hgs
parents:
diff changeset
   208
 * @param aMessage The message to be sent
hgs
parents:
diff changeset
   209
 */
hgs
parents:
diff changeset
   210
TInt DTraceCoreSendReceive::SendMessage( TTraceMessage &aMessage )
hgs
parents:
diff changeset
   211
    {
hgs
parents:
diff changeset
   212
    TInt retval = KErrGeneral;
hgs
parents:
diff changeset
   213
    if ( iSendInterface != NULL )
hgs
parents:
diff changeset
   214
        {      
hgs
parents:
diff changeset
   215
        // Send the message
hgs
parents:
diff changeset
   216
        retval = iSendInterface->Send( aMessage );
hgs
parents:
diff changeset
   217
        }
hgs
parents:
diff changeset
   218
    OstTrace1( TRACE_FLOW, DTRACECORESENDRECEIVE_SENDMESSAGE_EXIT, "DTraceCoreSendReceive::SendMessage %d", retval );
hgs
parents:
diff changeset
   219
    return retval;
hgs
parents:
diff changeset
   220
    }
hgs
parents:
diff changeset
   221
hgs
parents:
diff changeset
   222
// End of File