3 /* Interrupt request levels */
4 #define PASSIVE_LEVEL 0
7 #define DISPATCH_LEVEL 2
8 #define PROFILE_LEVEL 27
9 #define CLOCK1_LEVEL 28
10 #define CLOCK2_LEVEL 28
12 #define POWER_LEVEL 30
16 // Used to contain PFNs and PFN counts
18 typedef ULONG PFN_COUNT
;
19 typedef ULONG PFN_NUMBER
, *PPFN_NUMBER
;
20 typedef LONG SPFN_NUMBER
, *PSPFN_NUMBER
;
23 typedef struct _KFLOATING_SAVE
{
25 } KFLOATING_SAVE
, *PKFLOATING_SAVE
;
27 typedef struct _KPCR_TIB
{
28 PVOID ExceptionList
; /* 00 */
29 PVOID StackBase
; /* 04 */
30 PVOID StackLimit
; /* 08 */
31 PVOID SubSystemTib
; /* 0C */
32 _ANONYMOUS_UNION
union {
33 PVOID FiberData
; /* 10 */
34 ULONG Version
; /* 10 */
36 PVOID ArbitraryUserPointer
; /* 14 */
37 struct _KPCR_TIB
*Self
; /* 18 */
38 } KPCR_TIB
, *PKPCR_TIB
; /* 1C */
40 #define PCR_MINOR_VERSION 1
41 #define PCR_MAJOR_VERSION 1
43 typedef struct _KPCR
{
44 KPCR_TIB Tib
; /* 00 */
45 struct _KPCR
*Self
; /* 1C */
46 struct _KPRCB
*Prcb
; /* 20 */
49 ULONG IrrActive
; /* 2C */
51 PVOID KdVersionBlock
; /* 34 */
54 struct _KTSS
*TSS
; /* 40 */
55 USHORT MajorVersion
; /* 44 */
56 USHORT MinorVersion
; /* 46 */
57 KAFFINITY SetMember
; /* 48 */
58 ULONG StallScaleFactor
; /* 4C */
59 UCHAR SpareUnused
; /* 50 */
60 UCHAR Number
; /* 51 */
61 } KPCR
, *PKPCR
; /* 54 */
63 #define KeGetPcr() PCR
65 #define YieldProcessor() __asm__ __volatile__("nop");
70 KeGetCurrentProcessorNumber(VOID
)
73 __asm__
__volatile__ (
76 : "i" (FIELD_OFFSET(KPCR
, Number
))
86 #define KeLowerIrql(a) KfLowerIrql(a)
93 #define KeRaiseIrql(a,b) *(b) = KfRaiseIrql(a)
98 KeRaiseIrqlToDpcLevel(VOID
);
103 KeRaiseIrqlToSynchLevel(VOID
);