piprofiler/plugins/GeneralsPlugin/inc/IttSamplerImpl.h
author hgs
Thu, 13 May 2010 23:59:27 +0300
changeset 20 a71a3e32a2ae
permissions -rw-r--r--
201019
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
20
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef PROFILER_ITT_SAMPLER_H
hgs
parents:
diff changeset
    19
#define PROFILER_ITT_SAMPLER_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include "GeneralsConfig.h"
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
#include <kern_priv.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
#include <piprofiler/ProfilerGenericClassesKrn.h>
hgs
parents:
diff changeset
    26
#include <piprofiler/ProfilerTraces.h>
hgs
parents:
diff changeset
    27
#include "GppSamplerImpl.h"
hgs
parents:
diff changeset
    28
#include "IttEventHandler.h"
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
// CONSTANTS
hgs
parents:
diff changeset
    31
const TInt KITTSampleBufferSize = 256;
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
// flags
hgs
parents:
diff changeset
    34
#define ITT_EVENT_HANDLER   // enable event based ITT sampling
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
/*
hgs
parents:
diff changeset
    37
 *	
hgs
parents:
diff changeset
    38
 *	ITT sampler definition
hgs
parents:
diff changeset
    39
 *	
hgs
parents:
diff changeset
    40
 */
hgs
parents:
diff changeset
    41
class DIttEventHandler;
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
/*
hgs
parents:
diff changeset
    44
 * User side ITT sampler
hgs
parents:
diff changeset
    45
 */
hgs
parents:
diff changeset
    46
class IttSamplerImpl
hgs
parents:
diff changeset
    47
{
hgs
parents:
diff changeset
    48
public:
hgs
parents:
diff changeset
    49
	IttSamplerImpl();
hgs
parents:
diff changeset
    50
	~IttSamplerImpl();
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
	TInt	SampleImpl(TUint32 pc,TUint32 sampleNum);
hgs
parents:
diff changeset
    53
	TBool	SampleNeeded(TUint32 sampleNum);
hgs
parents:
diff changeset
    54
	TInt 	CreateFirstSample();
hgs
parents:
diff changeset
    55
	void	Reset();
hgs
parents:
diff changeset
    56
	TInt    ProcessEvent();
hgs
parents:
diff changeset
    57
	
hgs
parents:
diff changeset
    58
	TUint8*         itt_sample;
hgs
parents:
diff changeset
    59
	TInt            iIttSamplingPeriod;
hgs
parents:
diff changeset
    60
	TInt            iIttSamplingPeriodDiv2;
hgs
parents:
diff changeset
    61
	TBool           iTimeToSample;
hgs
parents:
diff changeset
    62
#ifdef ITT_EVENT_HANDLER
hgs
parents:
diff changeset
    63
    TBool           iEventReceived;
hgs
parents:
diff changeset
    64
    TBool           iFirstSampleTaken;
hgs
parents:
diff changeset
    65
#endif
hgs
parents:
diff changeset
    66
	
hgs
parents:
diff changeset
    67
private:
hgs
parents:
diff changeset
    68
#ifdef ITT_EVENT_HANDLER    
hgs
parents:
diff changeset
    69
    TInt            iCount;
hgs
parents:
diff changeset
    70
#endif
hgs
parents:
diff changeset
    71
    TInt            currentLibCount;
hgs
parents:
diff changeset
    72
    TInt            currentProcCount;
hgs
parents:
diff changeset
    73
    
hgs
parents:
diff changeset
    74
	TUint8          sample[KITTSampleBufferSize ];
hgs
parents:
diff changeset
    75
	TPtr8           sampleDescriptor;
hgs
parents:
diff changeset
    76
		
hgs
parents:
diff changeset
    77
	TBuf8<64>		iVersionData;
hgs
parents:
diff changeset
    78
	SDblQue* 		codeSegList;
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
 * ITT sampler kernel part
hgs
parents:
diff changeset
    84
 * 
hgs
parents:
diff changeset
    85
 */
hgs
parents:
diff changeset
    86
template <int BufferSize>
hgs
parents:
diff changeset
    87
class DProfilerIttSampler : public DProfilerGenericSampler<BufferSize>
hgs
parents:
diff changeset
    88
{
hgs
parents:
diff changeset
    89
public:
hgs
parents:
diff changeset
    90
	DProfilerIttSampler(struct TProfilerGppSamplerData* gppSamplerDataIn);
hgs
parents:
diff changeset
    91
	~DProfilerIttSampler();
hgs
parents:
diff changeset
    92
hgs
parents:
diff changeset
    93
	void	Sample();
hgs
parents:
diff changeset
    94
	TInt	Reset(DProfilerSampleStream* aStream, TUint32 aSyncOffset);
hgs
parents:
diff changeset
    95
	TInt	PostSample();
hgs
parents:
diff changeset
    96
	TBool	PostSampleNeeded();
hgs
parents:
diff changeset
    97
hgs
parents:
diff changeset
    98
private:
hgs
parents:
diff changeset
    99
#ifdef ITT_EVENT_HANDLER
hgs
parents:
diff changeset
   100
    DIttEventHandler*               iEventHandler;
hgs
parents:
diff changeset
   101
#endif
hgs
parents:
diff changeset
   102
	IttSamplerImpl					ittSamplerImpl;
hgs
parents:
diff changeset
   103
	struct TProfilerGppSamplerData*     gppSamplerData;
hgs
parents:
diff changeset
   104
	TBool							sampleInProgress;
hgs
parents:
diff changeset
   105
	TBool							sampleNeeded;
hgs
parents:
diff changeset
   106
};
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
/*  
hgs
parents:
diff changeset
   109
 *	ITT sampler implementation
hgs
parents:
diff changeset
   110
 *	
hgs
parents:
diff changeset
   111
 */ 
hgs
parents:
diff changeset
   112
template <int BufferSize>
hgs
parents:
diff changeset
   113
DProfilerIttSampler<BufferSize>::DProfilerIttSampler(struct TProfilerGppSamplerData* gppSamplerDataIn) :
hgs
parents:
diff changeset
   114
	DProfilerGenericSampler<BufferSize>(PROFILER_ITT_SAMPLER_ID)
hgs
parents:
diff changeset
   115
{
hgs
parents:
diff changeset
   116
	this->gppSamplerData = (struct TProfilerGppSamplerData*)gppSamplerDataIn;
hgs
parents:
diff changeset
   117
	this->sampleInProgress = false;
hgs
parents:
diff changeset
   118
	LOGSTRING2("CProfilerIttSampler<%d>::CProfilerIttSampler",BufferSize);	
hgs
parents:
diff changeset
   119
}
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
/*
hgs
parents:
diff changeset
   122
 *  DProfilerIttSampler::Reset()
hgs
parents:
diff changeset
   123
 *  
hgs
parents:
diff changeset
   124
 *  @param DProfilerSampleStream* sample stream
hgs
parents:
diff changeset
   125
 *  @param TUint32 Offset 
hgs
parents:
diff changeset
   126
 */
hgs
parents:
diff changeset
   127
template <int BufferSize>
hgs
parents:
diff changeset
   128
TInt DProfilerIttSampler<BufferSize>::Reset(DProfilerSampleStream* aStream, TUint32 aSyncOffset)
hgs
parents:
diff changeset
   129
{
hgs
parents:
diff changeset
   130
    Kern::Printf("DProfilerIttSampler<%d>::Reset - calling superclass reset",BufferSize);
hgs
parents:
diff changeset
   131
    DProfilerGenericSampler<BufferSize>::Reset(aStream);
hgs
parents:
diff changeset
   132
hgs
parents:
diff changeset
   133
    // check if reset called in stop (by driver)
hgs
parents:
diff changeset
   134
    if(aSyncOffset != 999999)
hgs
parents:
diff changeset
   135
        {
hgs
parents:
diff changeset
   136
#ifdef ITT_EVENT_HANDLER
hgs
parents:
diff changeset
   137
        // Itt event handler
hgs
parents:
diff changeset
   138
        if(iEventHandler)
hgs
parents:
diff changeset
   139
            {
hgs
parents:
diff changeset
   140
            // stop previous sampling if still running
hgs
parents:
diff changeset
   141
            Kern::Printf("Stopping DIttEventHandler");
hgs
parents:
diff changeset
   142
            iEventHandler->Stop();
hgs
parents:
diff changeset
   143
            iEventHandler->Close();
hgs
parents:
diff changeset
   144
            iEventHandler = NULL;
hgs
parents:
diff changeset
   145
            }
hgs
parents:
diff changeset
   146
    
hgs
parents:
diff changeset
   147
        Kern::Printf("Initiating DIttEventHandler");
hgs
parents:
diff changeset
   148
        iEventHandler = new DIttEventHandler(this->iSampleBuffer, this->gppSamplerData);
hgs
parents:
diff changeset
   149
        if(iEventHandler)
hgs
parents:
diff changeset
   150
            {
hgs
parents:
diff changeset
   151
            Kern::Printf("Creating DIttEventHandler");
hgs
parents:
diff changeset
   152
            TInt err(iEventHandler->Create());
hgs
parents:
diff changeset
   153
            if(err != KErrNone)
hgs
parents:
diff changeset
   154
                {
hgs
parents:
diff changeset
   155
                Kern::Printf("Error in creation of DIttEventHandler, error %d", err);
hgs
parents:
diff changeset
   156
                return err;
hgs
parents:
diff changeset
   157
                }
hgs
parents:
diff changeset
   158
            }
hgs
parents:
diff changeset
   159
        else
hgs
parents:
diff changeset
   160
            {
hgs
parents:
diff changeset
   161
            Kern::Printf("Could not initiate DIttEventHandler");
hgs
parents:
diff changeset
   162
            return KErrGeneral;
hgs
parents:
diff changeset
   163
            }
hgs
parents:
diff changeset
   164
    
hgs
parents:
diff changeset
   165
        // set first sample at the 10 ms, should be enough
hgs
parents:
diff changeset
   166
        this->ittSamplerImpl.iIttSamplingPeriod = 10;
hgs
parents:
diff changeset
   167
#else
hgs
parents:
diff changeset
   168
        this->ittSamplerImpl.iIttSamplingPeriod = this->iSamplingPeriod;
hgs
parents:
diff changeset
   169
#endif
hgs
parents:
diff changeset
   170
        this->ittSamplerImpl.iIttSamplingPeriodDiv2 = (TInt)(this->ittSamplerImpl.iIttSamplingPeriod / 2);
hgs
parents:
diff changeset
   171
        LOGSTRING3("CProfilerIttSampler<%d>::Reset - set ITT sampling period to %d",
hgs
parents:
diff changeset
   172
                                BufferSize,this->ittSamplerImpl.iIttSamplingPeriod);
hgs
parents:
diff changeset
   173
        }
hgs
parents:
diff changeset
   174
    else
hgs
parents:
diff changeset
   175
        {
hgs
parents:
diff changeset
   176
        LOGSTRING2("DProfilerIttSampler<%d>::Reset - reset in stop", BufferSize);
hgs
parents:
diff changeset
   177
#ifdef ITT_EVENT_HANDLER
hgs
parents:
diff changeset
   178
        // destroy memory event handler
hgs
parents:
diff changeset
   179
        if(iEventHandler)
hgs
parents:
diff changeset
   180
            {
hgs
parents:
diff changeset
   181
            // stop previous sampling if still running
hgs
parents:
diff changeset
   182
            iEventHandler->Stop();
hgs
parents:
diff changeset
   183
            iEventHandler->Close();
hgs
parents:
diff changeset
   184
            iEventHandler = NULL;
hgs
parents:
diff changeset
   185
            }
hgs
parents:
diff changeset
   186
#endif
hgs
parents:
diff changeset
   187
        return KErrNone;    // return if reset called in stop
hgs
parents:
diff changeset
   188
        }
hgs
parents:
diff changeset
   189
hgs
parents:
diff changeset
   190
    TInt length(ittSamplerImpl.CreateFirstSample());
hgs
parents:
diff changeset
   191
    this->iSampleBuffer->AddSample((TUint8*)&length,1);
hgs
parents:
diff changeset
   192
    this->iSampleBuffer->AddSample(ittSamplerImpl.itt_sample, length);
hgs
parents:
diff changeset
   193
    this->sampleInProgress = false;
hgs
parents:
diff changeset
   194
    this->sampleNeeded = false;
hgs
parents:
diff changeset
   195
    //LOGSTRING("DProfilerIttSampler::Reset - exit");
hgs
parents:
diff changeset
   196
	this->ittSamplerImpl.Reset();
hgs
parents:
diff changeset
   197
    return KErrNone;
hgs
parents:
diff changeset
   198
hgs
parents:
diff changeset
   199
}
hgs
parents:
diff changeset
   200
hgs
parents:
diff changeset
   201
/*
hgs
parents:
diff changeset
   202
 * DProfilerIttSampler::PostSample
hgs
parents:
diff changeset
   203
 * 
hgs
parents:
diff changeset
   204
 * Function for finishing sample
hgs
parents:
diff changeset
   205
 */
hgs
parents:
diff changeset
   206
template <int BufferSize> 
hgs
parents:
diff changeset
   207
TInt DProfilerIttSampler<BufferSize>::PostSample()
hgs
parents:
diff changeset
   208
{
hgs
parents:
diff changeset
   209
#ifdef ITT_EVENT_HANDLER
hgs
parents:
diff changeset
   210
    if(!ittSamplerImpl.iFirstSampleTaken)   // if we haven't read the initial state
hgs
parents:
diff changeset
   211
    {
hgs
parents:
diff changeset
   212
#endif
hgs
parents:
diff changeset
   213
        if(sampleNeeded)
hgs
parents:
diff changeset
   214
        {
hgs
parents:
diff changeset
   215
            this->sampleNeeded = false;
hgs
parents:
diff changeset
   216
            //LOGSTRING3("CProfilerIttSampler<%d>::PostSample - state %d",BufferSize,this->iSampleBuffer->GetBufferStatus());
hgs
parents:
diff changeset
   217
            //Kern::Printf("DProfilerIttSampler<%d>::PostSample - state %d",BufferSize,this->iSampleBuffer->GetBufferStatus());
hgs
parents:
diff changeset
   218
    
hgs
parents:
diff changeset
   219
            TInt length = this->ittSamplerImpl.SampleImpl(this->gppSamplerData->lastPcValue,
hgs
parents:
diff changeset
   220
                                                          this->gppSamplerData->sampleNumber);
hgs
parents:
diff changeset
   221
            if(length != 0)
hgs
parents:
diff changeset
   222
            {		
hgs
parents:
diff changeset
   223
                LOGSTRING("ITT sampler PostSample - starting to sample");
hgs
parents:
diff changeset
   224
    
hgs
parents:
diff changeset
   225
                while(length > 0)
hgs
parents:
diff changeset
   226
                {
hgs
parents:
diff changeset
   227
                    this->iSampleBuffer->AddSample(ittSamplerImpl.itt_sample,length);
hgs
parents:
diff changeset
   228
                    length = this->ittSamplerImpl.SampleImpl( this->gppSamplerData->lastPcValue,
hgs
parents:
diff changeset
   229
                                                          this->gppSamplerData->sampleNumber );	
hgs
parents:
diff changeset
   230
                    if(length == 0) 
hgs
parents:
diff changeset
   231
                    {
hgs
parents:
diff changeset
   232
                        LOGSTRING("MEM sampler PostSample - all samples generated!");
hgs
parents:
diff changeset
   233
                    }
hgs
parents:
diff changeset
   234
                }
hgs
parents:
diff changeset
   235
                LOGSTRING("ITT sampler PostSample - finished sampling");
hgs
parents:
diff changeset
   236
            }
hgs
parents:
diff changeset
   237
            this->sampleInProgress = false;
hgs
parents:
diff changeset
   238
        }
hgs
parents:
diff changeset
   239
#ifdef ITT_EVENT_HANDLER
hgs
parents:
diff changeset
   240
    }   
hgs
parents:
diff changeset
   241
        if(!iEventHandler->Tracking())
hgs
parents:
diff changeset
   242
            {
hgs
parents:
diff changeset
   243
            iEventHandler->Start();
hgs
parents:
diff changeset
   244
            Kern::Printf("DProfilerITTSampler<%d>::PostSample - ITT handler started",BufferSize);
hgs
parents:
diff changeset
   245
            }
hgs
parents:
diff changeset
   246
hgs
parents:
diff changeset
   247
#endif    
hgs
parents:
diff changeset
   248
	
hgs
parents:
diff changeset
   249
    LOGSTRING2("ITT sampler PostSample - finished sampling, time: %d", gppSamplerData->sampleNumber);
hgs
parents:
diff changeset
   250
    
hgs
parents:
diff changeset
   251
	// finally perform superclass postsample
hgs
parents:
diff changeset
   252
	TInt i(this->DProfilerGenericSampler<BufferSize>::PostSample());
hgs
parents:
diff changeset
   253
	return i;
hgs
parents:
diff changeset
   254
}
hgs
parents:
diff changeset
   255
hgs
parents:
diff changeset
   256
/*
hgs
parents:
diff changeset
   257
 *  DProfilerIttSampler::PostSampleNeeded()
hgs
parents:
diff changeset
   258
 *  
hgs
parents:
diff changeset
   259
 *  Function for deciding if sample handling is needed 
hgs
parents:
diff changeset
   260
 */
hgs
parents:
diff changeset
   261
template <int BufferSize> 
hgs
parents:
diff changeset
   262
TBool DProfilerIttSampler<BufferSize>::PostSampleNeeded()
hgs
parents:
diff changeset
   263
{
hgs
parents:
diff changeset
   264
	LOGSTRING3("CProfilerIttSampler<%d>::PostSampleNeeded - state %d",BufferSize,this->iSampleBuffer->GetBufferStatus());
hgs
parents:
diff changeset
   265
hgs
parents:
diff changeset
   266
	TUint32 status = this->iSampleBuffer->iBufferStatus;
hgs
parents:
diff changeset
   267
hgs
parents:
diff changeset
   268
	if(status == DProfilerSampleBuffer::BufferCopyAsap || status == DProfilerSampleBuffer::BufferFull || this->sampleNeeded == true)
hgs
parents:
diff changeset
   269
	{
hgs
parents:
diff changeset
   270
		return true;
hgs
parents:
diff changeset
   271
	}
hgs
parents:
diff changeset
   272
	
hgs
parents:
diff changeset
   273
	return false;
hgs
parents:
diff changeset
   274
}
hgs
parents:
diff changeset
   275
hgs
parents:
diff changeset
   276
/*
hgs
parents:
diff changeset
   277
 * DProfilerIttSampler::Sample
hgs
parents:
diff changeset
   278
 * 
hgs
parents:
diff changeset
   279
 * Function for initiating sampling
hgs
parents:
diff changeset
   280
 */
hgs
parents:
diff changeset
   281
template <int BufferSize>
hgs
parents:
diff changeset
   282
void DProfilerIttSampler<BufferSize>::Sample()
hgs
parents:
diff changeset
   283
{
hgs
parents:
diff changeset
   284
	LOGSTRING2("CProfilerIttSampler<%d>::Sample",BufferSize);	
hgs
parents:
diff changeset
   285
	
hgs
parents:
diff changeset
   286
	//#ifdef ITT_TEST
hgs
parents:
diff changeset
   287
	LOGSTRING2("CProfilerIttSampler<%d>::Sample",BufferSize);	
hgs
parents:
diff changeset
   288
	
hgs
parents:
diff changeset
   289
	if(ittSamplerImpl.SampleNeeded(this->gppSamplerData->sampleNumber) && this->sampleInProgress == false) 
hgs
parents:
diff changeset
   290
	{
hgs
parents:
diff changeset
   291
		this->sampleInProgress = true;
hgs
parents:
diff changeset
   292
		this->sampleNeeded = true;
hgs
parents:
diff changeset
   293
hgs
parents:
diff changeset
   294
		LOGSTRING2("CProfilerIttSampler<%d>::Sample - sample needed",BufferSize);	
hgs
parents:
diff changeset
   295
	}	
hgs
parents:
diff changeset
   296
#ifdef ITT_EVENT_HANDLER
hgs
parents:
diff changeset
   297
    // call this to increase the time stamp
hgs
parents:
diff changeset
   298
    else if(iEventHandler->SampleNeeded())
hgs
parents:
diff changeset
   299
        {
hgs
parents:
diff changeset
   300
        // set the flag for post sampling
hgs
parents:
diff changeset
   301
        this->sampleNeeded = true;
hgs
parents:
diff changeset
   302
        }
hgs
parents:
diff changeset
   303
#endif
hgs
parents:
diff changeset
   304
hgs
parents:
diff changeset
   305
	LOGSTRING2("CProfilerIttSampler<%d>::Sample",BufferSize);
hgs
parents:
diff changeset
   306
	return;
hgs
parents:
diff changeset
   307
}
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
/*
hgs
parents:
diff changeset
   310
 * Destructor
hgs
parents:
diff changeset
   311
 */
hgs
parents:
diff changeset
   312
template <int BufferSize>
hgs
parents:
diff changeset
   313
DProfilerIttSampler<BufferSize>::~DProfilerIttSampler()
hgs
parents:
diff changeset
   314
{
hgs
parents:
diff changeset
   315
	LOGSTRING2("CProfilerIttSampler<%d>::~CProfilerIttSampler",BufferSize);
hgs
parents:
diff changeset
   316
#ifdef ITT_EVENT_HANDLER
hgs
parents:
diff changeset
   317
     if(iEventHandler)
hgs
parents:
diff changeset
   318
         {
hgs
parents:
diff changeset
   319
         // stop previous sampling if still running
hgs
parents:
diff changeset
   320
         iEventHandler->Stop();
hgs
parents:
diff changeset
   321
         iEventHandler->Close();
hgs
parents:
diff changeset
   322
         iEventHandler = NULL;
hgs
parents:
diff changeset
   323
         }
hgs
parents:
diff changeset
   324
#endif
hgs
parents:
diff changeset
   325
}
hgs
parents:
diff changeset
   326
#endif
hgs
parents:
diff changeset
   327
// end of file