191 lines
8.2 KiB
C++
191 lines
8.2 KiB
C++
|
//----------------------------------------------------------------------------
|
||
|
//
|
||
|
// Alpha machine implementation.
|
||
|
//
|
||
|
// Copyright (C) Microsoft Corporation, 2000-2001.
|
||
|
//
|
||
|
//----------------------------------------------------------------------------
|
||
|
|
||
|
#ifndef __ALPHA_MACH_HPP__
|
||
|
#define __ALPHA_MACH_HPP__
|
||
|
|
||
|
//
|
||
|
// NOTE: Be very careful when using machine-specific header files
|
||
|
// such as nt<plat>.h. The machine implementation class is
|
||
|
// compiled for all platforms so the nt<plat>.h file will be the
|
||
|
// one for the build platform, not necessarily the platform
|
||
|
// of the machine implementation. ntdbg.h contains many cross-platform
|
||
|
// types and definitions that can be used to avoid problems.
|
||
|
//
|
||
|
|
||
|
class AlphaMachineInfo : public MachineInfo
|
||
|
{
|
||
|
public:
|
||
|
// MachineInfo.
|
||
|
virtual HRESULT InitializeConstants(void);
|
||
|
|
||
|
virtual void InitializeContext
|
||
|
(ULONG64 Pc, PDBGKD_ANY_CONTROL_REPORT ControlReport);
|
||
|
virtual HRESULT KdGetContextState(ULONG State);
|
||
|
virtual HRESULT KdSetContext(void);
|
||
|
virtual HRESULT ConvertContextFrom(PCROSS_PLATFORM_CONTEXT Context,
|
||
|
ULONG FromSver,
|
||
|
ULONG FromSize, PVOID From);
|
||
|
virtual HRESULT ConvertContextTo(PCROSS_PLATFORM_CONTEXT Context,
|
||
|
ULONG ToSver, ULONG ToSize, PVOID To);
|
||
|
virtual void InitializeContextFlags(PCROSS_PLATFORM_CONTEXT Context,
|
||
|
ULONG Version);
|
||
|
|
||
|
virtual int GetType(ULONG index);
|
||
|
virtual BOOL GetVal(ULONG index, REGVAL *val);
|
||
|
virtual BOOL SetVal(ULONG index, REGVAL *val);
|
||
|
|
||
|
virtual void OutputAll(ULONG Mask, ULONG OutMask);
|
||
|
|
||
|
virtual TRACEMODE GetTraceMode(void);
|
||
|
virtual void SetTraceMode(TRACEMODE Mode);
|
||
|
virtual BOOL IsStepStatusSupported(ULONG Status);
|
||
|
|
||
|
virtual ULONG ExecutingMachine(void);
|
||
|
|
||
|
virtual void Assemble(PADDR Addr, PSTR Input);
|
||
|
virtual BOOL Disassemble(PADDR Addr, PSTR Buffer, BOOL EffAddr);
|
||
|
|
||
|
virtual BOOL IsBreakpointInstruction(PADDR Addr);
|
||
|
virtual HRESULT InsertBreakpointInstruction(PUSER_DEBUG_SERVICES Services,
|
||
|
ULONG64 Process,
|
||
|
ULONG64 Offset,
|
||
|
PUCHAR SaveInstr,
|
||
|
PULONG64 ChangeStart,
|
||
|
PULONG ChangeLen);
|
||
|
virtual HRESULT RemoveBreakpointInstruction(PUSER_DEBUG_SERVICES Services,
|
||
|
ULONG64 Process,
|
||
|
ULONG64 Offset,
|
||
|
PUCHAR SaveInstr,
|
||
|
PULONG64 ChangeStart,
|
||
|
PULONG ChangeLen);
|
||
|
virtual void AdjustPCPastBreakpointInstruction(PADDR Addr,
|
||
|
ULONG BreakType);
|
||
|
|
||
|
virtual BOOL IsCallDisasm(PCSTR Disasm);
|
||
|
virtual BOOL IsReturnDisasm(PCSTR Disasm);
|
||
|
virtual BOOL IsSystemCallDisasm(PCSTR Disasm);
|
||
|
|
||
|
virtual BOOL IsDelayInstruction(PADDR Addr);
|
||
|
virtual void GetEffectiveAddr(PADDR Addr);
|
||
|
virtual void GetNextOffset(BOOL StepOver,
|
||
|
PADDR NextAddr, PULONG NextMachine);
|
||
|
|
||
|
virtual void IncrementBySmallestInstruction(PADDR Addr);
|
||
|
virtual void DecrementBySmallestInstruction(PADDR Addr);
|
||
|
virtual BOOL DisplayTrapFrame(ULONG64 FrameAddress,
|
||
|
OUT PCROSS_PLATFORM_CONTEXT Context);
|
||
|
virtual void ValidateCxr(PCROSS_PLATFORM_CONTEXT Context);
|
||
|
|
||
|
virtual void PrintStackFrameAddresses(ULONG Flags,
|
||
|
PDEBUG_STACK_FRAME StackFrame);
|
||
|
|
||
|
virtual HRESULT ReadKernelProcessorId
|
||
|
(ULONG Processor, PDEBUG_PROCESSOR_IDENTIFICATION_ALL Id);
|
||
|
|
||
|
// AlphaMachineInfo.
|
||
|
|
||
|
void OutputFunctionEntry64(PIMAGE_ALPHA64_RUNTIME_FUNCTION_ENTRY Entry);
|
||
|
|
||
|
ULONG GetIntRegNumber(ULONG Index)
|
||
|
{
|
||
|
return ALPHA_INT64_BASE + Index;
|
||
|
}
|
||
|
|
||
|
void BufferEffectiveAddress(ULONG64);
|
||
|
void BufferReg(ULONG);
|
||
|
void BufferFReg(ULONG);
|
||
|
};
|
||
|
|
||
|
class Axp32MachineInfo : public AlphaMachineInfo
|
||
|
{
|
||
|
public:
|
||
|
virtual HRESULT InitializeConstants(void);
|
||
|
virtual HRESULT InitializeForTarget(void);
|
||
|
|
||
|
virtual HRESULT GetContextFromThreadStack(ULONG64 ThreadBase,
|
||
|
PCROSS_PLATFORM_THREAD Thread,
|
||
|
PCROSS_PLATFORM_CONTEXT Context,
|
||
|
PDEBUG_STACK_FRAME Frame,
|
||
|
PULONG RunningOnProc);
|
||
|
|
||
|
virtual void GetPC(PADDR Address);
|
||
|
virtual void SetPC(PADDR Address);
|
||
|
virtual void GetFP(PADDR Address);
|
||
|
virtual void GetSP(PADDR Address);
|
||
|
virtual ULONG64 GetArgReg(void);
|
||
|
|
||
|
virtual HRESULT SetPageDirectory(ULONG Idx, ULONG64 PageDir,
|
||
|
PULONG NextIdx);
|
||
|
virtual HRESULT GetVirtualTranslationPhysicalOffsets
|
||
|
(ULONG64 Virt, PULONG64 Offsets, ULONG OffsetsSize,
|
||
|
PULONG Levels, PULONG PfIndex, PULONG64 LastPhys);
|
||
|
virtual HRESULT GetBaseTranslationVirtualOffset(PULONG64 Offset);
|
||
|
|
||
|
virtual void OutputFunctionEntry(PVOID RawEntry);
|
||
|
virtual HRESULT ReadDynamicFunctionTable(ULONG64 Table,
|
||
|
PULONG64 NextTable,
|
||
|
PULONG64 MinAddress,
|
||
|
PULONG64 MaxAddress,
|
||
|
PULONG64 BaseAddress,
|
||
|
PULONG64 TableData,
|
||
|
PULONG TableSize,
|
||
|
PWSTR OutOfProcessDll,
|
||
|
PCROSS_PLATFORM_DYNAMIC_FUNCTION_TABLE RawTable);
|
||
|
virtual PVOID FindDynamicFunctionEntry(PCROSS_PLATFORM_DYNAMIC_FUNCTION_TABLE Table,
|
||
|
ULONG64 Address,
|
||
|
PVOID TableData,
|
||
|
ULONG TableSize);
|
||
|
};
|
||
|
|
||
|
class Axp64MachineInfo : public AlphaMachineInfo
|
||
|
{
|
||
|
public:
|
||
|
virtual HRESULT InitializeConstants(void);
|
||
|
virtual HRESULT InitializeForTarget(void);
|
||
|
|
||
|
virtual HRESULT GetContextFromThreadStack(ULONG64 ThreadBase,
|
||
|
PCROSS_PLATFORM_THREAD Thread,
|
||
|
PCROSS_PLATFORM_CONTEXT Context,
|
||
|
PDEBUG_STACK_FRAME Frame,
|
||
|
PULONG RunningOnProc);
|
||
|
|
||
|
virtual void GetPC(PADDR Address);
|
||
|
virtual void SetPC(PADDR Address);
|
||
|
virtual void GetFP(PADDR Address);
|
||
|
virtual void GetSP(PADDR Address);
|
||
|
virtual ULONG64 GetArgReg(void);
|
||
|
|
||
|
virtual HRESULT SetPageDirectory(ULONG Idx, ULONG64 PageDir,
|
||
|
PULONG NextIdx);
|
||
|
virtual HRESULT GetVirtualTranslationPhysicalOffsets
|
||
|
(ULONG64 Virt, PULONG64 Offsets, ULONG OffsetsSize,
|
||
|
PULONG Levels, PULONG PfIndex, PULONG64 LastVal);
|
||
|
virtual HRESULT GetBaseTranslationVirtualOffset(PULONG64 Offset);
|
||
|
|
||
|
virtual void OutputFunctionEntry(PVOID RawEntry);
|
||
|
virtual HRESULT ReadDynamicFunctionTable(ULONG64 Table,
|
||
|
PULONG64 NextTable,
|
||
|
PULONG64 MinAddress,
|
||
|
PULONG64 MaxAddress,
|
||
|
PULONG64 BaseAddress,
|
||
|
PULONG64 TableData,
|
||
|
PULONG TableSize,
|
||
|
PWSTR OutOfProcessDll,
|
||
|
PCROSS_PLATFORM_DYNAMIC_FUNCTION_TABLE RawTable);
|
||
|
virtual PVOID FindDynamicFunctionEntry(PCROSS_PLATFORM_DYNAMIC_FUNCTION_TABLE Table,
|
||
|
ULONG64 Address,
|
||
|
PVOID TableData,
|
||
|
ULONG TableSize);
|
||
|
};
|
||
|
|
||
|
extern Axp32MachineInfo g_Axp32Machine;
|
||
|
extern Axp64MachineInfo g_Axp64Machine;
|
||
|
|
||
|
#endif // #ifndef __ALPHA_MACH_HPP__
|