1 /* Version definitions */
3 #define NTDDI_VERSION NTDDI_WIN10
5 #define _WIN32_WINNT _WIN32_WINNT_WIN10
10 #define C_ASSERT_FIELD(Type, Offset, MemberType, MemberName) C_ASSERT(FIELD_OFFSET(Type, MemberName) == Offset);
13 C_ASSERT_FIELD(KTHREAD
, 0x000, DISPATCHER_HEADER
, Header
)
14 C_ASSERT_FIELD(KTHREAD
, 0x010, PVOID
, SListFaultAddress
)
15 C_ASSERT_FIELD(KTHREAD
, 0x018, UINT64
, QuantumTarget
)
16 C_ASSERT_FIELD(KTHREAD
, 0x020, PVOID
, InitialStack
)
17 C_ASSERT_FIELD(KTHREAD
, 0x024, PVOID
, StackLimit
)
18 C_ASSERT_FIELD(KTHREAD
, 0x028, PVOID
, StackBase
)
19 C_ASSERT_FIELD(KTHREAD
, 0x02C, ULONG32
, ThreadLock
)
20 C_ASSERT_FIELD(KTHREAD
, 0x030, UINT64
, CycleTime
)
21 C_ASSERT_FIELD(KTHREAD
, 0x038, ULONG32
, HighCycleTime
)
22 C_ASSERT_FIELD(KTHREAD
, 0x03C, PVOID
, ServiceTable
)
23 C_ASSERT_FIELD(KTHREAD
, 0x040, ULONG32
, CurrentRunTime
)
24 C_ASSERT_FIELD(KTHREAD
, 0x044, ULONG32
, ExpectedRunTime
)
25 C_ASSERT_FIELD(KTHREAD
, 0x048, PVOID
, KernelStack
)
26 C_ASSERT_FIELD(KTHREAD
, 0x04C, XSAVE_FORMAT
*, StateSaveArea
)
27 C_ASSERT_FIELD(KTHREAD
, 0x050, KSCHEDULING_GROUP
*, SchedulingGroup
)
28 C_ASSERT_FIELD(KTHREAD
, 0x054, KWAIT_STATUS_REGISTER
, WaitRegister
)
29 C_ASSERT_FIELD(KTHREAD
, 0x055, UINT8
, Running
)
30 C_ASSERT_FIELD(KTHREAD
, 0x056, UINT8
[2], Alerted
)
31 C_ASSERT_FIELD(KTHREAD
, 0x058, LONG32
, MiscFlags
)
32 C_ASSERT_FIELD(KTHREAD
, 0x05C, LONG32
, ThreadFlags
)
33 C_ASSERT_FIELD(KTHREAD
, 0x060, UINT8
, Tag
)
34 C_ASSERT_FIELD(KTHREAD
, 0x061, UINT8
, SystemHeteroCpuPolicy
)
35 C_ASSERT_FIELD(KTHREAD
, 0x063, UINT8
, Spare0
)
36 C_ASSERT_FIELD(KTHREAD
, 0x064, ULONG32
, SystemCallNumber
)
37 C_ASSERT_FIELD(KTHREAD
, 0x068, PVOID
, FirstArgument
)
38 C_ASSERT_FIELD(KTHREAD
, 0x06C, KTRAP_FRAME
*, TrapFrame
)
39 C_ASSERT_FIELD(KTHREAD
, 0x070, KAPC_STATE
, ApcState
)
40 C_ASSERT_FIELD(KTHREAD
, 0x088, ULONG32
, UserIdealProcessor
)
41 C_ASSERT_FIELD(KTHREAD
, 0x08C, ULONG32
, ContextSwitches
)
42 C_ASSERT_FIELD(KTHREAD
, 0x090, UINT8
, State
)
43 C_ASSERT_FIELD(KTHREAD
, 0x091, CHAR
, Spare12
)
44 C_ASSERT_FIELD(KTHREAD
, 0x092, UINT8
, WaitIrql
)
45 C_ASSERT_FIELD(KTHREAD
, 0x093, CHAR
, WaitMode
)
46 C_ASSERT_FIELD(KTHREAD
, 0x094, LONG32
, WaitStatus
)
47 C_ASSERT_FIELD(KTHREAD
, 0x098, KWAIT_BLOCK
*, WaitBlockList
)
48 C_ASSERT_FIELD(KTHREAD
, 0x09C, LIST_ENTRY
, WaitListEntry
)
49 C_ASSERT_FIELD(KTHREAD
, 0x09C, SINGLE_LIST_ENTRY
, SwapListEntry
)
50 C_ASSERT_FIELD(KTHREAD
, 0x0A4, DISPATCHER_HEADER
*, Queue
)
51 C_ASSERT_FIELD(KTHREAD
, 0x0A8, PVOID
, Teb
)
52 C_ASSERT_FIELD(KTHREAD
, 0x0B0, UINT64
, RelativeTimerBias
)
53 C_ASSERT_FIELD(KTHREAD
, 0x0B8, KTIMER
, Timer
)
54 C_ASSERT_FIELD(KTHREAD
, 0x0E0, KWAIT_BLOCK
[4], WaitBlock
)
55 C_ASSERT_FIELD(KTHREAD
, 0x0F4, KTHREAD_COUNTERS
*, ThreadCounters
)
56 C_ASSERT_FIELD(KTHREAD
, 0x10C, XSTATE_SAVE
*, XStateSave
)
57 C_ASSERT_FIELD(KTHREAD
, 0x124, PVOID
, Win32Thread
)
58 C_ASSERT_FIELD(KTHREAD
, 0x138, ULONG32
, WaitTime
)
59 C_ASSERT_FIELD(KTHREAD
, 0x13C, INT16
, KernelApcDisable
)
60 C_ASSERT_FIELD(KTHREAD
, 0x13E, INT16
, SpecialApcDisable
)
61 C_ASSERT_FIELD(KTHREAD
, 0x13C, ULONG32
, CombinedApcDisable
)
62 C_ASSERT_FIELD(KTHREAD
, 0x140, LIST_ENTRY
, QueueListEntry
)
63 C_ASSERT_FIELD(KTHREAD
, 0x148, ULONG32
, NextProcessor
)
64 C_ASSERT_FIELD(KTHREAD
, 0x14C, LONG32
, QueuePriority
)
65 C_ASSERT_FIELD(KTHREAD
, 0x150, KPROCESS
*, Process
)
66 C_ASSERT_FIELD(KTHREAD
, 0x154, GROUP_AFFINITY
, UserAffinity
)
67 C_ASSERT_FIELD(KTHREAD
, 0x15A, CHAR
, PreviousMode
)
68 C_ASSERT_FIELD(KTHREAD
, 0x15B, CHAR
, BasePriority
)
69 C_ASSERT_FIELD(KTHREAD
, 0x15C, CHAR
, PriorityDecrement
)
70 C_ASSERT_FIELD(KTHREAD
, 0x15D, UINT8
, Preempted
)
71 C_ASSERT_FIELD(KTHREAD
, 0x15E, UINT8
, AdjustReason
)
72 C_ASSERT_FIELD(KTHREAD
, 0x15F, CHAR
, AdjustIncrement
)
73 C_ASSERT_FIELD(KTHREAD
, 0x160, ULONG32
, AffinityVersion
)
74 C_ASSERT_FIELD(KTHREAD
, 0x164, GROUP_AFFINITY
, Affinity
)
75 C_ASSERT_FIELD(KTHREAD
, 0x16A, UINT8
, ApcStateIndex
)
76 C_ASSERT_FIELD(KTHREAD
, 0x16B, UINT8
, WaitBlockCount
)
77 C_ASSERT_FIELD(KTHREAD
, 0x16C, ULONG32
, IdealProcessor
)
78 C_ASSERT_FIELD(KTHREAD
, 0x174, KAPC_STATE
, SavedApcState
)
79 C_ASSERT_FIELD(KTHREAD
, 0x18B, UINT8
, WaitReason
)
80 C_ASSERT_FIELD(KTHREAD
, 0x18C, CHAR
, SuspendCount
)
81 C_ASSERT_FIELD(KTHREAD
, 0x18D, CHAR
, Saturation
)
82 C_ASSERT_FIELD(KTHREAD
, 0x18E, UINT16
, SListFaultCount
)
83 C_ASSERT_FIELD(KTHREAD
, 0x190, KAPC
, SchedulerApc
)
84 C_ASSERT_FIELD(KTHREAD
, 0x191, UINT8
, ResourceIndex
)
85 C_ASSERT_FIELD(KTHREAD
, 0x193, UINT8
, QuantumReset
)
86 C_ASSERT_FIELD(KTHREAD
, 0x194, ULONG32
, KernelTime
)
87 C_ASSERT_FIELD(KTHREAD
, 0x1B4, KPRCB
*, WaitPrcb
)
88 C_ASSERT_FIELD(KTHREAD
, 0x1B8, PVOID
, LegoData
)
89 C_ASSERT_FIELD(KTHREAD
, 0x1BF, UINT8
, CallbackNestingLevel
)
90 C_ASSERT_FIELD(KTHREAD
, 0x1C0, ULONG32
, UserTime
)
91 C_ASSERT_FIELD(KTHREAD
, 0x1C4, KEVENT
, SuspendEvent
)
92 C_ASSERT_FIELD(KTHREAD
, 0x1D4, LIST_ENTRY
, ThreadListEntry
)
93 C_ASSERT_FIELD(KTHREAD
, 0x1DC, LIST_ENTRY
, MutantListHead
)
94 C_ASSERT_FIELD(KTHREAD
, 0x1E4, UINT8
, AbEntrySummary
)
95 C_ASSERT_FIELD(KTHREAD
, 0x1E5, UINT8
, AbWaitEntryCount
)
96 C_ASSERT_FIELD(KTHREAD
, 0x1E6, UINT16
, Spare20
)
97 C_ASSERT_FIELD(KTHREAD
, 0x1E8, KLOCK_ENTRY
[6], LockEntries
)
98 C_ASSERT_FIELD(KTHREAD
, 0x308, SINGLE_LIST_ENTRY
, PropagateBoostsEntry
)
99 C_ASSERT_FIELD(KTHREAD
, 0x30C, SINGLE_LIST_ENTRY
, IoSelfBoostsEntry
)
100 C_ASSERT_FIELD(KTHREAD
, 0x310, UINT8
[16], PriorityFloorCounts
)
101 C_ASSERT_FIELD(KTHREAD
, 0x320, ULONG32
, PriorityFloorSummary
)
102 C_ASSERT_FIELD(KTHREAD
, 0x324, LONG32
, AbCompletedIoBoostCount
)
103 C_ASSERT_FIELD(KTHREAD
, 0x328, INT16
, KeReferenceCount
)
104 C_ASSERT_FIELD(KTHREAD
, 0x32A, UINT8
, AbOrphanedEntrySummary
)
105 C_ASSERT_FIELD(KTHREAD
, 0x32B, UINT8
, AbOwnedEntryCount
)
106 C_ASSERT_FIELD(KTHREAD
, 0x32C, ULONG32
, ForegroundLossTime
)
107 C_ASSERT_FIELD(KTHREAD
, 0x330, LIST_ENTRY
, GlobalForegroundListEntry
)
108 C_ASSERT_FIELD(KTHREAD
, 0x330, SINGLE_LIST_ENTRY
, ForegroundDpcStackListEntry
)
109 C_ASSERT_FIELD(KTHREAD
, 0x334, ULONG32
, InGlobalForegroundList
)
110 C_ASSERT_FIELD(KTHREAD
, 0x338, KSCB
*, QueuedScb
)
111 C_ASSERT_FIELD(KTHREAD
, 0x340, UINT64
, NpxState
)