debugsrv/runmodedebug/rmdriver/inc/rm_debug_driver.h
author hgs
Fri, 08 Oct 2010 14:56:39 +0300
changeset 56 aa2539c91954
parent 42 0ff24a8f6ca2
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
42
hgs
parents:
diff changeset
     1
// Copyright (c) 2004-2009 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
56
hgs
parents: 42
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
42
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
hgs
parents:
diff changeset
    17
#ifndef __RM_DEBUG_DRIVER_H__
hgs
parents:
diff changeset
    18
#define __RM_DEBUG_DRIVER_H__
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
#include "d_rmd_stepping.h"
hgs
parents:
diff changeset
    21
#include "d_rmd_breakpoints.h"
hgs
parents:
diff changeset
    22
#include "d_driver_event_info.h"
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
// From mmboot.h header
hgs
parents:
diff changeset
    25
const TLinAddr	KDataSectionEnd			=0x40000000u;
hgs
parents:
diff changeset
    26
const TLinAddr	KRomLinearBase			=0xF8000000u;
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
#define ROM_LINEAR_BASE KRomLinearBase
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
// Result checking
hgs
parents:
diff changeset
    32
#define ReturnIfError(x) { TInt y = x; if (KErrNone != y) return y; }
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
//
hgs
parents:
diff changeset
    35
// class DRM_DebugDriverFactory
hgs
parents:
diff changeset
    36
//
hgs
parents:
diff changeset
    37
class DRM_DebugDriverFactory : public DLogicalDevice
hgs
parents:
diff changeset
    38
{
hgs
parents:
diff changeset
    39
public:
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
	DRM_DebugDriverFactory();
hgs
parents:
diff changeset
    42
	virtual TInt Install();
hgs
parents:
diff changeset
    43
	virtual void GetCaps(TDes8& aDes) const;
hgs
parents:
diff changeset
    44
	virtual TInt Create(DLogicalChannelBase*& aChannel);
hgs
parents:
diff changeset
    45
};
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
class DRM_DebugEventHandler;
hgs
parents:
diff changeset
    48
//
hgs
parents:
diff changeset
    49
// DRM_DebugChannel
hgs
parents:
diff changeset
    50
//
hgs
parents:
diff changeset
    51
class DRM_DebugChannel : public DLogicalChannel
hgs
parents:
diff changeset
    52
{
hgs
parents:
diff changeset
    53
public:
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
	DRM_DebugChannel(DLogicalDevice* aLogicalDevice);
hgs
parents:
diff changeset
    56
	~DRM_DebugChannel();
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
	virtual TInt DoCreate(TInt aUnit, const TDesC* anInfo, const TVersion& aVer);	
hgs
parents:
diff changeset
    59
	virtual void HandleMsg(TMessageBase* aMsg);
hgs
parents:
diff changeset
    60
	virtual TInt SendMsg(TMessageBase* aMsg);
hgs
parents:
diff changeset
    61
	TInt SendRequest(TMessageBase* aMsg);
hgs
parents:
diff changeset
    62
	
hgs
parents:
diff changeset
    63
	//called from the event handler
hgs
parents:
diff changeset
    64
	TBool RemoveProcess(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    65
	TBool StartThread(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    66
	TBool AddLibrary(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    67
	TBool RemoveLibrary(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    68
	TBool HandleEventKillThread(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    69
	TBool HandleSwException(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    70
	TBool HandleHwException(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    71
	TBool HandleUserTrace(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    72
	TBool HandleUnsupportedEvent(TAny* a1, TAny* a2) { return EFalse; }
hgs
parents:
diff changeset
    73
	TBool HandleAddProcessEvent(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    74
	TBool HandleRemoveProcessEvent(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    75
	
hgs
parents:
diff changeset
    76
	// Used to be able to signal events to the DSS
hgs
parents:
diff changeset
    77
	DThread* ClientThread(void) {return iClientThread; };
hgs
parents:
diff changeset
    78
	
hgs
parents:
diff changeset
    79
protected:
hgs
parents:
diff changeset
    80
	virtual void DoCancel(TInt aReqNo);
hgs
parents:
diff changeset
    81
	virtual void DoRequest(TInt aReqNo, TRequestStatus* aStatus, TAny* a1, TAny* a2);
hgs
parents:
diff changeset
    82
	virtual TInt DoControl(TInt aFunction, TAny *a1, TAny *a2);
hgs
parents:
diff changeset
    83
	
hgs
parents:
diff changeset
    84
private:
hgs
parents:
diff changeset
    85
	TInt PreAsyncGetValue(Debug::TEventInfo* aValue, TRequestStatus* aStatus);
hgs
parents:
diff changeset
    86
	TInt CreateDfcQ();
hgs
parents:
diff changeset
    87
	void DestroyDfcQ();
hgs
parents:
diff changeset
    88
	TBool HandleInvalidOpCodeException(TDriverEventInfo& aEventInfo, DThread* aCurrentThread);
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
	TInt SetBreak(TSetBreakInfo* aBreakInfo);
hgs
parents:
diff changeset
    91
	TInt StepRange(DThread* aThread, TRM_DebugStepInfo* aStepInfo);
hgs
parents:
diff changeset
    92
	TInt ReadMemory(DThread* aThread, TRM_DebugMemoryInfo* aMemoryInfo);
hgs
parents:
diff changeset
    93
	TInt WriteMemory(DThread* aThread, TRM_DebugMemoryInfo* aMemoryInfo);
hgs
parents:
diff changeset
    94
	TInt ReadRegistersLegacy(DThread* aThread, TRM_DebugRegisterInfo* aRegisterInfo);
hgs
parents:
diff changeset
    95
	TInt WriteRegistersLegacy(DThread* aThread, const TRM_DebugRegisterInfo* aRegisterInfo);
hgs
parents:
diff changeset
    96
	TInt ReadRegisters(DThread* aThread, TRM_DebugRegisterInformation* aRegisterInfo) const;
hgs
parents:
diff changeset
    97
	TInt WriteRegisters(DThread* aThread, TRM_DebugRegisterInformation* aRegisterInfo) const;
hgs
parents:
diff changeset
    98
	TInt GetProcessInfo(TInt aIndex, TRM_DebugTaskInfo* aTaskInfo);
hgs
parents:
diff changeset
    99
	TInt GetThreadInfo(TInt aIndex, TRM_DebugTaskInfo* aTaskInfo);
hgs
parents:
diff changeset
   100
	TInt GetList(TListInformation* aListInformation) const;
hgs
parents:
diff changeset
   101
	
hgs
parents:
diff changeset
   102
	TInt Step(const TUint32 aThreadId, const TUint32 aNumSteps);
hgs
parents:
diff changeset
   103
	TInt KillProcess(const TUint32 aProcessId, const TInt aReason);
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
	//Crash Flash	
hgs
parents:
diff changeset
   106
	TInt ReadCrashLog(TFlashInfo* aBuffer);
hgs
parents:
diff changeset
   107
	TInt WriteCrashLog(TFlashInfo* aBuffer) const;
hgs
parents:
diff changeset
   108
	TInt EraseCrashLog();
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
	// Stop/go
hgs
parents:
diff changeset
   111
	TInt DoSuspendThread(DThread *aThread);
hgs
parents:
diff changeset
   112
	TInt DoResumeThread(DThread *aThread);
hgs
parents:
diff changeset
   113
	TInt DoStepRange(DThread *aThread, const TUint32 aStartAddress, const TUint32 aStopAddress, TBool aStepInto, TBool aResumeOnceOutOfRange, const TUint32 aNumSteps, TBool aUserRequest = EFalse);
hgs
parents:
diff changeset
   114
	TInt DoReadMemory(const DThread *aThread, const TUint32 aAddress, const TUint32 aLength, TDes8 &aData) const;
hgs
parents:
diff changeset
   115
	TInt DoWriteMemory(DThread *aThread, const TUint32 aAddress, const TUint32 aLength, TDes8 &aData);
hgs
parents:
diff changeset
   116
	TInt DoReadRegisters(DThread *aThread, const TInt16 aFirstRegister, const TInt16 aLastRegister, TDes8 &aValues);
hgs
parents:
diff changeset
   117
	TInt DoReadRegisters(DThread *aThread, const TDesC8 &aRegisterIds, TDes8 &aRegisterValues, TDes8 &aRegisterFlags) const;
hgs
parents:
diff changeset
   118
	TInt DoWriteRegisters(DThread *aThread, const TInt16 aFirstRegister, const TInt16 aLastRegister, TDesC8 &aValues);
hgs
parents:
diff changeset
   119
	TInt DoWriteRegisters(DThread *aThread, const TDesC8 &aRegisterIds, TDesC8 &aRegisterValues, TDes8 &aRegisterFlags) const;
hgs
parents:
diff changeset
   120
	TInt DoGetProcessInfo(const TInt aIndex, TRM_DebugTaskInfo *aInfo);
hgs
parents:
diff changeset
   121
	TInt DoGetThreadInfo(const TInt aIndex, TRM_DebugTaskInfo *aInfo);
hgs
parents:
diff changeset
   122
	TBool DoSecurityCheck();
hgs
parents:
diff changeset
   123
hgs
parents:
diff changeset
   124
	TInt TryToReadMemory(const DThread *aThread, const TAny *aSrc, TAny *aDest, const TUint32 aLength) const;
hgs
parents:
diff changeset
   125
	TInt TryToWriteMemory(const DThread *aThread, TAny *aDest, const TAny *aSrc, const TUint32 aLength);
hgs
parents:
diff changeset
   126
	TInt32 ReadRegister(DThread *aThread, TInt aNum);
hgs
parents:
diff changeset
   127
	TInt32 ReadDebugRegisterValue(DThread *aThread, const Debug::TRegisterInfo aDebugRegisterId, T4ByteRegisterValue &aValue) const;
hgs
parents:
diff changeset
   128
	TInt32 ReadKernelRegisterValue(DThread *aThread, const TArmReg aKernelRegisterId, T4ByteRegisterValue &aValue) const;
hgs
parents:
diff changeset
   129
	
hgs
parents:
diff changeset
   130
	void NotifyEvent(const TDriverEventInfo& aEventInfo);
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
	TInt GetTRegisterInfo(const TDesC8 &aRegisterIds, const TUint aIndex, Debug::TRegisterInfo &aValue) const;
hgs
parents:
diff changeset
   133
	TInt GetDebugRegisterId(const TArmReg aKernelRegister, Debug::TRegisterInfo& aDebugRegister) const;
hgs
parents:
diff changeset
   134
	TInt GetKernelRegisterId(const Debug::TRegisterInfo aDebugRegister, TArmReg& aKernelRegister) const;
hgs
parents:
diff changeset
   135
	TBool GetFlagAtOffset(const TUint32 aFlags, const TArmReg aIndex) const;
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
	TInt AllocAndReadDes(DThread *aThread, const TDesC8& aSrcDes, TPtr8& aDestDes, const TBool aReadFromClient=ETrue, const TUint aOffset=0) const;
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
	TInt AttachProcess(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
   140
	TInt DetachProcess(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
   141
	TInt DetachAgent(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
   142
	TInt SetEventAction(TAny* a1, TAny* a2);
hgs
parents:
diff changeset
   143
	TBool CheckSuspended(const DThread *aThread) const;
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
	// Needed so moved functions can access iBreakpoint list and related functions
hgs
parents:
diff changeset
   146
	friend class D_RMD_Breakpoints;
hgs
parents:
diff changeset
   147
	// Needed so moved functions can access stepping functionality
hgs
parents:
diff changeset
   148
	friend class DRMDStepping;
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
	// helper function was previously in rm_debug_kerneldriver.cpp
hgs
parents:
diff changeset
   151
	inline TInt Bitcount(TUint32 val)
hgs
parents:
diff changeset
   152
		{
hgs
parents:
diff changeset
   153
			TInt nbits;
hgs
parents:
diff changeset
   154
hgs
parents:
diff changeset
   155
			for (nbits = 0; val != 0; nbits++)
hgs
parents:
diff changeset
   156
			{
hgs
parents:
diff changeset
   157
				val &= val - 1;		// delete rightmost 1-bit in val
hgs
parents:
diff changeset
   158
			}
hgs
parents:
diff changeset
   159
			
hgs
parents:
diff changeset
   160
			return nbits;
hgs
parents:
diff changeset
   161
		}
hgs
parents:
diff changeset
   162
hgs
parents:
diff changeset
   163
	// Security critical - this returns whether the specified process is debuggable or not
hgs
parents:
diff changeset
   164
	TInt IsDebuggable(const TUint32 aProcessId);
hgs
parents:
diff changeset
   165
	
hgs
parents:
diff changeset
   166
	TInt NotifyAgentsFromEventPid(const TDriverEventInfo& aEventInfo);
hgs
parents:
diff changeset
   167
hgs
parents:
diff changeset
   168
private:
hgs
parents:
diff changeset
   169
	DThread* iClientThread;
hgs
parents:
diff changeset
   170
	DRM_DebugEventHandler* iEventHandler;
hgs
parents:
diff changeset
   171
	
hgs
parents:
diff changeset
   172
	TUint32 iExcludedROMAddressStart;
hgs
parents:
diff changeset
   173
	TUint32 iExcludedROMAddressEnd;
hgs
parents:
diff changeset
   174
	
hgs
parents:
diff changeset
   175
	TUint32 iPageSize;
hgs
parents:
diff changeset
   176
	
hgs
parents:
diff changeset
   177
	RArray<Debug::TProcessInfo> iDebugProcessList; //processes that we are debugging
hgs
parents:
diff changeset
   178
hgs
parents:
diff changeset
   179
	D_RMD_Breakpoints* iBreakManager;	// new D_RMD_Breakpoints
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
	DRMDStepping* iStepper;				// new DRMDStepping
hgs
parents:
diff changeset
   182
hgs
parents:
diff changeset
   183
	DSemaphore* iStepLock;				// Synchronisation for stepping code.
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
	TDynamicDfcQue* iDfcQ;
hgs
parents:
diff changeset
   186
hgs
parents:
diff changeset
   187
	TBool	iInitialisedCodeModifier;	// Ensures we control its lifetime
hgs
parents:
diff changeset
   188
hgs
parents:
diff changeset
   189
	TClientDataRequest<Debug::TEventInfo>* iAsyncGetValueRequest;
hgs
parents:
diff changeset
   190
};
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
#endif //__RM_DEBUG_DRIVER_H__