837 lines
18 KiB
C
837 lines
18 KiB
C
#include "kxia64.h"
|
|
#include "regia64.h"
|
|
|
|
//
|
|
// Wait Reason and Wait Type Enumerated Type Values
|
|
//
|
|
|
|
#define WrExecutive 0x0
|
|
#define AsProcess 0x20
|
|
|
|
//
|
|
// Bug Check Code Definitions
|
|
//
|
|
|
|
#define APC_INDEX_MISMATCH 0x1
|
|
#define ATTEMPTED_SWITCH_FROM_DPC 0xb8
|
|
#define DATA_BUS_ERROR 0x2e
|
|
#define DATA_COHERENCY_EXCEPTION 0x55
|
|
#define HAL1_INITIALIZATION_FAILED 0x61
|
|
#define INSTRUCTION_BUS_ERROR 0x2f
|
|
#define INSTRUCTION_COHERENCY_EXCEPTION 0x56
|
|
#define INTERRUPT_EXCEPTION_NOT_HANDLED 0x3d
|
|
#define INTERRUPT_UNWIND_ATTEMPTED 0x3c
|
|
#define INVALID_AFFINITY_SET 0x3
|
|
#define INVALID_DATA_ACCESS_TRAP 0x4
|
|
#define IRQL_GT_ZERO_AT_SYSTEM_SERVICE 0x4a
|
|
#define IRQL_NOT_LESS_OR_EQUAL 0xa
|
|
#define KMODE_EXCEPTION_NOT_HANDLED 0x1e
|
|
#define NMI_HARDWARE_FAILURE 0x80
|
|
#define NO_USER_MODE_CONTEXT 0xe
|
|
#define PAGE_FAULT_WITH_INTERRUPTS_OFF 0x49
|
|
#define PANIC_STACK_SWITCH 0x2b
|
|
#define SPIN_LOCK_INIT_FAILURE 0x81
|
|
#define SYSTEM_EXIT_OWNED_MUTEX 0x39
|
|
#define SYSTEM_SERVICE_EXCEPTION 0x3b
|
|
#define SYSTEM_UNWIND_PREVIOUS_USER 0x3a
|
|
#define TRAP_CAUSE_UNKNOWN 0x12
|
|
#define UNEXPECTED_KERNEL_MODE_TRAP 0x7f
|
|
#define HARDWARE_INTERRUPT_STORM 0xf2
|
|
#define RECURSIVE_MACHINE_CHECK 0xfb
|
|
|
|
//
|
|
// Breakpoint type definitions
|
|
//
|
|
|
|
#define DBG_STATUS_CONTROL_C 0x1
|
|
|
|
//
|
|
// Exception Record Offset, Flag, and Enumerated Type Definitions
|
|
//
|
|
|
|
#define EXCEPTION_NONCONTINUABLE 0x1
|
|
#define EXCEPTION_UNWINDING 0x2
|
|
#define EXCEPTION_EXIT_UNWIND 0x4
|
|
#define EXCEPTION_STACK_INVALID 0x8
|
|
#define EXCEPTION_NESTED_CALL 0x10
|
|
#define EXCEPTION_TARGET_UNWIND 0x20
|
|
#define EXCEPTION_COLLIDED_UNWIND 0x40
|
|
#define EXCEPTION_UNWIND 0x66
|
|
#define EXCEPTION_EXECUTE_HANDLER 0x1
|
|
#define EXCEPTION_CONTINUE_SEARCH 0x0
|
|
#define EXCEPTION_CONTINUE_EXECUTION 0xffffffff
|
|
|
|
#define ExceptionContinueExecution 0x0
|
|
#define ExceptionContinueSearch 0x1
|
|
#define ExceptionNestedException 0x2
|
|
#define ExceptionCollidedUnwind 0x3
|
|
|
|
#define ErExceptionCode 0x0
|
|
#define ErExceptionFlags 0x4
|
|
#define ErExceptionRecord 0x8
|
|
#define ErExceptionAddress 0x10
|
|
#define ErNumberParameters 0x18
|
|
#define ErExceptionInformation 0x20
|
|
#define ExceptionRecordLength 0xa0
|
|
|
|
//
|
|
// Fast Mutex Structure Offset Definitions
|
|
//
|
|
|
|
#define FmCount 0x0
|
|
#define FmOwner 0x8
|
|
#define FmContention 0x10
|
|
#define FmEvent 0x18
|
|
#define FmOldIrql 0x30
|
|
|
|
//
|
|
// Interrupt Priority Request Level Definitions
|
|
//
|
|
|
|
#define PASSIVE_LEVEL 0x0
|
|
#define APC_LEVEL 0x1
|
|
#define DISPATCH_LEVEL 0x2
|
|
#define IPI_LEVEL 0xe
|
|
#define POWER_LEVEL 0xf
|
|
#define PROFILE_LEVEL 0xf
|
|
#define HIGH_LEVEL 0xf
|
|
#ifdef NT_UP
|
|
#define SYNCH_LEVEL 0x2
|
|
#else
|
|
#define SYNCH_LEVEL 0xc
|
|
#endif
|
|
|
|
//
|
|
// Large Integer Structure Offset Definitions
|
|
//
|
|
|
|
#define LiLowPart 0x0
|
|
#define LiHighPart 0x4
|
|
|
|
//
|
|
// List Entry Structure Offset Definitions
|
|
//
|
|
|
|
#define LsFlink 0x0
|
|
#define LsBlink 0x8
|
|
|
|
//
|
|
// String Structure Offset Definitions
|
|
//
|
|
|
|
#define StrLength 0x0
|
|
#define StrMaximumLength 0x2
|
|
#define StrBuffer 0x8
|
|
|
|
//
|
|
// Tick Count Offset Definitions
|
|
//
|
|
|
|
#define UsTickCount 0x320
|
|
|
|
//
|
|
// Time Structure Offset Definitions
|
|
//
|
|
|
|
#define TmLowTime 0x0
|
|
#define TmHighTime 0x4
|
|
|
|
//
|
|
// DPC object Structure Offset Definitions
|
|
//
|
|
|
|
#define DpType 0x0
|
|
#define DpNumber 0x2
|
|
#define DpImportance 0x3
|
|
#define DpDpcListEntry 0x8
|
|
#define DpDeferredRoutine 0x18
|
|
#define DpDeferredContext 0x20
|
|
#define DpSystemArgument1 0x28
|
|
#define DpSystemArgument2 0x30
|
|
#define DpDpcData 0x38
|
|
#define DpcObjectLength 0x40
|
|
|
|
//
|
|
// Interrupt Object Structure Offset Definitions
|
|
//
|
|
|
|
#define InLevelSensitive 0x0
|
|
#define InLatched 0x1
|
|
|
|
#define InType 0x0
|
|
#define InSize 0x2
|
|
#define InInterruptListEntry 0x8
|
|
#define InServiceRoutine 0x18
|
|
#define InServiceContext 0x20
|
|
#define InSpinLock 0x28
|
|
#define InTickCount 0x30
|
|
#define InActualLock 0x38
|
|
#define InDispatchAddress 0x40
|
|
#define InVector 0x48
|
|
#define InIrql 0x4c
|
|
#define InSynchronizeIrql 0x4d
|
|
#define InFloatingSave 0x4e
|
|
#define InConnected 0x4f
|
|
#define InNumber 0x50
|
|
#define InShareVector 0x51
|
|
#define InMode 0x54
|
|
#define InServiceCount 0x58
|
|
#define InDispatchCount 0x5c
|
|
#define InDispatchCode 0x60
|
|
#define InterruptObjectLength 0x70
|
|
#define PrDirectoryTableBase 0x28
|
|
#define ThDebugActive 0x3
|
|
#define ThStackLimit 0x30
|
|
#define ThApcState 0x78
|
|
|
|
//
|
|
// Processor Block Structure Offset Definitions
|
|
//
|
|
|
|
#define PRCB_MINOR_VERSION 0x1
|
|
#define PRCB_MAJOR_VERSION 0x1
|
|
#define PbMinorVersion 0x0
|
|
#define PbMajorVersion 0x2
|
|
#define PbCurrentThread 0x8
|
|
#define PbNextThread 0x10
|
|
#define PbIdleThread 0x18
|
|
#define PbNumber 0x20
|
|
#define PbBuildType 0x22
|
|
#define PbSetMember 0x28
|
|
#define PbRestartBlock 0x30
|
|
#define PbPcrPage 0x38
|
|
#define PbProcessorModel 0x50
|
|
#define PbProcessorRevision 0x54
|
|
#define PbProcessorFamily 0x58
|
|
#define PbProcessorSerialNumber 0x60
|
|
#define PbProcessorFeatureBits 0x68
|
|
#define PbProcessorVendorString 0x70
|
|
#define PbSystemReserved 0x80
|
|
#define PbHalReserved 0xc0
|
|
|
|
//
|
|
// Context Frame Offset and Flag Definitions
|
|
//
|
|
|
|
#define CONTEXT_FULL 0x8002f
|
|
#define CONTEXT_CONTROL 0x80001
|
|
#define CONTEXT_INTEGER 0x80008
|
|
#define CONTEXT_LOWER_FLOATING_POINT 0x80002
|
|
#define CONTEXT_HIGHER_FLOATING_POINT 0x80004
|
|
#define CONTEXT_FLOATING_POINT 0x80006
|
|
#define CONTEXT_DEBUG 0x80010
|
|
#define CONTEXT_IA32_CONTROL 0x80020
|
|
|
|
#define CxContextFlags 0x0
|
|
|
|
#define CxDbI0 0x10
|
|
#define CxDbI1 0x18
|
|
#define CxDbI2 0x20
|
|
#define CxDbI3 0x28
|
|
#define CxDbI4 0x30
|
|
#define CxDbI5 0x38
|
|
#define CxDbI6 0x40
|
|
#define CxDbI7 0x48
|
|
|
|
#define CxDbD0 0x50
|
|
#define CxDbD1 0x58
|
|
#define CxDbD2 0x60
|
|
#define CxDbD3 0x68
|
|
#define CxDbD4 0x70
|
|
#define CxDbD5 0x78
|
|
#define CxDbD6 0x80
|
|
#define CxDbD7 0x88
|
|
|
|
#define CxFltS0 0x90
|
|
#define CxFltS1 0xa0
|
|
#define CxFltS2 0xb0
|
|
#define CxFltS3 0xc0
|
|
|
|
#define CxFltT0 0xd0
|
|
#define CxFltT1 0xe0
|
|
#define CxFltT2 0xf0
|
|
#define CxFltT3 0x100
|
|
#define CxFltT4 0x110
|
|
#define CxFltT5 0x120
|
|
#define CxFltT6 0x130
|
|
#define CxFltT7 0x140
|
|
#define CxFltT8 0x150
|
|
#define CxFltT9 0x160
|
|
|
|
#define CxFltS4 0x170
|
|
#define CxFltS5 0x180
|
|
#define CxFltS6 0x190
|
|
#define CxFltS7 0x1a0
|
|
#define CxFltS8 0x1b0
|
|
#define CxFltS9 0x1c0
|
|
#define CxFltS10 0x1d0
|
|
#define CxFltS11 0x1e0
|
|
#define CxFltS12 0x1f0
|
|
#define CxFltS13 0x200
|
|
#define CxFltS14 0x210
|
|
#define CxFltS15 0x220
|
|
#define CxFltS16 0x230
|
|
#define CxFltS17 0x240
|
|
#define CxFltS18 0x250
|
|
#define CxFltS19 0x260
|
|
|
|
#define CxFltF32 0x270
|
|
#define CxFltF33 0x280
|
|
#define CxFltF34 0x290
|
|
#define CxFltF35 0x2a0
|
|
#define CxFltF36 0x2b0
|
|
#define CxFltF37 0x2c0
|
|
#define CxFltF38 0x2d0
|
|
#define CxFltF39 0x2e0
|
|
|
|
#define CxFltF40 0x2f0
|
|
#define CxFltF41 0x300
|
|
#define CxFltF42 0x310
|
|
#define CxFltF43 0x320
|
|
#define CxFltF44 0x330
|
|
#define CxFltF45 0x340
|
|
#define CxFltF46 0x350
|
|
#define CxFltF47 0x360
|
|
#define CxFltF48 0x370
|
|
#define CxFltF49 0x380
|
|
|
|
#define CxFltF50 0x390
|
|
#define CxFltF51 0x3a0
|
|
#define CxFltF52 0x3b0
|
|
#define CxFltF53 0x3c0
|
|
#define CxFltF54 0x3d0
|
|
#define CxFltF55 0x3e0
|
|
#define CxFltF56 0x3f0
|
|
#define CxFltF57 0x400
|
|
#define CxFltF58 0x410
|
|
#define CxFltF59 0x420
|
|
|
|
#define CxFltF60 0x430
|
|
#define CxFltF61 0x440
|
|
#define CxFltF62 0x450
|
|
#define CxFltF63 0x460
|
|
#define CxFltF64 0x470
|
|
#define CxFltF65 0x480
|
|
#define CxFltF66 0x490
|
|
#define CxFltF67 0x4a0
|
|
#define CxFltF68 0x4b0
|
|
#define CxFltF69 0x4c0
|
|
|
|
#define CxFltF70 0x4d0
|
|
#define CxFltF71 0x4e0
|
|
#define CxFltF72 0x4f0
|
|
#define CxFltF73 0x500
|
|
#define CxFltF74 0x510
|
|
#define CxFltF75 0x520
|
|
#define CxFltF76 0x530
|
|
#define CxFltF77 0x540
|
|
#define CxFltF78 0x550
|
|
#define CxFltF79 0x560
|
|
|
|
#define CxFltF80 0x570
|
|
#define CxFltF81 0x580
|
|
#define CxFltF82 0x590
|
|
#define CxFltF83 0x5a0
|
|
#define CxFltF84 0x5b0
|
|
#define CxFltF85 0x5c0
|
|
#define CxFltF86 0x5d0
|
|
#define CxFltF87 0x5e0
|
|
#define CxFltF88 0x5f0
|
|
#define CxFltF89 0x600
|
|
|
|
#define CxFltF90 0x610
|
|
#define CxFltF91 0x620
|
|
#define CxFltF92 0x630
|
|
#define CxFltF93 0x640
|
|
#define CxFltF94 0x650
|
|
#define CxFltF95 0x660
|
|
#define CxFltF96 0x670
|
|
#define CxFltF97 0x680
|
|
#define CxFltF98 0x690
|
|
#define CxFltF99 0x6a0
|
|
|
|
#define CxFltF100 0x6b0
|
|
#define CxFltF101 0x6c0
|
|
#define CxFltF102 0x6d0
|
|
#define CxFltF103 0x6e0
|
|
#define CxFltF104 0x6f0
|
|
#define CxFltF105 0x700
|
|
#define CxFltF106 0x710
|
|
#define CxFltF107 0x720
|
|
#define CxFltF108 0x730
|
|
#define CxFltF109 0x740
|
|
|
|
#define CxFltF110 0x750
|
|
#define CxFltF111 0x760
|
|
#define CxFltF112 0x770
|
|
#define CxFltF113 0x780
|
|
#define CxFltF114 0x790
|
|
#define CxFltF115 0x7a0
|
|
#define CxFltF116 0x7b0
|
|
#define CxFltF117 0x7c0
|
|
#define CxFltF118 0x7d0
|
|
#define CxFltF119 0x7e0
|
|
|
|
#define CxFltF120 0x7f0
|
|
#define CxFltF121 0x800
|
|
#define CxFltF122 0x810
|
|
#define CxFltF123 0x820
|
|
#define CxFltF124 0x830
|
|
#define CxFltF125 0x840
|
|
#define CxFltF126 0x850
|
|
#define CxFltF127 0x860
|
|
|
|
#define CxStFPSR 0x870
|
|
|
|
#define CxIntGp 0x878
|
|
#define CxIntT0 0x880
|
|
#define CxIntT1 0x888
|
|
#define CxIntS0 0x890
|
|
#define CxIntS1 0x898
|
|
#define CxIntS2 0x8a0
|
|
#define CxIntS3 0x8a8
|
|
#define CxIntV0 0x8b0
|
|
#define CxIntT2 0x8b8
|
|
#define CxIntT3 0x8c0
|
|
#define CxIntT4 0x8c8
|
|
#define CxIntSp 0x8d0
|
|
#define CxIntTeb 0x8d8
|
|
#define CxIntT5 0x8e0
|
|
#define CxIntT6 0x8e8
|
|
#define CxIntT7 0x8f0
|
|
#define CxIntT8 0x8f8
|
|
#define CxIntT9 0x900
|
|
|
|
#define CxIntT10 0x908
|
|
#define CxIntT11 0x910
|
|
#define CxIntT12 0x918
|
|
#define CxIntT13 0x920
|
|
#define CxIntT14 0x928
|
|
#define CxIntT15 0x930
|
|
#define CxIntT16 0x938
|
|
#define CxIntT17 0x940
|
|
#define CxIntT18 0x948
|
|
#define CxIntT19 0x950
|
|
#define CxIntT20 0x958
|
|
#define CxIntT21 0x960
|
|
#define CxIntT22 0x968
|
|
|
|
#define CxIntNats 0x970
|
|
#define CxPreds 0x978
|
|
|
|
#define CxBrRp 0x980
|
|
#define CxBrS0 0x988
|
|
#define CxBrS1 0x990
|
|
#define CxBrS2 0x998
|
|
#define CxBrS3 0x9a0
|
|
#define CxBrS4 0x9a8
|
|
#define CxBrT0 0x9b0
|
|
#define CxBrT1 0x9b8
|
|
|
|
#define CxApUNAT 0x9c0
|
|
#define CxApLC 0x9c8
|
|
#define CxApEC 0x9d0
|
|
#define CxApCCV 0x9d8
|
|
#define CxApDCR 0x9e0
|
|
#define CxRsPFS 0x9e8
|
|
#define CxRsBSP 0x9f0
|
|
#define CxRsBSPSTORE 0x9f8
|
|
#define CxRsRSC 0xa00
|
|
#define CxRsRNAT 0xa08
|
|
#define CxStIPSR 0xa10
|
|
#define CxStIIP 0xa18
|
|
#define CxStIFS 0xa20
|
|
|
|
#define CxStFCR 0xa28
|
|
#define CxEflag 0xa30
|
|
#define CxSegCSD 0xa38
|
|
#define CxSegSSD 0xa40
|
|
#define CxCflag 0xa48
|
|
#define CxStFSR 0xa50
|
|
#define CxStFIR 0xa58
|
|
#define CxStFDR 0xa60
|
|
|
|
#define ContextFrameLength 0xa70
|
|
|
|
|
|
//
|
|
// Dispatcher Context Structure Offset Definitions
|
|
//
|
|
|
|
#define DcControlPc 0x10
|
|
#define DcFunctionEntry 0x20
|
|
#define DcEstablisherFrame 0x0
|
|
#define DcContextRecord 0x28
|
|
|
|
//
|
|
// Debug Register Offset Definitions and Length
|
|
//
|
|
|
|
#define TsAr21 0x0
|
|
#define TsAr24 0x8
|
|
#define TsAr26 0x18
|
|
#define TsAr27 0x20
|
|
#define TsAr28 0x28
|
|
#define TsAr29 0x30
|
|
#define TsAr30 0x38
|
|
|
|
//
|
|
// Higher FP Volatile Offset Definitions and Length
|
|
//
|
|
|
|
#define HiFltF32 0x0
|
|
#define HiFltF33 0x10
|
|
#define HiFltF34 0x20
|
|
#define HiFltF35 0x30
|
|
#define HiFltF36 0x40
|
|
#define HiFltF37 0x50
|
|
#define HiFltF38 0x60
|
|
#define HiFltF39 0x70
|
|
|
|
#define HiFltF40 0x80
|
|
#define HiFltF41 0x90
|
|
#define HiFltF42 0xa0
|
|
#define HiFltF43 0xb0
|
|
#define HiFltF44 0xc0
|
|
#define HiFltF45 0xd0
|
|
#define HiFltF46 0xe0
|
|
#define HiFltF47 0xf0
|
|
#define HiFltF48 0x100
|
|
#define HiFltF49 0x110
|
|
|
|
#define HiFltF50 0x120
|
|
#define HiFltF51 0x130
|
|
#define HiFltF52 0x140
|
|
#define HiFltF53 0x150
|
|
#define HiFltF54 0x160
|
|
#define HiFltF55 0x170
|
|
#define HiFltF56 0x180
|
|
#define HiFltF57 0x190
|
|
#define HiFltF58 0x1a0
|
|
#define HiFltF59 0x1b0
|
|
|
|
#define HiFltF60 0x1c0
|
|
#define HiFltF61 0x1d0
|
|
#define HiFltF62 0x1e0
|
|
#define HiFltF63 0x1f0
|
|
#define HiFltF64 0x200
|
|
#define HiFltF65 0x210
|
|
#define HiFltF66 0x220
|
|
#define HiFltF67 0x230
|
|
#define HiFltF68 0x240
|
|
#define HiFltF69 0x250
|
|
|
|
#define HiFltF70 0x260
|
|
#define HiFltF71 0x270
|
|
#define HiFltF72 0x280
|
|
#define HiFltF73 0x290
|
|
#define HiFltF74 0x2a0
|
|
#define HiFltF75 0x2b0
|
|
#define HiFltF76 0x2c0
|
|
#define HiFltF77 0x2d0
|
|
#define HiFltF78 0x2e0
|
|
#define HiFltF79 0x2f0
|
|
|
|
#define HiFltF80 0x300
|
|
#define HiFltF81 0x310
|
|
#define HiFltF82 0x320
|
|
#define HiFltF83 0x330
|
|
#define HiFltF84 0x340
|
|
#define HiFltF85 0x350
|
|
#define HiFltF86 0x360
|
|
#define HiFltF87 0x370
|
|
#define HiFltF88 0x380
|
|
#define HiFltF89 0x390
|
|
|
|
#define HiFltF90 0x3a0
|
|
#define HiFltF91 0x3b0
|
|
#define HiFltF92 0x3c0
|
|
#define HiFltF93 0x3d0
|
|
#define HiFltF94 0x3e0
|
|
#define HiFltF95 0x3f0
|
|
#define HiFltF96 0x400
|
|
#define HiFltF97 0x410
|
|
#define HiFltF98 0x420
|
|
#define HiFltF99 0x430
|
|
|
|
#define HiFltF100 0x440
|
|
#define HiFltF101 0x450
|
|
#define HiFltF102 0x460
|
|
#define HiFltF103 0x470
|
|
#define HiFltF104 0x480
|
|
#define HiFltF105 0x490
|
|
#define HiFltF106 0x4a0
|
|
#define HiFltF107 0x4b0
|
|
#define HiFltF108 0x4c0
|
|
#define HiFltF109 0x4d0
|
|
|
|
#define HiFltF110 0x4e0
|
|
#define HiFltF111 0x4f0
|
|
#define HiFltF112 0x500
|
|
#define HiFltF113 0x510
|
|
#define HiFltF114 0x520
|
|
#define HiFltF115 0x530
|
|
#define HiFltF116 0x540
|
|
#define HiFltF117 0x550
|
|
#define HiFltF118 0x560
|
|
#define HiFltF119 0x570
|
|
|
|
#define HiFltF120 0x580
|
|
#define HiFltF121 0x590
|
|
#define HiFltF122 0x5a0
|
|
#define HiFltF123 0x5b0
|
|
#define HiFltF124 0x5c0
|
|
#define HiFltF125 0x5d0
|
|
#define HiFltF126 0x5e0
|
|
#define HiFltF127 0x5f0
|
|
|
|
|
|
//
|
|
// Debug Register Offset Definitions and Length
|
|
//
|
|
|
|
#define DrDbI0 0x0
|
|
#define DrDbI1 0x8
|
|
#define DrDbI2 0x10
|
|
#define DrDbI3 0x18
|
|
#define DrDbI4 0x20
|
|
#define DrDbI5 0x28
|
|
#define DrDbI6 0x30
|
|
#define DrDbI7 0x38
|
|
|
|
#define DrDbD0 0x40
|
|
#define DrDbD1 0x48
|
|
#define DrDbD2 0x50
|
|
#define DrDbD3 0x58
|
|
#define DrDbD4 0x60
|
|
#define DrDbD5 0x68
|
|
#define DrDbD6 0x70
|
|
#define DrDbD7 0x78
|
|
|
|
#define TsAppRegisters 0x0
|
|
#define TsPerfRegisters 0x40
|
|
#define TsHigherFPVolatile 0x80
|
|
#define TsDebugRegisters 0x680
|
|
#define ThreadStateSaveAreaLength 0x700
|
|
|
|
//
|
|
// Exception Frame Offset Definitions and Length
|
|
//
|
|
|
|
#define ExFltS0 0x60
|
|
#define ExFltS1 0x70
|
|
#define ExFltS2 0x80
|
|
#define ExFltS3 0x90
|
|
#define ExFltS4 0xa0
|
|
#define ExFltS5 0xb0
|
|
#define ExFltS6 0xc0
|
|
#define ExFltS7 0xd0
|
|
#define ExFltS8 0xe0
|
|
#define ExFltS9 0xf0
|
|
#define ExFltS10 0x100
|
|
#define ExFltS11 0x110
|
|
#define ExFltS12 0x120
|
|
#define ExFltS13 0x130
|
|
#define ExFltS14 0x140
|
|
#define ExFltS15 0x150
|
|
#define ExFltS16 0x160
|
|
#define ExFltS17 0x170
|
|
#define ExFltS18 0x180
|
|
#define ExFltS19 0x190
|
|
|
|
#define ExIntS0 0x18
|
|
#define ExIntS1 0x20
|
|
#define ExIntS2 0x28
|
|
#define ExIntS3 0x30
|
|
#define ExIntNats 0x10
|
|
|
|
#define ExBrS0 0x38
|
|
#define ExBrS1 0x40
|
|
#define ExBrS2 0x48
|
|
#define ExBrS3 0x50
|
|
#define ExBrS4 0x58
|
|
|
|
#define ExApEC 0x0
|
|
#define ExApLC 0x8
|
|
|
|
#define ExceptionFrameLength 0x1a0
|
|
|
|
//
|
|
// Switch Frame Offset Definitions and Length
|
|
//
|
|
|
|
#define SwExFrame 0x30
|
|
#define SwPreds 0x0
|
|
#define SwRp 0x8
|
|
#define SwPFS 0x10
|
|
#define SwFPSR 0x18
|
|
#define SwBsp 0x20
|
|
#define SwRnat 0x28
|
|
|
|
#define SwitchFrameLength 0x1d0
|
|
|
|
//
|
|
// Plabel structure offset definitions
|
|
//
|
|
|
|
#define PlEntryPoint 0x0
|
|
#define PlGlobalPointer 0x8
|
|
|
|
//
|
|
// Trap Frame Offset Definitions and Length
|
|
//
|
|
|
|
#define TrFltT0 0x50
|
|
#define TrFltT1 0x60
|
|
#define TrFltT2 0x70
|
|
#define TrFltT3 0x80
|
|
#define TrFltT4 0x90
|
|
#define TrFltT5 0xa0
|
|
#define TrFltT6 0xb0
|
|
#define TrFltT7 0xc0
|
|
#define TrFltT8 0xd0
|
|
#define TrFltT9 0xe0
|
|
|
|
#define TrIntGp 0xf0
|
|
#define TrIntT0 0xf8
|
|
#define TrIntT1 0x100
|
|
|
|
#define TrApUNAT 0x108
|
|
#define TrApCCV 0x110
|
|
#define TrSegCSD 0x118
|
|
#define TrPreds 0x120
|
|
|
|
#define TrIntV0 0x128
|
|
#define TrIntT2 0x130
|
|
#define TrIntT3 0x138
|
|
#define TrIntT4 0x140
|
|
#define TrIntSp 0x148
|
|
#define TrIntTeb 0x150
|
|
#define TrIntT5 0x158
|
|
#define TrIntT6 0x160
|
|
#define TrIntT7 0x168
|
|
#define TrIntT8 0x170
|
|
#define TrIntT9 0x178
|
|
|
|
#define TrIntT10 0x180
|
|
#define TrIntT11 0x188
|
|
#define TrIntT12 0x190
|
|
#define TrIntT13 0x198
|
|
#define TrIntT14 0x1a0
|
|
#define TrIntT15 0x1a8
|
|
#define TrIntT16 0x1b0
|
|
#define TrIntT17 0x1b8
|
|
#define TrIntT18 0x1c0
|
|
#define TrIntT19 0x1c8
|
|
#define TrIntT20 0x1d0
|
|
#define TrIntT21 0x1d8
|
|
#define TrIntT22 0x1e0
|
|
|
|
#define TrIntNats 0x1e8
|
|
|
|
#define TrBrRp 0x1f0
|
|
#define TrBrT0 0x1f8
|
|
#define TrBrT1 0x200
|
|
|
|
#define TrRsPFS 0x228
|
|
#define TrRsBSP 0x210
|
|
#define TrRsRSC 0x208
|
|
#define TrRsRNAT 0x220
|
|
#define TrRsBSPSTORE 0x218
|
|
|
|
#define TrStIPSR 0x230
|
|
#define TrStISR 0x250
|
|
#define TrStIFA 0x258
|
|
#define TrStIIP 0x238
|
|
#define TrStIIPA 0x260
|
|
#define TrStIFS 0x240
|
|
#define TrStIIM 0x268
|
|
#define TrStIHA 0x270
|
|
#define TrStFPSR 0x248
|
|
|
|
#define TrOldIrql 0x278
|
|
#define TrPreviousMode 0x27c
|
|
#define TrTrapFrame 0x280
|
|
#define TrNewBSP 0x328
|
|
#define TrEOFMarker 0x330
|
|
#define TrExceptionRecord 0x288
|
|
|
|
#define TrapFrameLength 0x340
|
|
#define TrapFrameArguments 0x40
|
|
#define KTRAP_FRAME_EOF 0xe0f0e0f0e0f0e000
|
|
|
|
//
|
|
// Translation Register Info Definitions
|
|
//
|
|
|
|
#define TrInfoValid 0x0
|
|
#define TrInfoPageSize 0x4
|
|
#define TrInfoVirtualAddress 0x8
|
|
#define TrInfoLength 0x28
|
|
|
|
//
|
|
// Loader Parameter Block Offset Definitions
|
|
//
|
|
|
|
#define LpbLoadOrderListHead 0x0
|
|
#define LpbMemoryDescriptorListHead 0x10
|
|
#define LpbKernelStack 0x30
|
|
#define LpbPrcb 0x38
|
|
#define LpbProcess 0x40
|
|
#define LpbThread 0x48
|
|
#define LpbAcpiRsdt 0x108
|
|
#define LpbKernelPhysicalBase 0xc0
|
|
#define LpbKernelVirtualBase 0xc8
|
|
#define LpbInterruptStack 0xd0
|
|
#define LpbPanicStack 0xd8
|
|
#define LpbPcrPage 0xe0
|
|
#define LpbPdrPage 0xe8
|
|
#define LpbPcrPage2 0xf0
|
|
#define LpbMachineType 0xb8
|
|
#define LpbItrInfo 0x188
|
|
#define LpbDtrInfo 0x2c8
|
|
|
|
//
|
|
// Address Space Layout Definitions
|
|
//
|
|
|
|
#define UREGION_INDEX 0x0
|
|
#define KSEG0_BASE 0xe000000080000000
|
|
#define KSEG2_BASE 0xe0000000a0000000
|
|
#define KADDRESS_BASE 0xe000000000000000
|
|
#define UADDRESS_BASE 0x0
|
|
#define SADDRESS_BASE 0x2000000000000000
|
|
|
|
//
|
|
// Page Table and Directory Entry Definitions
|
|
//
|
|
|
|
#define PAGE_SIZE 0x2000
|
|
#define PAGE_SHIFT 0xd
|
|
#define PDI_SHIFT 0x17
|
|
#define PTI_SHIFT 0xd
|
|
#define PTE_SHIFT 0x3
|
|
#define VHPT_PDE_BITS 0x28
|
|
#define LARGE_PAGE_SIZE 0x1000000
|
|
#define LARGE_PAGE_SHIFT 0x18
|
|
|
|
//
|
|
// Breakpoint Definitions
|
|
//
|
|
|
|
#define USER_BREAKPOINT 0x80002
|
|
#define KERNEL_BREAKPOINT 0x80001
|
|
#define BREAKPOINT_BREAKIN 0x80019
|
|
|
|
//
|
|
// Miscellaneous Definitions
|
|
//
|
|
|
|
#define Executive 0x0
|
|
#define KernelMode 0x0
|
|
#define UserMode 0x1
|
|
#define FALSE 0x0
|
|
#define TRUE 0x1
|
|
#define KiPcr 0xe0000000ffff0000
|
|
#define KiPcr2 0xe0000000fffe0000
|