VirtualBox

source: vbox/trunk/include/iprt/process.h@ 4011

Last change on this file since 4011 was 3630, checked in by vboxsync, 17 years ago

iprt_hdr_h -> _iprt_hdr_h

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 7.3 KB
Line 
1/** @file
2 * innotek Portable Runtime - Process Management.
3 */
4
5/*
6 * Copyright (C) 2006-2007 innotek GmbH
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License as published by the Free Software Foundation,
12 * in version 2 as it comes in the "COPYING" file of the VirtualBox OSE
13 * distribution. VirtualBox OSE is distributed in the hope that it will
14 * be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * If you received this file as part of a commercial VirtualBox
17 * distribution, then only the terms of your commercial VirtualBox
18 * license agreement apply instead of the previous paragraph.
19 */
20
21#ifndef ___iprt_process_h
22#define ___iprt_process_h
23
24#include <iprt/cdefs.h>
25#include <iprt/types.h>
26
27__BEGIN_DECLS
28
29/** @defgroup grp_rt_process RTProc - Process Management
30 * @ingroup grp_rt
31 * @{
32 */
33
34
35/**
36 * Process priority.
37 *
38 * The process priority is used to select how scheduling properties
39 * are assigned to the different thread types (see THREADTYPE).
40 *
41 * In addition to using the policy assigned to the process at startup (DEFAULT)
42 * it is possible to change the process priority at runtime. This allows for
43 * a GUI, resource manager or admin to adjust the general priorty of a task
44 * without upsetting the fine-tuned priority of the threads within.
45 */
46typedef enum RTPROCPRIORITY
47{
48 /** Invalid priority. */
49 RTPROCPRIORITY_INVALID = 0,
50 /** Default priority.
51 * Derive the schedulding policy from the priority of the RTR3Init()
52 * and RTProcSetPriority() callers and the rights the process have
53 * to alter its own priority.
54 */
55 RTPROCPRIORITY_DEFAULT,
56 /** Flat priority.
57 * Assumes a scheduling policy which puts the process at the default priority
58 * and with all thread at the same priority.
59 */
60 RTPROCPRIORITY_FLAT,
61 /** Low priority.
62 * Assumes a scheduling policy which puts the process mostly below the
63 * default priority of the host OS.
64 */
65 RTPROCPRIORITY_LOW,
66 /** Normal priority.
67 * Assume a scheduling policy which shares the cpu resources fairly with
68 * other processes running with the default priority of the host OS.
69 */
70 RTPROCPRIORITY_NORMAL,
71 /** High priority.
72 * Assumes a scheduling policy which puts the task above the default
73 * priority of the host OS. This policy might easily cause other tasks
74 * in the system to starve.
75 */
76 RTPROCPRIORITY_HIGH,
77 /** Last priority, used for validation. */
78 RTPROCPRIORITY_LAST
79} RTPROCPRIORITY;
80
81
82/**
83 * Get the current process identifier.
84 *
85 * @returns Process identifier.
86 */
87RTDECL(RTPROCESS) RTProcSelf(void);
88
89
90#ifdef IN_RING0
91/**
92 * Get the current process handle.
93 *
94 * @returns Ring-0 process handle.
95 */
96RTR0DECL(RTR0PROCESS) RTR0ProcHandleSelf(void);
97#endif
98
99
100#ifdef IN_RING3
101
102/**
103 * Attempts to alter the priority of the current process.
104 *
105 * @returns iprt status code.
106 * @param enmPriority The new priority.
107 */
108RTR3DECL(int) RTProcSetPriority(RTPROCPRIORITY enmPriority);
109
110/**
111 * Gets the current priority of this process.
112 *
113 * @returns The priority (see RTPROCPRIORITY).
114 */
115RTR3DECL(RTPROCPRIORITY) RTProcGetPriority(void);
116
117/**
118 * Create a child process.
119 *
120 * @returns iprt status code.
121 * @param pszExec Executable image to use to create the child process.
122 * @param papszArgs Pointer to an array of arguments to the child. The array terminated by an entry containing NULL.
123 * @param papszEnv Pointer to array of environment variables for the child process. An NULL entry
124 * terminates the array. The variables are on the form '\<var\>=\<value\>'.
125 * If NULL the environment of the process will be used.
126 * @param fFlags Flags. This is currently reserved and must be 0.
127 * @param pProcess Where to store the process identifier on successful return.
128 * The content is not changed on failure. NULL is allowed.
129 */
130RTR3DECL(int) RTProcCreate(const char *pszExec, const char * const *papszArgs, const char * const *papszEnv, unsigned fFlags, PRTPROCESS pProcess);
131
132/**
133 * Process exit reason.
134 */
135typedef enum RTPROCEXITREASON
136{
137 /** Normal exit. iStatus contains the exit code. */
138 RTPROCEXITREASON_NORMAL = 1,
139 /** Any abnormal exit. iStatus is undefined. */
140 RTPROCEXITREASON_ABEND,
141 /** Killed by a signal. The iStatus field contains the signal number. */
142 RTPROCEXITREASON_SIGNAL
143} RTPROCEXITREASON;
144
145/**
146 * Process exit status.
147 */
148typedef struct RTPROCSTATUS
149{
150 /** The process exit status if the exit was a normal one. */
151 int iStatus;
152 /** The reason the process terminated. */
153 RTPROCEXITREASON enmReason;
154} RTPROCSTATUS;
155/** Pointer to a process exit status structure. */
156typedef RTPROCSTATUS *PRTPROCSTATUS;
157/** Pointer to a const process exit status structure. */
158typedef const RTPROCSTATUS *PCRTPROCSTATUS;
159
160
161/** Flags for RTProcWait().
162 * @{ */
163/** Block indefinitly waiting for the process to exit. */
164#define RTPROCWAIT_FLAGS_BLOCK 0
165/** Don't block, just check if the process have exitted. */
166#define RTPROCWAIT_FLAGS_NOBLOCK 1
167/** @} */
168
169/**
170 * Waits for a process, resumes on interruption.
171 *
172 * @returns VINF_SUCCESS when the status code for the process was collected and put in *pProcStatus.
173 * @returns VERR_PROCESS_NOT_FOUND if the specified process wasn't found.
174 * @returns VERR_PROCESS_RUNNING when the RTPROCWAIT_FLAG_NOBLOCK and the process haven't exitted yet.
175 *
176 * @param Process The process to wait for.
177 * @param fFlags The wait flags, any of the RTPROCWAIT_FLAGS_ \#defines.
178 * @param pProcStatus Where to store the exit status on success.
179 */
180RTR3DECL(int) RTProcWait(RTPROCESS Process, unsigned fFlags, PRTPROCSTATUS pProcStatus);
181
182/**
183 * Waits for a process, returns on interruption.
184 *
185 * @returns VINF_SUCCESS when the status code for the process was collected and put in *pProcStatus.
186 * @returns VERR_PROCESS_NOT_FOUND if the specified process wasn't found.
187 * @returns VERR_PROCESS_RUNNING when the RTPROCWAIT_FLAG_NOBLOCK and the process haven't exitted yet.
188 * @returns VERR_INTERRUPTED when the wait was interrupted by the arrival of a signal or other async event.
189 *
190 * @param Process The process to wait for.
191 * @param fFlags The wait flags, any of the RTPROCWAIT_FLAGS_ \#defines.
192 * @param pProcStatus Where to store the exit status on success.
193 */
194RTR3DECL(int) RTProcWaitNoResume(RTPROCESS Process, unsigned fFlags, PRTPROCSTATUS pProcStatus);
195
196/**
197 * Terminates (kills) a running process.
198 *
199 * @returns IPRT status code.
200 * @param Process The process to terminate.
201 */
202RTR3DECL(int) RTProcTerminate(RTPROCESS Process);
203
204/**
205 * Gets the processor affinity mask of the current process.
206 *
207 * @returns The affinity mask.
208 */
209RTR3DECL(uint64_t) RTProcGetAffinityMask(void);
210
211/**
212 * Gets the executable image name of the current process.
213 *
214 *
215 * @returns pszExecName on success. NULL on buffer overflow or other errors.
216 *
217 * @param pszExecName Where to store the name.
218 * @param cchExecName The size of the buffer.
219 */
220RTR3DECL(char *) RTProcGetExecutableName(char *pszExecName, size_t cchExecName);
221
222#endif /* IN_RING3 */
223
224/** @} */
225
226__END_DECLS
227
228#endif
229
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette