tracesrv/tracecore/plugins/xti_if/common/src/TraceCoreXtiIf.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
hgs
parents:
diff changeset
    15
hgs
parents:
diff changeset
    16
//- Include Files  ----------------------------------------------------------
hgs
parents:
diff changeset
    17
#include <pn_const.h>
hgs
parents:
diff changeset
    18
#include <phonetisi.h>
hgs
parents:
diff changeset
    19
#include <xtirx.h>
hgs
parents:
diff changeset
    20
#include <xtitx.h>
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include "TraceCore.h"
hgs
parents:
diff changeset
    23
#include "TraceCoreXtiIf.h" 
hgs
parents:
diff changeset
    24
#include "TraceCoreDebug.h"
hgs
parents:
diff changeset
    25
#include "TraceCoreMediaIfCallback.h"
hgs
parents:
diff changeset
    26
#include "TraceCoreSubscriber.h"
hgs
parents:
diff changeset
    27
#include "TraceCoreMessageUtils.h"
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
#include "OstTraceDefinitions.h"
hgs
parents:
diff changeset
    30
#ifdef OST_TRACE_COMPILER_IN_USE
hgs
parents:
diff changeset
    31
#include "TraceCoreXtiIfTraces.h"
hgs
parents:
diff changeset
    32
#endif
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
#include "xtipluginvariantconstants.h"
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
/**
hgs
parents:
diff changeset
    37
 * 200 millisecond pulse time (0.2 sec)
hgs
parents:
diff changeset
    38
 */
hgs
parents:
diff changeset
    39
const TUint KXtiRegisterTimer = 200000;
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
/** 
hgs
parents:
diff changeset
    42
 * Default DFC queue priority
hgs
parents:
diff changeset
    43
 */
hgs
parents:
diff changeset
    44
const TUint8 KDefaultDfcPriority = 3;
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
/*
hgs
parents:
diff changeset
    47
 * ISI header remainder length, 2 + 2 filler bytes
hgs
parents:
diff changeset
    48
 */
hgs
parents:
diff changeset
    49
const TInt KIsiHeaderRemainder = 4;
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
/**
hgs
parents:
diff changeset
    53
 * Prints a message
hgs
parents:
diff changeset
    54
 *
hgs
parents:
diff changeset
    55
 * @param aMsg Reference to a message. 
hgs
parents:
diff changeset
    56
 */
hgs
parents:
diff changeset
    57
static void DebugPrintMsg( const TDesC8& aMsg )            
hgs
parents:
diff changeset
    58
    {
hgs
parents:
diff changeset
    59
    // Phonet message structure print
hgs
parents:
diff changeset
    60
    OstTraceData( TRACE_DUMP, TRACECOREXTIIF_PS_DEBUGPRINTMSG,
hgs
parents:
diff changeset
    61
    		"DTraceCoreXtiIf::DebugPrintMsg - Msg via XTI IF 0x%{hex8[]}", aMsg.Ptr(), aMsg.Size() );
hgs
parents:
diff changeset
    62
    }
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
/**
hgs
parents:
diff changeset
    65
 * Constructor
hgs
parents:
diff changeset
    66
 */
hgs
parents:
diff changeset
    67
DTraceCoreXtiIf::DTraceCoreXtiIf()
hgs
parents:
diff changeset
    68
: iReceiveDfc( DTraceCoreXtiIf::ReceiveDfc, this, DTraceCore::GetActivationQ(), KDefaultDfcPriority )
hgs
parents:
diff changeset
    69
, iXtiRegisterDfc( DTraceCoreXtiIf::XtiRegister, this, DTraceCore::GetActivationQ(), KDefaultDfcPriority )
hgs
parents:
diff changeset
    70
, iStatus( 0 )
hgs
parents:
diff changeset
    71
    {
hgs
parents:
diff changeset
    72
    // No implementation in constructor
hgs
parents:
diff changeset
    73
    }
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
/**
hgs
parents:
diff changeset
    76
 * Destructor
hgs
parents:
diff changeset
    77
 */
hgs
parents:
diff changeset
    78
DTraceCoreXtiIf::~DTraceCoreXtiIf()
hgs
parents:
diff changeset
    79
    {
hgs
parents:
diff changeset
    80
    //iCallback = NULL; 
hgs
parents:
diff changeset
    81
    }
hgs
parents:
diff changeset
    82
hgs
parents:
diff changeset
    83
/**
hgs
parents:
diff changeset
    84
 * Initializes the XTI IF
hgs
parents:
diff changeset
    85
 *
hgs
parents:
diff changeset
    86
 * @param aCallBack Callback to TraceCore
hgs
parents:
diff changeset
    87
 */
hgs
parents:
diff changeset
    88
TInt DTraceCoreXtiIf::Init( /*MTraceCoreMediaIfCallback& aCallback*/ )
hgs
parents:
diff changeset
    89
    {
hgs
parents:
diff changeset
    90
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "> DTraceCoreXtiIf::Init" ) );
hgs
parents:
diff changeset
    91
    
hgs
parents:
diff changeset
    92
    // Register media plugin to TraceCore
hgs
parents:
diff changeset
    93
    TInt ret = Register();
hgs
parents:
diff changeset
    94
    
hgs
parents:
diff changeset
    95
    StartTimer();
hgs
parents:
diff changeset
    96
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "< DTraceCoreXtiIf::Init" ) );
hgs
parents:
diff changeset
    97
    return KErrNone;
hgs
parents:
diff changeset
    98
    }
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
/**
hgs
parents:
diff changeset
   101
 * Starts the timer which calls the initialization function
hgs
parents:
diff changeset
   102
 */
hgs
parents:
diff changeset
   103
void DTraceCoreXtiIf::StartTimer()
hgs
parents:
diff changeset
   104
    {
hgs
parents:
diff changeset
   105
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "> DTraceCoreXtiIf::StartTimer" ) );
hgs
parents:
diff changeset
   106
    iXtiRegisterTimer.OneShot( KXtiRegisterTimer, XtiRegisterDfc, this );
hgs
parents:
diff changeset
   107
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "< DTraceCoreXtiIf::StartTimer" ) );
hgs
parents:
diff changeset
   108
    }
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
/**
hgs
parents:
diff changeset
   111
 * Add registering to own Dfc
hgs
parents:
diff changeset
   112
 * 
hgs
parents:
diff changeset
   113
 * @param aPtr Pointer to traceCoreIsaIf class
hgs
parents:
diff changeset
   114
 */
hgs
parents:
diff changeset
   115
void DTraceCoreXtiIf::XtiRegisterDfc( TAny* aPtr )
hgs
parents:
diff changeset
   116
    {
hgs
parents:
diff changeset
   117
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "> DTraceCoreXtiIf::XtiRegisterDfc" ) );
hgs
parents:
diff changeset
   118
    reinterpret_cast< DTraceCoreXtiIf* >( aPtr )->iXtiRegisterDfc.Enque();
hgs
parents:
diff changeset
   119
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "< DTraceCoreXtiIf::XtiRegisterDfc" ) );
hgs
parents:
diff changeset
   120
    }
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
/**
hgs
parents:
diff changeset
   123
 * Timer callback function to initialize the XTI IF
hgs
parents:
diff changeset
   124
 * 
hgs
parents:
diff changeset
   125
 * @param aPtr Pointer to DTraceCoreXtiIf class
hgs
parents:
diff changeset
   126
 */
hgs
parents:
diff changeset
   127
void DTraceCoreXtiIf::XtiRegister( TAny* aPtr )
hgs
parents:
diff changeset
   128
    {
hgs
parents:
diff changeset
   129
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "> DTraceCoreXtiIf::XtiRegister" ) );
hgs
parents:
diff changeset
   130
    DTraceCoreXtiIf* traceCoreXtiIf = static_cast< DTraceCoreXtiIf* >( aPtr );
hgs
parents:
diff changeset
   131
    __ASSERT_DEBUG( traceCoreXtiIf != NULL, 
hgs
parents:
diff changeset
   132
            Kern::Fault( "DTraceCoreXtiIf::XtiRegister - NULL", KErrGeneral ) );
hgs
parents:
diff changeset
   133
    traceCoreXtiIf->XtiRegister();
hgs
parents:
diff changeset
   134
    TC_TRACE( ETraceLevelFlow, Kern::Printf( "< DTraceCoreXtiIf::XtiRegister" ) );
hgs
parents:
diff changeset
   135
    }
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
/**
hgs
parents:
diff changeset
   138
 * Called from the static callback to register to XtiRx
hgs
parents:
diff changeset
   139
 */
hgs
parents:
diff changeset
   140
void DTraceCoreXtiIf::XtiRegister()
hgs
parents:
diff changeset
   141
    {
hgs
parents:
diff changeset
   142
    TInt ret = XtiRx::Register( &iReceiveDfc, iReceiveBuffer );
hgs
parents:
diff changeset
   143
    if ( ret != KErrNone )
hgs
parents:
diff changeset
   144
        {
hgs
parents:
diff changeset
   145
        TC_TRACE( ETraceLevelError, Kern::Printf( "DTraceCoreXtiIf::XtiRegister - Register failed: %d", ret ) );
hgs
parents:
diff changeset
   146
        }
hgs
parents:
diff changeset
   147
    }
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
/**
hgs
parents:
diff changeset
   150
 * Handle incoming messages from XTI
hgs
parents:
diff changeset
   151
 * 
hgs
parents:
diff changeset
   152
 * @param aPtr Pointer to DTraceCoreXtiIf class.
hgs
parents:
diff changeset
   153
 */
hgs
parents:
diff changeset
   154
void DTraceCoreXtiIf::ReceiveDfc( TAny* aPtr )
hgs
parents:
diff changeset
   155
    {
hgs
parents:
diff changeset
   156
    OstTrace0( TRACE_FLOW, DTRACECOREXTIIF_PS_RECEIVEDFC_ENTRY, "> DTraceCoreXtiIf::ReceiveDfc");
hgs
parents:
diff changeset
   157
    DTraceCoreXtiIf* traceCoreXtiIf = static_cast< DTraceCoreXtiIf* >( aPtr );
hgs
parents:
diff changeset
   158
    __ASSERT_DEBUG( traceCoreXtiIf != NULL, 
hgs
parents:
diff changeset
   159
            Kern::Fault( "DTraceCoreXtiIf::ReceiveDfc - NULL", KErrGeneral ) );
hgs
parents:
diff changeset
   160
    traceCoreXtiIf->ReceiveDfc();
hgs
parents:
diff changeset
   161
    OstTrace0( TRACE_FLOW, DTRACECOREXTIIF_PS_RECEIVEDFC_EXIT, "< DTraceCoreXtiIf::ReceiveDfc");
hgs
parents:
diff changeset
   162
    }
hgs
parents:
diff changeset
   163
hgs
parents:
diff changeset
   164
/**
hgs
parents:
diff changeset
   165
 * Processes incoming XTI messages
hgs
parents:
diff changeset
   166
 */
hgs
parents:
diff changeset
   167
void DTraceCoreXtiIf::ReceiveDfc()
hgs
parents:
diff changeset
   168
    {
hgs
parents:
diff changeset
   169
    // Determine the message we received
hgs
parents:
diff changeset
   170
    if ( iReceiveBuffer.Length() > ISI_HEADER_OFFSET_MESSAGEID )
hgs
parents:
diff changeset
   171
        {
hgs
parents:
diff changeset
   172
        TUint8 resource = iReceiveBuffer[ ISI_HEADER_OFFSET_RESOURCEID ];
hgs
parents:
diff changeset
   173
        
hgs
parents:
diff changeset
   174
        // Check that resource is PN_EPOC_MON
hgs
parents:
diff changeset
   175
        if ( resource == PN_EPOC_MON )
hgs
parents:
diff changeset
   176
            {
hgs
parents:
diff changeset
   177
            DebugPrintMsg ( iReceiveBuffer );
hgs
parents:
diff changeset
   178
            
hgs
parents:
diff changeset
   179
            NotifyCallback();
hgs
parents:
diff changeset
   180
            }
hgs
parents:
diff changeset
   181
        }
hgs
parents:
diff changeset
   182
    XtiRx::SetReceiveBufferRead();    
hgs
parents:
diff changeset
   183
    }
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
/**
hgs
parents:
diff changeset
   186
 * Notifies the callback with the incoming message
hgs
parents:
diff changeset
   187
 * 
hgs
parents:
diff changeset
   188
 * @return one of symbian error codes
hgs
parents:
diff changeset
   189
 */
hgs
parents:
diff changeset
   190
void DTraceCoreXtiIf::NotifyCallback()
hgs
parents:
diff changeset
   191
    {
hgs
parents:
diff changeset
   192
    OstTrace0( TRACE_FLOW, DTRACECOREXTIIF_PS_NOTIFYCALLBACK_ENTRY, "> DTraceCoreXtiIf::NotifyCallback");
hgs
parents:
diff changeset
   193
    // Header length is header size + remainders
hgs
parents:
diff changeset
   194
    TInt headerLength = ISI_HEADER_SIZE + KIsiHeaderRemainder;
hgs
parents:
diff changeset
   195
    if ( iReceiveBuffer.Length() < headerLength ) {
hgs
parents:
diff changeset
   196
        headerLength = iReceiveBuffer.Length();
hgs
parents:
diff changeset
   197
    }
hgs
parents:
diff changeset
   198
    
hgs
parents:
diff changeset
   199
    // Create TraceMessage
hgs
parents:
diff changeset
   200
    TTraceMessage traceMsg;
hgs
parents:
diff changeset
   201
    TPtrC header( iReceiveBuffer.Ptr(), headerLength );
hgs
parents:
diff changeset
   202
    TPtrC data( NULL, 0 );
hgs
parents:
diff changeset
   203
    if ( iReceiveBuffer.Length() > headerLength ) {
hgs
parents:
diff changeset
   204
        data.Set( iReceiveBuffer.Ptr() + headerLength, iReceiveBuffer.Length() - headerLength );
hgs
parents:
diff changeset
   205
    }
hgs
parents:
diff changeset
   206
hgs
parents:
diff changeset
   207
    traceMsg.iMsgFormat = EMessageHeaderFormatProprietary;
hgs
parents:
diff changeset
   208
    traceMsg.iHeader = &header;
hgs
parents:
diff changeset
   209
    traceMsg.iData = &data;
hgs
parents:
diff changeset
   210
    traceMsg.iMessageId = iReceiveBuffer[ ISI_HEADER_OFFSET_MESSAGEID ];
hgs
parents:
diff changeset
   211
    
hgs
parents:
diff changeset
   212
    // Call base class MessageReceived
hgs
parents:
diff changeset
   213
    MessageReceived( traceMsg );
hgs
parents:
diff changeset
   214
    
hgs
parents:
diff changeset
   215
    OstTrace0( TRACE_FLOW, DTRACECOREXTIIF_PS_NOTIFYCALLBACK_EXIT, "< DTraceCoreXtiIf::NotifyCallback");
hgs
parents:
diff changeset
   216
    }
hgs
parents:
diff changeset
   217
hgs
parents:
diff changeset
   218
/**
hgs
parents:
diff changeset
   219
 * Sends messages to XTI
hgs
parents:
diff changeset
   220
 * 
hgs
parents:
diff changeset
   221
 * @param aMsg Message to be sent.
hgs
parents:
diff changeset
   222
 * @return KErrNone if send successful
hgs
parents:
diff changeset
   223
 */
hgs
parents:
diff changeset
   224
TInt DTraceCoreXtiIf::Send( TTraceMessage& aMsg )
hgs
parents:
diff changeset
   225
    {
hgs
parents:
diff changeset
   226
    OstTrace0( TRACE_FLOW, DTRACECOREXTIIF_PS_SEND_ENTRY, "> DTraceCoreXtiIf::Send");
hgs
parents:
diff changeset
   227
    TInt ret;
hgs
parents:
diff changeset
   228
    if ( aMsg.iData != NULL )
hgs
parents:
diff changeset
   229
        {
hgs
parents:
diff changeset
   230
        ret = TXtiIfMessageUtils::GetMessageLength( aMsg );
hgs
parents:
diff changeset
   231
        if ( ret > 0 )
hgs
parents:
diff changeset
   232
            {
hgs
parents:
diff changeset
   233
            // First send the phone formatted start character
hgs
parents:
diff changeset
   234
            ret = XtiTx::StartWrite( KChannel0, KPhoneFormattedMessage );
hgs
parents:
diff changeset
   235
            if ( ret == KErrNone )
hgs
parents:
diff changeset
   236
                {
hgs
parents:
diff changeset
   237
                // Send trace data and end trace
hgs
parents:
diff changeset
   238
                SendData( aMsg );
hgs
parents:
diff changeset
   239
                XtiTx::StopWrite( KChannel0 );
hgs
parents:
diff changeset
   240
                if ( aMsg.iHeader != NULL ) 
hgs
parents:
diff changeset
   241
                    {
hgs
parents:
diff changeset
   242
                    DebugPrintMsg( iSendBuffer );
hgs
parents:
diff changeset
   243
                    }
hgs
parents:
diff changeset
   244
                else
hgs
parents:
diff changeset
   245
                    {
hgs
parents:
diff changeset
   246
                    DebugPrintMsg( *aMsg.iData );
hgs
parents:
diff changeset
   247
                    }
hgs
parents:
diff changeset
   248
                }
hgs
parents:
diff changeset
   249
            else
hgs
parents:
diff changeset
   250
                {
hgs
parents:
diff changeset
   251
                OstTrace1( TRACE_IMPORTANT , DTRACECOREXTIIF_PS_SEND_START_WRITE_FAILED,
hgs
parents:
diff changeset
   252
                		"DTraceCoreXtiIf::Send - XTI StartWrite failed. Ret:%d", ret );
hgs
parents:
diff changeset
   253
                }
hgs
parents:
diff changeset
   254
            }
hgs
parents:
diff changeset
   255
        else
hgs
parents:
diff changeset
   256
            {
hgs
parents:
diff changeset
   257
            ret = KErrArgument;
hgs
parents:
diff changeset
   258
            }
hgs
parents:
diff changeset
   259
        }
hgs
parents:
diff changeset
   260
    else
hgs
parents:
diff changeset
   261
        {
hgs
parents:
diff changeset
   262
        OstTrace0( TRACE_IMPORTANT , DTRACECOREXTIIF_PS_SEND_INVALID_DATA, "DTraceCoreXtiIf::Send - NULL data in message");
hgs
parents:
diff changeset
   263
        ret = KErrArgument;
hgs
parents:
diff changeset
   264
        }
hgs
parents:
diff changeset
   265
    OstTrace1( TRACE_FLOW, DTRACECOREXTIIF_PS_SEND_EXIT, "< DTraceCoreXtiIf::Send. Ret:%d", ret );
hgs
parents:
diff changeset
   266
    return ret;
hgs
parents:
diff changeset
   267
    }
hgs
parents:
diff changeset
   268
    
hgs
parents:
diff changeset
   269
/**
hgs
parents:
diff changeset
   270
 * Called from the TraceCore to send message out.
hgs
parents:
diff changeset
   271
 */
hgs
parents:
diff changeset
   272
TInt DTraceCoreXtiIf::SendMessage( TTraceMessage &aMsg )
hgs
parents:
diff changeset
   273
    {
hgs
parents:
diff changeset
   274
    TInt ret = Send( aMsg );
hgs
parents:
diff changeset
   275
    return ret;
hgs
parents:
diff changeset
   276
    }
hgs
parents:
diff changeset
   277
hgs
parents:
diff changeset
   278
/**
hgs
parents:
diff changeset
   279
 * Sends message to XTI
hgs
parents:
diff changeset
   280
 * 
hgs
parents:
diff changeset
   281
 * @param aMsg Message to be sent.
hgs
parents:
diff changeset
   282
 */
hgs
parents:
diff changeset
   283
void DTraceCoreXtiIf::SendData( TTraceMessage& aMsg )
hgs
parents:
diff changeset
   284
    {
hgs
parents:
diff changeset
   285
    const TText8* pS = NULL;
hgs
parents:
diff changeset
   286
    const TText8* pE = NULL;
hgs
parents:
diff changeset
   287
    if ( aMsg.iHeader != NULL )
hgs
parents:
diff changeset
   288
        {
hgs
parents:
diff changeset
   289
        // Utility function is used to merge the data
hgs
parents:
diff changeset
   290
        TInt ret = TXtiIfMessageUtils::MergeHeaderAndData( aMsg, iSendBuffer );
hgs
parents:
diff changeset
   291
        if ( ret == KErrNone )
hgs
parents:
diff changeset
   292
            {
hgs
parents:
diff changeset
   293
            pS = iSendBuffer.Ptr();
hgs
parents:
diff changeset
   294
            pE = pS + iSendBuffer.Length();
hgs
parents:
diff changeset
   295
            }
hgs
parents:
diff changeset
   296
        }
hgs
parents:
diff changeset
   297
    else
hgs
parents:
diff changeset
   298
        {
hgs
parents:
diff changeset
   299
        // Header doesn't exists, all data is in data part
hgs
parents:
diff changeset
   300
        pS = aMsg.iData->Ptr();
hgs
parents:
diff changeset
   301
        pE = pS + aMsg.iData->Length();
hgs
parents:
diff changeset
   302
        }
hgs
parents:
diff changeset
   303
    
hgs
parents:
diff changeset
   304
    // Print using 8bit write
hgs
parents:
diff changeset
   305
    while ( pS < pE )
hgs
parents:
diff changeset
   306
        {
hgs
parents:
diff changeset
   307
        XtiTx::WriteData8( KChannel0, *( pS++ ) );
hgs
parents:
diff changeset
   308
        }
hgs
parents:
diff changeset
   309
    }
hgs
parents:
diff changeset
   310
hgs
parents:
diff changeset
   311
/**
hgs
parents:
diff changeset
   312
 * The entry point for a standard extension. Creates TraceCoreXtiIfPlugin extension.
hgs
parents:
diff changeset
   313
 *
hgs
parents:
diff changeset
   314
 *  @return KErrNone, if successful
hgs
parents:
diff changeset
   315
 */
hgs
parents:
diff changeset
   316
DECLARE_STANDARD_EXTENSION()    //lint !e960 !e1717 ¤/#((& Symbian
hgs
parents:
diff changeset
   317
    {
hgs
parents:
diff changeset
   318
    TC_TRACE( ETraceLevelNormal, Kern::Printf( "DECLARE_STANDARD_EXTENSION Start Trace Core XTI IF Plugin" ) );
hgs
parents:
diff changeset
   319
    
hgs
parents:
diff changeset
   320
    TInt ret = KErrNone;
hgs
parents:
diff changeset
   321
    
hgs
parents:
diff changeset
   322
       // Certificate check should be done here e.g. if ( XtiTx::IsTraceEnabled() )
hgs
parents:
diff changeset
   323
       // CpuPage::IsRdcAvailable();
hgs
parents:
diff changeset
   324
        {
hgs
parents:
diff changeset
   325
        DTraceCoreXtiIf* xtiIfPlugin = new DTraceCoreXtiIf();
hgs
parents:
diff changeset
   326
        
hgs
parents:
diff changeset
   327
        if ( xtiIfPlugin != NULL )
hgs
parents:
diff changeset
   328
            {
hgs
parents:
diff changeset
   329
            ret = xtiIfPlugin->Init();
hgs
parents:
diff changeset
   330
            if ( ret != KErrNone )
hgs
parents:
diff changeset
   331
                {
hgs
parents:
diff changeset
   332
                delete xtiIfPlugin;
hgs
parents:
diff changeset
   333
                }
hgs
parents:
diff changeset
   334
            }
hgs
parents:
diff changeset
   335
        else
hgs
parents:
diff changeset
   336
            {
hgs
parents:
diff changeset
   337
            ret = KErrNoMemory;
hgs
parents:
diff changeset
   338
            }
hgs
parents:
diff changeset
   339
        }
hgs
parents:
diff changeset
   340
hgs
parents:
diff changeset
   341
	if (ret == KErrNone) 
hgs
parents:
diff changeset
   342
		{
hgs
parents:
diff changeset
   343
        POSTCODE( Kern::Printf("[POST][TraceCoreXtiIfPlugin][Start][OK]"); )
hgs
parents:
diff changeset
   344
		}
hgs
parents:
diff changeset
   345
	else
hgs
parents:
diff changeset
   346
		{
hgs
parents:
diff changeset
   347
        POSTCODE( Kern::Printf("[POST][TraceCoreXtiIfPlugin][FAIL][%d]", ret ); )
hgs
parents:
diff changeset
   348
		}           
hgs
parents:
diff changeset
   349
        
hgs
parents:
diff changeset
   350
    return ret;
hgs
parents:
diff changeset
   351
    }
hgs
parents:
diff changeset
   352
hgs
parents:
diff changeset
   353
// End of File