[NTOSKRNL]
[reactos.git] / reactos / ntoskrnl / include / internal / ps.h
1 /*
2 * PROJECT: ReactOS Kernel
3 * LICENSE: GPL - See COPYING in the top level directory
4 * FILE: ntoskrnl/include/internal/ps.h
5 * PURPOSE: Internal header for the Process Manager
6 * PROGRAMMERS: Alex Ionescu (alex.ionescu@reactos.org)
7 */
8
9 //
10 // Define this if you want debugging support
11 //
12 #define _PS_DEBUG_ 0x00
13
14 //
15 // These define the Debug Masks Supported
16 //
17 #define PS_THREAD_DEBUG 0x01
18 #define PS_PROCESS_DEBUG 0x02
19 #define PS_SECURITY_DEBUG 0x04
20 #define PS_JOB_DEBUG 0x08
21 #define PS_NOTIFICATIONS_DEBUG 0x10
22 #define PS_WIN32K_DEBUG 0x20
23 #define PS_STATE_DEBUG 0x40
24 #define PS_QUOTA_DEBUG 0x80
25 #define PS_KILL_DEBUG 0x100
26 #define PS_REF_DEBUG 0x200
27
28 //
29 // Debug/Tracing support
30 //
31 #if _PS_DEBUG_
32 #ifdef NEW_DEBUG_SYSTEM_IMPLEMENTED // enable when Debug Filters are implemented
33 #define PSTRACE(x, ...) \
34 { \
35 DbgPrintEx("%s [%.16s] - ", \
36 __FUNCTION__, \
37 PsGetCurrentProcess()->ImageFileName); \
38 DbgPrintEx(__VA_ARGS__); \
39 }
40 #else
41 #define PSTRACE(x, ...) \
42 if (x & PspTraceLevel) \
43 { \
44 DbgPrint("%s [%.16s] - ", \
45 __FUNCTION__, \
46 PsGetCurrentProcess()->ImageFileName); \
47 DbgPrint(__VA_ARGS__); \
48 }
49 #endif
50 #define PSREFTRACE(x) \
51 PSTRACE(PS_REF_DEBUG, \
52 "Pointer Count [%p] @%d: %lx\n", \
53 x, \
54 __LINE__, \
55 OBJECT_TO_OBJECT_HEADER(x)->PointerCount)
56 #else
57 #define PSTRACE(x, fmt, ...) DPRINT(fmt, ##__VA_ARGS__)
58 #define PSREFTRACE(x)
59 #endif
60
61 //
62 // Maximum Count of Notification Routines
63 //
64 #define PSP_MAX_CREATE_THREAD_NOTIFY 8
65 #define PSP_MAX_LOAD_IMAGE_NOTIFY 8
66 #define PSP_MAX_CREATE_PROCESS_NOTIFY 8
67
68 //
69 // Maximum Job Scheduling Classes
70 //
71 #define PSP_JOB_SCHEDULING_CLASSES 10
72
73 //
74 // Thread "Set/Get Context" Context Structure
75 //
76 typedef struct _GET_SET_CTX_CONTEXT
77 {
78 KAPC Apc;
79 KEVENT Event;
80 KPROCESSOR_MODE Mode;
81 CONTEXT Context;
82 } GET_SET_CTX_CONTEXT, *PGET_SET_CTX_CONTEXT;
83
84 //
85 // Initialization Functions
86 //
87 VOID
88 NTAPI
89 PspShutdownProcessManager(
90 VOID
91 );
92
93 BOOLEAN
94 NTAPI
95 PsInitSystem(
96 IN PLOADER_PARAMETER_BLOCK LoaderBlock
97 );
98
99 //
100 // Utility Routines
101 //
102 PETHREAD
103 NTAPI
104 PsGetNextProcessThread(
105 IN PEPROCESS Process,
106 IN PETHREAD Thread OPTIONAL
107 );
108
109 PEPROCESS
110 NTAPI
111 PsGetNextProcess(
112 IN PEPROCESS OldProcess OPTIONAL
113 );
114
115 NTSTATUS
116 NTAPI
117 PspMapSystemDll(
118 IN PEPROCESS Process,
119 OUT PVOID *DllBase,
120 IN BOOLEAN UseLargePages
121 );
122
123 NTSTATUS
124 NTAPI
125 PsLocateSystemDll(
126 VOID
127 );
128
129 NTSTATUS
130 NTAPI
131 PspGetSystemDllEntryPoints(
132 VOID
133 );
134
135 VOID
136 NTAPI
137 PsChangeQuantumTable(
138 IN BOOLEAN Immediate,
139 IN ULONG PrioritySeparation
140 );
141
142 NTSTATUS
143 NTAPI
144 PsReferenceProcessFilePointer(
145 IN PEPROCESS Process,
146 OUT PFILE_OBJECT *FileObject
147 );
148
149 //
150 // Process Routines
151 //
152 NTSTATUS
153 NTAPI
154 PspCreateProcess(
155 OUT PHANDLE ProcessHandle,
156 IN ACCESS_MASK DesiredAccess,
157 IN POBJECT_ATTRIBUTES ObjectAttributes OPTIONAL,
158 IN HANDLE ParentProcess OPTIONAL,
159 IN ULONG Flags,
160 IN HANDLE SectionHandle OPTIONAL,
161 IN HANDLE DebugPort OPTIONAL,
162 IN HANDLE ExceptionPort OPTIONAL,
163 IN BOOLEAN InJob
164 );
165
166 //
167 // Security Routines
168 //
169 PACCESS_TOKEN
170 NTAPI
171 PsReferenceEffectiveToken(
172 IN PETHREAD Thread,
173 OUT PTOKEN_TYPE TokenType,
174 OUT PUCHAR b,
175 OUT PSECURITY_IMPERSONATION_LEVEL Level
176 );
177
178 NTSTATUS
179 NTAPI
180 PsOpenTokenOfProcess(
181 IN HANDLE ProcessHandle,
182 OUT PACCESS_TOKEN* Token
183 );
184
185 NTSTATUS
186 NTAPI
187 PspSetPrimaryToken(
188 IN PEPROCESS Process,
189 IN HANDLE TokenHandle OPTIONAL,
190 IN PACCESS_TOKEN Token OPTIONAL
191 );
192
193 NTSTATUS
194 NTAPI
195 PspInitializeProcessSecurity(
196 IN PEPROCESS Process,
197 IN PEPROCESS Parent OPTIONAL
198 );
199
200 VOID
201 NTAPI
202 PspDeleteProcessSecurity(
203 IN PEPROCESS Process
204 );
205
206 VOID
207 NTAPI
208 PspDeleteThreadSecurity(
209 IN PETHREAD Thread
210 );
211
212 //
213 // Reaping and Deletion
214 //
215 VOID
216 NTAPI
217 PsExitSpecialApc(
218 PKAPC Apc,
219 PKNORMAL_ROUTINE *NormalRoutine,
220 PVOID *NormalContext,
221 PVOID *SystemArgument1,
222 PVOID *SystemArgument2
223 );
224
225 VOID
226 NTAPI
227 PspReapRoutine(
228 IN PVOID Context
229 );
230
231 VOID
232 NTAPI
233 PspExitThread(
234 IN NTSTATUS ExitStatus
235 );
236
237 NTSTATUS
238 NTAPI
239 PspTerminateThreadByPointer(
240 IN PETHREAD Thread,
241 IN NTSTATUS ExitStatus,
242 IN BOOLEAN bSelf
243 );
244
245 VOID
246 NTAPI
247 PspExitProcess(
248 IN BOOLEAN LastThread,
249 IN PEPROCESS Process
250 );
251
252 NTSTATUS
253 NTAPI
254 PsTerminateProcess(
255 IN PEPROCESS Process,
256 IN NTSTATUS ExitStatus
257 );
258
259 VOID
260 NTAPI
261 PspDeleteProcess(
262 IN PVOID ObjectBody
263 );
264
265 VOID
266 NTAPI
267 PspDeleteThread(
268 IN PVOID ObjectBody
269 );
270
271 //
272 // Thread/Process Startup
273 //
274 VOID
275 NTAPI
276 PspSystemThreadStartup(
277 PKSTART_ROUTINE StartRoutine,
278 PVOID StartContext
279 );
280
281 VOID
282 NTAPI
283 PsIdleThreadMain(
284 IN PVOID Context
285 );
286
287 //
288 // Quota Support
289 //
290 VOID
291 NTAPI
292 PspInheritQuota(
293 IN PEPROCESS Process,
294 IN PEPROCESS ParentProcess
295 );
296
297 VOID
298 NTAPI
299 PspDestroyQuotaBlock(
300 IN PEPROCESS Process
301 );
302
303 NTSTATUS
304 NTAPI
305 PspSetQuotaLimits(
306 _In_ PEPROCESS Process,
307 _In_ ULONG Unused,
308 _In_ PVOID QuotaLimits,
309 _In_ ULONG QuotaLimitsLength,
310 _In_ KPROCESSOR_MODE PreviousMode);
311
312 #if defined(_X86_)
313 //
314 // VDM and LDT Support
315 //
316 VOID
317 NTAPI
318 PspDeleteLdt(
319 IN PEPROCESS Process
320 );
321
322 VOID
323 NTAPI
324 PspDeleteVdmObjects(
325 IN PEPROCESS Process
326 );
327
328 NTSTATUS
329 NTAPI
330 PspQueryDescriptorThread(
331 IN PETHREAD Thread,
332 IN PVOID ThreadInformation,
333 IN ULONG ThreadInformationLength,
334 OUT PULONG ReturnLength OPTIONAL
335 );
336 #endif
337
338 //
339 // Job Routines
340 //
341 VOID
342 NTAPI
343 PspExitProcessFromJob(
344 IN PEJOB Job,
345 IN PEPROCESS Process
346 );
347
348 VOID
349 NTAPI
350 PspRemoveProcessFromJob(
351 IN PEPROCESS Process,
352 IN PEJOB Job
353 );
354
355 VOID
356 NTAPI
357 PspInitializeJobStructures(
358 VOID
359 );
360
361 VOID
362 NTAPI
363 PspDeleteJob(
364 IN PVOID ObjectBody
365 );
366
367 //
368 // State routines
369 //
370 NTSTATUS
371 NTAPI
372 PsResumeThread(
373 IN PETHREAD Thread,
374 OUT PULONG PreviousCount OPTIONAL
375 );
376
377 NTSTATUS
378 NTAPI
379 PsSuspendThread(
380 IN PETHREAD Thread,
381 OUT PULONG PreviousCount OPTIONAL
382 );
383
384 VOID
385 NTAPI
386 PspGetOrSetContextKernelRoutine(
387 IN PKAPC Apc,
388 IN OUT PKNORMAL_ROUTINE* NormalRoutine,
389 IN OUT PVOID* NormalContext,
390 IN OUT PVOID* SystemArgument1,
391 IN OUT PVOID* SystemArgument2
392 );
393
394 //
395 // Process Quotas
396 //
397 NTSTATUS
398 NTAPI
399 PsReturnProcessPageFileQuota(
400 IN PEPROCESS Process,
401 IN SIZE_T Amount
402 );
403
404 NTSTATUS
405 NTAPI
406 PsChargeProcessPageFileQuota(
407 IN PEPROCESS Process,
408 IN SIZE_T Amount
409 );
410
411 BOOLEAN
412 NTAPI
413 PspIsProcessExiting(IN PEPROCESS Process);
414
415 //
416 // Apphelp functions
417 //
418 NTSTATUS
419 NTAPI
420 ApphelpCacheInitialize(VOID);
421
422 VOID
423 NTAPI
424 ApphelpCacheShutdown(VOID);
425
426 //
427 // Global data inside the Process Manager
428 //
429 extern ULONG PspTraceLevel;
430 extern LCID PsDefaultThreadLocaleId;
431 extern LCID PsDefaultSystemLocaleId;
432 extern LIST_ENTRY PspReaperListHead;
433 extern WORK_QUEUE_ITEM PspReaperWorkItem;
434 extern BOOLEAN PspReaping;
435 extern PEPROCESS PsIdleProcess;
436 extern LIST_ENTRY PsActiveProcessHead;
437 extern KGUARDED_MUTEX PspActiveProcessMutex;
438 extern LARGE_INTEGER ShortPsLockDelay;
439 extern EPROCESS_QUOTA_BLOCK PspDefaultQuotaBlock;
440 extern PHANDLE_TABLE PspCidTable;
441 extern EX_CALLBACK PspThreadNotifyRoutine[PSP_MAX_CREATE_THREAD_NOTIFY];
442 extern EX_CALLBACK PspProcessNotifyRoutine[PSP_MAX_CREATE_PROCESS_NOTIFY];
443 extern EX_CALLBACK PspLoadImageNotifyRoutine[PSP_MAX_LOAD_IMAGE_NOTIFY];
444 extern PLEGO_NOTIFY_ROUTINE PspLegoNotifyRoutine;
445 extern ULONG PspThreadNotifyRoutineCount, PspProcessNotifyRoutineCount;
446 extern BOOLEAN PsImageNotifyEnabled;
447 extern PKWIN32_PROCESS_CALLOUT PspW32ProcessCallout;
448 extern PKWIN32_THREAD_CALLOUT PspW32ThreadCallout;
449 extern PVOID PspSystemDllEntryPoint;
450 extern PVOID PspSystemDllBase;
451 extern BOOLEAN PspUseJobSchedulingClasses;
452 extern CHAR PspJobSchedulingClasses[PSP_JOB_SCHEDULING_CLASSES];
453 extern ULONG PsRawPrioritySeparation;
454 extern ULONG PsPrioritySeparation;
455 extern POBJECT_TYPE _PsThreadType, _PsProcessType;
456 extern PTOKEN PspBootAccessToken;
457 extern GENERIC_MAPPING PspJobMapping;
458 extern POBJECT_TYPE PsJobType;
459 extern LARGE_INTEGER ShortPsLockDelay;
460 extern UNICODE_STRING PsNtDllPathName;
461 extern LIST_ENTRY PsLoadedModuleList;
462 extern KSPIN_LOCK PsLoadedModuleSpinLock;
463 extern ERESOURCE PsLoadedModuleResource;
464 extern ULONG_PTR PsNtosImageBase;
465
466 //
467 // Inlined Functions
468 //
469 #include "ps_x.h"