VirtualBox

source: vbox/trunk/include/iprt/initterm.h@ 94817

Last change on this file since 94817 was 93115, checked in by vboxsync, 3 years ago

scm --update-copyright-year

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 8.5 KB
Line 
1/** @file
2 * IPRT - Runtime Init/Term.
3 */
4
5/*
6 * Copyright (C) 2006-2022 Oracle Corporation
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 (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef IPRT_INCLUDED_initterm_h
27#define IPRT_INCLUDED_initterm_h
28#ifndef RT_WITHOUT_PRAGMA_ONCE
29# pragma once
30#endif
31
32#include <iprt/cdefs.h>
33#include <iprt/types.h>
34
35RT_C_DECLS_BEGIN
36
37/** @defgroup grp_rt IPRT C/C++ APIs
38 * @{
39 */
40
41/** @defgroup grp_rt_initterm RTInit/RTTerm - Initialization and Termination
42 *
43 * APIs for initializing and terminating the IPRT, optionally it can also
44 * convert input arguments to UTF-8 (in ring-3).
45 *
46 * @sa RTOnce, RTOnceEx.
47 *
48 * @{
49 */
50
51#ifdef IN_RING3
52
53/** @name RTR3INIT_FLAGS_XXX - RTR3Init* flags.
54 * @see RTR3InitExeNoArguments, RTR3InitExe, RTR3InitDll, RTR3InitEx
55 * @{ */
56/** Initializing IPRT from a DLL. */
57# define RTR3INIT_FLAGS_DLL RT_BIT(0)
58/** The caller ensures that the argument vector is UTF-8. */
59# define RTR3INIT_FLAGS_UTF8_ARGV RT_BIT(1)
60/** Indicates that this is a standalone application without any additional
61 * shared libraries in the application directory. Mainly windows loader mess. */
62# define RTR3INIT_FLAGS_STANDALONE_APP RT_BIT(2)
63/** We are sharing a process space, so we need to behave. */
64# define RTR3INIT_FLAGS_UNOBTRUSIVE RT_BIT(3)
65
66/** Initialize SUPLib (must not fail). */
67# define RTR3INIT_FLAGS_SUPLIB RT_BIT(16)
68/** Try initialize SUPLib and ignore failures. */
69# define RTR3INIT_FLAGS_TRY_SUPLIB RT_BIT(17)
70/** Shift count for passing thru SUPR3INIT_F_XXX flags. */
71# define RTR3INIT_FLAGS_SUPLIB_SHIFT 18
72/** The mask covering the passthru SUPR3INIT_F_XXX flags. */
73# define RTR3INIT_FLAGS_SUPLIB_MASK UINT32_C(0xfffc0000)
74
75/** Valid flag mask. */
76# define RTR3INIT_FLAGS_VALID_MASK UINT32_C(0xffff000f)
77/** @} */
78
79/** @name RTR3InitEx version
80 * @{ */
81/** Version 1. */
82# define RTR3INIT_VER_1 UINT32_C(1)
83/** Version 2 - new flags, rearranged a bit. */
84# define RTR3INIT_VER_2 UINT32_C(2)
85/** The current version. */
86# define RTR3INIT_VER_CUR RTR3INIT_VER_2
87/** @} */
88
89/**
90 * Initializes the runtime library.
91 *
92 * @returns iprt status code.
93 * @param fFlags Flags, see RTR3INIT_FLAGS_XXX.
94 */
95RTR3DECL(int) RTR3InitExeNoArguments(uint32_t fFlags);
96
97/**
98 * Initializes the runtime library.
99 *
100 * @returns iprt status code.
101 * @param cArgs Pointer to the argument count.
102 * @param ppapszArgs Pointer to the argument vector pointer.
103 * @param fFlags Flags, see RTR3INIT_FLAGS_XXX.
104 */
105RTR3DECL(int) RTR3InitExe(int cArgs, char ***ppapszArgs, uint32_t fFlags);
106
107/**
108 * Initializes the runtime library.
109 *
110 * @returns iprt status code.
111 * @param fFlags Flags, see RTR3INIT_FLAGS_XXX.
112 */
113RTR3DECL(int) RTR3InitDll(uint32_t fFlags);
114
115/**
116 * Initializes the runtime library and possibly also SUPLib too.
117 *
118 * Avoid this interface, it's not considered stable.
119 *
120 * @returns IPRT status code.
121 * @param iVersion The interface version. Must be 0 atm.
122 * @param fFlags Flags, see RTR3INIT_FLAGS_XXX.
123 * @param cArgs Pointer to the argument count.
124 * @param ppapszArgs Pointer to the argument vector pointer. NULL
125 * allowed if @a cArgs is 0.
126 * @param pszProgramPath The program path. Pass NULL if we're to figure it
127 * out ourselves.
128 */
129RTR3DECL(int) RTR3InitEx(uint32_t iVersion, uint32_t fFlags, int cArgs, char ***ppapszArgs, const char *pszProgramPath);
130
131/**
132 * Terminates the runtime library.
133 */
134RTR3DECL(void) RTR3Term(void);
135
136/**
137 * Is IPRT succesfully initialized?
138 *
139 * @returns true/false.
140 */
141RTR3DECL(bool) RTR3InitIsInitialized(void);
142
143/**
144 * Are we running in unobtrusive mode?
145 * @returns true/false.
146 */
147RTR3DECL(bool) RTR3InitIsUnobtrusive(void);
148
149#endif /* IN_RING3 */
150
151
152#ifdef IN_RING0
153/**
154 * Initializes the ring-0 driver runtime library.
155 *
156 * @returns iprt status code.
157 * @param fReserved Flags reserved for the future.
158 */
159RTR0DECL(int) RTR0Init(unsigned fReserved);
160
161/**
162 * Terminates the ring-0 driver runtime library.
163 */
164RTR0DECL(void) RTR0Term(void);
165
166/**
167 * Forcibily terminates the ring-0 driver runtime library.
168 *
169 * This should be used when statically linking the IPRT. Module using dynamic
170 * linking shall use RTR0Term. If you're not sure, use RTR0Term!
171 */
172RTR0DECL(void) RTR0TermForced(void);
173#endif
174
175#ifdef IN_RC
176/**
177 * Initializes the raw-mode context runtime library.
178 *
179 * @returns iprt status code.
180 *
181 * @param u64ProgramStartNanoTS The startup timestamp.
182 */
183RTRCDECL(int) RTRCInit(uint64_t u64ProgramStartNanoTS);
184
185/**
186 * Terminates the raw-mode context runtime library.
187 */
188RTRCDECL(void) RTRCTerm(void);
189#endif
190
191
192/**
193 * Termination reason.
194 */
195typedef enum RTTERMREASON
196{
197 /** Normal exit. iStatus contains the exit code. */
198 RTTERMREASON_EXIT = 1,
199 /** Any abnormal exit. iStatus is 0 and has no meaning. */
200 RTTERMREASON_ABEND,
201 /** Killed by a signal. The iStatus contains the signal number. */
202 RTTERMREASON_SIGNAL,
203 /** The IPRT module is being unloaded. iStatus is 0 and has no meaning. */
204 RTTERMREASON_UNLOAD
205} RTTERMREASON;
206
207/** Whether lazy clean up is Okay or not.
208 * When the process is exiting, it is a waste of time to for instance free heap
209 * memory or close open files. OTOH, when the runtime is unloaded from the
210 * process, it is important to release absolutely all resources to prevent
211 * resource leaks. */
212#define RTTERMREASON_IS_LAZY_CLEANUP_OK(enmReason) ((enmReason) != RTTERMREASON_UNLOAD)
213
214
215/**
216 * IPRT termination callback function.
217 *
218 * @param enmReason The cause of the termination.
219 * @param iStatus The meaning of this depends on enmReason.
220 * @param pvUser User argument passed to RTTermRegisterCallback.
221 */
222typedef DECLCALLBACKTYPE(void, FNRTTERMCALLBACK,(RTTERMREASON enmReason, int32_t iStatus, void *pvUser));
223/** Pointer to an IPRT termination callback function. */
224typedef FNRTTERMCALLBACK *PFNRTTERMCALLBACK;
225
226
227/**
228 * Registers a termination callback.
229 *
230 * This is intended for performing clean up during IPRT termination. Frequently
231 * paired with lazy initialization thru RTOnce.
232 *
233 * The callbacks are called in LIFO order.
234 *
235 * @returns IPRT status code.
236 *
237 * @param pfnCallback The callback function.
238 * @param pvUser The user argument for the callback.
239 *
240 * @remarks May need to acquire a fast mutex or critical section, so use with
241 * some care in ring-0 context.
242 *
243 * @remarks Be very careful using this from code that may be unloaded before
244 * IPRT terminates. Unlike some atexit and on_exit implementations,
245 * IPRT will not automatically unregister callbacks when a module gets
246 * unloaded.
247 */
248RTDECL(int) RTTermRegisterCallback(PFNRTTERMCALLBACK pfnCallback, void *pvUser);
249
250/**
251 * Deregister a termination callback.
252 *
253 * @returns VINF_SUCCESS if found, VERR_NOT_FOUND if the callback/pvUser pair
254 * wasn't found.
255 *
256 * @param pfnCallback The callback function.
257 * @param pvUser The user argument for the callback.
258 */
259RTDECL(int) RTTermDeregisterCallback(PFNRTTERMCALLBACK pfnCallback, void *pvUser);
260
261/**
262 * Runs the termination callback queue.
263 *
264 * Normally called by an internal IPRT termination function, but may also be
265 * called by external code immediately prior to terminating IPRT if it is in a
266 * better position to state the termination reason and/or status.
267 *
268 * @param enmReason The reason why it's called.
269 * @param iStatus The associated exit status or signal number.
270 */
271RTDECL(void) RTTermRunCallbacks(RTTERMREASON enmReason, int32_t iStatus);
272
273/** @} */
274
275/** @} */
276
277RT_C_DECLS_END
278
279
280#endif /* !IPRT_INCLUDED_initterm_h */
281
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