tracesrv/tracecore/btrace_handler/src/TraceCoreWriter.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 "TraceCoreWriter.h"
hgs
parents:
diff changeset
    18
#include "TraceCore.h"
hgs
parents:
diff changeset
    19
#include "TraceCoreDebug.h"
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include "TraceCoreConstants.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 "TraceCoreWriterTraces.h"
hgs
parents:
diff changeset
    25
#endif
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
#ifdef WRITE_OST_HEADER
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
const TUint KDWordShift = 32;
hgs
parents:
diff changeset
    30
const TUint KDWordMask = 0xFFFFFFFF;
hgs
parents:
diff changeset
    31
const TUint KNanoSeconds = 1000000000;
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
/**
hgs
parents:
diff changeset
    34
 * Musti timestamp mask. First 4 bits are reserved for flags
hgs
parents:
diff changeset
    35
 */
hgs
parents:
diff changeset
    36
const TUint KTimestampMask = 0x0FFFFFFF;
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
/**
hgs
parents:
diff changeset
    39
 * Musti timestamp flags for XTIv2
hgs
parents:
diff changeset
    40
 */
hgs
parents:
diff changeset
    41
const TUint KTimestampFlags = 0xD0000000;
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
const TUint KComponentIdLength(4);
hgs
parents:
diff changeset
    44
const TUint KGroupIdLength(4);
hgs
parents:
diff changeset
    45
const TUint KTimestampLenght(8);
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
#endif // WRITE_OST_HEADER
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
/**
hgs
parents:
diff changeset
    50
 * Constructor
hgs
parents:
diff changeset
    51
 */
hgs
parents:
diff changeset
    52
EXPORT_C DTraceCoreWriter::DTraceCoreWriter( TWriterType aWriterType )
hgs
parents:
diff changeset
    53
: iWriterType( aWriterType )
hgs
parents:
diff changeset
    54
    {
hgs
parents:
diff changeset
    55
    }
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
/**
hgs
parents:
diff changeset
    59
 * Destructor
hgs
parents:
diff changeset
    60
 */
hgs
parents:
diff changeset
    61
EXPORT_C DTraceCoreWriter::~DTraceCoreWriter()
hgs
parents:
diff changeset
    62
    {
hgs
parents:
diff changeset
    63
    Unregister();
hgs
parents:
diff changeset
    64
    }
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
/**
hgs
parents:
diff changeset
    68
 * Registers this writer to TraceCore
hgs
parents:
diff changeset
    69
 */
hgs
parents:
diff changeset
    70
EXPORT_C TInt DTraceCoreWriter::Register()
hgs
parents:
diff changeset
    71
    {
hgs
parents:
diff changeset
    72
    TInt ret= KErrGeneral;  
hgs
parents:
diff changeset
    73
    // Get TraceCore
hgs
parents:
diff changeset
    74
    DTraceCore* traceCore = DTraceCore::GetInstance();
hgs
parents:
diff changeset
    75
    if ( traceCore != NULL )
hgs
parents:
diff changeset
    76
        {
hgs
parents:
diff changeset
    77
        // Register this writer
hgs
parents:
diff changeset
    78
        ret = traceCore->RegisterWriter( *this );
hgs
parents:
diff changeset
    79
        }
hgs
parents:
diff changeset
    80
    OstTrace1( TRACE_BORDER, DTRACECOREWRITER_REGISTER_EXIT, "< DTraceCoreWriter::Register %d", ret );
hgs
parents:
diff changeset
    81
    return ret;
hgs
parents:
diff changeset
    82
    }
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
hgs
parents:
diff changeset
    85
/**
hgs
parents:
diff changeset
    86
 * Unregisters this writer from TraceCore
hgs
parents:
diff changeset
    87
 */
hgs
parents:
diff changeset
    88
void DTraceCoreWriter::Unregister()
hgs
parents:
diff changeset
    89
    {
hgs
parents:
diff changeset
    90
    // Get TraceCore
hgs
parents:
diff changeset
    91
    DTraceCore* traceCore = DTraceCore::GetInstance();
hgs
parents:
diff changeset
    92
    if ( traceCore != NULL )
hgs
parents:
diff changeset
    93
        {
hgs
parents:
diff changeset
    94
        // Unregister this writer
hgs
parents:
diff changeset
    95
        traceCore->UnregisterWriter( *this );
hgs
parents:
diff changeset
    96
        }
hgs
parents:
diff changeset
    97
    }
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
/**
hgs
parents:
diff changeset
   101
 * Gets the writer type
hgs
parents:
diff changeset
   102
 */
hgs
parents:
diff changeset
   103
TWriterType DTraceCoreWriter::GetWriterType()
hgs
parents:
diff changeset
   104
    {
hgs
parents:
diff changeset
   105
    return iWriterType;
hgs
parents:
diff changeset
   106
    }
hgs
parents:
diff changeset
   107
    
hgs
parents:
diff changeset
   108
    
hgs
parents:
diff changeset
   109
/**
hgs
parents:
diff changeset
   110
 * Outputs a TraceCore frame. This calls WriteStart, writes the component and group ID's,
hgs
parents:
diff changeset
   111
 * calls WriteBTraceFrame and calls WriteEnd.
hgs
parents:
diff changeset
   112
 * 
hgs
parents:
diff changeset
   113
 * Tracing is not allowed from this method.
hgs
parents:
diff changeset
   114
 *
hgs
parents:
diff changeset
   115
 * @param aComponentId the component ID
hgs
parents:
diff changeset
   116
 * @param aTraceWord The trace word containing the group ID and the trace ID to write
hgs
parents:
diff changeset
   117
 * @param aHeader BTrace header
hgs
parents:
diff changeset
   118
 * @param aHeader2 Extra header data
hgs
parents:
diff changeset
   119
 * @param aContext The thread context in which this function was called
hgs
parents:
diff changeset
   120
 * @param a1 The first trace parameter
hgs
parents:
diff changeset
   121
 * @param a2 The second trace parameter
hgs
parents:
diff changeset
   122
 * @param a3 The third trace parameter
hgs
parents:
diff changeset
   123
 * @param aExtra Extra trace data
hgs
parents:
diff changeset
   124
 * @param aPc The program counter value
hgs
parents:
diff changeset
   125
 * @param aRecordSize The record size
hgs
parents:
diff changeset
   126
 */
hgs
parents:
diff changeset
   127
EXPORT_C void DTraceCoreWriter::WriteTraceCoreFrame( const TUint32 aComponentId, const TUint32 aTraceWord, 
hgs
parents:
diff changeset
   128
        TUint32 aHeader, TUint32 aHeader2, const TUint32 aContext, const TUint32 a1, 
hgs
parents:
diff changeset
   129
        const TUint32 a2, const TUint32 a3, const TUint32 aExtra, const TUint32 aPc, TUint32 aRecordSize )
hgs
parents:
diff changeset
   130
    {    
hgs
parents:
diff changeset
   131
    //TODO: tidy up code from #ifdef's
hgs
parents:
diff changeset
   132
    
hgs
parents:
diff changeset
   133
#ifdef USE_OPTIMIZED_WRITE
hgs
parents:
diff changeset
   134
	if ( iWriterType == EWriterTypeXTI ) 
hgs
parents:
diff changeset
   135
#else
hgs
parents:
diff changeset
   136
    if ( false )
hgs
parents:
diff changeset
   137
#endif
hgs
parents:
diff changeset
   138
		{
hgs
parents:
diff changeset
   139
		}
hgs
parents:
diff changeset
   140
	else
hgs
parents:
diff changeset
   141
		{
hgs
parents:
diff changeset
   142
	    TUint32 entryId = WriteStart( EWriterEntryTrace );
hgs
parents:
diff changeset
   143
hgs
parents:
diff changeset
   144
#ifdef WRITE_OST_HEADER
hgs
parents:
diff changeset
   145
	if ( iWriterType == EWriterTypeXTI )
hgs
parents:
diff changeset
   146
	    {
hgs
parents:
diff changeset
   147
        // Size is in the beginning of the 
hgs
parents:
diff changeset
   148
        TUint32 size = aRecordSize + KTimestampLenght + KComponentIdLength + KGroupIdLength; //+(aHeader & 0xff)
hgs
parents:
diff changeset
   149
    #ifdef AUTOGEN_ADD_BTRACE_TIMESTAMP
hgs
parents:
diff changeset
   150
        size += KTimestampSize;
hgs
parents:
diff changeset
   151
    #endif
hgs
parents:
diff changeset
   152
    
hgs
parents:
diff changeset
   153
        // Decrease component, group and trace ID (8 bytes) from the size as they are also included in the BTrace
hgs
parents:
diff changeset
   154
        // variables and they won't be written in the BTrace packet anymore
hgs
parents:
diff changeset
   155
        size -= ( KA1Size + KA2Size );
hgs
parents:
diff changeset
   156
        
hgs
parents:
diff changeset
   157
        //  version(0x05);    // OST Base Protocol version "1.0" (v00-80-00_r1-04.pdf)
hgs
parents:
diff changeset
   158
        //  entityId(0x01);   // Entity id TODO: check if this needs to change with CPU
hgs
parents:
diff changeset
   159
        //  protocolId(0x03); // Simple Application Trace Protocol (Not in MIPI specs 08 yet)
hgs
parents:
diff changeset
   160
        
hgs
parents:
diff changeset
   161
        WriteData( entryId, ( TUint8 )0x05 ); // Version "0.5" because BTrace header included with protocol id 0x03
hgs
parents:
diff changeset
   162
        WriteData( entryId, ( TUint8 )0x01 ); // EntityId
hgs
parents:
diff changeset
   163
        WriteData( entryId, ( TUint8 )0x03 ); // ProtocolId (not specified in MIPI specs yet)
hgs
parents:
diff changeset
   164
        
hgs
parents:
diff changeset
   165
        // Set length
hgs
parents:
diff changeset
   166
        // If write size less than 256
hgs
parents:
diff changeset
   167
        if(size < 256 )
hgs
parents:
diff changeset
   168
            {
hgs
parents:
diff changeset
   169
            //  length(size);
hgs
parents:
diff changeset
   170
            WriteData( entryId, ( TUint8 )size );
hgs
parents:
diff changeset
   171
            
hgs
parents:
diff changeset
   172
            }
hgs
parents:
diff changeset
   173
        else
hgs
parents:
diff changeset
   174
            {
hgs
parents:
diff changeset
   175
            //  extendedLengthBits0_7(0x00);
hgs
parents:
diff changeset
   176
            //  extendedLengthBits8_15(0x00);
hgs
parents:
diff changeset
   177
            //  extendedLengthBits16_23(0x00);
hgs
parents:
diff changeset
   178
            //  extendedLengthBits24_31(0x00);
hgs
parents:
diff changeset
   179
            WriteData( entryId, ( TUint8 )0x00 ); // length field 0 if extended length in use
hgs
parents:
diff changeset
   180
            //WriteData( entryId, ( TUint32 )size );// No swap, Length in protocol is little endian //SWAP_DATA( size ) );
hgs
parents:
diff changeset
   181
            // Swap needed after all to make little endian in XTI trace??
hgs
parents:
diff changeset
   182
            WriteData( entryId, ( TUint32 )SWAP_DATA( size ) );
hgs
parents:
diff changeset
   183
            }
hgs
parents:
diff changeset
   184
            
hgs
parents:
diff changeset
   185
        // Write timestamp
hgs
parents:
diff changeset
   186
        TUint64 timestamp = NKern::FastCounter();
hgs
parents:
diff changeset
   187
        timestamp = (timestamp * KNanoSeconds ) / NKern::FastCounterFrequency();
hgs
parents:
diff changeset
   188
        
hgs
parents:
diff changeset
   189
        TUint32 timestampLSB = timestamp & KDWordMask;
hgs
parents:
diff changeset
   190
        TUint32 timestampMSB = ( (timestamp >> KDWordShift ) & KTimestampMask ) | KTimestampFlags;
hgs
parents:
diff changeset
   191
        
hgs
parents:
diff changeset
   192
        WriteData( entryId, SWAP_ID( timestampMSB ) );
hgs
parents:
diff changeset
   193
        WriteData( entryId, SWAP_ID( timestampLSB ) );
hgs
parents:
diff changeset
   194
	    }
hgs
parents:
diff changeset
   195
        
hgs
parents:
diff changeset
   196
    // Write Component  and groupid (including traceid )
hgs
parents:
diff changeset
   197
    WriteData( entryId, SWAP_ID( aComponentId ) );
hgs
parents:
diff changeset
   198
    WriteData( entryId, SWAP_ID( aTraceWord ) );          
hgs
parents:
diff changeset
   199
        
hgs
parents:
diff changeset
   200
#else // WRITE_OST_HEADER 
hgs
parents:
diff changeset
   201
    WriteData( entryId, SWAP_ID( aComponentId ) );
hgs
parents:
diff changeset
   202
    WriteData( entryId, SWAP_ID( aTraceWord ) );
hgs
parents:
diff changeset
   203
#endif
hgs
parents:
diff changeset
   204
    WriteBTraceFrame( entryId, aHeader, aHeader2, aContext, a1, a2, a3, aExtra, aPc, aRecordSize );
hgs
parents:
diff changeset
   205
    
hgs
parents:
diff changeset
   206
    WriteEnd( entryId );
hgs
parents:
diff changeset
   207
		}
hgs
parents:
diff changeset
   208
		
hgs
parents:
diff changeset
   209
    }
hgs
parents:
diff changeset
   210
hgs
parents:
diff changeset
   211
hgs
parents:
diff changeset
   212
/**
hgs
parents:
diff changeset
   213
 * Outputs a BTrace frame into this writer.
hgs
parents:
diff changeset
   214
 * Tracing is not allowed from this method.
hgs
parents:
diff changeset
   215
 *
hgs
parents:
diff changeset
   216
 * @param aEntryId the entry ID returned by WriteStart
hgs
parents:
diff changeset
   217
 * @param aHeader BTrace header
hgs
parents:
diff changeset
   218
 * @param aHeader2 Extra header data
hgs
parents:
diff changeset
   219
 * @param aContext The thread context in which this function was called
hgs
parents:
diff changeset
   220
 * @param a1 The first trace parameter
hgs
parents:
diff changeset
   221
 * @param a2 The second trace parameter
hgs
parents:
diff changeset
   222
 * @param a3 The third trace parameter
hgs
parents:
diff changeset
   223
 * @param aExtra Extra trace data
hgs
parents:
diff changeset
   224
 * @param aPc The program counter value
hgs
parents:
diff changeset
   225
 * @param aRecordSize The record size
hgs
parents:
diff changeset
   226
 */
hgs
parents:
diff changeset
   227
void DTraceCoreWriter::WriteBTraceFrame( const TUint32 aEntryId, TUint32 aHeader, TUint32 aHeader2, 
hgs
parents:
diff changeset
   228
        const TUint32 aContext, const TUint32 a1, const TUint32 a2, const TUint32 a3, 
hgs
parents:
diff changeset
   229
        const TUint32 aExtra, const TUint32 aPc, TUint32 aRecordSize )
hgs
parents:
diff changeset
   230
    {
hgs
parents:
diff changeset
   231
    // BTrace frame header. Don't read size from the header because Multipart trace can bigger than can fit to one byte.
hgs
parents:
diff changeset
   232
    TUint32 size = aRecordSize;
hgs
parents:
diff changeset
   233
    TUint8 flags = static_cast< TUint8 >( ( aHeader >> ( BTrace::EFlagsIndex * KByteSize ) ) & KByteMask );
hgs
parents:
diff changeset
   234
    TUint8 category = static_cast< TUint8 >( ( aHeader >> ( BTrace::ECategoryIndex * KByteSize ) ) & KByteMask );
hgs
parents:
diff changeset
   235
    TUint8 subcategory = static_cast< TUint8 >( ( aHeader >> ( BTrace::ESubCategoryIndex * KByteSize ) ) & KByteMask );
hgs
parents:
diff changeset
   236
    
hgs
parents:
diff changeset
   237
    #ifdef __SMP__
hgs
parents:
diff changeset
   238
	// Header 2 always present and contains CPU number
hgs
parents:
diff changeset
   239
	// If Header2 not originally there, add 4 to size
hgs
parents:
diff changeset
   240
	if (!( flags & BTrace::EHeader2Present))
hgs
parents:
diff changeset
   241
		{
hgs
parents:
diff changeset
   242
        flags |= BTrace::EHeader2Present;
hgs
parents:
diff changeset
   243
        aHeader2 = 0;
hgs
parents:
diff changeset
   244
        size += KHeader2Size;
hgs
parents:
diff changeset
   245
	    }
hgs
parents:
diff changeset
   246
	aHeader2 = (aHeader2 &~ BTrace::ECpuIdMask) | (NKern::CurrentCpu()<<20); 
hgs
parents:
diff changeset
   247
	#endif
hgs
parents:
diff changeset
   248
    
hgs
parents:
diff changeset
   249
    // If timestamp is added to frame, the timestamp flag is also set to the header
hgs
parents:
diff changeset
   250
    // and the header size is increased by the size of the timestamp
hgs
parents:
diff changeset
   251
#ifdef AUTOGEN_ADD_BTRACE_TIMESTAMP
hgs
parents:
diff changeset
   252
	if (!( flags & BTrace::ETimestampPresent))
hgs
parents:
diff changeset
   253
	    {
hgs
parents:
diff changeset
   254
	    size += KTimestampSize;
hgs
parents:
diff changeset
   255
	    flags |= BTrace::ETimestampPresent;
hgs
parents:
diff changeset
   256
	    }
hgs
parents:
diff changeset
   257
#endif
hgs
parents:
diff changeset
   258
hgs
parents:
diff changeset
   259
    // In case of autogen and OST categories, the BTrace frame size needs to be adjusted
hgs
parents:
diff changeset
   260
    // depending on whether the group / trace ID info is replicated into the
hgs
parents:
diff changeset
   261
    // frame or not.
hgs
parents:
diff changeset
   262
    if ( category == KCategoryNokiaAutogen )
hgs
parents:
diff changeset
   263
        {
hgs
parents:
diff changeset
   264
        // Group and trace ID's are not written -> Skip a1
hgs
parents:
diff changeset
   265
        size -= KA1Size;
hgs
parents:
diff changeset
   266
        }
hgs
parents:
diff changeset
   267
        
hgs
parents:
diff changeset
   268
    // Same applies to OST categories
hgs
parents:
diff changeset
   269
    else if (category >= KMaxKernelCategory    && // category <= KMaxCategory && // Not needed since category is a TUint8
hgs
parents:
diff changeset
   270
       	     category != KCategoryNokiaBranchCoverage)
hgs
parents:
diff changeset
   271
        {
hgs
parents:
diff changeset
   272
        // Component, group and trace ID's from a1 and a2 are skipped
hgs
parents:
diff changeset
   273
        size -= ( KA1Size + KA2Size );
hgs
parents:
diff changeset
   274
        }
hgs
parents:
diff changeset
   275
    else
hgs
parents:
diff changeset
   276
        {
hgs
parents:
diff changeset
   277
        // Other categories do not have component / group / trace ID's
hgs
parents:
diff changeset
   278
        // -> No flagging is needed here
hgs
parents:
diff changeset
   279
        }
hgs
parents:
diff changeset
   280
hgs
parents:
diff changeset
   281
    // Insert possibly changed values to BTrace header
hgs
parents:
diff changeset
   282
    TUint8 sizeToHeader = size;
hgs
parents:
diff changeset
   283
    if (size >= KByteMask )
hgs
parents:
diff changeset
   284
        {
hgs
parents:
diff changeset
   285
        sizeToHeader = KByteMask;
hgs
parents:
diff changeset
   286
        }
hgs
parents:
diff changeset
   287
    
hgs
parents:
diff changeset
   288
    aHeader = ( sizeToHeader << ( BTrace::ESizeIndex * KByteSize ) )
hgs
parents:
diff changeset
   289
            | ( flags << ( BTrace::EFlagsIndex * KByteSize ) )
hgs
parents:
diff changeset
   290
            | ( category << ( BTrace::ECategoryIndex * KByteSize ) )
hgs
parents:
diff changeset
   291
            | ( subcategory << ( BTrace::ESubCategoryIndex * KByteSize ) );
hgs
parents:
diff changeset
   292
    
hgs
parents:
diff changeset
   293
    // Writes the header
hgs
parents:
diff changeset
   294
    WriteData( aEntryId, SWAP_DATA( aHeader ) );
hgs
parents:
diff changeset
   295
    size -= KHeaderSize; // Subtract header size
hgs
parents:
diff changeset
   296
    
hgs
parents:
diff changeset
   297
    if ( flags & BTrace::EHeader2Present )
hgs
parents:
diff changeset
   298
        {
hgs
parents:
diff changeset
   299
        WriteData( aEntryId, SWAP_DATA( aHeader2 ) );
hgs
parents:
diff changeset
   300
    	size -= KHeader2Size;
hgs
parents:
diff changeset
   301
        }
hgs
parents:
diff changeset
   302
hgs
parents:
diff changeset
   303
#ifdef AUTOGEN_ADD_BTRACE_TIMESTAMP
hgs
parents:
diff changeset
   304
    // Timestamp is written after header2
hgs
parents:
diff changeset
   305
    TUint32 timestamp = NKern::FastCounter();
hgs
parents:
diff changeset
   306
    WriteData( aEntryId, SWAP_DATA( timestamp ) );
hgs
parents:
diff changeset
   307
    size -= KTimestampSize;
hgs
parents:
diff changeset
   308
#endif
hgs
parents:
diff changeset
   309
hgs
parents:
diff changeset
   310
    if ( flags & BTrace::EContextIdPresent )
hgs
parents:
diff changeset
   311
        {
hgs
parents:
diff changeset
   312
        WriteData( aEntryId, SWAP_DATA( aContext ) );
hgs
parents:
diff changeset
   313
        size -= KContextIdSize;
hgs
parents:
diff changeset
   314
        }
hgs
parents:
diff changeset
   315
    if ( flags & BTrace::EPcPresent )
hgs
parents:
diff changeset
   316
        {
hgs
parents:
diff changeset
   317
        WriteData( aEntryId, SWAP_DATA( aPc ) );
hgs
parents:
diff changeset
   318
        size -= KPcSize;
hgs
parents:
diff changeset
   319
        }
hgs
parents:
diff changeset
   320
    if ( flags & BTrace::EExtraPresent )
hgs
parents:
diff changeset
   321
        {
hgs
parents:
diff changeset
   322
        WriteData( aEntryId, SWAP_DATA( aExtra ) );
hgs
parents:
diff changeset
   323
        size -= KExtraSize;
hgs
parents:
diff changeset
   324
        }
hgs
parents:
diff changeset
   325
    // If A1 is present, it is written
hgs
parents:
diff changeset
   326
    if ( size >= KA1Size )
hgs
parents:
diff changeset
   327
        {
hgs
parents:
diff changeset
   328
        if ( category == KCategoryNokiaAutogen )
hgs
parents:
diff changeset
   329
            {
hgs
parents:
diff changeset
   330
            // Don't write anything
hgs
parents:
diff changeset
   331
            }
hgs
parents:
diff changeset
   332
        else if (category >= KMaxKernelCategory    && // category <= KMaxCategory && // Not needed since category is a TUint8
hgs
parents:
diff changeset
   333
           	     category != KCategoryNokiaBranchCoverage)
hgs
parents:
diff changeset
   334
            {
hgs
parents:
diff changeset
   335
            // Don't write anything
hgs
parents:
diff changeset
   336
            }
hgs
parents:
diff changeset
   337
        else
hgs
parents:
diff changeset
   338
            {
hgs
parents:
diff changeset
   339
            WriteData( aEntryId, SWAP_DATA( a1 ) );
hgs
parents:
diff changeset
   340
            size -= KA1Size;
hgs
parents:
diff changeset
   341
            }
hgs
parents:
diff changeset
   342
    
hgs
parents:
diff changeset
   343
        // If A2 is present, it is written
hgs
parents:
diff changeset
   344
        if ( size >= KA2Size )
hgs
parents:
diff changeset
   345
            {
hgs
parents:
diff changeset
   346
            if (category >= KMaxKernelCategory    && // category <= KMaxCategory && // Not needed since category is a TUint8
hgs
parents:
diff changeset
   347
                category != KCategoryNokiaBranchCoverage)
hgs
parents:
diff changeset
   348
                {
hgs
parents:
diff changeset
   349
                // In OST, group / trace ID is in a2 -> Not written
hgs
parents:
diff changeset
   350
                }
hgs
parents:
diff changeset
   351
            else
hgs
parents:
diff changeset
   352
                {
hgs
parents:
diff changeset
   353
                WriteData( aEntryId, SWAP_DATA( a2 ) );
hgs
parents:
diff changeset
   354
                size -= KA2Size;
hgs
parents:
diff changeset
   355
                }
hgs
parents:
diff changeset
   356
            
hgs
parents:
diff changeset
   357
            // If there is 4 bytes of data left, A3 is written as is
hgs
parents:
diff changeset
   358
            // If more, the data is read from buffer pointed by A3
hgs
parents:
diff changeset
   359
            if ( size <= KA3Size && size > 0 )
hgs
parents:
diff changeset
   360
                {
hgs
parents:
diff changeset
   361
                WriteData( aEntryId, SWAP_DATA( a3 ) );
hgs
parents:
diff changeset
   362
                }
hgs
parents:
diff changeset
   363
            else if ( size > 0 )
hgs
parents:
diff changeset
   364
                {
hgs
parents:
diff changeset
   365
                WriteRemainingBytes( aEntryId, size, a3 );
hgs
parents:
diff changeset
   366
                }
hgs
parents:
diff changeset
   367
            }
hgs
parents:
diff changeset
   368
        }
hgs
parents:
diff changeset
   369
    }
hgs
parents:
diff changeset
   370
hgs
parents:
diff changeset
   371
    
hgs
parents:
diff changeset
   372
/**
hgs
parents:
diff changeset
   373
 * Writes the remaining bytes if data is not 32-bit aligned
hgs
parents:
diff changeset
   374
 */
hgs
parents:
diff changeset
   375
void DTraceCoreWriter::WriteRemainingBytes( TUint32 aEntryId, TUint32 aSize, TUint32 a3 )
hgs
parents:
diff changeset
   376
    {
hgs
parents:
diff changeset
   377
    TUint8 extra = aSize % 4; // CodForChk_Dis_Magic
hgs
parents:
diff changeset
   378
    TUint32* ptr = ( TUint32* )a3;
hgs
parents:
diff changeset
   379
    TUint32* end = ( TUint32* )( ( ( TUint8* )a3 ) + ( aSize - extra ) );
hgs
parents:
diff changeset
   380
    TUint32 val;
hgs
parents:
diff changeset
   381
    while( ptr < end )
hgs
parents:
diff changeset
   382
        {
hgs
parents:
diff changeset
   383
        val = *ptr++;
hgs
parents:
diff changeset
   384
        WriteData( aEntryId, SWAP_DATA( val ) );
hgs
parents:
diff changeset
   385
        }
hgs
parents:
diff changeset
   386
    // Write remaining bytes and aligns to 32-bit boundary
hgs
parents:
diff changeset
   387
    if ( extra > 0 )
hgs
parents:
diff changeset
   388
        {
hgs
parents:
diff changeset
   389
        TUint8* ptr8 = ( TUint8* )ptr;
hgs
parents:
diff changeset
   390
        TUint8* end8 = ptr8 + extra;
hgs
parents:
diff changeset
   391
        TUint8* alignEnd = ( TUint8* )( end + 1 );
hgs
parents:
diff changeset
   392
        while ( ptr8 < alignEnd )
hgs
parents:
diff changeset
   393
            {
hgs
parents:
diff changeset
   394
            if ( ptr8 < end8 )
hgs
parents:
diff changeset
   395
                {
hgs
parents:
diff changeset
   396
                WriteData( aEntryId, *ptr8++ );
hgs
parents:
diff changeset
   397
                }
hgs
parents:
diff changeset
   398
            else
hgs
parents:
diff changeset
   399
                {
hgs
parents:
diff changeset
   400
                WriteData( aEntryId, ( TUint8 )0 );
hgs
parents:
diff changeset
   401
                ptr8++;
hgs
parents:
diff changeset
   402
                }
hgs
parents:
diff changeset
   403
            }
hgs
parents:
diff changeset
   404
        }
hgs
parents:
diff changeset
   405
    }
hgs
parents:
diff changeset
   406
hgs
parents:
diff changeset
   407
   
hgs
parents:
diff changeset
   408
EXPORT_C void DTraceCoreWriter::WriteEnd( const TWriteEndParams& aWriteEndParams )
hgs
parents:
diff changeset
   409
    {
hgs
parents:
diff changeset
   410
    WriteEnd( aWriteEndParams.iEntryId );
hgs
parents:
diff changeset
   411
    }
hgs
parents:
diff changeset
   412
hgs
parents:
diff changeset
   413
hgs
parents:
diff changeset
   414
/**
hgs
parents:
diff changeset
   415
 * Signal to TraceCore if there has been a dropped trace
hgs
parents:
diff changeset
   416
 * 
hgs
parents:
diff changeset
   417
 * @param aDropped ETrue if the writer dropped the trace - otherwise EFalse
hgs
parents:
diff changeset
   418
 * 
hgs
parents:
diff changeset
   419
 */
hgs
parents:
diff changeset
   420
hgs
parents:
diff changeset
   421
EXPORT_C void DTraceCoreWriter::TraceDropped(TBool aDropped)
hgs
parents:
diff changeset
   422
    {
hgs
parents:
diff changeset
   423
    DTraceCore* tracecore = DTraceCore::GetInstance();
hgs
parents:
diff changeset
   424
    tracecore->SetPreviousTraceDropped(aDropped);
hgs
parents:
diff changeset
   425
    }
hgs
parents:
diff changeset
   426
hgs
parents:
diff changeset
   427
hgs
parents:
diff changeset
   428
/**
hgs
parents:
diff changeset
   429
  * Interrogates tracecore if the last trace was dropped
hgs
parents:
diff changeset
   430
  * 
hgs
parents:
diff changeset
   431
  * @return  returns ETrue if the trace was dropped otherwise EFalse
hgs
parents:
diff changeset
   432
  * 
hgs
parents:
diff changeset
   433
  */
hgs
parents:
diff changeset
   434
EXPORT_C TBool DTraceCoreWriter::WasLastTraceDropped() const 
hgs
parents:
diff changeset
   435
    {
hgs
parents:
diff changeset
   436
    TBool ret = EFalse;
hgs
parents:
diff changeset
   437
    DTraceCore* tracecore = DTraceCore::GetInstance();
hgs
parents:
diff changeset
   438
    ret = tracecore->PreviousTraceDropped();
hgs
parents:
diff changeset
   439
    return ret;
hgs
parents:
diff changeset
   440
    }
hgs
parents:
diff changeset
   441
hgs
parents:
diff changeset
   442
hgs
parents:
diff changeset
   443
hgs
parents:
diff changeset
   444
EXPORT_C TBool DTraceCoreWriter::AbleToWrite(TUint /*aTraceSize*/)
hgs
parents:
diff changeset
   445
    {
hgs
parents:
diff changeset
   446
    return ETrue;
hgs
parents:
diff changeset
   447
    }
hgs
parents:
diff changeset
   448
   
hgs
parents:
diff changeset
   449
// End of File