tracesrv/tracecore/btrace_handler/src/TraceCoreOstLddIf.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 "TraceCoreOstLddIf.h" 
hgs
parents:
diff changeset
    19
#include "TraceCoreDebug.h"
hgs
parents:
diff changeset
    20
#include "TraceCoreMediaIfCallback.h"
hgs
parents:
diff changeset
    21
#include "TraceCoreSubscriber.h"
hgs
parents:
diff changeset
    22
#include "TraceCoreMessageUtils.h"
hgs
parents:
diff changeset
    23
#include "TraceCoreOstHeader.h"
hgs
parents:
diff changeset
    24
#include "OstTraceDefinitions.h"
hgs
parents:
diff changeset
    25
#ifdef OST_TRACE_COMPILER_IN_USE
hgs
parents:
diff changeset
    26
#include "TraceCoreOstLddIfTraces.h"
hgs
parents:
diff changeset
    27
#endif
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
/** 
hgs
parents:
diff changeset
    30
 * Default DFC queue priority
hgs
parents:
diff changeset
    31
 */
hgs
parents:
diff changeset
    32
const TUint8 KDefaultDfcPriority = 3;
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
/**
hgs
parents:
diff changeset
    35
 * Prints a message
hgs
parents:
diff changeset
    36
 *
hgs
parents:
diff changeset
    37
 * @param aMsg Reference to a message. 
hgs
parents:
diff changeset
    38
 */
hgs
parents:
diff changeset
    39
static void DebugPrintMsg( const TDesC8& /*aMsg*/ )            
hgs
parents:
diff changeset
    40
    {
hgs
parents:
diff changeset
    41
    // Message structure print
hgs
parents:
diff changeset
    42
    }
hgs
parents:
diff changeset
    43
hgs
parents:
diff changeset
    44
static DTraceCoreOstLddIf* TraceCoreOstLddIf = NULL;
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
/**
hgs
parents:
diff changeset
    47
 * Constructor
hgs
parents:
diff changeset
    48
 */
hgs
parents:
diff changeset
    49
DTraceCoreOstLddIf::DTraceCoreOstLddIf()
hgs
parents:
diff changeset
    50
: DTraceCoreMediaIf( KMediaIfSendSupported | KMediaIfSendTraceSupported  )
hgs
parents:
diff changeset
    51
, iReceiveDfc( DTraceCoreOstLddIf::ReceiveDfc, this, DTraceCore::GetActivationQ(), KDefaultDfcPriority )
hgs
parents:
diff changeset
    52
, iStatus( 0 )
hgs
parents:
diff changeset
    53
, iTraceCoreOstConnectionRegistered( EFalse )
hgs
parents:
diff changeset
    54
, iTraceCoreOstConnection( NULL )
hgs
parents:
diff changeset
    55
    {
hgs
parents:
diff changeset
    56
    // No implementation in constructor
hgs
parents:
diff changeset
    57
    }
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
/**
hgs
parents:
diff changeset
    61
 * Destructor
hgs
parents:
diff changeset
    62
 */
hgs
parents:
diff changeset
    63
DTraceCoreOstLddIf::~DTraceCoreOstLddIf()
hgs
parents:
diff changeset
    64
    {
hgs
parents:
diff changeset
    65
    iCallback = NULL; 
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
 * Initializes the OstLddIf
hgs
parents:
diff changeset
    71
 *
hgs
parents:
diff changeset
    72
 * @param aCallBack Callback to TraceCore
hgs
parents:
diff changeset
    73
 */
hgs
parents:
diff changeset
    74
TInt DTraceCoreOstLddIf::Init( MTraceCoreMediaIfCallback& aCallback )
hgs
parents:
diff changeset
    75
    {
hgs
parents:
diff changeset
    76
    iCallback = &aCallback;
hgs
parents:
diff changeset
    77
    TraceCoreOstLddIf = this;
hgs
parents:
diff changeset
    78
    return KErrNone;
hgs
parents:
diff changeset
    79
    }
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
/**
hgs
parents:
diff changeset
    83
 * Handle incoming messages from OstConnection
hgs
parents:
diff changeset
    84
 * 
hgs
parents:
diff changeset
    85
 * @param aPtr Pointer to DTraceCoreOstLddIf class.
hgs
parents:
diff changeset
    86
 */
hgs
parents:
diff changeset
    87
void DTraceCoreOstLddIf::ReceiveDfc( TAny* aPtr )
hgs
parents:
diff changeset
    88
    {
hgs
parents:
diff changeset
    89
    DTraceCoreOstLddIf* TraceCoreOstLddIf = static_cast< DTraceCoreOstLddIf* >( aPtr );
hgs
parents:
diff changeset
    90
    __ASSERT_DEBUG( TraceCoreOstLddIf != NULL, Kern::Fault( "DTraceCoreOstLddIf::ReceiveDfc - NULL", KErrGeneral ) );
hgs
parents:
diff changeset
    91
    TraceCoreOstLddIf->ReceiveDfc();
hgs
parents:
diff changeset
    92
    }
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
/**
hgs
parents:
diff changeset
    96
 * Processes incoming OST messages
hgs
parents:
diff changeset
    97
 */
hgs
parents:
diff changeset
    98
void DTraceCoreOstLddIf::ReceiveDfc()
hgs
parents:
diff changeset
    99
    {
hgs
parents:
diff changeset
   100
    // Determine the message we received
hgs
parents:
diff changeset
   101
    if ( iReceiveBuffer.Length() > OstHeader::OstBaseProtocol::KOstHeaderLengthOffset )
hgs
parents:
diff changeset
   102
        {
hgs
parents:
diff changeset
   103
        DebugPrintMsg ( iReceiveBuffer );
hgs
parents:
diff changeset
   104
        if ( iCallback != NULL )
hgs
parents:
diff changeset
   105
            {
hgs
parents:
diff changeset
   106
            NotifyCallback();
hgs
parents:
diff changeset
   107
            }
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
/**
hgs
parents:
diff changeset
   113
 * Notifies the callback with the incoming message
hgs
parents:
diff changeset
   114
 * 
hgs
parents:
diff changeset
   115
 * @return one of symbian error codes
hgs
parents:
diff changeset
   116
 */
hgs
parents:
diff changeset
   117
void DTraceCoreOstLddIf::NotifyCallback()
hgs
parents:
diff changeset
   118
    {
hgs
parents:
diff changeset
   119
    // Header length is header size + remainders
hgs
parents:
diff changeset
   120
    TInt headerLength = OstHeader::OstBaseProtocol::KOstBaseHeaderSize;
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
    // Check message ID
hgs
parents:
diff changeset
   123
    TTraceMessage traceMsg;
hgs
parents:
diff changeset
   124
    traceMsg.iMessageId = iReceiveBuffer[ OstHeader::OstBaseProtocol::KOstHeaderProtocolIdOffset ];
hgs
parents:
diff changeset
   125
    
hgs
parents:
diff changeset
   126
    // If message ID is TraceCore Protocol, the header is longer and the message ID might be in different place
hgs
parents:
diff changeset
   127
    if (traceMsg.iMessageId == OstConstants::OstBaseProtocol::KOstTraceCoreProtocol)
hgs
parents:
diff changeset
   128
        {
hgs
parents:
diff changeset
   129
        headerLength += OstHeader::OstTraceCoreProtocol::KHeaderSize;
hgs
parents:
diff changeset
   130
        
hgs
parents:
diff changeset
   131
        // Subscriber protocol
hgs
parents:
diff changeset
   132
        if (iReceiveBuffer[ OstHeader::OstBaseProtocol::KOstBaseHeaderSize + 
hgs
parents:
diff changeset
   133
                            OstHeader::OstTraceCoreProtocol::KProtocolIdOffset ] == 
hgs
parents:
diff changeset
   134
                OstHeader::OstTraceCoreProtocol::KSubscriberProtocol)
hgs
parents:
diff changeset
   135
            {
hgs
parents:
diff changeset
   136
            traceMsg.iMessageId = iReceiveBuffer[ OstHeader::OstBaseProtocol::KOstBaseHeaderSize + 
hgs
parents:
diff changeset
   137
                                                  OstHeader::OstTraceCoreProtocol::KSubscriberIdOffset ];
hgs
parents:
diff changeset
   138
            }
hgs
parents:
diff changeset
   139
        }
hgs
parents:
diff changeset
   140
    
hgs
parents:
diff changeset
   141
    if ( iReceiveBuffer.Length() < headerLength ) 
hgs
parents:
diff changeset
   142
        {
hgs
parents:
diff changeset
   143
        headerLength = iReceiveBuffer.Length();
hgs
parents:
diff changeset
   144
        }
hgs
parents:
diff changeset
   145
hgs
parents:
diff changeset
   146
    // Create TraceMessage
hgs
parents:
diff changeset
   147
    TPtrC header( iReceiveBuffer.Ptr(), headerLength );
hgs
parents:
diff changeset
   148
    TPtrC data( NULL, 0 );
hgs
parents:
diff changeset
   149
    if ( iReceiveBuffer.Length() > headerLength ) {
hgs
parents:
diff changeset
   150
        data.Set( iReceiveBuffer.Ptr() + headerLength, iReceiveBuffer.Length() - headerLength );
hgs
parents:
diff changeset
   151
    }
hgs
parents:
diff changeset
   152
hgs
parents:
diff changeset
   153
    traceMsg.iMsgFormat = EMessageHeaderFormatOst;
hgs
parents:
diff changeset
   154
    traceMsg.iHeader = &header;
hgs
parents:
diff changeset
   155
    traceMsg.iData = &data;
hgs
parents:
diff changeset
   156
    
hgs
parents:
diff changeset
   157
    // Set Sender media to be same as receiver
hgs
parents:
diff changeset
   158
    iCallback->SetSenderMedia(this);
hgs
parents:
diff changeset
   159
    
hgs
parents:
diff changeset
   160
    iCallback->MessageReceived( traceMsg );
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
 * Sends messages to USB OstConnection
hgs
parents:
diff changeset
   166
 * 
hgs
parents:
diff changeset
   167
 * @param aMsg Message to be sent.
hgs
parents:
diff changeset
   168
 * @return KErrNone if send successful
hgs
parents:
diff changeset
   169
 */
hgs
parents:
diff changeset
   170
TInt DTraceCoreOstLddIf::Send( TTraceMessage& aMsg )
hgs
parents:
diff changeset
   171
    {
hgs
parents:
diff changeset
   172
    TInt ret = KErrArgument;
hgs
parents:
diff changeset
   173
    if ( aMsg.iData != NULL )
hgs
parents:
diff changeset
   174
        {
hgs
parents:
diff changeset
   175
        ret = TTraceCoreMessageUtils::GetMessageLength( aMsg );
hgs
parents:
diff changeset
   176
        if ( ret > 0 )
hgs
parents:
diff changeset
   177
            {
hgs
parents:
diff changeset
   178
            // First send the phone formatted start character
hgs
parents:
diff changeset
   179
            // Send trace data and end trace
hgs
parents:
diff changeset
   180
            SendData( aMsg );
hgs
parents:
diff changeset
   181
            if ( aMsg.iHeader != NULL ) 
hgs
parents:
diff changeset
   182
                {
hgs
parents:
diff changeset
   183
                DebugPrintMsg( iSendBuffer );
hgs
parents:
diff changeset
   184
                }
hgs
parents:
diff changeset
   185
            else
hgs
parents:
diff changeset
   186
                {
hgs
parents:
diff changeset
   187
                DebugPrintMsg( *aMsg.iData );
hgs
parents:
diff changeset
   188
                }
hgs
parents:
diff changeset
   189
            }
hgs
parents:
diff changeset
   190
        else
hgs
parents:
diff changeset
   191
            {
hgs
parents:
diff changeset
   192
            ret = KErrArgument;
hgs
parents:
diff changeset
   193
            }
hgs
parents:
diff changeset
   194
        }
hgs
parents:
diff changeset
   195
    
hgs
parents:
diff changeset
   196
    return ret;
hgs
parents:
diff changeset
   197
    }
hgs
parents:
diff changeset
   198
    
hgs
parents:
diff changeset
   199
hgs
parents:
diff changeset
   200
/**
hgs
parents:
diff changeset
   201
 * Sends message to TraceCoreOstLdd
hgs
parents:
diff changeset
   202
 * 
hgs
parents:
diff changeset
   203
 * @param aMsg Message to be sent.
hgs
parents:
diff changeset
   204
 */
hgs
parents:
diff changeset
   205
void DTraceCoreOstLddIf::SendData( TTraceMessage& aMsg )
hgs
parents:
diff changeset
   206
    {
hgs
parents:
diff changeset
   207
    if ( aMsg.iHeader != NULL )
hgs
parents:
diff changeset
   208
        {
hgs
parents:
diff changeset
   209
        // Utility function is used to merge the data
hgs
parents:
diff changeset
   210
        TInt ret = TTraceCoreMessageUtils::MergeHeaderAndData( aMsg, iSendBuffer );
hgs
parents:
diff changeset
   211
        
hgs
parents:
diff changeset
   212
        if ( ret == KErrNone )
hgs
parents:
diff changeset
   213
            {
hgs
parents:
diff changeset
   214
            if(iTraceCoreOstConnection)
hgs
parents:
diff changeset
   215
                {
hgs
parents:
diff changeset
   216
                iTraceCoreOstConnection->TxMessage( iSendBuffer );
hgs
parents:
diff changeset
   217
                }
hgs
parents:
diff changeset
   218
            }
hgs
parents:
diff changeset
   219
        }
hgs
parents:
diff changeset
   220
    else
hgs
parents:
diff changeset
   221
        {
hgs
parents:
diff changeset
   222
         // Header doesn't exists, all data is in data part
hgs
parents:
diff changeset
   223
        }
hgs
parents:
diff changeset
   224
    }
hgs
parents:
diff changeset
   225
hgs
parents:
diff changeset
   226
hgs
parents:
diff changeset
   227
/**
hgs
parents:
diff changeset
   228
 * Similar to send, except does not generate traces, since they would loop back to this function
hgs
parents:
diff changeset
   229
 * 
hgs
parents:
diff changeset
   230
 * @param aMsg Message to be sent.
hgs
parents:
diff changeset
   231
 * @return KErrNone if send successful
hgs
parents:
diff changeset
   232
 */
hgs
parents:
diff changeset
   233
TInt DTraceCoreOstLddIf::SendTrace(const TDesC8& aMsg)
hgs
parents:
diff changeset
   234
    {
hgs
parents:
diff changeset
   235
    TInt ret(KErrNone);
hgs
parents:
diff changeset
   236
    
hgs
parents:
diff changeset
   237
    if ( iTraceCoreOstConnection && iTraceCoreOstConnectionRegistered )
hgs
parents:
diff changeset
   238
        {
hgs
parents:
diff changeset
   239
        iTraceCoreOstConnection->TxMessage(aMsg);
hgs
parents:
diff changeset
   240
        }
hgs
parents:
diff changeset
   241
    else
hgs
parents:
diff changeset
   242
        {
hgs
parents:
diff changeset
   243
        ret = KErrGeneral;
hgs
parents:
diff changeset
   244
        }
hgs
parents:
diff changeset
   245
    
hgs
parents:
diff changeset
   246
    return ret;
hgs
parents:
diff changeset
   247
    }
hgs
parents:
diff changeset
   248
hgs
parents:
diff changeset
   249
hgs
parents:
diff changeset
   250
/**
hgs
parents:
diff changeset
   251
 * GetSet
hgs
parents:
diff changeset
   252
 * 
hgs
parents:
diff changeset
   253
 * @param aFunc Function choosed (@see ETraceCoreOstLddIfGetSet)
hgs
parents:
diff changeset
   254
 * @return TDfc* if aFunc is EGetDfc, TDes8* EGetBuf and 0 with ESetWriter.
hgs
parents:
diff changeset
   255
 */
hgs
parents:
diff changeset
   256
EXPORT_C TUint32 DTraceCoreOstLddIf::GetSet(TTraceCoreOstLddIfGetSet aFunc, TUint32 aParam)
hgs
parents:
diff changeset
   257
    {
hgs
parents:
diff changeset
   258
    OstTraceExt2( TRACE_FLOW, DTRACECOREOSTLDDIF_GETSET_ENTRY, "> DTraceCoreOstLddIf::GetSet aFunc:%d, aParam:%d", aFunc, aParam );
hgs
parents:
diff changeset
   259
    
hgs
parents:
diff changeset
   260
    TUint32 ret(0);
hgs
parents:
diff changeset
   261
    switch(aFunc)
hgs
parents:
diff changeset
   262
        {
hgs
parents:
diff changeset
   263
        case EGetDfc:
hgs
parents:
diff changeset
   264
            {
hgs
parents:
diff changeset
   265
            TraceCoreOstLddIf->iTraceCoreOstConnectionRegistered = ETrue;
hgs
parents:
diff changeset
   266
            ret = reinterpret_cast<TUint32>(&(TraceCoreOstLddIf->iReceiveDfc));
hgs
parents:
diff changeset
   267
            break;
hgs
parents:
diff changeset
   268
            }
hgs
parents:
diff changeset
   269
        case EGetBuf:
hgs
parents:
diff changeset
   270
            {
hgs
parents:
diff changeset
   271
            ret = reinterpret_cast<TUint32>(&(TraceCoreOstLddIf->iReceiveBuffer));
hgs
parents:
diff changeset
   272
            break;
hgs
parents:
diff changeset
   273
            }
hgs
parents:
diff changeset
   274
        case ESetWriter:
hgs
parents:
diff changeset
   275
            {
hgs
parents:
diff changeset
   276
            // Set Writer to XTI if parameter is 0, otherwise USB
hgs
parents:
diff changeset
   277
            DTraceCore* traceCore = DTraceCore::GetInstance();
hgs
parents:
diff changeset
   278
            if ( traceCore != NULL )
hgs
parents:
diff changeset
   279
                {
hgs
parents:
diff changeset
   280
                // TraceSwitch uses 0 for XTI writer and 1 to OST writer
hgs
parents:
diff changeset
   281
                // So it is not mapping one to one to enum found in TraceCoreWriter.h
hgs
parents:
diff changeset
   282
                // for example to EWriterTypeXTI = 1
hgs
parents:
diff changeset
   283
                // See TraceCoreWriter.h
hgs
parents:
diff changeset
   284
                if(aParam==0)
hgs
parents:
diff changeset
   285
                    {
hgs
parents:
diff changeset
   286
                    traceCore->SwitchToWriter(EWriterTypeXTI);
hgs
parents:
diff changeset
   287
                    }
hgs
parents:
diff changeset
   288
                else if(aParam==1)
hgs
parents:
diff changeset
   289
                    {
hgs
parents:
diff changeset
   290
                    traceCore->SwitchToWriter(EWriterTypeUSBPhonet);
hgs
parents:
diff changeset
   291
                    }
hgs
parents:
diff changeset
   292
                // For other writers (>2) we use same as the enum
hgs
parents:
diff changeset
   293
                else if(aParam > EWriterTypeUSBPhonet)
hgs
parents:
diff changeset
   294
                    {
hgs
parents:
diff changeset
   295
                    traceCore->SwitchToWriter((TWriterType) aParam);
hgs
parents:
diff changeset
   296
                    }
hgs
parents:
diff changeset
   297
                }
hgs
parents:
diff changeset
   298
            break;
hgs
parents:
diff changeset
   299
            }
hgs
parents:
diff changeset
   300
        case ERegister:
hgs
parents:
diff changeset
   301
            {
hgs
parents:
diff changeset
   302
            TraceCoreOstLddIf->iTraceCoreOstConnection = (MTraceCoreOstConnectionIf*)aParam;
hgs
parents:
diff changeset
   303
            break;
hgs
parents:
diff changeset
   304
            }    
hgs
parents:
diff changeset
   305
        default:
hgs
parents:
diff changeset
   306
            __ASSERT_DEBUG( EFalse, Kern::Fault( "DTraceCoreOstLddIf::GetSet: Default case!", KErrArgument ) );
hgs
parents:
diff changeset
   307
            break;
hgs
parents:
diff changeset
   308
        }
hgs
parents:
diff changeset
   309
    
hgs
parents:
diff changeset
   310
    return ret;
hgs
parents:
diff changeset
   311
    }
hgs
parents:
diff changeset
   312
hgs
parents:
diff changeset
   313
// End of File