debugsrv/runmodedebug/securityserver/src/c_security_svr_async.cpp
author hgs
Fri, 27 Aug 2010 11:37:29 +0300
changeset 42 0ff24a8f6ca2
child 56 aa2539c91954
permissions -rw-r--r--
201033
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
42
hgs
parents:
diff changeset
     1
// Copyright (c) 2006-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 the License "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
// Asynchronous security server active object class.
hgs
parents:
diff changeset
    15
// 
hgs
parents:
diff changeset
    16
//
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#include <e32base.h>
hgs
parents:
diff changeset
    19
#include <e32base_private.h>
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include "c_security_svr_async.h"
hgs
parents:
diff changeset
    22
#include "rm_debug_logging.h"
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
using namespace Debug;
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
__ASSERT_COMPILE(_FOFF(TEventInfo, iEventType) == 20); // Checking that adding iActionTaken hasn't resized the class
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
CSecuritySvrAsync::CSecuritySvrAsync(CSecuritySvrSession* aSession, TProcessId aAgentId)
hgs
parents:
diff changeset
    29
	: CActive(CActive::EPriorityStandard),
hgs
parents:
diff changeset
    30
	iSession(aSession),
hgs
parents:
diff changeset
    31
	iProcessName(NULL),
hgs
parents:
diff changeset
    32
	iAgentId(aAgentId)
hgs
parents:
diff changeset
    33
	{
hgs
parents:
diff changeset
    34
	LOG_MSG2("CSecuritySvrAsync::CSecuritySvrAsync(aAgentId=0x%x)", TUint(aAgentId.Id()));
hgs
parents:
diff changeset
    35
	CActiveScheduler::Add(this);
hgs
parents:
diff changeset
    36
	}
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
// returns a CSecuritySvrAsync active object associated with
hgs
parents:
diff changeset
    39
// the specified agent and debugged process.
hgs
parents:
diff changeset
    40
CSecuritySvrAsync* CSecuritySvrAsync::NewL(CSecuritySvrSession* aSession, const TDesC8& aProcessName, TProcessId aAgentId)
hgs
parents:
diff changeset
    41
	{
hgs
parents:
diff changeset
    42
	CSecuritySvrAsync* me = new (ELeave) CSecuritySvrAsync(aSession, aAgentId);
hgs
parents:
diff changeset
    43
hgs
parents:
diff changeset
    44
	CleanupStack::PushL(me);
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
	me->ConstructL(aProcessName);
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
	CleanupStack::Pop(me);
hgs
parents:
diff changeset
    49
	LOG_MSG2("CSecuritySvrAsync::NewL() obj addr=0x%x", me);
hgs
parents:
diff changeset
    50
	return (me);
hgs
parents:
diff changeset
    51
	}
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
// dtor
hgs
parents:
diff changeset
    54
CSecuritySvrAsync::~CSecuritySvrAsync()
hgs
parents:
diff changeset
    55
	{
hgs
parents:
diff changeset
    56
	LOG_MSG("CSecuritySvrAsync::~CSecuritySvrAsync()");
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
	// NOTE: the Cancel() function calls DoCancel() which may rely on class members so be careful not
hgs
parents:
diff changeset
    59
	// to destroy/close data members before this call if they are needed
hgs
parents:
diff changeset
    60
	Cancel();
hgs
parents:
diff changeset
    61
	iProcessName.Close();
hgs
parents:
diff changeset
    62
	}
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
// Associates the agent id and process name with the Active Object being constructed
hgs
parents:
diff changeset
    65
void CSecuritySvrAsync::ConstructL(const TDesC8& aProcessName)
hgs
parents:
diff changeset
    66
	{
hgs
parents:
diff changeset
    67
	LOG_MSG("CSecuritySvrAsync::ConstructL()");
hgs
parents:
diff changeset
    68
	iProcessName.CreateL(aProcessName.Length());
hgs
parents:
diff changeset
    69
	iProcessName.Copy(aProcessName);
hgs
parents:
diff changeset
    70
	}
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
// RunL() completes a previously issued call (currently only GetEvent() completion)
hgs
parents:
diff changeset
    73
void CSecuritySvrAsync::RunL()
hgs
parents:
diff changeset
    74
	{
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
	LOG_MSG4("CSecuritySvrAsync::RunL() &iInfo=0x%08x,  iAgentId.Id()=0x%x, iEventType=%d", 
hgs
parents:
diff changeset
    77
	        (TUint8*)&iInfo, iAgentId.Id(), iInfo.iEventType);
hgs
parents:
diff changeset
    78
    LOG_MSG5(" RunL() : iProcessIdValid=%d, iThreadId=0x%x, iProcessId=0x%x, &iStatus=0x%x",
hgs
parents:
diff changeset
    79
            iInfo.iProcessIdValid, TUint(iInfo.iThreadId) , TUint(iInfo.iProcessId), &iStatus );
hgs
parents:
diff changeset
    80
    
hgs
parents:
diff changeset
    81
	// Something bad happened in the driver
hgs
parents:
diff changeset
    82
	User::LeaveIfError(iStatus.Int());
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
	// Write back the event data to the debug agent.
hgs
parents:
diff changeset
    85
	// For compatibility we need to check the size of the buffer that the
hgs
parents:
diff changeset
    86
	// client has passed in as the size of TEventInfo will increase over time.
hgs
parents:
diff changeset
    87
	// Clients can calculate the required size from the EApiConstantsTEventInfoSize entry 
hgs
parents:
diff changeset
    88
	// in the Debug Functionality block but may still pass in buffers which
hgs
parents:
diff changeset
    89
	// are smaller than the Debug Security Server's calculation of sizeof(TEventInfo), 
hgs
parents:
diff changeset
    90
	// returning KErrTooBig in this case would be
hgs
parents:
diff changeset
    91
	// inappropriate as we would break compatibility.
hgs
parents:
diff changeset
    92
	TInt dataLengthToReturn = sizeof(TEventInfo);
hgs
parents:
diff changeset
    93
	TInt maxLengthClientSide = iMessage.GetDesMaxLengthL(1);
hgs
parents:
diff changeset
    94
	if(maxLengthClientSide < dataLengthToReturn)
hgs
parents:
diff changeset
    95
		{
hgs
parents:
diff changeset
    96
		dataLengthToReturn = maxLengthClientSide;
hgs
parents:
diff changeset
    97
		}
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
	TPtr8 data((TUint8*)&iInfo, dataLengthToReturn, dataLengthToReturn);
hgs
parents:
diff changeset
   101
	iMessage.WriteL(1, data, 0);
hgs
parents:
diff changeset
   102
	iMessage.Complete(KErrNone);
hgs
parents:
diff changeset
   103
	}
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
// Cancels the oustanding GetEvent call. May cope with other async calls in future.
hgs
parents:
diff changeset
   106
void CSecuritySvrAsync::DoCancel()
hgs
parents:
diff changeset
   107
	{
hgs
parents:
diff changeset
   108
	LOG_MSG("CSecuritySvrAsync::DoCancel()");
hgs
parents:
diff changeset
   109
	iSession->Server().iKernelDriver.CancelGetEvent(iProcessName,iAgentId.Id());
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
	iMessage.Complete(KErrCancel);
hgs
parents:
diff changeset
   112
	}
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
// Report any leave to the client if possible.
hgs
parents:
diff changeset
   115
TInt CSecuritySvrAsync::RunError(TInt aError)
hgs
parents:
diff changeset
   116
	{
hgs
parents:
diff changeset
   117
	LOG_MSG2("CSecuritySvrAsync::RunError()=%d", aError);
hgs
parents:
diff changeset
   118
	iMessage.Complete(aError);
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
	return KErrNone;
hgs
parents:
diff changeset
   121
	}
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
/**
hgs
parents:
diff changeset
   124
 * Start an asynchronous GetEvent call to the debug driver
hgs
parents:
diff changeset
   125
 * and activates this active object. 
hgs
parents:
diff changeset
   126
 * If active object already active, completes the message with error KErrInUse
hgs
parents:
diff changeset
   127
 * and takes no further action. 
hgs
parents:
diff changeset
   128
 */
hgs
parents:
diff changeset
   129
void CSecuritySvrAsync::GetEvent(const RMessage2& aMessage)
hgs
parents:
diff changeset
   130
	{
hgs
parents:
diff changeset
   131
 	if( !IsActive() )
hgs
parents:
diff changeset
   132
 		{
hgs
parents:
diff changeset
   133
		iMessage = aMessage;
hgs
parents:
diff changeset
   134
		LOG_MSG4("CSecuritySvrAsync::GetEvent() this = 0x%08x, iInfo=0x%08x, iStatus=0x%08x", this, &iInfo, &iStatus);
hgs
parents:
diff changeset
   135
		
hgs
parents:
diff changeset
   136
		SetActive();
hgs
parents:
diff changeset
   137
		iSession->Server().iKernelDriver.GetEvent(iProcessName,iAgentId.Id(),iStatus,iInfo);
hgs
parents:
diff changeset
   138
		}
hgs
parents:
diff changeset
   139
	else
hgs
parents:
diff changeset
   140
		{
hgs
parents:
diff changeset
   141
		LOG_MSG2("CSecuritySvrAsync::GetEvent() this = 0x%08x: ! Warning: ActiveObject is active. Returning with no effect",
hgs
parents:
diff changeset
   142
			this );
hgs
parents:
diff changeset
   143
		aMessage.Complete( KErrInUse );
hgs
parents:
diff changeset
   144
		}
hgs
parents:
diff changeset
   145
	}
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
// Used for identifying which AO is associated with a debugged process
hgs
parents:
diff changeset
   148
const TDesC8& CSecuritySvrAsync::ProcessName(void)
hgs
parents:
diff changeset
   149
	{
hgs
parents:
diff changeset
   150
	return iProcessName;
hgs
parents:
diff changeset
   151
	}
hgs
parents:
diff changeset
   152
hgs
parents:
diff changeset
   153
// End of file - c_security_svr_async.cpp
hgs
parents:
diff changeset
   154