perfsrv/memspy/Driver/Kernel/Source/SubChannels/MemSpyDriverLogChanProcessInspection.cpp
author hgs
Mon, 06 Sep 2010 15:00:47 +0300
changeset 51 98307c651589
permissions -rw-r--r--
201035
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
51
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
#include "MemSpyDriverLogChanProcessInspection.h"
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
// System includes
hgs
parents:
diff changeset
    21
#include <u32hal.h>
hgs
parents:
diff changeset
    22
#include <e32rom.h>
hgs
parents:
diff changeset
    23
#include <memspy/driver/memspydriverobjectsshared.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
// Shared includes
hgs
parents:
diff changeset
    26
#include "MemSpyDriverOpCodes.h"
hgs
parents:
diff changeset
    27
#include "MemSpyDriverObjectsInternal.h"
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
// User includes
hgs
parents:
diff changeset
    30
#include "MemSpyDriverUtils.h"
hgs
parents:
diff changeset
    31
#include "MemSpyDriverDevice.h"
hgs
parents:
diff changeset
    32
#include "MemSpyDriverInspectedProcess.h"
hgs
parents:
diff changeset
    33
#include "MemSpyDriverInspectedProcessManager.h"
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
DMemSpyDriverLogChanProcessInspection::DMemSpyDriverLogChanProcessInspection( DMemSpyDriverDevice& aDevice, DThread& aThread )
hgs
parents:
diff changeset
    37
:   DMemSpyDriverLogChanBase( aDevice, aThread )
hgs
parents:
diff changeset
    38
    {
hgs
parents:
diff changeset
    39
    TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::DMemSpyDriverLogChanProcessInspection() - this: 0x%08x", this ));
hgs
parents:
diff changeset
    40
    }
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
DMemSpyDriverLogChanProcessInspection::~DMemSpyDriverLogChanProcessInspection()
hgs
parents:
diff changeset
    44
	{
hgs
parents:
diff changeset
    45
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::~DMemSpyDriverLogChanProcessInspection() - START - this: 0x%08x", this ));
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::~DMemSpyDriverLogChanProcessInspection() - END - this: 0x%08x", this ));
hgs
parents:
diff changeset
    48
	}
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
TInt DMemSpyDriverLogChanProcessInspection::Request( TInt aFunction, TAny* a1, TAny* a2 )
hgs
parents:
diff changeset
    56
	{
hgs
parents:
diff changeset
    57
	TInt r = DMemSpyDriverLogChanBase::Request( aFunction, a1, a2 );
hgs
parents:
diff changeset
    58
    if  ( r == KErrNone )
hgs
parents:
diff changeset
    59
        {
hgs
parents:
diff changeset
    60
	    switch( aFunction )
hgs
parents:
diff changeset
    61
		    {
hgs
parents:
diff changeset
    62
        case EMemSpyDriverOpCodeProcessInspectOpen:
hgs
parents:
diff changeset
    63
            r = ProcessInspectionOpen( (TUint) a1 );
hgs
parents:
diff changeset
    64
            break;
hgs
parents:
diff changeset
    65
        case EMemSpyDriverOpCodeProcessInspectClose:
hgs
parents:
diff changeset
    66
            r = ProcessInspectionClose( (TUint) a1 );
hgs
parents:
diff changeset
    67
            break;
hgs
parents:
diff changeset
    68
        case EMemSpyDriverOpCodeProcessInspectRequestChanges:
hgs
parents:
diff changeset
    69
            r = ProcessInspectionRequestChanges( (TRequestStatus*) a1, (TMemSpyDriverProcessInspectionInfo*) a2 );
hgs
parents:
diff changeset
    70
            break;
hgs
parents:
diff changeset
    71
        case EMemSpyDriverOpCodeProcessInspectRequestChangesCancel:
hgs
parents:
diff changeset
    72
            r = ProcessInspectionRequestChangesCancel( (TUint) a1 );
hgs
parents:
diff changeset
    73
            break;
hgs
parents:
diff changeset
    74
        case EMemSpyDriverOpCodeProcessInspectAutoStartListReset:
hgs
parents:
diff changeset
    75
            r = ProcessInspectionAutoStartItemsClear();
hgs
parents:
diff changeset
    76
            break;
hgs
parents:
diff changeset
    77
        case EMemSpyDriverOpCodeProcessInspectAutoStartListAdd:
hgs
parents:
diff changeset
    78
            r = ProcessInspectionAutoStartItemsAdd( (TUint) a1 );
hgs
parents:
diff changeset
    79
            break;
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
        default:
hgs
parents:
diff changeset
    82
            r = KErrNotSupported;
hgs
parents:
diff changeset
    83
		    break;
hgs
parents:
diff changeset
    84
		    }
hgs
parents:
diff changeset
    85
        }
hgs
parents:
diff changeset
    86
    //
hgs
parents:
diff changeset
    87
    return r;
hgs
parents:
diff changeset
    88
	}
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
TBool DMemSpyDriverLogChanProcessInspection::IsHandler( TInt aFunction ) const
hgs
parents:
diff changeset
    92
    {
hgs
parents:
diff changeset
    93
    return ( aFunction > EMemSpyDriverOpCodeProcessInspectBase && aFunction < EMemSpyDriverOpCodeProcessInspectEnd );
hgs
parents:
diff changeset
    94
    }
hgs
parents:
diff changeset
    95
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
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
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
hgs
parents:
diff changeset
   111
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
TInt DMemSpyDriverLogChanProcessInspection::ProcessInspectionOpen( TUint aPid )
hgs
parents:
diff changeset
   122
    {
hgs
parents:
diff changeset
   123
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionOpen() - START"));
hgs
parents:
diff changeset
   124
    NKern::ThreadEnterCS();
hgs
parents:
diff changeset
   125
    
hgs
parents:
diff changeset
   126
    TInt error = OpenTempObject( aPid, EProcess );
hgs
parents:
diff changeset
   127
    if  ( error == KErrNone )
hgs
parents:
diff changeset
   128
    	{
hgs
parents:
diff changeset
   129
        DMemSpyInspectedProcessManager& pidManager = MemSpyDevice().ProcessInspectionManager();
hgs
parents:
diff changeset
   130
        error = pidManager.ProcessOpen( (DProcess*) TempObject() );
hgs
parents:
diff changeset
   131
	    CloseTempObject();
hgs
parents:
diff changeset
   132
    	}
hgs
parents:
diff changeset
   133
    //
hgs
parents:
diff changeset
   134
    NKern::ThreadLeaveCS();
hgs
parents:
diff changeset
   135
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionOpen() - END - error: %d", error ));
hgs
parents:
diff changeset
   136
    return error;
hgs
parents:
diff changeset
   137
    }
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
TInt DMemSpyDriverLogChanProcessInspection::ProcessInspectionClose( TUint aPid )
hgs
parents:
diff changeset
   141
    {
hgs
parents:
diff changeset
   142
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionClose() - START"));
hgs
parents:
diff changeset
   143
    NKern::ThreadEnterCS();
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
    TInt error = OpenTempObject( aPid, EProcess );
hgs
parents:
diff changeset
   146
    if  ( error == KErrNone )
hgs
parents:
diff changeset
   147
    	{
hgs
parents:
diff changeset
   148
        DMemSpyInspectedProcessManager& pidManager = MemSpyDevice().ProcessInspectionManager();
hgs
parents:
diff changeset
   149
        error = pidManager.ProcessClose( (DProcess*) TempObject() );
hgs
parents:
diff changeset
   150
	    CloseTempObject();
hgs
parents:
diff changeset
   151
    	}
hgs
parents:
diff changeset
   152
    
hgs
parents:
diff changeset
   153
    NKern::ThreadLeaveCS();
hgs
parents:
diff changeset
   154
hgs
parents:
diff changeset
   155
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionClose() - END - error: %d", error ));
hgs
parents:
diff changeset
   156
    return error;
hgs
parents:
diff changeset
   157
    }
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
TInt DMemSpyDriverLogChanProcessInspection::ProcessInspectionRequestChanges( TRequestStatus* aStatus, TMemSpyDriverProcessInspectionInfo* aInfo )
hgs
parents:
diff changeset
   161
    {
hgs
parents:
diff changeset
   162
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionRequestChanges() - START"));
hgs
parents:
diff changeset
   163
    NKern::ThreadEnterCS();
hgs
parents:
diff changeset
   164
hgs
parents:
diff changeset
   165
    // Read client info
hgs
parents:
diff changeset
   166
    TMemSpyDriverProcessInspectionInfo info;
hgs
parents:
diff changeset
   167
	TInt error = Kern::ThreadRawRead( &ClientThread(), aInfo, &info, sizeof(TMemSpyDriverProcessInspectionInfo) );
hgs
parents:
diff changeset
   168
    //
hgs
parents:
diff changeset
   169
    if  ( error == KErrNone )
hgs
parents:
diff changeset
   170
        {
hgs
parents:
diff changeset
   171
        DMemSpyInspectedProcessManager& pidManager = MemSpyDevice().ProcessInspectionManager();
hgs
parents:
diff changeset
   172
        DMemSpyInspectedProcess* pid = pidManager.InspectedProcessByProcessId( info.iProcessId );
hgs
parents:
diff changeset
   173
        //
hgs
parents:
diff changeset
   174
        if ( pid != NULL )
hgs
parents:
diff changeset
   175
            {
hgs
parents:
diff changeset
   176
            error = pid->NotifyOnChange( &ClientThread(), aStatus, aInfo );
hgs
parents:
diff changeset
   177
            }
hgs
parents:
diff changeset
   178
        else
hgs
parents:
diff changeset
   179
            {
hgs
parents:
diff changeset
   180
            error = KErrNotFound;
hgs
parents:
diff changeset
   181
            }
hgs
parents:
diff changeset
   182
        }
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
    // NB: Let client take care of completing request in error situations
hgs
parents:
diff changeset
   185
    NKern::ThreadLeaveCS();
hgs
parents:
diff changeset
   186
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionRequestChanges() - END - error: %d", error ));
hgs
parents:
diff changeset
   187
    return error;
hgs
parents:
diff changeset
   188
    }
hgs
parents:
diff changeset
   189
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
TInt DMemSpyDriverLogChanProcessInspection::ProcessInspectionRequestChangesCancel( TUint aPid )
hgs
parents:
diff changeset
   192
    {
hgs
parents:
diff changeset
   193
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionRequestChangesCancel() - START"));
hgs
parents:
diff changeset
   194
    NKern::ThreadEnterCS();
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
    TInt error = KErrNotFound;
hgs
parents:
diff changeset
   197
hgs
parents:
diff changeset
   198
    DMemSpyInspectedProcessManager& pidManager = MemSpyDevice().ProcessInspectionManager();
hgs
parents:
diff changeset
   199
    DMemSpyInspectedProcess* pid = pidManager.InspectedProcessByProcessId( aPid );
hgs
parents:
diff changeset
   200
    //
hgs
parents:
diff changeset
   201
    if ( pid != NULL )
hgs
parents:
diff changeset
   202
        {
hgs
parents:
diff changeset
   203
        error = pid->NotifyOnChangeCancel();
hgs
parents:
diff changeset
   204
        }
hgs
parents:
diff changeset
   205
hgs
parents:
diff changeset
   206
    NKern::ThreadLeaveCS();
hgs
parents:
diff changeset
   207
hgs
parents:
diff changeset
   208
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionRequestChangesCancel() - END - error: %d", error ));
hgs
parents:
diff changeset
   209
    return error;
hgs
parents:
diff changeset
   210
    }
hgs
parents:
diff changeset
   211
hgs
parents:
diff changeset
   212
hgs
parents:
diff changeset
   213
TInt DMemSpyDriverLogChanProcessInspection::ProcessInspectionAutoStartItemsClear()
hgs
parents:
diff changeset
   214
    {
hgs
parents:
diff changeset
   215
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionAutoStartItemsClear() - START"));
hgs
parents:
diff changeset
   216
hgs
parents:
diff changeset
   217
    NKern::ThreadEnterCS();
hgs
parents:
diff changeset
   218
hgs
parents:
diff changeset
   219
    DMemSpyInspectedProcessManager& pidManager = MemSpyDevice().ProcessInspectionManager();
hgs
parents:
diff changeset
   220
    pidManager.AutoStartListReset();
hgs
parents:
diff changeset
   221
hgs
parents:
diff changeset
   222
    NKern::ThreadLeaveCS();
hgs
parents:
diff changeset
   223
hgs
parents:
diff changeset
   224
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionAutoStartItemsClear() - END" ));
hgs
parents:
diff changeset
   225
    return KErrNone;
hgs
parents:
diff changeset
   226
    }
hgs
parents:
diff changeset
   227
hgs
parents:
diff changeset
   228
hgs
parents:
diff changeset
   229
TInt DMemSpyDriverLogChanProcessInspection::ProcessInspectionAutoStartItemsAdd( TUint aSID )
hgs
parents:
diff changeset
   230
    {
hgs
parents:
diff changeset
   231
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionAutoStartItemsAdd() - START - aSID: 0x%08x", aSID ));
hgs
parents:
diff changeset
   232
hgs
parents:
diff changeset
   233
    NKern::ThreadEnterCS();
hgs
parents:
diff changeset
   234
    DMemSpyInspectedProcessManager& pidManager = MemSpyDevice().ProcessInspectionManager();
hgs
parents:
diff changeset
   235
    const TInt error = pidManager.AutoStartListAdd( aSID );
hgs
parents:
diff changeset
   236
    NKern::ThreadLeaveCS();
hgs
parents:
diff changeset
   237
hgs
parents:
diff changeset
   238
	TRACE( Kern::Printf("DMemSpyDriverLogChanProcessInspection::ProcessInspectionAutoStartItemsAdd() - END - error: %d", error ));
hgs
parents:
diff changeset
   239
    return error;
hgs
parents:
diff changeset
   240
    }
hgs
parents:
diff changeset
   241
hgs
parents:
diff changeset
   242
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
hgs
parents:
diff changeset
   245
hgs
parents:
diff changeset
   246
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
hgs
parents:
diff changeset
   252
hgs
parents:
diff changeset
   253
hgs
parents:
diff changeset
   254
hgs
parents:
diff changeset
   255
hgs
parents:
diff changeset
   256