]>
Commit | Line | Data |
---|---|---|
056a1eb7 SF |
1 | /** @file |
2 | * IPRT - Status Codes. | |
3 | */ | |
4 | ||
5 | /* | |
6d209b23 | 6 | * Copyright (C) 2006-2017 Oracle Corporation |
056a1eb7 SF |
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_err_h | |
27 | #define ___iprt_err_h | |
28 | ||
29 | #include <iprt/cdefs.h> | |
30 | #include <iprt/types.h> | |
31 | #include <iprt/stdarg.h> | |
32 | ||
33 | ||
34 | /** @defgroup grp_rt_err RTErr - Status Codes | |
35 | * @ingroup grp_rt | |
36 | * | |
37 | * The IPRT status codes are in two ranges: {0..999} and {22000..32766}. The | |
38 | * IPRT users are free to use the range {1000..21999}. See RTERR_RANGE1_FIRST, | |
39 | * RTERR_RANGE1_LAST, RTERR_RANGE2_FIRST, RTERR_RANGE2_LAST, RTERR_USER_FIRST | |
40 | * and RTERR_USER_LAST. | |
41 | * | |
42 | * @{ | |
43 | */ | |
44 | ||
45 | /** @defgroup grp_rt_err_hlp Status Code Helpers | |
46 | * @{ | |
47 | */ | |
48 | ||
49 | #ifdef __cplusplus | |
50 | /** | |
51 | * Strict type validation class. | |
52 | * | |
53 | * This is only really useful for type checking the arguments to RT_SUCCESS, | |
54 | * RT_SUCCESS_NP, RT_FAILURE and RT_FAILURE_NP. The RTErrStrictType2 | |
55 | * constructor is for integration with external status code strictness regimes. | |
56 | */ | |
57 | class RTErrStrictType | |
58 | { | |
59 | protected: | |
60 | int32_t m_rc; | |
61 | ||
62 | public: | |
63 | /** | |
64 | * Constructor for interaction with external status code strictness regimes. | |
65 | * | |
66 | * This is a special constructor for helping external return code validator | |
67 | * classes interact cleanly with RT_SUCCESS, RT_SUCCESS_NP, RT_FAILURE and | |
68 | * RT_FAILURE_NP while barring automatic cast to integer. | |
69 | * | |
70 | * @param rcObj IPRT status code object from an automatic cast. | |
71 | */ | |
72 | RTErrStrictType(RTErrStrictType2 const rcObj) | |
73 | : m_rc(rcObj.getValue()) | |
74 | { | |
75 | } | |
76 | ||
77 | /** | |
78 | * Integer constructor used by RT_SUCCESS_NP. | |
79 | * | |
80 | * @param rc IPRT style status code. | |
81 | */ | |
82 | RTErrStrictType(int32_t rc) | |
83 | : m_rc(rc) | |
84 | { | |
85 | } | |
86 | ||
87 | #if 0 /** @todo figure where int32_t is long instead of int. */ | |
88 | /** | |
89 | * Integer constructor used by RT_SUCCESS_NP. | |
90 | * | |
91 | * @param rc IPRT style status code. | |
92 | */ | |
93 | RTErrStrictType(signed int rc) | |
94 | : m_rc(rc) | |
95 | { | |
96 | } | |
97 | #endif | |
98 | ||
99 | /** | |
100 | * Test for success. | |
101 | */ | |
102 | bool success() const | |
103 | { | |
104 | return m_rc >= 0; | |
105 | } | |
106 | ||
107 | private: | |
108 | /** @name Try ban a number of wrong types. | |
109 | * @{ */ | |
110 | RTErrStrictType(uint8_t rc) : m_rc(-999) { NOREF(rc); } | |
111 | RTErrStrictType(uint16_t rc) : m_rc(-999) { NOREF(rc); } | |
112 | RTErrStrictType(uint32_t rc) : m_rc(-999) { NOREF(rc); } | |
113 | RTErrStrictType(uint64_t rc) : m_rc(-999) { NOREF(rc); } | |
114 | RTErrStrictType(int8_t rc) : m_rc(-999) { NOREF(rc); } | |
115 | RTErrStrictType(int16_t rc) : m_rc(-999) { NOREF(rc); } | |
116 | RTErrStrictType(int64_t rc) : m_rc(-999) { NOREF(rc); } | |
117 | /** @todo fight long here - clashes with int32_t/int64_t on some platforms. */ | |
118 | /** @} */ | |
119 | }; | |
120 | #endif /* __cplusplus */ | |
121 | ||
122 | ||
123 | /** @def RTERR_STRICT_RC | |
124 | * Indicates that RT_SUCCESS_NP, RT_SUCCESS, RT_FAILURE_NP and RT_FAILURE should | |
125 | * make type enforcing at compile time. | |
126 | * | |
127 | * @remarks Only define this for C++ code. | |
128 | */ | |
129 | #if defined(__cplusplus) \ | |
130 | && !defined(RTERR_STRICT_RC) \ | |
131 | && ( defined(DOXYGEN_RUNNING) \ | |
132 | || defined(DEBUG) \ | |
133 | || defined(RT_STRICT) ) | |
134 | # define RTERR_STRICT_RC 1 | |
135 | #endif | |
136 | ||
137 | ||
138 | /** @def RT_SUCCESS | |
139 | * Check for success. We expect success in normal cases, that is the code path depending on | |
140 | * this check is normally taken. To prevent any prediction use RT_SUCCESS_NP instead. | |
141 | * | |
142 | * @returns true if rc indicates success. | |
143 | * @returns false if rc indicates failure. | |
144 | * | |
145 | * @param rc The iprt status code to test. | |
146 | */ | |
147 | #define RT_SUCCESS(rc) ( RT_LIKELY(RT_SUCCESS_NP(rc)) ) | |
148 | ||
149 | /** @def RT_SUCCESS_NP | |
150 | * Check for success. Don't predict the result. | |
151 | * | |
152 | * @returns true if rc indicates success. | |
153 | * @returns false if rc indicates failure. | |
154 | * | |
155 | * @param rc The iprt status code to test. | |
156 | */ | |
157 | #ifdef RTERR_STRICT_RC | |
158 | # define RT_SUCCESS_NP(rc) ( RTErrStrictType(rc).success() ) | |
159 | #else | |
160 | # define RT_SUCCESS_NP(rc) ( (int)(rc) >= VINF_SUCCESS ) | |
161 | #endif | |
162 | ||
163 | /** @def RT_FAILURE | |
164 | * Check for failure, predicting unlikely. | |
165 | * | |
166 | * We don't expect in normal cases, that is the code path depending on this | |
167 | * check is normally NOT taken. To prevent any prediction use RT_FAILURE_NP | |
168 | * instead. | |
169 | * | |
170 | * @returns true if rc indicates failure. | |
171 | * @returns false if rc indicates success. | |
172 | * | |
173 | * @param rc The iprt status code to test. | |
174 | * | |
175 | * @remarks Please structure your code to use the RT_SUCCESS() macro instead of | |
176 | * RT_FAILURE() where possible, as that gives us a better shot at good | |
177 | * code with the windows compilers. | |
178 | */ | |
179 | #define RT_FAILURE(rc) ( RT_UNLIKELY(!RT_SUCCESS_NP(rc)) ) | |
180 | ||
181 | /** @def RT_FAILURE_NP | |
182 | * Check for failure, no prediction. | |
183 | * | |
184 | * @returns true if rc indicates failure. | |
185 | * @returns false if rc indicates success. | |
186 | * | |
187 | * @param rc The iprt status code to test. | |
188 | */ | |
189 | #define RT_FAILURE_NP(rc) ( !RT_SUCCESS_NP(rc) ) | |
190 | ||
191 | RT_C_DECLS_BEGIN | |
192 | ||
193 | /** | |
194 | * Converts a Darwin HRESULT error to an iprt status code. | |
195 | * | |
196 | * @returns iprt status code. | |
197 | * @param iNativeCode HRESULT error code. | |
198 | * @remark Darwin ring-3 only. | |
199 | */ | |
200 | RTDECL(int) RTErrConvertFromDarwinCOM(int32_t iNativeCode); | |
201 | ||
202 | /** | |
203 | * Converts a Darwin IOReturn error to an iprt status code. | |
204 | * | |
205 | * @returns iprt status code. | |
206 | * @param iNativeCode IOReturn error code. | |
207 | * @remark Darwin only. | |
208 | */ | |
209 | RTDECL(int) RTErrConvertFromDarwinIO(int iNativeCode); | |
210 | ||
211 | /** | |
212 | * Converts a Darwin kern_return_t error to an iprt status code. | |
213 | * | |
214 | * @returns iprt status code. | |
215 | * @param iNativeCode kern_return_t error code. | |
216 | * @remark Darwin only. | |
217 | */ | |
218 | RTDECL(int) RTErrConvertFromDarwinKern(int iNativeCode); | |
219 | ||
220 | /** | |
221 | * Converts a Darwin error to an iprt status code. | |
222 | * | |
223 | * This will consult RTErrConvertFromDarwinKern, RTErrConvertFromDarwinIO | |
224 | * and RTErrConvertFromDarwinCOM in this order. The latter is ring-3 only as it | |
225 | * doesn't apply elsewhere. | |
226 | * | |
227 | * @returns iprt status code. | |
228 | * @param iNativeCode Darwin error code. | |
229 | * @remarks Darwin only. | |
230 | * @remarks This is recommended over RTErrConvertFromDarwinKern and RTErrConvertFromDarwinIO | |
231 | * since these are really just subsets of the same error space. | |
232 | */ | |
233 | RTDECL(int) RTErrConvertFromDarwin(int iNativeCode); | |
234 | ||
235 | /** | |
236 | * Converts errno to iprt status code. | |
237 | * | |
238 | * @returns iprt status code. | |
239 | * @param uNativeCode errno code. | |
240 | */ | |
241 | RTDECL(int) RTErrConvertFromErrno(unsigned uNativeCode); | |
242 | ||
243 | /** | |
244 | * Converts a L4 errno to a iprt status code. | |
245 | * | |
246 | * @returns iprt status code. | |
247 | * @param uNativeCode l4 errno. | |
248 | * @remark L4 only. | |
249 | */ | |
250 | RTDECL(int) RTErrConvertFromL4Errno(unsigned uNativeCode); | |
251 | ||
252 | /** | |
253 | * Converts NT status code to iprt status code. | |
254 | * | |
255 | * Needless to say, this is only available on NT and winXX targets. | |
256 | * | |
257 | * @returns iprt status code. | |
258 | * @param lNativeCode NT status code. | |
259 | * @remark Windows only. | |
260 | */ | |
261 | RTDECL(int) RTErrConvertFromNtStatus(long lNativeCode); | |
262 | ||
263 | /** | |
264 | * Converts OS/2 error code to iprt status code. | |
265 | * | |
266 | * @returns iprt status code. | |
267 | * @param uNativeCode OS/2 error code. | |
268 | * @remark OS/2 only. | |
269 | */ | |
270 | RTDECL(int) RTErrConvertFromOS2(unsigned uNativeCode); | |
271 | ||
272 | /** | |
273 | * Converts Win32 error code to iprt status code. | |
274 | * | |
275 | * @returns iprt status code. | |
276 | * @param uNativeCode Win32 error code. | |
277 | * @remark Windows only. | |
278 | */ | |
279 | RTDECL(int) RTErrConvertFromWin32(unsigned uNativeCode); | |
280 | ||
281 | /** | |
282 | * Converts an iprt status code to a errno status code. | |
283 | * | |
284 | * @returns errno status code. | |
285 | * @param iErr iprt status code. | |
286 | */ | |
287 | RTDECL(int) RTErrConvertToErrno(int iErr); | |
288 | ||
289 | #ifdef IN_RING3 | |
290 | ||
291 | /** | |
292 | * iprt status code message. | |
293 | */ | |
294 | typedef struct RTSTATUSMSG | |
295 | { | |
296 | /** Pointer to the short message string. */ | |
297 | const char *pszMsgShort; | |
298 | /** Pointer to the full message string. */ | |
299 | const char *pszMsgFull; | |
300 | /** Pointer to the define string. */ | |
301 | const char *pszDefine; | |
302 | /** Status code number. */ | |
303 | int iCode; | |
304 | } RTSTATUSMSG; | |
305 | /** Pointer to iprt status code message. */ | |
306 | typedef RTSTATUSMSG *PRTSTATUSMSG; | |
307 | /** Pointer to const iprt status code message. */ | |
308 | typedef const RTSTATUSMSG *PCRTSTATUSMSG; | |
309 | ||
310 | /** | |
311 | * Get the message structure corresponding to a given iprt status code. | |
312 | * | |
313 | * @returns Pointer to read-only message description. | |
314 | * @param rc The status code. | |
315 | */ | |
316 | RTDECL(PCRTSTATUSMSG) RTErrGet(int rc); | |
317 | ||
318 | /** | |
319 | * Get the define corresponding to a given iprt status code. | |
320 | * | |
321 | * @returns Pointer to read-only string with the \#define identifier. | |
322 | * @param rc The status code. | |
323 | */ | |
324 | #define RTErrGetDefine(rc) (RTErrGet(rc)->pszDefine) | |
325 | ||
326 | /** | |
327 | * Get the short description corresponding to a given iprt status code. | |
328 | * | |
329 | * @returns Pointer to read-only string with the description. | |
330 | * @param rc The status code. | |
331 | */ | |
332 | #define RTErrGetShort(rc) (RTErrGet(rc)->pszMsgShort) | |
333 | ||
334 | /** | |
335 | * Get the full description corresponding to a given iprt status code. | |
336 | * | |
337 | * @returns Pointer to read-only string with the description. | |
338 | * @param rc The status code. | |
339 | */ | |
340 | #define RTErrGetFull(rc) (RTErrGet(rc)->pszMsgFull) | |
341 | ||
342 | #ifdef RT_OS_WINDOWS | |
343 | /** | |
344 | * Windows error code message. | |
345 | */ | |
346 | typedef struct RTWINERRMSG | |
347 | { | |
348 | /** Pointer to the full message string. */ | |
349 | const char *pszMsgFull; | |
350 | /** Pointer to the define string. */ | |
351 | const char *pszDefine; | |
352 | /** Error code number. */ | |
353 | long iCode; | |
354 | } RTWINERRMSG; | |
355 | /** Pointer to Windows error code message. */ | |
356 | typedef RTWINERRMSG *PRTWINERRMSG; | |
357 | /** Pointer to const Windows error code message. */ | |
358 | typedef const RTWINERRMSG *PCRTWINERRMSG; | |
359 | ||
360 | /** | |
361 | * Get the message structure corresponding to a given Windows error code. | |
362 | * | |
363 | * @returns Pointer to read-only message description. | |
364 | * @param rc The status code. | |
365 | */ | |
366 | RTDECL(PCRTWINERRMSG) RTErrWinGet(long rc); | |
367 | ||
368 | /** On windows COM errors are part of the Windows error database. */ | |
369 | typedef RTWINERRMSG RTCOMERRMSG; | |
370 | ||
371 | #else /* !RT_OS_WINDOWS */ | |
372 | ||
373 | /** | |
374 | * COM/XPCOM error code message. | |
375 | */ | |
376 | typedef struct RTCOMERRMSG | |
377 | { | |
378 | /** Pointer to the full message string. */ | |
379 | const char *pszMsgFull; | |
380 | /** Pointer to the define string. */ | |
381 | const char *pszDefine; | |
382 | /** Error code number. */ | |
383 | uint32_t iCode; | |
384 | } RTCOMERRMSG; | |
385 | #endif /* !RT_OS_WINDOWS */ | |
386 | /** Pointer to a XPCOM/COM error code message. */ | |
387 | typedef RTCOMERRMSG *PRTCOMERRMSG; | |
388 | /** Pointer to const a XPCOM/COM error code message. */ | |
389 | typedef const RTCOMERRMSG *PCRTCOMERRMSG; | |
390 | ||
391 | /** | |
392 | * Get the message structure corresponding to a given COM/XPCOM error code. | |
393 | * | |
394 | * @returns Pointer to read-only message description. | |
395 | * @param rc The status code. | |
396 | */ | |
397 | RTDECL(PCRTCOMERRMSG) RTErrCOMGet(uint32_t rc); | |
398 | ||
399 | #endif /* IN_RING3 */ | |
400 | ||
401 | /** @defgroup RTERRINFO_FLAGS_XXX RTERRINFO::fFlags | |
402 | * @{ */ | |
403 | /** Custom structure (the default). */ | |
404 | #define RTERRINFO_FLAGS_T_CUSTOM UINT32_C(0) | |
405 | /** Static structure (RTERRINFOSTATIC). */ | |
406 | #define RTERRINFO_FLAGS_T_STATIC UINT32_C(1) | |
407 | /** Allocated structure (RTErrInfoAlloc). */ | |
408 | #define RTERRINFO_FLAGS_T_ALLOC UINT32_C(2) | |
409 | /** Reserved type. */ | |
410 | #define RTERRINFO_FLAGS_T_RESERVED UINT32_C(3) | |
411 | /** Type mask. */ | |
412 | #define RTERRINFO_FLAGS_T_MASK UINT32_C(3) | |
413 | /** Error info is set. */ | |
414 | #define RTERRINFO_FLAGS_SET RT_BIT_32(2) | |
415 | /** Fixed flags (magic). */ | |
416 | #define RTERRINFO_FLAGS_MAGIC UINT32_C(0xbabe0000) | |
417 | /** The bit mask for the magic value. */ | |
418 | #define RTERRINFO_FLAGS_MAGIC_MASK UINT32_C(0xffff0000) | |
419 | /** @} */ | |
420 | ||
421 | /** | |
422 | * Initializes an error info structure. | |
423 | * | |
424 | * @returns @a pErrInfo. | |
425 | * @param pErrInfo The error info structure to init. | |
426 | * @param pszMsg The message buffer. Must be at least one byte. | |
427 | * @param cbMsg The size of the message buffer. | |
428 | */ | |
429 | DECLINLINE(PRTERRINFO) RTErrInfoInit(PRTERRINFO pErrInfo, char *pszMsg, size_t cbMsg) | |
430 | { | |
431 | *pszMsg = '\0'; | |
432 | ||
433 | pErrInfo->fFlags = RTERRINFO_FLAGS_T_CUSTOM | RTERRINFO_FLAGS_MAGIC; | |
434 | pErrInfo->rc = /*VINF_SUCCESS*/ 0; | |
435 | pErrInfo->pszMsg = pszMsg; | |
436 | pErrInfo->cbMsg = cbMsg; | |
437 | pErrInfo->apvReserved[0] = NULL; | |
438 | pErrInfo->apvReserved[1] = NULL; | |
439 | ||
440 | return pErrInfo; | |
441 | } | |
442 | ||
443 | /** | |
444 | * Initialize a static error info structure. | |
445 | * | |
446 | * @returns Pointer to the core error info structure. | |
447 | * @param pStaticErrInfo The static error info structure to init. | |
448 | */ | |
449 | DECLINLINE(PRTERRINFO) RTErrInfoInitStatic(PRTERRINFOSTATIC pStaticErrInfo) | |
450 | { | |
451 | RTErrInfoInit(&pStaticErrInfo->Core, pStaticErrInfo->szMsg, sizeof(pStaticErrInfo->szMsg)); | |
452 | pStaticErrInfo->Core.fFlags = RTERRINFO_FLAGS_T_STATIC | RTERRINFO_FLAGS_MAGIC; | |
453 | return &pStaticErrInfo->Core; | |
454 | } | |
455 | ||
456 | /** | |
457 | * Allocates a error info structure with a buffer at least the given size. | |
458 | * | |
459 | * @returns Pointer to an error info structure on success, NULL on failure. | |
460 | * | |
461 | * @param cbMsg The minimum message buffer size. Use 0 to get | |
462 | * the default buffer size. | |
463 | */ | |
464 | RTDECL(PRTERRINFO) RTErrInfoAlloc(size_t cbMsg); | |
465 | ||
466 | /** | |
467 | * Same as RTErrInfoAlloc, except that an IPRT status code is returned. | |
468 | * | |
469 | * @returns IPRT status code. | |
470 | * | |
471 | * @param cbMsg The minimum message buffer size. Use 0 to get | |
472 | * the default buffer size. | |
473 | * @param ppErrInfo Where to store the pointer to the allocated | |
474 | * error info structure on success. This is | |
475 | * always set to NULL. | |
476 | */ | |
477 | RTDECL(int) RTErrInfoAllocEx(size_t cbMsg, PRTERRINFO *ppErrInfo); | |
478 | ||
479 | /** | |
480 | * Frees an error info structure allocated by RTErrInfoAlloc or | |
481 | * RTErrInfoAllocEx. | |
482 | * | |
483 | * @param pErrInfo The error info structure. | |
484 | */ | |
485 | RTDECL(void) RTErrInfoFree(PRTERRINFO pErrInfo); | |
486 | ||
487 | /** | |
488 | * Fills in the error info details. | |
489 | * | |
490 | * @returns @a rc. | |
491 | * | |
492 | * @param pErrInfo The error info structure to fill in. | |
493 | * @param rc The status code to return. | |
494 | * @param pszMsg The error message string. | |
495 | */ | |
496 | RTDECL(int) RTErrInfoSet(PRTERRINFO pErrInfo, int rc, const char *pszMsg); | |
497 | ||
498 | /** | |
499 | * Fills in the error info details, with a sprintf style message. | |
500 | * | |
501 | * @returns @a rc. | |
502 | * | |
503 | * @param pErrInfo The error info structure to fill in. | |
504 | * @param rc The status code to return. | |
505 | * @param pszFormat The format string. | |
506 | * @param ... The format arguments. | |
507 | */ | |
508 | RTDECL(int) RTErrInfoSetF(PRTERRINFO pErrInfo, int rc, const char *pszFormat, ...) RT_IPRT_FORMAT_ATTR(3, 4); | |
509 | ||
510 | /** | |
511 | * Fills in the error info details, with a vsprintf style message. | |
512 | * | |
513 | * @returns @a rc. | |
514 | * | |
515 | * @param pErrInfo The error info structure to fill in. | |
516 | * @param rc The status code to return. | |
517 | * @param pszFormat The format string. | |
518 | * @param va The format arguments. | |
519 | */ | |
520 | RTDECL(int) RTErrInfoSetV(PRTERRINFO pErrInfo, int rc, const char *pszFormat, va_list va) RT_IPRT_FORMAT_ATTR(3, 0); | |
521 | ||
522 | /** | |
523 | * Adds more error info details. | |
524 | * | |
525 | * @returns @a rc. | |
526 | * | |
527 | * @param pErrInfo The error info structure to fill in. | |
528 | * @param rc The status code to return. | |
529 | * @param pszMsg The error message string to add. | |
530 | */ | |
531 | RTDECL(int) RTErrInfoAdd(PRTERRINFO pErrInfo, int rc, const char *pszMsg); | |
532 | ||
533 | /** | |
534 | * Adds more error info details, with a sprintf style message. | |
535 | * | |
536 | * @returns @a rc. | |
537 | * | |
538 | * @param pErrInfo The error info structure to fill in. | |
539 | * @param rc The status code to return. | |
540 | * @param pszFormat The format string to add. | |
541 | * @param ... The format arguments. | |
542 | */ | |
543 | RTDECL(int) RTErrInfoAddF(PRTERRINFO pErrInfo, int rc, const char *pszFormat, ...) RT_IPRT_FORMAT_ATTR(3, 4); | |
544 | ||
545 | /** | |
546 | * Adds more error info details, with a vsprintf style message. | |
547 | * | |
548 | * @returns @a rc. | |
549 | * | |
550 | * @param pErrInfo The error info structure to fill in. | |
551 | * @param rc The status code to return. | |
552 | * @param pszFormat The format string to add. | |
553 | * @param va The format arguments. | |
554 | */ | |
555 | RTDECL(int) RTErrInfoAddV(PRTERRINFO pErrInfo, int rc, const char *pszFormat, va_list va) RT_IPRT_FORMAT_ATTR(3, 0); | |
556 | ||
6d209b23 SF |
557 | /** @name RTERRINFO_LOG_F_XXX |
558 | * @{ */ | |
559 | /** Both debug and release log. */ | |
560 | #define RTERRINFO_LOG_F_RELEASE RT_BIT_32(0) | |
561 | /** @} */ | |
562 | ||
563 | /** | |
564 | * Fills in the error info details. | |
565 | * | |
566 | * @returns @a rc. | |
567 | * | |
568 | * @param pErrInfo The error info structure to fill in. | |
569 | * @param rc The status code to return. | |
570 | * @param iLogGroup The logging group. | |
571 | * @param fFlags RTERRINFO_LOG_F_XXX. | |
572 | * @param pszMsg The error message string. | |
573 | */ | |
574 | RTDECL(int) RTErrInfoLogAndSet(PRTERRINFO pErrInfo, int rc, uint32_t iLogGroup, uint32_t fFlags, const char *pszMsg); | |
575 | ||
576 | /** | |
577 | * Fills in the error info details, with a sprintf style message. | |
578 | * | |
579 | * @returns @a rc. | |
580 | * | |
581 | * @param pErrInfo The error info structure to fill in. | |
582 | * @param rc The status code to return. | |
583 | * @param iLogGroup The logging group. | |
584 | * @param fFlags RTERRINFO_LOG_F_XXX. | |
585 | * @param pszFormat The format string. | |
586 | * @param ... The format arguments. | |
587 | */ | |
588 | RTDECL(int) RTErrInfoLogAndSetF(PRTERRINFO pErrInfo, int rc, uint32_t iLogGroup, uint32_t fFlags, const char *pszFormat, ...) RT_IPRT_FORMAT_ATTR(5, 6); | |
589 | ||
590 | /** | |
591 | * Fills in the error info details, with a vsprintf style message. | |
592 | * | |
593 | * @returns @a rc. | |
594 | * | |
595 | * @param pErrInfo The error info structure to fill in. | |
596 | * @param rc The status code to return. | |
597 | * @param iLogGroup The logging group. | |
598 | * @param fFlags RTERRINFO_LOG_F_XXX. | |
599 | * @param pszFormat The format string. | |
600 | * @param va The format arguments. | |
601 | */ | |
602 | RTDECL(int) RTErrInfoLogAndSetV(PRTERRINFO pErrInfo, int rc, uint32_t iLogGroup, uint32_t fFlags, const char *pszFormat, va_list va) RT_IPRT_FORMAT_ATTR(5, 0); | |
603 | ||
604 | /** | |
605 | * Adds more error info details. | |
606 | * | |
607 | * @returns @a rc. | |
608 | * | |
609 | * @param pErrInfo The error info structure to fill in. | |
610 | * @param rc The status code to return. | |
611 | * @param iLogGroup The logging group. | |
612 | * @param fFlags RTERRINFO_LOG_F_XXX. | |
613 | * @param pszMsg The error message string to add. | |
614 | */ | |
615 | RTDECL(int) RTErrInfoLogAndAdd(PRTERRINFO pErrInfo, int rc, uint32_t iLogGroup, uint32_t fFlags, const char *pszMsg); | |
616 | ||
617 | /** | |
618 | * Adds more error info details, with a sprintf style message. | |
619 | * | |
620 | * @returns @a rc. | |
621 | * | |
622 | * @param pErrInfo The error info structure to fill in. | |
623 | * @param rc The status code to return. | |
624 | * @param iLogGroup The logging group. | |
625 | * @param fFlags RTERRINFO_LOG_F_XXX. | |
626 | * @param pszFormat The format string to add. | |
627 | * @param ... The format arguments. | |
628 | */ | |
629 | RTDECL(int) RTErrInfoLogAndAddF(PRTERRINFO pErrInfo, int rc, uint32_t iLogGroup, uint32_t fFlags, const char *pszFormat, ...) RT_IPRT_FORMAT_ATTR(5, 6); | |
630 | ||
631 | /** | |
632 | * Adds more error info details, with a vsprintf style message. | |
633 | * | |
634 | * @returns @a rc. | |
635 | * | |
636 | * @param pErrInfo The error info structure to fill in. | |
637 | * @param rc The status code to return. | |
638 | * @param iLogGroup The logging group. | |
639 | * @param fFlags RTERRINFO_LOG_F_XXX. | |
640 | * @param pszFormat The format string to add. | |
641 | * @param va The format arguments. | |
642 | */ | |
643 | RTDECL(int) RTErrInfoLogAndAddV(PRTERRINFO pErrInfo, int rc, uint32_t iLogGroup, uint32_t fFlags, const char *pszFormat, va_list va) RT_IPRT_FORMAT_ATTR(5, 0); | |
644 | ||
645 | /** @name Macros wrapping the RTErrInfoLog* functions. | |
646 | * @{ */ | |
647 | #define RTERRINFO_LOG_SET( a_pErrInfo, a_rc, a_pszMsg) RTErrInfoLogAndSet( a_pErrInfo, a_rc, LOG_GROUP, 0, a_pszMsg) | |
648 | #define RTERRINFO_LOG_SET_V(a_pErrInfo, a_rc, a_pszMsg, a_va) RTErrInfoLogAndSetV(a_pErrInfo, a_rc, LOG_GROUP, 0, a_pszMsg, a_va) | |
649 | #define RTERRINFO_LOG_ADD( a_pErrInfo, a_rc, a_pszMsg) RTErrInfoLogAndAdd( a_pErrInfo, a_rc, LOG_GROUP, 0, a_pszMsg) | |
650 | #define RTERRINFO_LOG_ADD_V(a_pErrInfo, a_rc, a_pszMsg, a_va) RTErrInfoLogAndAddV(a_pErrInfo, a_rc, LOG_GROUP, 0, a_pszMsg, a_va) | |
651 | #ifdef RT_COMPILER_SUPPORTS_VA_ARGS | |
652 | # define RTERRINFO_LOG_ADD_F(a_pErrInfo, a_rc, ...) RTErrInfoLogAndAddF(a_pErrInfo, a_rc, LOG_GROUP, 0, __VA_ARGS__) | |
653 | # define RTERRINFO_LOG_SET_F(a_pErrInfo, a_rc, ...) RTErrInfoLogAndSetF(a_pErrInfo, a_rc, LOG_GROUP, 0, __VA_ARGS__) | |
654 | #endif | |
655 | ||
656 | #define RTERRINFO_LOG_REL_SET( a_pErrInfo, a_rc, a_pszMsg) RTErrInfoLogAndSet( a_pErrInfo, a_rc, LOG_GROUP, RTERRINFO_LOG_F_RELEASE, a_pszMsg) | |
657 | #define RTERRINFO_LOG_REL_SET_V(a_pErrInfo, a_rc, a_pszMsg, a_va) RTErrInfoLogAndSetV(a_pErrInfo, a_rc, LOG_GROUP, RTERRINFO_LOG_F_RELEASE, a_pszMsg, a_va) | |
658 | #define RTERRINFO_LOG_REL_ADD( a_pErrInfo, a_rc, a_pszMsg) RTErrInfoLogAndAdd( a_pErrInfo, a_rc, LOG_GROUP, RTERRINFO_LOG_F_RELEASE, a_pszMsg) | |
659 | #define RTERRINFO_LOG_REL_ADD_V(a_pErrInfo, a_rc, a_pszMsg, a_va) RTErrInfoLogAndAddV(a_pErrInfo, a_rc, LOG_GROUP, RTERRINFO_LOG_F_RELEASE, a_pszMsg, a_va) | |
660 | #ifdef RT_COMPILER_SUPPORTS_VA_ARGS | |
661 | # define RTERRINFO_LOG_REL_ADD_F(a_pErrInfo, a_rc, ...) RTErrInfoLogAndAddF(a_pErrInfo, a_rc, LOG_GROUP, RTERRINFO_LOG_F_RELEASE, __VA_ARGS__) | |
662 | # define RTERRINFO_LOG_REL_SET_F(a_pErrInfo, a_rc, ...) RTErrInfoLogAndSetF(a_pErrInfo, a_rc, LOG_GROUP, RTERRINFO_LOG_F_RELEASE, __VA_ARGS__) | |
663 | #else | |
664 | # define RTERRINFO_LOG_REL_ADD_F RTErrInfoSetF | |
665 | # define RTERRINFO_LOG_REL_SET_F RTErrInfoAddF | |
666 | #endif | |
667 | /** @} */ | |
668 | ||
669 | ||
056a1eb7 SF |
670 | /** |
671 | * Checks if the error info is set. | |
672 | * | |
673 | * @returns true if set, false if not. | |
674 | * @param pErrInfo The error info structure. NULL is OK. | |
675 | */ | |
676 | DECLINLINE(bool) RTErrInfoIsSet(PCRTERRINFO pErrInfo) | |
677 | { | |
678 | if (!pErrInfo) | |
679 | return false; | |
680 | return (pErrInfo->fFlags & (RTERRINFO_FLAGS_MAGIC_MASK | RTERRINFO_FLAGS_SET)) | |
681 | == (RTERRINFO_FLAGS_MAGIC | RTERRINFO_FLAGS_SET); | |
682 | } | |
683 | ||
684 | /** | |
685 | * Clears the error info structure. | |
686 | * | |
687 | * @param pErrInfo The error info structure. NULL is OK. | |
688 | */ | |
689 | DECLINLINE(void) RTErrInfoClear(PRTERRINFO pErrInfo) | |
690 | { | |
691 | if (pErrInfo) | |
692 | { | |
693 | pErrInfo->fFlags &= ~RTERRINFO_FLAGS_SET; | |
694 | pErrInfo->rc = /*VINF_SUCCESS*/0; | |
695 | *pErrInfo->pszMsg = '\0'; | |
696 | } | |
697 | } | |
698 | ||
699 | /** | |
700 | * Storage for error variables. | |
701 | * | |
702 | * @remarks Do NOT touch the members! They are platform specific and what's | |
703 | * where may change at any time! | |
704 | */ | |
705 | typedef union RTERRVARS | |
706 | { | |
707 | int8_t ai8Vars[32]; | |
708 | int16_t ai16Vars[16]; | |
709 | int32_t ai32Vars[8]; | |
710 | int64_t ai64Vars[4]; | |
711 | } RTERRVARS; | |
712 | /** Pointer to an error variable storage union. */ | |
713 | typedef RTERRVARS *PRTERRVARS; | |
714 | /** Pointer to a const error variable storage union. */ | |
715 | typedef RTERRVARS const *PCRTERRVARS; | |
716 | ||
717 | /** | |
718 | * Saves the error variables. | |
719 | * | |
720 | * @returns @a pVars. | |
721 | * @param pVars The variable storage union. | |
722 | */ | |
723 | RTDECL(PRTERRVARS) RTErrVarsSave(PRTERRVARS pVars); | |
724 | ||
725 | /** | |
726 | * Restores the error variables. | |
727 | * | |
728 | * @param pVars The variable storage union. | |
729 | */ | |
730 | RTDECL(void) RTErrVarsRestore(PCRTERRVARS pVars); | |
731 | ||
732 | /** | |
733 | * Checks if the first variable set equals the second. | |
734 | * | |
735 | * @returns true if they are equal, false if not. | |
736 | * @param pVars1 The first variable storage union. | |
737 | * @param pVars2 The second variable storage union. | |
738 | */ | |
739 | RTDECL(bool) RTErrVarsAreEqual(PCRTERRVARS pVars1, PCRTERRVARS pVars2); | |
740 | ||
741 | /** | |
742 | * Checks if the (live) error variables have changed since we saved them. | |
743 | * | |
744 | * @returns @c true if they have changed, @c false if not. | |
745 | * @param pVars The saved variables to compare the current state | |
746 | * against. | |
747 | */ | |
748 | RTDECL(bool) RTErrVarsHaveChanged(PCRTERRVARS pVars); | |
749 | ||
750 | RT_C_DECLS_END | |
751 | ||
752 | /** @} */ | |
753 | ||
754 | /** @name Status Code Ranges | |
755 | * @{ */ | |
756 | /** The first status code in the primary IPRT range. */ | |
757 | #define RTERR_RANGE1_FIRST 0 | |
758 | /** The last status code in the primary IPRT range. */ | |
759 | #define RTERR_RANGE1_LAST 999 | |
760 | ||
761 | /** The first status code in the secondary IPRT range. */ | |
762 | #define RTERR_RANGE2_FIRST 22000 | |
763 | /** The last status code in the secondary IPRT range. */ | |
764 | #define RTERR_RANGE2_LAST 32766 | |
765 | ||
766 | /** The first status code in the user range. */ | |
767 | #define RTERR_USER_FIRST 1000 | |
768 | /** The last status code in the user range. */ | |
769 | #define RTERR_USER_LAST 21999 | |
770 | /** @} */ | |
771 | ||
772 | ||
773 | /* SED-START */ | |
774 | ||
775 | /** @name Misc. Status Codes | |
776 | * @{ | |
777 | */ | |
778 | /** Success. */ | |
779 | #define VINF_SUCCESS 0 | |
780 | ||
781 | /** General failure - DON'T USE THIS!!! */ | |
782 | #define VERR_GENERAL_FAILURE (-1) | |
783 | /** Invalid parameter. */ | |
784 | #define VERR_INVALID_PARAMETER (-2) | |
785 | /** Invalid parameter. */ | |
786 | #define VWRN_INVALID_PARAMETER 2 | |
787 | /** Invalid magic or cookie. */ | |
788 | #define VERR_INVALID_MAGIC (-3) | |
789 | /** Invalid magic or cookie. */ | |
790 | #define VWRN_INVALID_MAGIC 3 | |
791 | /** Invalid loader handle. */ | |
792 | #define VERR_INVALID_HANDLE (-4) | |
793 | /** Invalid loader handle. */ | |
794 | #define VWRN_INVALID_HANDLE 4 | |
795 | /** Failed to lock the address range. */ | |
796 | #define VERR_LOCK_FAILED (-5) | |
797 | /** Invalid memory pointer. */ | |
798 | #define VERR_INVALID_POINTER (-6) | |
799 | /** Failed to patch the IDT. */ | |
800 | #define VERR_IDT_FAILED (-7) | |
801 | /** Memory allocation failed. */ | |
802 | #define VERR_NO_MEMORY (-8) | |
803 | /** Already loaded. */ | |
804 | #define VERR_ALREADY_LOADED (-9) | |
805 | /** Permission denied. */ | |
806 | #define VERR_PERMISSION_DENIED (-10) | |
807 | /** Permission denied. */ | |
808 | #define VINF_PERMISSION_DENIED 10 | |
809 | /** Version mismatch. */ | |
810 | #define VERR_VERSION_MISMATCH (-11) | |
811 | /** The request function is not implemented. */ | |
812 | #define VERR_NOT_IMPLEMENTED (-12) | |
813 | /** Invalid flags was given. */ | |
814 | #define VERR_INVALID_FLAGS (-13) | |
815 | ||
816 | /** Not equal. */ | |
817 | #define VERR_NOT_EQUAL (-18) | |
818 | /** The specified path does not point at a symbolic link. */ | |
819 | #define VERR_NOT_SYMLINK (-19) | |
820 | /** Failed to allocate temporary memory. */ | |
821 | #define VERR_NO_TMP_MEMORY (-20) | |
822 | /** Invalid file mode mask (RTFMODE). */ | |
823 | #define VERR_INVALID_FMODE (-21) | |
824 | /** Incorrect call order. */ | |
825 | #define VERR_WRONG_ORDER (-22) | |
826 | /** There is no TLS (thread local storage) available for storing the current thread. */ | |
827 | #define VERR_NO_TLS_FOR_SELF (-23) | |
828 | /** Failed to set the TLS (thread local storage) entry which points to our thread structure. */ | |
829 | #define VERR_FAILED_TO_SET_SELF_TLS (-24) | |
830 | /** Not able to allocate contiguous memory. */ | |
831 | #define VERR_NO_CONT_MEMORY (-26) | |
832 | /** No memory available for page table or page directory. */ | |
833 | #define VERR_NO_PAGE_MEMORY (-27) | |
834 | /** Already initialized. */ | |
835 | #define VINF_ALREADY_INITIALIZED 28 | |
836 | /** The specified thread is dead. */ | |
837 | #define VERR_THREAD_IS_DEAD (-29) | |
838 | /** The specified thread is not waitable. */ | |
839 | #define VERR_THREAD_NOT_WAITABLE (-30) | |
840 | /** Pagetable not present. */ | |
841 | #define VERR_PAGE_TABLE_NOT_PRESENT (-31) | |
842 | /** Invalid context. | |
843 | * Typically an API was used by the wrong thread. */ | |
844 | #define VERR_INVALID_CONTEXT (-32) | |
845 | /** The per process timer is busy. */ | |
846 | #define VERR_TIMER_BUSY (-33) | |
847 | /** Address conflict. */ | |
848 | #define VERR_ADDRESS_CONFLICT (-34) | |
849 | /** Unresolved (unknown) host platform error. */ | |
850 | #define VERR_UNRESOLVED_ERROR (-35) | |
851 | /** Invalid function. */ | |
852 | #define VERR_INVALID_FUNCTION (-36) | |
853 | /** Not supported. */ | |
854 | #define VERR_NOT_SUPPORTED (-37) | |
855 | /** Not supported. */ | |
856 | #define VINF_NOT_SUPPORTED 37 | |
857 | /** Access denied. */ | |
858 | #define VERR_ACCESS_DENIED (-38) | |
859 | /** Call interrupted. */ | |
860 | #define VERR_INTERRUPTED (-39) | |
861 | /** Call interrupted. */ | |
862 | #define VINF_INTERRUPTED 39 | |
863 | /** Timeout. */ | |
864 | #define VERR_TIMEOUT (-40) | |
865 | /** Timeout. */ | |
866 | #define VINF_TIMEOUT 40 | |
867 | /** Buffer too small to save result. */ | |
868 | #define VERR_BUFFER_OVERFLOW (-41) | |
869 | /** Buffer too small to save result. */ | |
870 | #define VINF_BUFFER_OVERFLOW 41 | |
871 | /** Data size overflow. */ | |
872 | #define VERR_TOO_MUCH_DATA (-42) | |
873 | /** Max threads number reached. */ | |
874 | #define VERR_MAX_THRDS_REACHED (-43) | |
875 | /** Max process number reached. */ | |
876 | #define VERR_MAX_PROCS_REACHED (-44) | |
877 | /** The recipient process has refused the signal. */ | |
878 | #define VERR_SIGNAL_REFUSED (-45) | |
879 | /** A signal is already pending. */ | |
880 | #define VERR_SIGNAL_PENDING (-46) | |
881 | /** The signal being posted is not correct. */ | |
882 | #define VERR_SIGNAL_INVALID (-47) | |
883 | /** The state changed. | |
884 | * This is a generic error message and needs a context to make sense. */ | |
885 | #define VERR_STATE_CHANGED (-48) | |
886 | /** Warning, the state changed. | |
887 | * This is a generic error message and needs a context to make sense. */ | |
888 | #define VWRN_STATE_CHANGED 48 | |
889 | /** Error while parsing UUID string */ | |
890 | #define VERR_INVALID_UUID_FORMAT (-49) | |
891 | /** The specified process was not found. */ | |
892 | #define VERR_PROCESS_NOT_FOUND (-50) | |
893 | /** The process specified to a non-block wait had not exited. */ | |
894 | #define VERR_PROCESS_RUNNING (-51) | |
895 | /** Retry the operation. */ | |
896 | #define VERR_TRY_AGAIN (-52) | |
897 | /** Retry the operation. */ | |
898 | #define VINF_TRY_AGAIN 52 | |
899 | /** Generic parse error. */ | |
900 | #define VERR_PARSE_ERROR (-53) | |
901 | /** Value out of range. */ | |
902 | #define VERR_OUT_OF_RANGE (-54) | |
903 | /** A numeric conversion encountered a value which was too big for the target. */ | |
904 | #define VERR_NUMBER_TOO_BIG (-55) | |
905 | /** A numeric conversion encountered a value which was too big for the target. */ | |
906 | #define VWRN_NUMBER_TOO_BIG 55 | |
907 | /** The number begin converted (string) contained no digits. */ | |
908 | #define VERR_NO_DIGITS (-56) | |
909 | /** The number begin converted (string) contained no digits. */ | |
910 | #define VWRN_NO_DIGITS 56 | |
911 | /** Encountered a '-' during conversion to an unsigned value. */ | |
912 | #define VERR_NEGATIVE_UNSIGNED (-57) | |
913 | /** Encountered a '-' during conversion to an unsigned value. */ | |
914 | #define VWRN_NEGATIVE_UNSIGNED 57 | |
915 | /** Error while characters translation (unicode and so). */ | |
916 | #define VERR_NO_TRANSLATION (-58) | |
917 | /** Error while characters translation (unicode and so). */ | |
918 | #define VWRN_NO_TRANSLATION 58 | |
919 | /** Encountered unicode code point which is reserved for use as endian indicator (0xffff or 0xfffe). */ | |
920 | #define VERR_CODE_POINT_ENDIAN_INDICATOR (-59) | |
921 | /** Encountered unicode code point in the surrogate range (0xd800 to 0xdfff). */ | |
922 | #define VERR_CODE_POINT_SURROGATE (-60) | |
923 | /** A string claiming to be UTF-8 is incorrectly encoded. */ | |
924 | #define VERR_INVALID_UTF8_ENCODING (-61) | |
925 | /** A string claiming to be in UTF-16 is incorrectly encoded. */ | |
926 | #define VERR_INVALID_UTF16_ENCODING (-62) | |
927 | /** Encountered a unicode code point which cannot be represented as UTF-16. */ | |
928 | #define VERR_CANT_RECODE_AS_UTF16 (-63) | |
929 | /** Got an out of memory condition trying to allocate a string. */ | |
930 | #define VERR_NO_STR_MEMORY (-64) | |
931 | /** Got an out of memory condition trying to allocate a UTF-16 (/UCS-2) string. */ | |
932 | #define VERR_NO_UTF16_MEMORY (-65) | |
933 | /** Get an out of memory condition trying to allocate a code point array. */ | |
934 | #define VERR_NO_CODE_POINT_MEMORY (-66) | |
935 | /** Can't free the memory because it's used in mapping. */ | |
936 | #define VERR_MEMORY_BUSY (-67) | |
937 | /** The timer can't be started because it's already active. */ | |
938 | #define VERR_TIMER_ACTIVE (-68) | |
939 | /** The timer can't be stopped because it's already suspended. */ | |
940 | #define VERR_TIMER_SUSPENDED (-69) | |
941 | /** The operation was cancelled by the user (copy) or another thread (local ipc). */ | |
942 | #define VERR_CANCELLED (-70) | |
943 | /** Failed to initialize a memory object. | |
944 | * Exactly what this means is OS specific. */ | |
945 | #define VERR_MEMOBJ_INIT_FAILED (-71) | |
946 | /** Out of memory condition when allocating memory with low physical backing. */ | |
947 | #define VERR_NO_LOW_MEMORY (-72) | |
948 | /** Out of memory condition when allocating physical memory (without mapping). */ | |
949 | #define VERR_NO_PHYS_MEMORY (-73) | |
950 | /** The address (virtual or physical) is too big. */ | |
951 | #define VERR_ADDRESS_TOO_BIG (-74) | |
952 | /** Failed to map a memory object. */ | |
953 | #define VERR_MAP_FAILED (-75) | |
954 | /** Trailing characters. */ | |
955 | #define VERR_TRAILING_CHARS (-76) | |
956 | /** Trailing characters. */ | |
957 | #define VWRN_TRAILING_CHARS 76 | |
958 | /** Trailing spaces. */ | |
959 | #define VERR_TRAILING_SPACES (-77) | |
960 | /** Trailing spaces. */ | |
961 | #define VWRN_TRAILING_SPACES 77 | |
962 | /** Generic not found error. */ | |
963 | #define VERR_NOT_FOUND (-78) | |
964 | /** Generic not found warning. */ | |
965 | #define VWRN_NOT_FOUND 78 | |
966 | /** Generic invalid state error. */ | |
967 | #define VERR_INVALID_STATE (-79) | |
968 | /** Generic invalid state warning. */ | |
969 | #define VWRN_INVALID_STATE 79 | |
970 | /** Generic out of resources error. */ | |
971 | #define VERR_OUT_OF_RESOURCES (-80) | |
972 | /** Generic out of resources warning. */ | |
973 | #define VWRN_OUT_OF_RESOURCES 80 | |
974 | /** No more handles available, too many open handles. */ | |
975 | #define VERR_NO_MORE_HANDLES (-81) | |
976 | /** Preemption is disabled. | |
977 | * The requested operation can only be performed when preemption is enabled. */ | |
978 | #define VERR_PREEMPT_DISABLED (-82) | |
979 | /** End of string. */ | |
980 | #define VERR_END_OF_STRING (-83) | |
981 | /** End of string. */ | |
982 | #define VINF_END_OF_STRING 83 | |
983 | /** A page count is out of range. */ | |
984 | #define VERR_PAGE_COUNT_OUT_OF_RANGE (-84) | |
985 | /** Generic object destroyed status. */ | |
986 | #define VERR_OBJECT_DESTROYED (-85) | |
987 | /** Generic object was destroyed by the call status. */ | |
988 | #define VINF_OBJECT_DESTROYED 85 | |
989 | /** Generic dangling objects status. */ | |
990 | #define VERR_DANGLING_OBJECTS (-86) | |
991 | /** Generic dangling objects status. */ | |
992 | #define VWRN_DANGLING_OBJECTS 86 | |
993 | /** Invalid Base64 encoding. */ | |
994 | #define VERR_INVALID_BASE64_ENCODING (-87) | |
995 | /** Return instigated by a callback or similar. */ | |
996 | #define VERR_CALLBACK_RETURN (-88) | |
997 | /** Return instigated by a callback or similar. */ | |
998 | #define VINF_CALLBACK_RETURN 88 | |
999 | /** Authentication failure. */ | |
1000 | #define VERR_AUTHENTICATION_FAILURE (-89) | |
1001 | /** Not a power of two. */ | |
1002 | #define VERR_NOT_POWER_OF_TWO (-90) | |
1003 | /** Status code, typically given as a parameter, that isn't supposed to be used. */ | |
1004 | #define VERR_IGNORED (-91) | |
1005 | /** Concurrent access to the object is not allowed. */ | |
1006 | #define VERR_CONCURRENT_ACCESS (-92) | |
1007 | /** The caller does not have a reference to the object. | |
1008 | * This status is used when two threads is caught sharing the same object | |
1009 | * reference. */ | |
1010 | #define VERR_CALLER_NO_REFERENCE (-93) | |
1011 | /** Generic no change error. */ | |
1012 | #define VERR_NO_CHANGE (-95) | |
1013 | /** Generic no change info. */ | |
1014 | #define VINF_NO_CHANGE 95 | |
1015 | /** Out of memory condition when allocating executable memory. */ | |
1016 | #define VERR_NO_EXEC_MEMORY (-96) | |
1017 | /** The alignment is not supported. */ | |
1018 | #define VERR_UNSUPPORTED_ALIGNMENT (-97) | |
1019 | /** The alignment is not really supported, however we got lucky with this | |
1020 | * allocation. */ | |
1021 | #define VINF_UNSUPPORTED_ALIGNMENT 97 | |
1022 | /** Duplicate something. */ | |
1023 | #define VERR_DUPLICATE (-98) | |
1024 | /** Something is missing. */ | |
1025 | #define VERR_MISSING (-99) | |
1026 | /** An unexpected (/unknown) exception was caught. */ | |
1027 | #define VERR_UNEXPECTED_EXCEPTION (-22400) | |
1028 | /** Buffer underflow. */ | |
1029 | #define VERR_BUFFER_UNDERFLOW (-22401) | |
1030 | /** Buffer underflow. */ | |
1031 | #define VINF_BUFFER_UNDERFLOW 22401 | |
1032 | /** Uneven input. */ | |
1033 | #define VERR_UNEVEN_INPUT (-22402) | |
1034 | /** Something is not available or not working properly. */ | |
1035 | #define VERR_NOT_AVAILABLE (-22403) | |
1036 | /** The RTPROC_FLAGS_DETACHED flag isn't supported. */ | |
1037 | #define VERR_PROC_DETACH_NOT_SUPPORTED (-22404) | |
1038 | /** An account is restricted in a certain way. */ | |
1039 | #define VERR_ACCOUNT_RESTRICTED (-22405) | |
1040 | /** An account is restricted in a certain way. */ | |
1041 | #define VINF_ACCOUNT_RESTRICTED 22405 | |
1042 | /** Not able satisfy all the requirements of the request. */ | |
1043 | #define VERR_UNABLE_TO_SATISFY_REQUIREMENTS (-22406) | |
1044 | /** Not able satisfy all the requirements of the request. */ | |
1045 | #define VWRN_UNABLE_TO_SATISFY_REQUIREMENTS 22406 | |
1046 | /** The requested allocation is too big. */ | |
1047 | #define VERR_ALLOCATION_TOO_BIG (-22407) | |
1048 | /** Mismatch. */ | |
1049 | #define VERR_MISMATCH (-22408) | |
1050 | /** Wrong type. */ | |
1051 | #define VERR_WRONG_TYPE (-22409) | |
1052 | /** This indicates that the process does not have sufficient privileges to | |
1053 | * perform the operation. */ | |
1054 | #define VERR_PRIVILEGE_NOT_HELD (-22410) | |
1055 | /** Process does not have the trusted code base (TCB) privilege needed for user | |
1056 | * authentication or/and process creation as a given user. TCB is also called | |
1057 | * 'Act as part of the operating system'. */ | |
1058 | #define VERR_PROC_TCB_PRIV_NOT_HELD (-22411) | |
1059 | /** Process does not have the assign primary token (APT) privilege needed | |
1060 | * for creating process as a given user. APT is also called 'Replace a process | |
1061 | * level token'. */ | |
1062 | #define VERR_PROC_APT_PRIV_NOT_HELD (-22412) | |
1063 | /** Process does not have the increase quota (IQ) privilege needed for | |
1064 | * creating a process as a given user. IQ is also called 'Increase quotas'. */ | |
1065 | #define VERR_PROC_IQ_PRIV_NOT_HELD (-22413) | |
1066 | /** The system has too many CPUs. */ | |
1067 | #define VERR_MP_TOO_MANY_CPUS (-22414) | |
1068 | /** @} */ | |
1069 | ||
1070 | ||
1071 | /** @name Common File/Disk/Pipe/etc Status Codes | |
1072 | * @{ | |
1073 | */ | |
1074 | /** Unresolved (unknown) file i/o error. */ | |
1075 | #define VERR_FILE_IO_ERROR (-100) | |
1076 | /** File/Device open failed. */ | |
1077 | #define VERR_OPEN_FAILED (-101) | |
1078 | /** File not found. */ | |
1079 | #define VERR_FILE_NOT_FOUND (-102) | |
1080 | /** Path not found. */ | |
1081 | #define VERR_PATH_NOT_FOUND (-103) | |
1082 | /** Invalid (malformed) file/path name. */ | |
1083 | #define VERR_INVALID_NAME (-104) | |
1084 | /** The object in question already exists. */ | |
1085 | #define VERR_ALREADY_EXISTS (-105) | |
1086 | /** The object in question already exists. */ | |
1087 | #define VWRN_ALREADY_EXISTS 105 | |
1088 | /** Too many open files. */ | |
1089 | #define VERR_TOO_MANY_OPEN_FILES (-106) | |
1090 | /** Seek error. */ | |
1091 | #define VERR_SEEK (-107) | |
1092 | /** Seek below file start. */ | |
1093 | #define VERR_NEGATIVE_SEEK (-108) | |
1094 | /** Trying to seek on device. */ | |
1095 | #define VERR_SEEK_ON_DEVICE (-109) | |
1096 | /** Reached the end of the file. */ | |
1097 | #define VERR_EOF (-110) | |
1098 | /** Reached the end of the file. */ | |
1099 | #define VINF_EOF 110 | |
1100 | /** Generic file read error. */ | |
1101 | #define VERR_READ_ERROR (-111) | |
1102 | /** Generic file write error. */ | |
1103 | #define VERR_WRITE_ERROR (-112) | |
1104 | /** Write protect error. */ | |
1105 | #define VERR_WRITE_PROTECT (-113) | |
1106 | /** Sharing violation, file is being used by another process. */ | |
1107 | #define VERR_SHARING_VIOLATION (-114) | |
1108 | /** Unable to lock a region of a file. */ | |
1109 | #define VERR_FILE_LOCK_FAILED (-115) | |
1110 | /** File access error, another process has locked a portion of the file. */ | |
1111 | #define VERR_FILE_LOCK_VIOLATION (-116) | |
1112 | /** File or directory can't be created. */ | |
1113 | #define VERR_CANT_CREATE (-117) | |
1114 | /** Directory can't be deleted. */ | |
1115 | #define VERR_CANT_DELETE_DIRECTORY (-118) | |
1116 | /** Can't move file to another disk. */ | |
1117 | #define VERR_NOT_SAME_DEVICE (-119) | |
1118 | /** The filename or extension is too long. */ | |
1119 | #define VERR_FILENAME_TOO_LONG (-120) | |
1120 | /** Media not present in drive. */ | |
1121 | #define VERR_MEDIA_NOT_PRESENT (-121) | |
1122 | /** The type of media was not recognized. Not formatted? */ | |
1123 | #define VERR_MEDIA_NOT_RECOGNIZED (-122) | |
1124 | /** Can't unlock - region was not locked. */ | |
1125 | #define VERR_FILE_NOT_LOCKED (-123) | |
1126 | /** Unrecoverable error: lock was lost. */ | |
1127 | #define VERR_FILE_LOCK_LOST (-124) | |
1128 | /** Can't delete directory with files. */ | |
1129 | #define VERR_DIR_NOT_EMPTY (-125) | |
1130 | /** A directory operation was attempted on a non-directory object. */ | |
1131 | #define VERR_NOT_A_DIRECTORY (-126) | |
1132 | /** A non-directory operation was attempted on a directory object. */ | |
1133 | #define VERR_IS_A_DIRECTORY (-127) | |
1134 | /** Tried to grow a file beyond the limit imposed by the process or the filesystem. */ | |
1135 | #define VERR_FILE_TOO_BIG (-128) | |
1136 | /** No pending request the aio context has to wait for completion. */ | |
1137 | #define VERR_FILE_AIO_NO_REQUEST (-129) | |
1138 | /** The request could not be canceled or prepared for another transfer | |
1139 | * because it is still in progress. */ | |
1140 | #define VERR_FILE_AIO_IN_PROGRESS (-130) | |
1141 | /** The request could not be canceled because it already completed. */ | |
1142 | #define VERR_FILE_AIO_COMPLETED (-131) | |
1143 | /** The I/O context couldn't be destroyed because there are still pending requests. */ | |
1144 | #define VERR_FILE_AIO_BUSY (-132) | |
1145 | /** The requests couldn't be submitted because that would exceed the capacity of the context. */ | |
1146 | #define VERR_FILE_AIO_LIMIT_EXCEEDED (-133) | |
1147 | /** The request was canceled. */ | |
1148 | #define VERR_FILE_AIO_CANCELED (-134) | |
1149 | /** The request wasn't submitted so it can't be canceled. */ | |
1150 | #define VERR_FILE_AIO_NOT_SUBMITTED (-135) | |
1151 | /** A request was not prepared and thus could not be submitted. */ | |
1152 | #define VERR_FILE_AIO_NOT_PREPARED (-136) | |
1153 | /** Not all requests could be submitted due to resource shortage. */ | |
1154 | #define VERR_FILE_AIO_INSUFFICIENT_RESSOURCES (-137) | |
1155 | /** Device or resource is busy. */ | |
1156 | #define VERR_RESOURCE_BUSY (-138) | |
1157 | /** A file operation was attempted on a non-file object. */ | |
1158 | #define VERR_NOT_A_FILE (-139) | |
1159 | /** A non-file operation was attempted on a file object. */ | |
1160 | #define VERR_IS_A_FILE (-140) | |
1161 | /** Unexpected filesystem object type. */ | |
1162 | #define VERR_UNEXPECTED_FS_OBJ_TYPE (-141) | |
1163 | /** A path does not start with a root specification. */ | |
1164 | #define VERR_PATH_DOES_NOT_START_WITH_ROOT (-142) | |
1165 | /** A path is relative, expected an absolute path. */ | |
1166 | #define VERR_PATH_IS_RELATIVE (-143) | |
1167 | /** A path is not relative (start with root), expected an relative path. */ | |
1168 | #define VERR_PATH_IS_NOT_RELATIVE (-144) | |
1169 | /** Zero length path. */ | |
1170 | #define VERR_PATH_ZERO_LENGTH (-145) | |
1171 | /** There are not enough events available on the host to create the I/O context. | |
1172 | * This exact meaning is host platform dependent. */ | |
1173 | #define VERR_FILE_AIO_INSUFFICIENT_EVENTS (-146) | |
1174 | /** @} */ | |
1175 | ||
1176 | ||
1177 | /** @name Generic Filesystem I/O Status Codes | |
1178 | * @{ | |
1179 | */ | |
1180 | /** Unresolved (unknown) disk i/o error. */ | |
1181 | #define VERR_DISK_IO_ERROR (-150) | |
1182 | /** Invalid drive number. */ | |
1183 | #define VERR_INVALID_DRIVE (-151) | |
1184 | /** Disk is full. */ | |
1185 | #define VERR_DISK_FULL (-152) | |
1186 | /** Disk was changed. */ | |
1187 | #define VERR_DISK_CHANGE (-153) | |
1188 | /** Drive is locked. */ | |
1189 | #define VERR_DRIVE_LOCKED (-154) | |
1190 | /** The specified disk or diskette cannot be accessed. */ | |
1191 | #define VERR_DISK_INVALID_FORMAT (-155) | |
1192 | /** Too many symbolic links. */ | |
1193 | #define VERR_TOO_MANY_SYMLINKS (-156) | |
1194 | /** The OS does not support setting the time stamps on a symbolic link. */ | |
1195 | #define VERR_NS_SYMLINK_SET_TIME (-157) | |
1196 | /** The OS does not support changing the owner of a symbolic link. */ | |
1197 | #define VERR_NS_SYMLINK_CHANGE_OWNER (-158) | |
6d209b23 SF |
1198 | /** Symbolic link not allowed. */ |
1199 | #define VERR_SYMLINK_NOT_ALLOWED (-159) | |
056a1eb7 SF |
1200 | /** @} */ |
1201 | ||
1202 | ||
1203 | /** @name Generic Directory Enumeration Status Codes | |
1204 | * @{ | |
1205 | */ | |
1206 | /** Unresolved (unknown) search error. */ | |
1207 | #define VERR_SEARCH_ERROR (-200) | |
1208 | /** No more files found. */ | |
1209 | #define VERR_NO_MORE_FILES (-201) | |
1210 | /** No more search handles available. */ | |
1211 | #define VERR_NO_MORE_SEARCH_HANDLES (-202) | |
1212 | /** RTDirReadEx() failed to retrieve the extra data which was requested. */ | |
1213 | #define VWRN_NO_DIRENT_INFO 203 | |
1214 | /** @} */ | |
1215 | ||
1216 | ||
1217 | /** @name Internal Processing Errors | |
1218 | * @{ | |
1219 | */ | |
1220 | /** Internal error - this should never happen. */ | |
1221 | #define VERR_INTERNAL_ERROR (-225) | |
1222 | /** Internal error no. 2. */ | |
1223 | #define VERR_INTERNAL_ERROR_2 (-226) | |
1224 | /** Internal error no. 3. */ | |
1225 | #define VERR_INTERNAL_ERROR_3 (-227) | |
1226 | /** Internal error no. 4. */ | |
1227 | #define VERR_INTERNAL_ERROR_4 (-228) | |
1228 | /** Internal error no. 5. */ | |
1229 | #define VERR_INTERNAL_ERROR_5 (-229) | |
1230 | /** Internal error: Unexpected status code. */ | |
1231 | #define VERR_IPE_UNEXPECTED_STATUS (-230) | |
1232 | /** Internal error: Unexpected status code. */ | |
1233 | #define VERR_IPE_UNEXPECTED_INFO_STATUS (-231) | |
1234 | /** Internal error: Unexpected status code. */ | |
1235 | #define VERR_IPE_UNEXPECTED_ERROR_STATUS (-232) | |
1236 | /** Internal error: Uninitialized status code. | |
1237 | * @remarks This is used by value elsewhere. */ | |
1238 | #define VERR_IPE_UNINITIALIZED_STATUS (-233) | |
1239 | /** Internal error: Supposedly unreachable default case in a switch. */ | |
1240 | #define VERR_IPE_NOT_REACHED_DEFAULT_CASE (-234) | |
1241 | /** @} */ | |
1242 | ||
1243 | ||
1244 | /** @name Generic Device I/O Status Codes | |
1245 | * @{ | |
1246 | */ | |
1247 | /** Unresolved (unknown) device i/o error. */ | |
1248 | #define VERR_DEV_IO_ERROR (-250) | |
1249 | /** Device i/o: Bad unit. */ | |
1250 | #define VERR_IO_BAD_UNIT (-251) | |
1251 | /** Device i/o: Not ready. */ | |
1252 | #define VERR_IO_NOT_READY (-252) | |
1253 | /** Device i/o: Bad command. */ | |
1254 | #define VERR_IO_BAD_COMMAND (-253) | |
1255 | /** Device i/o: CRC error. */ | |
1256 | #define VERR_IO_CRC (-254) | |
1257 | /** Device i/o: Bad length. */ | |
1258 | #define VERR_IO_BAD_LENGTH (-255) | |
1259 | /** Device i/o: Sector not found. */ | |
1260 | #define VERR_IO_SECTOR_NOT_FOUND (-256) | |
1261 | /** Device i/o: General failure. */ | |
1262 | #define VERR_IO_GEN_FAILURE (-257) | |
1263 | /** @} */ | |
1264 | ||
1265 | ||
1266 | /** @name Generic Pipe I/O Status Codes | |
1267 | * @{ | |
1268 | */ | |
1269 | /** Unresolved (unknown) pipe i/o error. */ | |
1270 | #define VERR_PIPE_IO_ERROR (-300) | |
1271 | /** Broken pipe. */ | |
1272 | #define VERR_BROKEN_PIPE (-301) | |
1273 | /** Bad pipe. */ | |
1274 | #define VERR_BAD_PIPE (-302) | |
1275 | /** Pipe is busy. */ | |
1276 | #define VERR_PIPE_BUSY (-303) | |
1277 | /** No data in pipe. */ | |
1278 | #define VERR_NO_DATA (-304) | |
1279 | /** Pipe is not connected. */ | |
1280 | #define VERR_PIPE_NOT_CONNECTED (-305) | |
1281 | /** More data available in pipe. */ | |
1282 | #define VERR_MORE_DATA (-306) | |
1283 | /** Expected read pipe, got a write pipe instead. */ | |
1284 | #define VERR_PIPE_NOT_READ (-307) | |
1285 | /** Expected write pipe, got a read pipe instead. */ | |
1286 | #define VERR_PIPE_NOT_WRITE (-308) | |
1287 | /** @} */ | |
1288 | ||
1289 | ||
1290 | /** @name Generic Semaphores Status Codes | |
1291 | * @{ | |
1292 | */ | |
1293 | /** Unresolved (unknown) semaphore error. */ | |
1294 | #define VERR_SEM_ERROR (-350) | |
1295 | /** Too many semaphores. */ | |
1296 | #define VERR_TOO_MANY_SEMAPHORES (-351) | |
1297 | /** Exclusive semaphore is owned by another process. */ | |
1298 | #define VERR_EXCL_SEM_ALREADY_OWNED (-352) | |
1299 | /** The semaphore is set and cannot be closed. */ | |
1300 | #define VERR_SEM_IS_SET (-353) | |
1301 | /** The semaphore cannot be set again. */ | |
1302 | #define VERR_TOO_MANY_SEM_REQUESTS (-354) | |
1303 | /** Attempt to release mutex not owned by caller. */ | |
1304 | #define VERR_NOT_OWNER (-355) | |
1305 | /** The semaphore has been opened too many times. */ | |
1306 | #define VERR_TOO_MANY_OPENS (-356) | |
1307 | /** The maximum posts for the event semaphore has been reached. */ | |
1308 | #define VERR_TOO_MANY_POSTS (-357) | |
1309 | /** The event semaphore has already been posted. */ | |
1310 | #define VERR_ALREADY_POSTED (-358) | |
1311 | /** The event semaphore has already been reset. */ | |
1312 | #define VERR_ALREADY_RESET (-359) | |
1313 | /** The semaphore is in use. */ | |
1314 | #define VERR_SEM_BUSY (-360) | |
1315 | /** The previous ownership of this semaphore has ended. */ | |
1316 | #define VERR_SEM_OWNER_DIED (-361) | |
1317 | /** Failed to open semaphore by name - not found. */ | |
1318 | #define VERR_SEM_NOT_FOUND (-362) | |
1319 | /** Semaphore destroyed while waiting. */ | |
1320 | #define VERR_SEM_DESTROYED (-363) | |
1321 | /** Nested ownership requests are not permitted for this semaphore type. */ | |
1322 | #define VERR_SEM_NESTED (-364) | |
1323 | /** The release call only release a semaphore nesting, i.e. the caller is still | |
1324 | * holding the semaphore. */ | |
1325 | #define VINF_SEM_NESTED (364) | |
1326 | /** Deadlock detected. */ | |
1327 | #define VERR_DEADLOCK (-365) | |
1328 | /** Ping-Pong listen or speak out of turn error. */ | |
1329 | #define VERR_SEM_OUT_OF_TURN (-366) | |
1330 | /** Tried to take a semaphore in a bad context. */ | |
1331 | #define VERR_SEM_BAD_CONTEXT (-367) | |
1332 | /** Don't spin for the semaphore, but it is safe to try grab it. */ | |
1333 | #define VINF_SEM_BAD_CONTEXT (367) | |
1334 | /** Wrong locking order detected. */ | |
1335 | #define VERR_SEM_LV_WRONG_ORDER (-368) | |
1336 | /** Wrong release order detected. */ | |
1337 | #define VERR_SEM_LV_WRONG_RELEASE_ORDER (-369) | |
1338 | /** Attempt to recursively enter a non-recursive lock. */ | |
1339 | #define VERR_SEM_LV_NESTED (-370) | |
1340 | /** Invalid parameters passed to the lock validator. */ | |
1341 | #define VERR_SEM_LV_INVALID_PARAMETER (-371) | |
1342 | /** The lock validator detected a deadlock. */ | |
1343 | #define VERR_SEM_LV_DEADLOCK (-372) | |
1344 | /** The lock validator detected an existing deadlock. | |
1345 | * The deadlock was not caused by the current operation, but existed already. */ | |
1346 | #define VERR_SEM_LV_EXISTING_DEADLOCK (-373) | |
1347 | /** Not the lock owner according our records. */ | |
1348 | #define VERR_SEM_LV_NOT_OWNER (-374) | |
1349 | /** An illegal lock upgrade was attempted. */ | |
1350 | #define VERR_SEM_LV_ILLEGAL_UPGRADE (-375) | |
1351 | /** The thread is not a valid signaller of the event. */ | |
1352 | #define VERR_SEM_LV_NOT_SIGNALLER (-376) | |
1353 | /** Internal error in the lock validator or related components. */ | |
1354 | #define VERR_SEM_LV_INTERNAL_ERROR (-377) | |
1355 | /** @} */ | |
1356 | ||
1357 | ||
1358 | /** @name Generic Network I/O Status Codes | |
1359 | * @{ | |
1360 | */ | |
1361 | /** Unresolved (unknown) network error. */ | |
1362 | #define VERR_NET_IO_ERROR (-400) | |
1363 | /** The network is busy or is out of resources. */ | |
1364 | #define VERR_NET_OUT_OF_RESOURCES (-401) | |
1365 | /** Net host name not found. */ | |
1366 | #define VERR_NET_HOST_NOT_FOUND (-402) | |
1367 | /** Network path not found. */ | |
1368 | #define VERR_NET_PATH_NOT_FOUND (-403) | |
1369 | /** General network printing error. */ | |
1370 | #define VERR_NET_PRINT_ERROR (-404) | |
1371 | /** The machine is not on the network. */ | |
1372 | #define VERR_NET_NO_NETWORK (-405) | |
1373 | /** Name is not unique on the network. */ | |
1374 | #define VERR_NET_NOT_UNIQUE_NAME (-406) | |
1375 | ||
1376 | /* These are BSD networking error codes - numbers correspond, don't mess! */ | |
1377 | /** Operation in progress. */ | |
1378 | #define VERR_NET_IN_PROGRESS (-436) | |
1379 | /** Operation already in progress. */ | |
1380 | #define VERR_NET_ALREADY_IN_PROGRESS (-437) | |
1381 | /** Attempted socket operation with a non-socket handle. | |
1382 | * (This includes closed handles.) */ | |
1383 | #define VERR_NET_NOT_SOCKET (-438) | |
1384 | /** Destination address required. */ | |
1385 | #define VERR_NET_DEST_ADDRESS_REQUIRED (-439) | |
1386 | /** Message too long. */ | |
1387 | #define VERR_NET_MSG_SIZE (-440) | |
1388 | /** Protocol wrong type for socket. */ | |
1389 | #define VERR_NET_PROTOCOL_TYPE (-441) | |
1390 | /** Protocol not available. */ | |
1391 | #define VERR_NET_PROTOCOL_NOT_AVAILABLE (-442) | |
1392 | /** Protocol not supported. */ | |
1393 | #define VERR_NET_PROTOCOL_NOT_SUPPORTED (-443) | |
1394 | /** Socket type not supported. */ | |
1395 | #define VERR_NET_SOCKET_TYPE_NOT_SUPPORTED (-444) | |
1396 | /** Operation not supported. */ | |
1397 | #define VERR_NET_OPERATION_NOT_SUPPORTED (-445) | |
1398 | /** Protocol family not supported. */ | |
1399 | #define VERR_NET_PROTOCOL_FAMILY_NOT_SUPPORTED (-446) | |
1400 | /** Address family not supported by protocol family. */ | |
1401 | #define VERR_NET_ADDRESS_FAMILY_NOT_SUPPORTED (-447) | |
1402 | /** Address already in use. */ | |
1403 | #define VERR_NET_ADDRESS_IN_USE (-448) | |
1404 | /** Can't assign requested address. */ | |
1405 | #define VERR_NET_ADDRESS_NOT_AVAILABLE (-449) | |
1406 | /** Network is down. */ | |
1407 | #define VERR_NET_DOWN (-450) | |
1408 | /** Network is unreachable. */ | |
1409 | #define VERR_NET_UNREACHABLE (-451) | |
1410 | /** Network dropped connection on reset. */ | |
1411 | #define VERR_NET_CONNECTION_RESET (-452) | |
1412 | /** Software caused connection abort. */ | |
1413 | #define VERR_NET_CONNECTION_ABORTED (-453) | |
1414 | /** Connection reset by peer. */ | |
1415 | #define VERR_NET_CONNECTION_RESET_BY_PEER (-454) | |
1416 | /** No buffer space available. */ | |
1417 | #define VERR_NET_NO_BUFFER_SPACE (-455) | |
1418 | /** Socket is already connected. */ | |
1419 | #define VERR_NET_ALREADY_CONNECTED (-456) | |
1420 | /** Socket is not connected. */ | |
1421 | #define VERR_NET_NOT_CONNECTED (-457) | |
1422 | /** Can't send after socket shutdown. */ | |
1423 | #define VERR_NET_SHUTDOWN (-458) | |
1424 | /** Too many references: can't splice. */ | |
1425 | #define VERR_NET_TOO_MANY_REFERENCES (-459) | |
1426 | /** Too many references: can't splice. */ | |
1427 | #define VERR_NET_CONNECTION_TIMED_OUT (-460) | |
1428 | /** Connection refused. */ | |
1429 | #define VERR_NET_CONNECTION_REFUSED (-461) | |
1430 | /* ELOOP is not net. */ | |
1431 | /* ENAMETOOLONG is not net. */ | |
1432 | /** Host is down. */ | |
1433 | #define VERR_NET_HOST_DOWN (-464) | |
1434 | /** No route to host. */ | |
1435 | #define VERR_NET_HOST_UNREACHABLE (-465) | |
1436 | /** Protocol error. */ | |
1437 | #define VERR_NET_PROTOCOL_ERROR (-466) | |
1438 | /** Incomplete packet was submitted by guest. */ | |
1439 | #define VERR_NET_INCOMPLETE_TX_PACKET (-467) | |
1440 | /** @} */ | |
1441 | ||
1442 | ||
1443 | /** @name TCP Status Codes | |
1444 | * @{ | |
1445 | */ | |
1446 | /** Stop the TCP server. */ | |
1447 | #define VERR_TCP_SERVER_STOP (-500) | |
1448 | /** The server was stopped. */ | |
1449 | #define VINF_TCP_SERVER_STOP 500 | |
1450 | /** The TCP server was shut down using RTTcpServerShutdown. */ | |
1451 | #define VERR_TCP_SERVER_SHUTDOWN (-501) | |
1452 | /** The TCP server was destroyed. */ | |
1453 | #define VERR_TCP_SERVER_DESTROYED (-502) | |
1454 | /** The TCP server has no client associated with it. */ | |
1455 | #define VINF_TCP_SERVER_NO_CLIENT 503 | |
1456 | /** @} */ | |
1457 | ||
1458 | ||
1459 | /** @name UDP Status Codes | |
1460 | * @{ | |
1461 | */ | |
1462 | /** Stop the UDP server. */ | |
1463 | #define VERR_UDP_SERVER_STOP (-520) | |
1464 | /** The server was stopped. */ | |
1465 | #define VINF_UDP_SERVER_STOP 520 | |
1466 | /** The UDP server was shut down using RTUdpServerShutdown. */ | |
1467 | #define VERR_UDP_SERVER_SHUTDOWN (-521) | |
1468 | /** The UDP server was destroyed. */ | |
1469 | #define VERR_UDP_SERVER_DESTROYED (-522) | |
1470 | /** The UDP server has no client associated with it. */ | |
1471 | #define VINF_UDP_SERVER_NO_CLIENT 523 | |
1472 | /** @} */ | |
1473 | ||
1474 | ||
1475 | /** @name L4 Specific Status Codes | |
1476 | * @{ | |
1477 | */ | |
1478 | /** Invalid offset in an L4 dataspace */ | |
1479 | #define VERR_L4_INVALID_DS_OFFSET (-550) | |
1480 | /** IPC error */ | |
1481 | #define VERR_IPC (-551) | |
1482 | /** Item already used */ | |
1483 | #define VERR_RESOURCE_IN_USE (-552) | |
1484 | /** Source/destination not found */ | |
1485 | #define VERR_IPC_PROCESS_NOT_FOUND (-553) | |
1486 | /** Receive timeout */ | |
1487 | #define VERR_IPC_RECEIVE_TIMEOUT (-554) | |
1488 | /** Send timeout */ | |
1489 | #define VERR_IPC_SEND_TIMEOUT (-555) | |
1490 | /** Receive cancelled */ | |
1491 | #define VERR_IPC_RECEIVE_CANCELLED (-556) | |
1492 | /** Send cancelled */ | |
1493 | #define VERR_IPC_SEND_CANCELLED (-557) | |
1494 | /** Receive aborted */ | |
1495 | #define VERR_IPC_RECEIVE_ABORTED (-558) | |
1496 | /** Send aborted */ | |
1497 | #define VERR_IPC_SEND_ABORTED (-559) | |
1498 | /** Couldn't map pages during receive */ | |
1499 | #define VERR_IPC_RECEIVE_MAP_FAILED (-560) | |
1500 | /** Couldn't map pages during send */ | |
1501 | #define VERR_IPC_SEND_MAP_FAILED (-561) | |
1502 | /** Send pagefault timeout in receive */ | |
1503 | #define VERR_IPC_RECEIVE_SEND_PF_TIMEOUT (-562) | |
1504 | /** Send pagefault timeout in send */ | |
1505 | #define VERR_IPC_SEND_SEND_PF_TIMEOUT (-563) | |
1506 | /** (One) receive buffer was too small, or too few buffers */ | |
1507 | #define VINF_IPC_RECEIVE_MSG_CUT 564 | |
1508 | /** (One) send buffer was too small, or too few buffers */ | |
1509 | #define VINF_IPC_SEND_MSG_CUT 565 | |
1510 | /** Dataspace manager server not found */ | |
1511 | #define VERR_L4_DS_MANAGER_NOT_FOUND (-566) | |
1512 | /** @} */ | |
1513 | ||
1514 | ||
1515 | /** @name Loader Status Codes. | |
1516 | * @{ | |
1517 | */ | |
1518 | /** Invalid executable signature. */ | |
1519 | #define VERR_INVALID_EXE_SIGNATURE (-600) | |
1520 | /** The iprt loader recognized a ELF image, but doesn't support loading it. */ | |
1521 | #define VERR_ELF_EXE_NOT_SUPPORTED (-601) | |
1522 | /** The iprt loader recognized a PE image, but doesn't support loading it. */ | |
1523 | #define VERR_PE_EXE_NOT_SUPPORTED (-602) | |
1524 | /** The iprt loader recognized a LX image, but doesn't support loading it. */ | |
1525 | #define VERR_LX_EXE_NOT_SUPPORTED (-603) | |
1526 | /** The iprt loader recognized a LE image, but doesn't support loading it. */ | |
1527 | #define VERR_LE_EXE_NOT_SUPPORTED (-604) | |
1528 | /** The iprt loader recognized a NE image, but doesn't support loading it. */ | |
1529 | #define VERR_NE_EXE_NOT_SUPPORTED (-605) | |
1530 | /** The iprt loader recognized a MZ image, but doesn't support loading it. */ | |
1531 | #define VERR_MZ_EXE_NOT_SUPPORTED (-606) | |
1532 | /** The iprt loader recognized an a.out image, but doesn't support loading it. */ | |
1533 | #define VERR_AOUT_EXE_NOT_SUPPORTED (-607) | |
1534 | /** Bad executable. */ | |
1535 | #define VERR_BAD_EXE_FORMAT (-608) | |
1536 | /** Symbol (export) not found. */ | |
1537 | #define VERR_SYMBOL_NOT_FOUND (-609) | |
1538 | /** Module not found. */ | |
1539 | #define VERR_MODULE_NOT_FOUND (-610) | |
1540 | /** The loader resolved an external symbol to an address to big for the image format. */ | |
1541 | #define VERR_SYMBOL_VALUE_TOO_BIG (-611) | |
1542 | /** The image is too big. */ | |
1543 | #define VERR_IMAGE_TOO_BIG (-612) | |
1544 | /** The image base address is to high for this image type. */ | |
1545 | #define VERR_IMAGE_BASE_TOO_HIGH (-614) | |
1546 | /** Mismatching architecture. */ | |
1547 | #define VERR_LDR_ARCH_MISMATCH (-615) | |
1548 | /** Mismatch between IPRT and native loader. */ | |
1549 | #define VERR_LDR_MISMATCH_NATIVE (-616) | |
1550 | /** Failed to resolve an imported (external) symbol. */ | |
1551 | #define VERR_LDR_IMPORTED_SYMBOL_NOT_FOUND (-617) | |
1552 | /** Generic loader failure. */ | |
1553 | #define VERR_LDR_GENERAL_FAILURE (-618) | |
1554 | /** Code signing error. */ | |
1555 | #define VERR_LDR_IMAGE_HASH (-619) | |
1556 | /** The PE loader encountered delayed imports, a feature which hasn't been implemented yet. */ | |
1557 | #define VERR_LDRPE_DELAY_IMPORT (-620) | |
1558 | /** The PE loader encountered a malformed certificate. */ | |
1559 | #define VERR_LDRPE_CERT_MALFORMED (-621) | |
1560 | /** The PE loader encountered a certificate with an unsupported type or structure revision. */ | |
1561 | #define VERR_LDRPE_CERT_UNSUPPORTED (-622) | |
1562 | /** The PE loader doesn't know how to deal with the global pointer data directory entry yet. */ | |
1563 | #define VERR_LDRPE_GLOBALPTR (-623) | |
1564 | /** The PE loader doesn't support the TLS data directory yet. */ | |
1565 | #define VERR_LDRPE_TLS (-624) | |
1566 | /** The PE loader doesn't grok the COM descriptor data directory entry. */ | |
1567 | #define VERR_LDRPE_COM_DESCRIPTOR (-625) | |
1568 | /** The PE loader encountered an unknown load config directory/header size. */ | |
1569 | #define VERR_LDRPE_LOAD_CONFIG_SIZE (-626) | |
1570 | /** The PE loader encountered a lock prefix table, a feature which hasn't been implemented yet. */ | |
1571 | #define VERR_LDRPE_LOCK_PREFIX_TABLE (-627) | |
1572 | /** The PE loader encountered some Guard CF stuff in the load config. */ | |
1573 | #define VERR_LDRPE_GUARD_CF_STUFF (-628) | |
1574 | /** The ELF loader doesn't handle foreign endianness. */ | |
1575 | #define VERR_LDRELF_ODD_ENDIAN (-630) | |
1576 | /** The ELF image is 'dynamic', the ELF loader can only deal with 'relocatable' images at present. */ | |
1577 | #define VERR_LDRELF_DYN (-631) | |
1578 | /** The ELF image is 'executable', the ELF loader can only deal with 'relocatable' images at present. */ | |
1579 | #define VERR_LDRELF_EXEC (-632) | |
1580 | /** The ELF image was created for an unsupported target machine type. */ | |
1581 | #define VERR_LDRELF_MACHINE (-633) | |
1582 | /** The ELF version is not supported. */ | |
1583 | #define VERR_LDRELF_VERSION (-634) | |
1584 | /** The ELF loader cannot handle multiple SYMTAB sections. */ | |
1585 | #define VERR_LDRELF_MULTIPLE_SYMTABS (-635) | |
1586 | /** The ELF loader encountered a relocation type which is not implemented. */ | |
1587 | #define VERR_LDRELF_RELOCATION_NOT_SUPPORTED (-636) | |
1588 | /** The ELF loader encountered a bad symbol index. */ | |
1589 | #define VERR_LDRELF_INVALID_SYMBOL_INDEX (-637) | |
1590 | /** The ELF loader encountered an invalid symbol name offset. */ | |
1591 | #define VERR_LDRELF_INVALID_SYMBOL_NAME_OFFSET (-638) | |
1592 | /** The ELF loader encountered an invalid relocation offset. */ | |
1593 | #define VERR_LDRELF_INVALID_RELOCATION_OFFSET (-639) | |
1594 | /** The ELF loader didn't find the symbol/string table for the image. */ | |
1595 | #define VERR_LDRELF_NO_SYMBOL_OR_NO_STRING_TABS (-640) | |
1596 | /** Invalid link address. */ | |
1597 | #define VERR_LDR_INVALID_LINK_ADDRESS (-647) | |
1598 | /** Invalid image relative virtual address. */ | |
1599 | #define VERR_LDR_INVALID_RVA (-648) | |
1600 | /** Invalid segment:offset address. */ | |
1601 | #define VERR_LDR_INVALID_SEG_OFFSET (-649) | |
1602 | /** @}*/ | |
1603 | ||
1604 | /** @name Debug Info Reader Status Codes. | |
1605 | * @{ | |
1606 | */ | |
1607 | /** The module contains no line number information. */ | |
1608 | #define VERR_DBG_NO_LINE_NUMBERS (-650) | |
1609 | /** The module contains no symbol information. */ | |
1610 | #define VERR_DBG_NO_SYMBOLS (-651) | |
1611 | /** The specified segment:offset address was invalid. Typically an attempt at | |
1612 | * addressing outside the segment boundary. */ | |
1613 | #define VERR_DBG_INVALID_ADDRESS (-652) | |
1614 | /** Invalid segment index. */ | |
1615 | #define VERR_DBG_INVALID_SEGMENT_INDEX (-653) | |
1616 | /** Invalid segment offset. */ | |
1617 | #define VERR_DBG_INVALID_SEGMENT_OFFSET (-654) | |
1618 | /** Invalid image relative virtual address. */ | |
1619 | #define VERR_DBG_INVALID_RVA (-655) | |
1620 | /** Invalid image relative virtual address. */ | |
1621 | #define VERR_DBG_SPECIAL_SEGMENT (-656) | |
1622 | /** Address conflict within a module/segment. | |
1623 | * Attempted to add a segment, symbol or line number that fully or partially | |
1624 | * overlaps with an existing one. */ | |
1625 | #define VERR_DBG_ADDRESS_CONFLICT (-657) | |
1626 | /** Duplicate symbol within the module. | |
1627 | * Attempted to add a symbol which name already exists within the module. */ | |
1628 | #define VERR_DBG_DUPLICATE_SYMBOL (-658) | |
1629 | /** The segment index specified when adding a new segment is already in use. */ | |
1630 | #define VERR_DBG_SEGMENT_INDEX_CONFLICT (-659) | |
1631 | /** No line number was found for the specified address/ordinal/whatever. */ | |
1632 | #define VERR_DBG_LINE_NOT_FOUND (-660) | |
1633 | /** The length of the symbol name is out of range. | |
1634 | * This means it is an empty string or that it's greater or equal to | |
1635 | * RTDBG_SYMBOL_NAME_LENGTH. */ | |
1636 | #define VERR_DBG_SYMBOL_NAME_OUT_OF_RANGE (-661) | |
1637 | /** The length of the file name is out of range. | |
1638 | * This means it is an empty string or that it's greater or equal to | |
1639 | * RTDBG_FILE_NAME_LENGTH. */ | |
1640 | #define VERR_DBG_FILE_NAME_OUT_OF_RANGE (-662) | |
1641 | /** The length of the segment name is out of range. | |
1642 | * This means it is an empty string or that it is greater or equal to | |
1643 | * RTDBG_SEGMENT_NAME_LENGTH. */ | |
1644 | #define VERR_DBG_SEGMENT_NAME_OUT_OF_RANGE (-663) | |
1645 | /** The specified address range wraps around. */ | |
1646 | #define VERR_DBG_ADDRESS_WRAP (-664) | |
1647 | /** The file is not a valid NM map file. */ | |
1648 | #define VERR_DBG_NOT_NM_MAP_FILE (-665) | |
1649 | /** The file is not a valid /proc/kallsyms file. */ | |
1650 | #define VERR_DBG_NOT_LINUX_KALLSYMS (-666) | |
1651 | /** No debug module interpreter matching the debug info. */ | |
1652 | #define VERR_DBG_NO_MATCHING_INTERPRETER (-667) | |
1653 | /** Bad DWARF line number header. */ | |
1654 | #define VERR_DWARF_BAD_LINE_NUMBER_HEADER (-668) | |
1655 | /** Unexpected end of DWARF unit. */ | |
1656 | #define VERR_DWARF_UNEXPECTED_END (-669) | |
1657 | /** DWARF LEB value overflows the decoder type. */ | |
1658 | #define VERR_DWARF_LEB_OVERFLOW (-670) | |
1659 | /** Bad DWARF extended line number opcode. */ | |
1660 | #define VERR_DWARF_BAD_LNE (-671) | |
1661 | /** Bad DWARF string. */ | |
1662 | #define VERR_DWARF_BAD_STRING (-672) | |
1663 | /** Bad DWARF position. */ | |
1664 | #define VERR_DWARF_BAD_POS (-673) | |
1665 | /** Bad DWARF info. */ | |
1666 | #define VERR_DWARF_BAD_INFO (-674) | |
1667 | /** Bad DWARF abbreviation data. */ | |
1668 | #define VERR_DWARF_BAD_ABBREV (-675) | |
1669 | /** A DWARF abbreviation was not found. */ | |
1670 | #define VERR_DWARF_ABBREV_NOT_FOUND (-676) | |
1671 | /** Encountered an unknown attribute form. */ | |
1672 | #define VERR_DWARF_UNKNOWN_FORM (-677) | |
1673 | /** Encountered an unexpected attribute form. */ | |
1674 | #define VERR_DWARF_UNEXPECTED_FORM (-678) | |
1675 | /** Unfinished code. */ | |
1676 | #define VERR_DWARF_TODO (-679) | |
1677 | /** Unknown location opcode. */ | |
1678 | #define VERR_DWARF_UNKNOWN_LOC_OPCODE (-680) | |
1679 | /** Expression stack overflow. */ | |
1680 | #define VERR_DWARF_STACK_OVERFLOW (-681) | |
1681 | /** Expression stack underflow. */ | |
1682 | #define VERR_DWARF_STACK_UNDERFLOW (-682) | |
1683 | /** Internal processing error in the DWARF code. */ | |
1684 | #define VERR_DWARF_IPE (-683) | |
1685 | /** Invalid configuration property value. */ | |
1686 | #define VERR_DBG_CFG_INVALID_VALUE (-684) | |
1687 | /** Not an integer property. */ | |
1688 | #define VERR_DBG_CFG_NOT_UINT_PROP (-685) | |
1689 | /** Deferred loading of information failed. */ | |
1690 | #define VERR_DBG_DEFERRED_LOAD_FAILED (-686) | |
1691 | /** Unfinished debug info reader code. */ | |
1692 | #define VERR_DBG_TODO (-687) | |
1693 | /** Found file, but it didn't match the search criteria. */ | |
1694 | #define VERR_DBG_FILE_MISMATCH (-688) | |
1695 | /** Internal processing error in the debug module reader code. */ | |
1696 | #define VERR_DBG_MOD_IPE (-689) | |
1697 | /** The symbol size was adjusted while adding it. */ | |
1698 | #define VINF_DBG_ADJUSTED_SYM_SIZE 690 | |
1699 | /** Unable to parse the CodeView debug information. */ | |
1700 | #define VERR_CV_BAD_FORMAT (-691) | |
1701 | /** Unfinished CodeView debug information feature. */ | |
1702 | #define VERR_CV_TODO (-692) | |
1703 | /** Internal processing error the CodeView debug information reader. */ | |
1704 | #define VERR_CV_IPE (-693) | |
1705 | /** @} */ | |
1706 | ||
1707 | /** @name Request Packet Status Codes. | |
1708 | * @{ | |
1709 | */ | |
1710 | /** Invalid RT request type. | |
1711 | * For the RTReqAlloc() case, the caller just specified an illegal enmType. For | |
1712 | * all the other occurrences it means indicates corruption, broken logic, or stupid | |
1713 | * interface user. */ | |
1714 | #define VERR_RT_REQUEST_INVALID_TYPE (-700) | |
1715 | /** Invalid RT request state. | |
1716 | * The state of the request packet was not the expected and accepted one(s). Either | |
1717 | * the interface user screwed up, or we've got corruption/broken logic. */ | |
1718 | #define VERR_RT_REQUEST_STATE (-701) | |
1719 | /** Invalid RT request packet. | |
1720 | * One or more of the RT controlled packet members didn't contain the correct | |
1721 | * values. Some thing's broken. */ | |
1722 | #define VERR_RT_REQUEST_INVALID_PACKAGE (-702) | |
1723 | /** The status field has not been updated yet as the request is still | |
1724 | * pending completion. Someone queried the iStatus field before the request | |
1725 | * has been fully processed. */ | |
1726 | #define VERR_RT_REQUEST_STATUS_STILL_PENDING (-703) | |
1727 | /** The request has been freed, don't read the status now. | |
1728 | * Someone is reading the iStatus field of a freed request packet. */ | |
1729 | #define VERR_RT_REQUEST_STATUS_FREED (-704) | |
1730 | /** @} */ | |
1731 | ||
1732 | /** @name Environment Status Code | |
1733 | * @{ | |
1734 | */ | |
1735 | /** The specified environment variable was not found. (RTEnvGetEx) */ | |
1736 | #define VERR_ENV_VAR_NOT_FOUND (-750) | |
1737 | /** The specified environment variable was not found. (RTEnvUnsetEx) */ | |
1738 | #define VINF_ENV_VAR_NOT_FOUND (750) | |
1739 | /** Unable to translate all the variables in the default environment due to | |
1740 | * codeset issues (LANG / LC_ALL / LC_CTYPE). */ | |
1741 | #define VWRN_ENV_NOT_FULLY_TRANSLATED (751) | |
1742 | /** Invalid environment variable name. */ | |
1743 | #define VERR_ENV_INVALID_VAR_NAME (-752) | |
1744 | /** The environment variable is an unset record. */ | |
1745 | #define VINF_ENV_VAR_UNSET (753) | |
1746 | /** The environment variable has been recorded as being unset. */ | |
1747 | #define VERR_ENV_VAR_UNSET (-753) | |
1748 | /** @} */ | |
1749 | ||
1750 | /** @name Multiprocessor Status Codes. | |
1751 | * @{ | |
1752 | */ | |
1753 | /** The specified cpu is offline. */ | |
1754 | #define VERR_CPU_OFFLINE (-800) | |
1755 | /** The specified cpu was not found. */ | |
1756 | #define VERR_CPU_NOT_FOUND (-801) | |
1757 | /** Not all of the requested CPUs showed up in the PFNRTMPWORKER. */ | |
1758 | #define VERR_NOT_ALL_CPUS_SHOWED (-802) | |
1759 | /** Internal processing error in the RTMp code.*/ | |
1760 | #define VERR_CPU_IPE_1 (-803) | |
1761 | /** @} */ | |
1762 | ||
1763 | /** @name RTGetOpt status codes | |
1764 | * @{ */ | |
1765 | /** RTGetOpt: Command line option not recognized. */ | |
1766 | #define VERR_GETOPT_UNKNOWN_OPTION (-825) | |
1767 | /** RTGetOpt: Command line option needs argument. */ | |
1768 | #define VERR_GETOPT_REQUIRED_ARGUMENT_MISSING (-826) | |
1769 | /** RTGetOpt: Command line option has argument with bad format. */ | |
1770 | #define VERR_GETOPT_INVALID_ARGUMENT_FORMAT (-827) | |
1771 | /** RTGetOpt: Not an option. */ | |
1772 | #define VINF_GETOPT_NOT_OPTION 828 | |
1773 | /** RTGetOpt: Command line option needs an index. */ | |
1774 | #define VERR_GETOPT_INDEX_MISSING (-829) | |
1775 | /** @} */ | |
1776 | ||
1777 | /** @name RTCache status codes | |
1778 | * @{ */ | |
1779 | /** RTCache: cache is full. */ | |
1780 | #define VERR_CACHE_FULL (-850) | |
1781 | /** RTCache: cache is empty. */ | |
1782 | #define VERR_CACHE_EMPTY (-851) | |
1783 | /** @} */ | |
1784 | ||
1785 | /** @name RTMemCache status codes | |
1786 | * @{ */ | |
1787 | /** Reached the max cache size. */ | |
1788 | #define VERR_MEM_CACHE_MAX_SIZE (-855) | |
1789 | /** @} */ | |
1790 | ||
1791 | /** @name RTS3 status codes | |
1792 | * @{ */ | |
1793 | /** Access denied error. */ | |
1794 | #define VERR_S3_ACCESS_DENIED (-875) | |
1795 | /** The bucket/key wasn't found. */ | |
1796 | #define VERR_S3_NOT_FOUND (-876) | |
1797 | /** Bucket already exists. */ | |
1798 | #define VERR_S3_BUCKET_ALREADY_EXISTS (-877) | |
1799 | /** Can't delete bucket with keys. */ | |
1800 | #define VERR_S3_BUCKET_NOT_EMPTY (-878) | |
1801 | /** The current operation was canceled. */ | |
1802 | #define VERR_S3_CANCELED (-879) | |
1803 | /** @} */ | |
1804 | ||
1805 | /** @name HTTP status codes | |
1806 | * @{ */ | |
1807 | /** HTTP initialization failed. */ | |
1808 | #define VERR_HTTP_INIT_FAILED (-885) | |
1809 | /** The server has not found anything matching the URI given. */ | |
1810 | #define VERR_HTTP_NOT_FOUND (-886) | |
1811 | /** The request is for something forbidden. Authorization will not help. */ | |
1812 | #define VERR_HTTP_ACCESS_DENIED (-887) | |
1813 | /** The server did not understand the request due to bad syntax. */ | |
1814 | #define VERR_HTTP_BAD_REQUEST (-888) | |
1815 | /** Couldn't connect to the server (proxy?). */ | |
1816 | #define VERR_HTTP_COULDNT_CONNECT (-889) | |
1817 | /** SSL connection error. */ | |
1818 | #define VERR_HTTP_SSL_CONNECT_ERROR (-890) | |
1819 | /** CAcert is missing or has the wrong format. */ | |
1820 | #define VERR_HTTP_CACERT_WRONG_FORMAT (-891) | |
1821 | /** Certificate cannot be authenticated with the given CA certificates. */ | |
1822 | #define VERR_HTTP_CACERT_CANNOT_AUTHENTICATE (-892) | |
1823 | /** The current HTTP request was forcefully aborted */ | |
1824 | #define VERR_HTTP_ABORTED (-893) | |
1825 | /** Request was redirected. */ | |
1826 | #define VERR_HTTP_REDIRECTED (-894) | |
1827 | /** Proxy couldn't be resolved. */ | |
1828 | #define VERR_HTTP_PROXY_NOT_FOUND (-895) | |
1829 | /** The remote host couldn't be resolved. */ | |
1830 | #define VERR_HTTP_HOST_NOT_FOUND (-896) | |
1831 | /** Unexpected cURL error configure the proxy. */ | |
1832 | #define VERR_HTTP_CURL_PROXY_CONFIG (-897) | |
1833 | /** Generic CURL error. */ | |
1834 | #define VERR_HTTP_CURL_ERROR (-899) | |
1835 | /** @} */ | |
1836 | ||
1837 | /** @name RTManifest status codes | |
1838 | * @{ */ | |
1839 | /** A digest type used in the manifest file isn't supported. */ | |
1840 | #define VERR_MANIFEST_UNSUPPORTED_DIGEST_TYPE (-900) | |
1841 | /** An entry in the manifest file couldn't be interpreted correctly. */ | |
1842 | #define VERR_MANIFEST_WRONG_FILE_FORMAT (-901) | |
1843 | /** A digest doesn't match the corresponding file. */ | |
1844 | #define VERR_MANIFEST_DIGEST_MISMATCH (-902) | |
1845 | /** The file list doesn't match to the content of the manifest file. */ | |
1846 | #define VERR_MANIFEST_FILE_MISMATCH (-903) | |
1847 | /** The specified attribute (name) was not found in the manifest. */ | |
1848 | #define VERR_MANIFEST_ATTR_NOT_FOUND (-904) | |
1849 | /** The attribute type did not match. */ | |
1850 | #define VERR_MANIFEST_ATTR_TYPE_MISMATCH (-905) | |
1851 | /** No attribute of the specified types was found. */ | |
1852 | #define VERR_MANIFEST_ATTR_TYPE_NOT_FOUND (-906) | |
1853 | /** @} */ | |
1854 | ||
1855 | /** @name RTTar status codes | |
1856 | * @{ */ | |
1857 | /** The checksum of a tar header record doesn't match. */ | |
1858 | #define VERR_TAR_CHKSUM_MISMATCH (-925) | |
1859 | /** The tar end of file record was read. */ | |
1860 | #define VERR_TAR_END_OF_FILE (-926) | |
1861 | /** The tar file ended unexpectedly. */ | |
1862 | #define VERR_TAR_UNEXPECTED_EOS (-927) | |
1863 | /** The tar termination records was encountered without reaching the end of | |
1864 | * the input stream. */ | |
1865 | #define VERR_TAR_EOS_MORE_INPUT (-928) | |
1866 | /** A number tar header field was malformed. */ | |
1867 | #define VERR_TAR_BAD_NUM_FIELD (-929) | |
1868 | /** A numeric tar header field was not terminated correctly. */ | |
1869 | #define VERR_TAR_BAD_NUM_FIELD_TERM (-930) | |
1870 | /** A number tar header field was encoded using base-256 which this | |
1871 | * tar implementation currently does not support. */ | |
1872 | #define VERR_TAR_BASE_256_NOT_SUPPORTED (-931) | |
1873 | /** A number tar header field yielded a value too large for the internal | |
1874 | * variable of the tar interpreter. */ | |
1875 | #define VERR_TAR_NUM_VALUE_TOO_LARGE (-932) | |
1876 | /** The combined minor and major device number type is too small to hold the | |
1877 | * value stored in the tar header. */ | |
1878 | #define VERR_TAR_DEV_VALUE_TOO_LARGE (-933) | |
1879 | /** The mode field in a tar header is bad. */ | |
1880 | #define VERR_TAR_BAD_MODE_FIELD (-934) | |
1881 | /** The mode field should not include the type. */ | |
1882 | #define VERR_TAR_MODE_WITH_TYPE (-935) | |
1883 | /** The size field should be zero for links and symlinks. */ | |
1884 | #define VERR_TAR_SIZE_NOT_ZERO (-936) | |
1885 | /** Encountered an unknown type flag. */ | |
1886 | #define VERR_TAR_UNKNOWN_TYPE_FLAG (-937) | |
1887 | /** The tar header is all zeros. */ | |
1888 | #define VERR_TAR_ZERO_HEADER (-938) | |
1889 | /** Not a uniform standard tape v0.0 archive header. */ | |
1890 | #define VERR_TAR_NOT_USTAR_V00 (-939) | |
1891 | /** The name is empty. */ | |
1892 | #define VERR_TAR_EMPTY_NAME (-940) | |
1893 | /** A non-directory entry has a name ending with a slash. */ | |
1894 | #define VERR_TAR_NON_DIR_ENDS_WITH_SLASH (-941) | |
1895 | /** Encountered an unsupported portable archive exchange (pax) header. */ | |
1896 | #define VERR_TAR_UNSUPPORTED_PAX_TYPE (-942) | |
1897 | /** Encountered an unsupported Solaris Tar extension. */ | |
1898 | #define VERR_TAR_UNSUPPORTED_SOLARIS_HDR_TYPE (-943) | |
1899 | /** Encountered an unsupported GNU Tar extension. */ | |
1900 | #define VERR_TAR_UNSUPPORTED_GNU_HDR_TYPE (-944) | |
1901 | /** Malformed checksum field in the tar header. */ | |
1902 | #define VERR_TAR_BAD_CHKSUM_FIELD (-945) | |
1903 | /** Malformed checksum field in the tar header. */ | |
1904 | #define VERR_TAR_MALFORMED_GNU_LONGXXXX (-946) | |
1905 | /** Too long name or link string. */ | |
1906 | #define VERR_TAR_NAME_TOO_LONG (-947) | |
1907 | /** A directory entry in the archive. */ | |
1908 | #define VINF_TAR_DIR_PATH (948) | |
1909 | /** @} */ | |
1910 | ||
1911 | /** @name RTPoll status codes | |
1912 | * @{ */ | |
1913 | /** The handle is not pollable. */ | |
1914 | #define VERR_POLL_HANDLE_NOT_POLLABLE (-950) | |
1915 | /** The handle ID is already present in the poll set. */ | |
1916 | #define VERR_POLL_HANDLE_ID_EXISTS (-951) | |
1917 | /** The handle ID was not found in the set. */ | |
1918 | #define VERR_POLL_HANDLE_ID_NOT_FOUND (-952) | |
1919 | /** The poll set is full. */ | |
1920 | #define VERR_POLL_SET_IS_FULL (-953) | |
1921 | /** @} */ | |
1922 | ||
1923 | /** @name Pkzip status codes | |
1924 | * @{ */ | |
1925 | /** No end of central directory record found. */ | |
1926 | #define VERR_PKZIP_NO_EOCB (-960) | |
1927 | /** Too long name string. */ | |
1928 | #define VERR_PKZIP_NAME_TOO_LONG (-961) | |
1929 | /** Local file header corrupt. */ | |
1930 | #define VERR_PKZIP_BAD_LF_HEADER (-962) | |
1931 | /** Central directory file header corrupt. */ | |
1932 | #define VERR_PKZIP_BAD_CDF_HEADER (-963) | |
1933 | /** Encountered an unknown type flag. */ | |
1934 | #define VERR_PKZIP_UNKNOWN_TYPE_FLAG (-964) | |
1935 | /** Found a ZIP64 Extra Information Field in a ZIP32 file. */ | |
1936 | #define VERR_PKZIP_ZIP64EX_IN_ZIP32 (-965) | |
1937 | ||
1938 | ||
1939 | /** @name RTZip status codes | |
1940 | * @{ */ | |
1941 | /** Generic zip error. */ | |
1942 | #define VERR_ZIP_ERROR (-22000) | |
1943 | /** The compressed data was corrupted. */ | |
1944 | #define VERR_ZIP_CORRUPTED (-22001) | |
1945 | /** Ran out of memory while compressing or uncompressing. */ | |
1946 | #define VERR_ZIP_NO_MEMORY (-22002) | |
1947 | /** The compression format version is unsupported. */ | |
1948 | #define VERR_ZIP_UNSUPPORTED_VERSION (-22003) | |
1949 | /** The compression method is unsupported. */ | |
1950 | #define VERR_ZIP_UNSUPPORTED_METHOD (-22004) | |
1951 | /** The compressed data started with a bad header. */ | |
1952 | #define VERR_ZIP_BAD_HEADER (-22005) | |
1953 | /** @} */ | |
1954 | ||
1955 | /** @name RTVfs status codes | |
1956 | * @{ */ | |
1957 | /** The VFS chain specification does not have a valid prefix. */ | |
1958 | #define VERR_VFS_CHAIN_NO_PREFIX (-22100) | |
1959 | /** The VFS chain specification is empty. */ | |
1960 | #define VERR_VFS_CHAIN_EMPTY (-22101) | |
1961 | /** Expected an element. */ | |
1962 | #define VERR_VFS_CHAIN_EXPECTED_ELEMENT (-22102) | |
1963 | /** The VFS object type is not known. */ | |
1964 | #define VERR_VFS_CHAIN_UNKNOWN_TYPE (-22103) | |
1965 | /** Expected a left parentheses. */ | |
1966 | #define VERR_VFS_CHAIN_EXPECTED_LEFT_PARENTHESES (-22104) | |
1967 | /** Expected a right parentheses. */ | |
1968 | #define VERR_VFS_CHAIN_EXPECTED_RIGHT_PARENTHESES (-22105) | |
1969 | /** Expected a provider name. */ | |
1970 | #define VERR_VFS_CHAIN_EXPECTED_PROVIDER_NAME (-22106) | |
6d209b23 SF |
1971 | /** Expected an element separator (| or :). */ |
1972 | #define VERR_VFS_CHAIN_EXPECTED_SEPARATOR (-22107) | |
1973 | /** Leading element separator not permitted. */ | |
1974 | #define VERR_VFS_CHAIN_LEADING_SEPARATOR (-22108) | |
1975 | /** Trailing element separator not permitted. */ | |
1976 | #define VERR_VFS_CHAIN_TRAILING_SEPARATOR (-22109) | |
1977 | /** The provider is only allowed as the first element. */ | |
1978 | #define VERR_VFS_CHAIN_MUST_BE_FIRST_ELEMENT (-22110) | |
1979 | /** The provider cannot be the first element. */ | |
1980 | #define VERR_VFS_CHAIN_CANNOT_BE_FIRST_ELEMENT (-22111) | |
1981 | /** VFS object cast failed. */ | |
1982 | #define VERR_VFS_CHAIN_CAST_FAILED (-22112) | |
1983 | /** Internal error in the VFS chain code. */ | |
1984 | #define VERR_VFS_CHAIN_IPE (-22113) | |
1985 | /** VFS chain element provider not found. */ | |
1986 | #define VERR_VFS_CHAIN_PROVIDER_NOT_FOUND (-22114) | |
1987 | /** VFS chain does not terminate with the desired object type. */ | |
1988 | #define VERR_VFS_CHAIN_FINAL_TYPE_MISMATCH (-22115) | |
1989 | /** VFS chain element takes no arguments. */ | |
1990 | #define VERR_VFS_CHAIN_NO_ARGS (-22116) | |
1991 | /** VFS chain element takes exactly one argument. */ | |
1992 | #define VERR_VFS_CHAIN_ONE_ARG (-22117) | |
1993 | /** VFS chain element expected at most one argument. */ | |
1994 | #define VERR_VFS_CHAIN_AT_MOST_ONE_ARG (-22118) | |
1995 | /** VFS chain element expected at least one argument. */ | |
1996 | #define VERR_VFS_CHAIN_AT_LEAST_ONE_ARG (-22119) | |
1997 | /** VFS chain element takes exactly two arguments. */ | |
1998 | #define VERR_VFS_CHAIN_TWO_ARGS (-22120) | |
1999 | /** VFS chain element expected at least two arguments. */ | |
2000 | #define VERR_VFS_CHAIN_AT_LEAST_TWO_ARGS (-22121) | |
2001 | /** VFS chain element expected at most two arguments. */ | |
2002 | #define VERR_VFS_CHAIN_AT_MOST_TWO_ARGS (-22122) | |
2003 | /** VFS chain element takes exactly three arguments. */ | |
2004 | #define VERR_VFS_CHAIN_THREE_ARGS (-22123) | |
2005 | /** VFS chain element expected at least three arguments. */ | |
2006 | #define VERR_VFS_CHAIN_AT_LEAST_THREE_ARGS (-22124) | |
2007 | /** VFS chain element expected at most three arguments. */ | |
2008 | #define VERR_VFS_CHAIN_AT_MOST_THREE_ARGS (-22125) | |
2009 | /** VFS chain element takes exactly four arguments. */ | |
2010 | #define VERR_VFS_CHAIN_FOUR_ARGS (-22126) | |
2011 | /** VFS chain element expected at least four arguments. */ | |
2012 | #define VERR_VFS_CHAIN_AT_LEAST_FOUR_ARGS (-22127) | |
2013 | /** VFS chain element expected at most four arguments. */ | |
2014 | #define VERR_VFS_CHAIN_AT_MOST_FOUR_ARGS (-22128) | |
2015 | /** VFS chain element takes exactly five arguments. */ | |
2016 | #define VERR_VFS_CHAIN_FIVE_ARGS (-22129) | |
2017 | /** VFS chain element expected at least five arguments. */ | |
2018 | #define VERR_VFS_CHAIN_AT_LEAST_FIVE_ARGS (-22130) | |
2019 | /** VFS chain element expected at most five arguments. */ | |
2020 | #define VERR_VFS_CHAIN_AT_MOST_FIVE_ARGS (-22131) | |
2021 | /** VFS chain element takes exactly six arguments. */ | |
2022 | #define VERR_VFS_CHAIN_SIX_ARGS (-22132) | |
2023 | /** VFS chain element expected at least six arguments. */ | |
2024 | #define VERR_VFS_CHAIN_AT_LEAST_SIX_ARGS (-22133) | |
2025 | /** VFS chain element expected at most six arguments. */ | |
2026 | #define VERR_VFS_CHAIN_AT_MOST_SIX_ARGS (-22134) | |
2027 | /** VFS chain element expected at most six arguments. */ | |
2028 | #define VERR_VFS_CHAIN_TOO_FEW_ARGS (-22135) | |
2029 | /** VFS chain element expected at most six arguments. */ | |
2030 | #define VERR_VFS_CHAIN_TOO_MANY_ARGS (-22136) | |
2031 | /** VFS chain element expected non-empty argument. */ | |
2032 | #define VERR_VFS_CHAIN_EMPTY_ARG (-22137) | |
2033 | /** Invalid argument to VFS chain element. */ | |
2034 | #define VERR_VFS_CHAIN_INVALID_ARGUMENT (-22138) | |
2035 | /** VFS chain element only provides file and I/O stream (ios) objects. */ | |
2036 | #define VERR_VFS_CHAIN_ONLY_FILE_OR_IOS (-22139) | |
2037 | /** VFS chain element only provides I/O stream (ios) objects. */ | |
2038 | #define VERR_VFS_CHAIN_ONLY_IOS (-22140) | |
2039 | /** VFS chain element only provides directory (dir) objects. */ | |
2040 | #define VERR_VFS_CHAIN_ONLY_DIR (-22141) | |
2041 | /** VFS chain element only provides file system stream (fss) objects. */ | |
2042 | #define VERR_VFS_CHAIN_ONLY_FSS (-22142) | |
2043 | /** VFS chain element only provides file system (vfs) objects. */ | |
2044 | #define VERR_VFS_CHAIN_ONLY_VFS (-22143) | |
2045 | /** VFS chain element only provides file, I/O stream (ios), or | |
2046 | * directory (dir) objects. */ | |
2047 | #define VERR_VFS_CHAIN_ONLY_FILE_OR_IOS_OR_DIR (-22144) | |
2048 | /** VFS chain element only provides file, I/O stream (ios), or | |
2049 | * directory (dir) objects. */ | |
2050 | #define VERR_VFS_CHAIN_ONLY_DIR_OR_VFS (-22145) | |
2051 | /** VFS chain element takes a file object as input. */ | |
2052 | #define VERR_VFS_CHAIN_TAKES_FILE (-22146) | |
2053 | /** VFS chain element takes a file or I/O stream (ios) object as input. */ | |
2054 | #define VERR_VFS_CHAIN_TAKES_FILE_OR_IOS (-22147) | |
2055 | /** VFS chain element takes a directory (dir) object as input. */ | |
2056 | #define VERR_VFS_CHAIN_TAKES_DIR (-22148) | |
2057 | /** VFS chain element takes a file system stream (fss) object as input. */ | |
2058 | #define VERR_VFS_CHAIN_TAKES_FSS (-22149) | |
2059 | /** VFS chain element takes a file system (vfs) object as input. */ | |
2060 | #define VERR_VFS_CHAIN_TAKES_VFS (-22150) | |
2061 | /** VFS chain element takes a directory (dir) or file system (vfs) | |
2062 | * object as input. */ | |
2063 | #define VERR_VFS_CHAIN_TAKES_DIR_OR_VFS (-22151) | |
2064 | /** VFS chain element takes a directory (dir), file system stream (fss), | |
2065 | * or file system (vfs) object as input. */ | |
2066 | #define VERR_VFS_CHAIN_TAKES_DIR_OR_FSS_OR_VFS (-22152) | |
2067 | /** VFS chain element only provides a read-only I/O stream, while the chain | |
2068 | * requires write access. */ | |
2069 | #define VERR_VFS_CHAIN_READ_ONLY_IOS (-22153) | |
2070 | /** VFS chain element only provides a read-only I/O stream, while the chain | |
2071 | * read access. */ | |
2072 | #define VERR_VFS_CHAIN_WRITE_ONLY_IOS (-22154) | |
2073 | /** VFS chain only has a single element and it is just a path, need to be | |
2074 | * treated as a normal file system request. */ | |
2075 | #define VERR_VFS_CHAIN_PATH_ONLY (-22155) | |
2076 | /** VFS chain element preceding the final path needs to be a directory, file | |
2077 | * system or file system stream. */ | |
2078 | #define VERR_VFS_CHAIN_TYPE_MISMATCH_PATH_ONLY (-22156) | |
2079 | /** VFS chain doesn't end with a path only element. */ | |
2080 | #define VERR_VFS_CHAIN_NOT_PATH_ONLY (-22157) | |
26894aac SF |
2081 | /** The path only element at the end of the VFS chain is too short to make out |
2082 | * the parent directory. */ | |
2083 | #define VERR_VFS_CHAIN_TOO_SHORT_FOR_PARENT (-22158) | |
056a1eb7 SF |
2084 | /** @} */ |
2085 | ||
2086 | /** @name RTDvm status codes | |
2087 | * @{ */ | |
2088 | /** The volume map doesn't contain any valid volume. */ | |
2089 | #define VERR_DVM_MAP_EMPTY (-22200) | |
2090 | /** There is no volume behind the current one. */ | |
2091 | #define VERR_DVM_MAP_NO_VOLUME (-22201) | |
2092 | /** @} */ | |
2093 | ||
2094 | /** @name Logger status codes | |
2095 | * @{ */ | |
2096 | /** The internal logger revision did not match. */ | |
2097 | #define VERR_LOG_REVISION_MISMATCH (-22300) | |
2098 | /** @} */ | |
2099 | ||
2100 | /* see above, 22400..22499 is used for misc codes! */ | |
2101 | ||
2102 | /** @name Logger status codes | |
2103 | * @{ */ | |
2104 | /** Power off is not supported by the hardware or the OS. */ | |
2105 | #define VERR_SYS_CANNOT_POWER_OFF (-22500) | |
2106 | /** The halt action was requested, but the OS may actually power | |
2107 | * off the machine. */ | |
2108 | #define VINF_SYS_MAY_POWER_OFF (22501) | |
2109 | /** Shutdown failed. */ | |
2110 | #define VERR_SYS_SHUTDOWN_FAILED (-22502) | |
2111 | /** @} */ | |
2112 | ||
2113 | /** @name Filesystem status codes | |
2114 | * @{ */ | |
2115 | /** Filesystem can't be opened because it is corrupt. */ | |
2116 | #define VERR_FILESYSTEM_CORRUPT (-22600) | |
2117 | /** @} */ | |
2118 | ||
2119 | /** @name RTZipXar status codes. | |
2120 | * @{ */ | |
2121 | /** Wrong magic value. */ | |
2122 | #define VERR_XAR_WRONG_MAGIC (-22700) | |
2123 | /** Bad header size. */ | |
2124 | #define VERR_XAR_BAD_HDR_SIZE (-22701) | |
2125 | /** Unsupported version. */ | |
2126 | #define VERR_XAR_UNSUPPORTED_VERSION (-22702) | |
2127 | /** Unsupported hashing function. */ | |
2128 | #define VERR_XAR_UNSUPPORTED_HASH_FUNCTION (-22703) | |
2129 | /** The table of content (TOC) is too small and therefore can't be valid. */ | |
2130 | #define VERR_XAR_TOC_TOO_SMALL (-22704) | |
2131 | /** The table of content (TOC) is too big. */ | |
2132 | #define VERR_XAR_TOC_TOO_BIG (-22705) | |
2133 | /** The compressed table of content is too big. */ | |
2134 | #define VERR_XAR_TOC_TOO_BIG_COMPRESSED (-22706) | |
2135 | /** The uncompressed table of content size in the header didn't match what | |
2136 | * ZLib returned. */ | |
2137 | #define VERR_XAR_TOC_UNCOMP_SIZE_MISMATCH (-22707) | |
2138 | /** The table of content string length didn't match the size specified in the | |
2139 | * header. */ | |
2140 | #define VERR_XAR_TOC_STRLEN_MISMATCH (-22708) | |
2141 | /** The table of content isn't valid UTF-8. */ | |
2142 | #define VERR_XAR_TOC_UTF8_ENCODING (-22709) | |
2143 | /** XML error while parsing the table of content. */ | |
2144 | #define VERR_XAR_TOC_XML_PARSE_ERROR (-22710) | |
2145 | /** The table of content XML document does not have a toc element. */ | |
2146 | #define VERR_XML_TOC_ELEMENT_MISSING (-22711) | |
2147 | /** The table of content XML element (toc) has siblings, we expected it to be | |
2148 | * an only child or the root element (xar). */ | |
2149 | #define VERR_XML_TOC_ELEMENT_HAS_SIBLINGS (-22712) | |
2150 | /** The XAR table of content digest doesn't match. */ | |
2151 | #define VERR_XAR_TOC_DIGEST_MISMATCH (-22713) | |
2152 | /** Bad or missing XAR checksum element. */ | |
2153 | #define VERR_XAR_BAD_CHECKSUM_ELEMENT (-22714) | |
2154 | /** The hash function in the header doesn't match the one in the table of | |
2155 | * content. */ | |
2156 | #define VERR_XAR_HASH_FUNCTION_MISMATCH (-22715) | |
2157 | /** Bad digest length encountered in the table of content. */ | |
2158 | #define VERR_XAR_BAD_DIGEST_LENGTH (-22716) | |
2159 | /** The order of elements in the XAR file does not lend it self to expansion | |
2160 | * from via an I/O stream. */ | |
2161 | #define VERR_XAR_NOT_STREAMBLE_ELEMENT_ORDER (-22717) | |
2162 | /** Missing offset element in table of content sub-element. */ | |
2163 | #define VERR_XAR_MISSING_OFFSET_ELEMENT (-22718) | |
2164 | /** Bad offset element in table of content sub-element. */ | |
2165 | #define VERR_XAR_BAD_OFFSET_ELEMENT (-22719) | |
2166 | /** Missing size element in table of content sub-element. */ | |
2167 | #define VERR_XAR_MISSING_SIZE_ELEMENT (-22720) | |
2168 | /** Bad size element in table of content sub-element. */ | |
2169 | #define VERR_XAR_BAD_SIZE_ELEMENT (-22721) | |
2170 | /** Missing length element in table of content sub-element. */ | |
2171 | #define VERR_XAR_MISSING_LENGTH_ELEMENT (-22722) | |
2172 | /** Bad length element in table of content sub-element. */ | |
2173 | #define VERR_XAR_BAD_LENGTH_ELEMENT (-22723) | |
2174 | /** Bad file element in XAR table of content. */ | |
2175 | #define VERR_XAR_BAD_FILE_ELEMENT (-22724) | |
2176 | /** Missing data element for XAR file. */ | |
2177 | #define VERR_XAR_MISSING_DATA_ELEMENT (-22725) | |
2178 | /** Unknown XAR file type value. */ | |
2179 | #define VERR_XAR_UNKNOWN_FILE_TYPE (-22726) | |
2180 | /** Missing encoding element for XAR data stream. */ | |
2181 | #define VERR_XAR_NO_ENCODING (-22727) | |
2182 | /** Bad timestamp for XAR file. */ | |
2183 | #define VERR_XAR_BAD_FILE_TIMESTAMP (-22728) | |
2184 | /** Bad file mode for XAR file. */ | |
2185 | #define VERR_XAR_BAD_FILE_MODE (-22729) | |
2186 | /** Bad file user id for XAR file. */ | |
2187 | #define VERR_XAR_BAD_FILE_UID (-22730) | |
2188 | /** Bad file group id for XAR file. */ | |
2189 | #define VERR_XAR_BAD_FILE_GID (-22731) | |
2190 | /** Bad file inode device number for XAR file. */ | |
2191 | #define VERR_XAR_BAD_FILE_DEVICE_NO (-22732) | |
2192 | /** Bad file inode number for XAR file. */ | |
2193 | #define VERR_XAR_BAD_FILE_INODE (-22733) | |
2194 | /** Invalid name for XAR file. */ | |
2195 | #define VERR_XAR_INVALID_FILE_NAME (-22734) | |
2196 | /** The message digest of the extracted data does not match the one supplied. */ | |
2197 | #define VERR_XAR_EXTRACTED_HASH_MISMATCH (-22735) | |
2198 | /** The extracted data has exceeded the expected size. */ | |
2199 | #define VERR_XAR_EXTRACTED_SIZE_EXCEEDED (-22736) | |
2200 | /** The message digest of the archived data does not match the one supplied. */ | |
2201 | #define VERR_XAR_ARCHIVED_HASH_MISMATCH (-22737) | |
2202 | /** The decompressor completed without using all the input data. */ | |
2203 | #define VERR_XAR_UNUSED_ARCHIVED_DATA (-22738) | |
2204 | /** Expected the archived and extracted XAR data sizes to be the same for | |
2205 | * uncompressed data. */ | |
2206 | #define VERR_XAR_ARCHIVED_AND_EXTRACTED_SIZES_MISMATCH (-22739) | |
2207 | /** @} */ | |
2208 | ||
2209 | /** @name RTX509 status codes | |
2210 | * @{ */ | |
2211 | /** Error reading a certificate in PEM format from BIO. */ | |
2212 | #define VERR_X509_READING_CERT_FROM_BIO (-23100) | |
2213 | /** Error extracting a public key from the certificate. */ | |
2214 | #define VERR_X509_EXTRACT_PUBKEY_FROM_CERT (-23101) | |
2215 | /** Error extracting RSA from the public key. */ | |
2216 | #define VERR_X509_EXTRACT_RSA_FROM_PUBLIC_KEY (-23102) | |
2217 | /** Signature verification failed. */ | |
2218 | #define VERR_X509_RSA_VERIFICATION_FUILURE (-23103) | |
2219 | /** Basic constraints were not found. */ | |
2220 | #define VERR_X509_NO_BASIC_CONSTARAINTS (-23104) | |
2221 | /** Error getting extensions from the certificate. */ | |
2222 | #define VERR_X509_GETTING_EXTENSION_FROM_CERT (-23105) | |
2223 | /** Error getting a data from the extension. */ | |
2224 | #define VERR_X509_GETTING_DATA_FROM_EXTENSION (-23106) | |
2225 | /** Error formatting an extension. */ | |
2226 | #define VERR_X509_PRINT_EXTENSION_TO_BIO (-23107) | |
2227 | /** X509 certificate verification error. */ | |
2228 | #define VERR_X509_CERTIFICATE_VERIFICATION_FAILURE (-23108) | |
2229 | /** X509 certificate isn't self signed. */ | |
2230 | #define VERR_X509_NOT_SELFSIGNED_CERTIFICATE (-23109) | |
2231 | /** Warning X509 certificate isn't self signed. */ | |
2232 | #define VINF_X509_NOT_SELFSIGNED_CERTIFICATE 23109 | |
2233 | /** @} */ | |
2234 | ||
2235 | /** @name RTAsn1 status codes | |
2236 | * @{ */ | |
2237 | /** Temporary place holder. */ | |
2238 | #define VERR_ASN1_ERROR (-22800) | |
2239 | /** Encountered an ASN.1 string type that is not supported. */ | |
2240 | #define VERR_ASN1_STRING_TYPE_NOT_IMPLEMENTED (-22801) | |
2241 | /** Invalid ASN.1 UTF-8 STRING encoding. */ | |
2242 | #define VERR_ASN1_INVALID_UTF8_STRING_ENCODING (-22802) | |
2243 | /** Invalid ASN.1 NUMERIC STRING encoding. */ | |
2244 | #define VERR_ASN1_INVALID_NUMERIC_STRING_ENCODING (-22803) | |
2245 | /** Invalid ASN.1 PRINTABLE STRING encoding. */ | |
2246 | #define VERR_ASN1_INVALID_PRINTABLE_STRING_ENCODING (-22804) | |
2247 | /** Invalid ASN.1 T61/TELETEX STRING encoding. */ | |
2248 | #define VERR_ASN1_INVALID_T61_STRING_ENCODING (-22805) | |
2249 | /** Invalid ASN.1 VIDEOTEX STRING encoding. */ | |
2250 | #define VERR_ASN1_INVALID_VIDEOTEX_STRING_ENCODING (-22806) | |
2251 | /** Invalid ASN.1 IA5 STRING encoding. */ | |
2252 | #define VERR_ASN1_INVALID_IA5_STRING_ENCODING (-22807) | |
2253 | /** Invalid ASN.1 GRAPHIC STRING encoding. */ | |
2254 | #define VERR_ASN1_INVALID_GRAPHIC_STRING_ENCODING (-22808) | |
2255 | /** Invalid ASN.1 ISO-646/VISIBLE STRING encoding. */ | |
2256 | #define VERR_ASN1_INVALID_VISIBLE_STRING_ENCODING (-22809) | |
2257 | /** Invalid ASN.1 GENERAL STRING encoding. */ | |
2258 | #define VERR_ASN1_INVALID_GENERAL_STRING_ENCODING (-22810) | |
2259 | /** Invalid ASN.1 UNIVERSAL STRING encoding. */ | |
2260 | #define VERR_ASN1_INVALID_UNIVERSAL_STRING_ENCODING (-22811) | |
2261 | /** Invalid ASN.1 BMP STRING encoding. */ | |
2262 | #define VERR_ASN1_INVALID_BMP_STRING_ENCODING (-22812) | |
2263 | /** Invalid ASN.1 OBJECT IDENTIFIER encoding. */ | |
2264 | #define VERR_ASN1_INVALID_OBJID_ENCODING (-22813) | |
2265 | /** A component value of an ASN.1 OBJECT IDENTIFIER is too big for our | |
2266 | * internal representation (32-bits). */ | |
2267 | #define VERR_ASN1_OBJID_COMPONENT_TOO_BIG (-22814) | |
2268 | /** Too many components in an ASN.1 OBJECT IDENTIFIER for our internal | |
2269 | * representation. */ | |
2270 | #define VERR_ASN1_OBJID_TOO_MANY_COMPONENTS (-22815) | |
2271 | /** The dotted-string representation of an ASN.1 OBJECT IDENTIFIER would be too | |
2272 | * long for our internal representation. */ | |
2273 | #define VERR_ASN1_OBJID_TOO_LONG_STRING_FORM (-22816) | |
2274 | /** Invalid dotted string. */ | |
2275 | #define VERR_ASN1_OBJID_INVALID_DOTTED_STRING (-22817) | |
2276 | /** Constructed string type not implemented. */ | |
2277 | #define VERR_ASN1_CONSTRUCTED_STRING_NOT_IMPL (-22818) | |
2278 | /** Expected a different string tag. */ | |
2279 | #define VERR_ASN1_STRING_TAG_MISMATCH (-22819) | |
2280 | /** Expected a different time tag. */ | |
2281 | #define VERR_ASN1_TIME_TAG_MISMATCH (-22820) | |
2282 | /** More unconsumed data available. */ | |
2283 | #define VINF_ASN1_MORE_DATA (22821) | |
2284 | /** RTAsnEncodeWriteHeader return code indicating that nothing was written | |
2285 | * and the content should be skipped as well. */ | |
2286 | #define VINF_ASN1_NOT_ENCODED (22822) | |
2287 | /** Unknown escape sequence encountered in TeletexString. */ | |
2288 | #define VERR_ASN1_TELETEX_UNKNOWN_ESC_SEQ (-22823) | |
2289 | /** Unsupported escape sequence encountered in TeletexString. */ | |
2290 | #define VERR_ASN1_TELETEX_UNSUPPORTED_ESC_SEQ (-22824) | |
2291 | /** Unsupported character set. */ | |
2292 | #define VERR_ASN1_TELETEX_UNSUPPORTED_CHARSET (-22825) | |
2293 | /** ASN.1 object has no virtual method table. */ | |
2294 | #define VERR_ASN1_NO_VTABLE (-22826) | |
2295 | /** ASN.1 object has no pfnCheckSanity method. */ | |
2296 | #define VERR_ASN1_NO_CHECK_SANITY_METHOD (-22827) | |
2297 | /** ASN.1 object is not present */ | |
2298 | #define VERR_ASN1_NOT_PRESENT (-22828) | |
2299 | /** There are unconsumed bytes after decoding an ASN.1 object. */ | |
2300 | #define VERR_ASN1_CURSOR_NOT_AT_END (-22829) | |
2301 | /** Long ASN.1 tag form is not implemented. */ | |
2302 | #define VERR_ASN1_CURSOR_LONG_TAG (-22830) | |
2303 | /** Bad ASN.1 object length encoding. */ | |
2304 | #define VERR_ASN1_CURSOR_BAD_LENGTH_ENCODING (-22831) | |
2305 | /** Indefinite length form is against the rules. */ | |
2306 | #define VERR_ASN1_CURSOR_ILLEGAL_IDEFINITE_LENGTH (-22832) | |
2307 | /** Indefinite length form is not implemented. */ | |
2308 | #define VERR_ASN1_CURSOR_IDEFINITE_LENGTH_NOT_SUP (-22833) | |
2309 | /** ASN.1 object length goes beyond the end of the byte stream being decoded. */ | |
2310 | #define VERR_ASN1_CURSOR_BAD_LENGTH (-22834) | |
2311 | /** Not more data in ASN.1 byte stream. */ | |
2312 | #define VERR_ASN1_CURSOR_NO_MORE_DATA (-22835) | |
2313 | /** Too little data in ASN.1 byte stream. */ | |
2314 | #define VERR_ASN1_CURSOR_TOO_LITTLE_DATA_LEFT (-22836) | |
2315 | /** Constructed string is not according to the encoding rules. */ | |
2316 | #define VERR_ASN1_CURSOR_ILLEGAL_CONSTRUCTED_STRING (-22837) | |
2317 | /** Unexpected ASN.1 tag encountered while decoding. */ | |
2318 | #define VERR_ASN1_CURSOR_TAG_MISMATCH (-22838) | |
2319 | /** Unexpected ASN.1 tag class/flag encountered while decoding. */ | |
2320 | #define VERR_ASN1_CURSOR_TAG_FLAG_CLASS_MISMATCH (-22839) | |
2321 | /** ASN.1 bit string object is out of bounds. */ | |
2322 | #define VERR_ASN1_BITSTRING_OUT_OF_BOUNDS (-22840) | |
2323 | /** Bad ASN.1 time object. */ | |
2324 | #define VERR_ASN1_TIME_BAD_NORMALIZE_INPUT (-22841) | |
2325 | /** Failed to normalize ASN.1 time object. */ | |
2326 | #define VERR_ASN1_TIME_NORMALIZE_ERROR (-22842) | |
2327 | /** Normalization of ASN.1 time object didn't work out. */ | |
2328 | #define VERR_ASN1_TIME_NORMALIZE_MISMATCH (-22843) | |
2329 | /** Invalid ASN.1 UTC TIME encoding. */ | |
2330 | #define VERR_ASN1_INVALID_UTC_TIME_ENCODING (-22844) | |
2331 | /** Invalid ASN.1 GENERALIZED TIME encoding. */ | |
2332 | #define VERR_ASN1_INVALID_GENERALIZED_TIME_ENCODING (-22845) | |
2333 | /** Invalid ASN.1 BOOLEAN encoding. */ | |
2334 | #define VERR_ASN1_INVALID_BOOLEAN_ENCODING (-22846) | |
2335 | /** Invalid ASN.1 NULL encoding. */ | |
2336 | #define VERR_ASN1_INVALID_NULL_ENCODING (-22847) | |
2337 | /** Invalid ASN.1 BIT STRING encoding. */ | |
2338 | #define VERR_ASN1_INVALID_BITSTRING_ENCODING (-22848) | |
2339 | /** Unimplemented ASN.1 tag reached the RTAsn1DynType code. */ | |
2340 | #define VERR_ASN1_DYNTYPE_TAG_NOT_IMPL (-22849) | |
2341 | /** ASN.1 tag and flags/class mismatch in RTAsn1DynType code. */ | |
2342 | #define VERR_ASN1_DYNTYPE_BAD_TAG (-22850) | |
2343 | /** Unexpected ASN.1 fake/dummy object. */ | |
2344 | #define VERR_ASN1_DUMMY_OBJECT (-22851) | |
2345 | /** ASN.1 object is too long. */ | |
2346 | #define VERR_ASN1_TOO_LONG (-22852) | |
2347 | /** Expected primitive ASN.1 object. */ | |
2348 | #define VERR_ASN1_EXPECTED_PRIMITIVE (-22853) | |
2349 | /** Expected valid data pointer for ASN.1 object. */ | |
2350 | #define VERR_ASN1_INVALID_DATA_POINTER (-22854) | |
2351 | /** The ASN.1 encoding is too deeply nested for the decoder. */ | |
2352 | #define VERR_ASN1_TOO_DEEPLY_NESTED (-22855) | |
2353 | /** Generic unexpected object ID error. */ | |
2354 | #define VERR_ASN1_UNEXPECTED_OBJ_ID (-22856) | |
2355 | ||
2356 | /** ANS.1 internal error 1. */ | |
2357 | #define VERR_ASN1_INTERNAL_ERROR_1 (-22895) | |
2358 | /** ANS.1 internal error 2. */ | |
2359 | #define VERR_ASN1_INTERNAL_ERROR_2 (-22896) | |
2360 | /** ANS.1 internal error 3. */ | |
2361 | #define VERR_ASN1_INTERNAL_ERROR_3 (-22897) | |
2362 | /** ANS.1 internal error 4. */ | |
2363 | #define VERR_ASN1_INTERNAL_ERROR_4 (-22898) | |
2364 | /** ANS.1 internal error 5. */ | |
2365 | #define VERR_ASN1_INTERNAL_ERROR_5 (-22899) | |
2366 | /** @} */ | |
2367 | ||
2368 | /** @name More RTLdr status codes. | |
2369 | * @{ */ | |
2370 | /** Image Verification Failure: No Authenticode Signature. */ | |
2371 | #define VERR_LDRVI_NOT_SIGNED (-22900) | |
2372 | /** Image Verification Warning: No Authenticode Signature, but on whitelist. */ | |
2373 | #define VINF_LDRVI_NOT_SIGNED (22900) | |
2374 | /** Image Verification Failure: Error reading image headers. */ | |
2375 | #define VERR_LDRVI_READ_ERROR_HDR (-22901) | |
2376 | /** Image Verification Failure: Error reading section headers. */ | |
2377 | #define VERR_LDRVI_READ_ERROR_SHDRS (-22902) | |
2378 | /** Image Verification Failure: Error reading authenticode signature data. */ | |
2379 | #define VERR_LDRVI_READ_ERROR_SIGNATURE (-22903) | |
2380 | /** Image Verification Failure: Error reading file for hashing. */ | |
2381 | #define VERR_LDRVI_READ_ERROR_HASH (-22904) | |
2382 | /** Image Verification Failure: Error determining the file length. */ | |
2383 | #define VERR_LDRVI_FILE_LENGTH_ERROR (-22905) | |
2384 | /** Image Verification Failure: Error allocating memory for state data. */ | |
2385 | #define VERR_LDRVI_NO_MEMORY_STATE (-22906) | |
2386 | /** Image Verification Failure: Error allocating memory for authenticode | |
2387 | * signature data. */ | |
2388 | #define VERR_LDRVI_NO_MEMORY_SIGNATURE (-22907) | |
2389 | /** Image Verification Failure: Error allocating memory for section headers. */ | |
2390 | #define VERR_LDRVI_NO_MEMORY_SHDRS (-22908) | |
2391 | /** Image Verification Failure: Authenticode parsing output. */ | |
2392 | #define VERR_LDRVI_NO_MEMORY_PARSE_OUTPUT (-22909) | |
2393 | /** Image Verification Failure: Invalid security directory entry. */ | |
2394 | #define VERR_LDRVI_INVALID_SECURITY_DIR_ENTRY (-22910) | |
2395 | /** Image Verification Failure: */ | |
2396 | #define VERR_LDRVI_BAD_CERT_HDR_LENGTH (-22911) | |
2397 | /** Image Verification Failure: */ | |
2398 | #define VERR_LDRVI_BAD_CERT_HDR_REVISION (-22912) | |
2399 | /** Image Verification Failure: */ | |
2400 | #define VERR_LDRVI_BAD_CERT_HDR_TYPE (-22913) | |
2401 | /** Image Verification Failure: More than one certificate table entry. */ | |
2402 | #define VERR_LDRVI_BAD_CERT_MULTIPLE (-22914) | |
2403 | ||
2404 | /** Image Verification Failure: */ | |
2405 | #define VERR_LDRVI_BAD_MZ_OFFSET (-22915) | |
2406 | /** Image Verification Failure: Invalid section count. */ | |
2407 | #define VERR_LDRVI_INVALID_SECTION_COUNT (-22916) | |
2408 | /** Image Verification Failure: Raw data offsets and sizes are out of range. */ | |
2409 | #define VERR_LDRVI_SECTION_RAW_DATA_VALUES (-22917) | |
2410 | /** Optional header magic and target machine does not match. */ | |
2411 | #define VERR_LDRVI_MACHINE_OPT_HDR_MAGIC_MISMATCH (-22918) | |
2412 | /** Unsupported image target architecture. */ | |
2413 | #define VERR_LDRVI_UNSUPPORTED_ARCH (-22919) | |
2414 | ||
2415 | /** Image Verification Failure: Internal error in signature parser. */ | |
2416 | #define VERR_LDRVI_PARSE_IPE (-22921) | |
2417 | /** Generic BER parse error. Will be refined later. */ | |
2418 | #define VERR_LDRVI_PARSE_BER_ERROR (-22922) | |
2419 | ||
2420 | /** Expected the signed data content to be the object ID of | |
2421 | * SpcIndirectDataContent, found something else instead. */ | |
2422 | #define VERR_LDRVI_EXPECTED_INDIRECT_DATA_CONTENT_OID (-22923) | |
2423 | /** Page hash table size overflow. */ | |
2424 | #define VERR_LDRVI_PAGE_HASH_TAB_SIZE_OVERFLOW (-22924) | |
2425 | /** Page hash table is too long (covers signature data, i.e. itself). */ | |
2426 | #define VERR_LDRVI_PAGE_HASH_TAB_TOO_LONG (-22925) | |
2427 | /** The page hash table is not strictly ordered by offset. */ | |
2428 | #define VERR_LDRVI_PAGE_HASH_TAB_NOT_STRICTLY_SORTED (-22926) | |
2429 | /** The page hash table hashes data outside the defined and implicit sections. */ | |
2430 | #define VERR_PAGE_HASH_TAB_HASHES_NON_SECTION_DATA (-22927) | |
2431 | /** Page hash mismatch. */ | |
2432 | #define VERR_LDRVI_PAGE_HASH_MISMATCH (-22928) | |
2433 | /** Image hash mismatch. */ | |
2434 | #define VERR_LDRVI_IMAGE_HASH_MISMATCH (-22929) | |
2435 | ||
2436 | /** Cannot resolve symbol because it's a forwarder. */ | |
2437 | #define VERR_LDR_FORWARDER (-22950) | |
2438 | /** The symbol is not a forwarder. */ | |
2439 | #define VERR_LDR_NOT_FORWARDER (-22951) | |
2440 | /** Malformed forwarder entry. */ | |
2441 | #define VERR_LDR_BAD_FORWARDER (-22952) | |
2442 | /** Too long forwarder chain or there is a loop. */ | |
2443 | #define VERR_LDR_FORWARDER_CHAIN_TOO_LONG (-22953) | |
2444 | /** Support for forwarders has not been implemented. */ | |
2445 | #define VERR_LDR_FORWARDERS_NOT_SUPPORTED (-22954) | |
2446 | /** @} */ | |
2447 | ||
2448 | /** @name RTCrX509 status codes. | |
2449 | * @{ */ | |
2450 | /** Generic X.509 error. */ | |
2451 | #define VERR_CR_X509_GENERIC_ERROR (-23000) | |
2452 | /** Internal error in the X.509 code. */ | |
2453 | #define VERR_CR_X509_INTERNAL_ERROR (-23001) | |
2454 | /** Internal error in the X.509 certificate path building and verification | |
2455 | * code. */ | |
2456 | #define VERR_CR_X509_CERTPATHS_INTERNAL_ERROR (-23002) | |
2457 | /** Path not verified yet. */ | |
2458 | #define VERR_CR_X509_NOT_VERIFIED (-23003) | |
2459 | /** The certificate path has no trust anchor. */ | |
2460 | #define VERR_CR_X509_NO_TRUST_ANCHOR (-23004) | |
2461 | /** Unknown X.509 certificate signature algorithm. */ | |
2462 | #define VERR_CR_X509_UNKNOWN_CERT_SIGN_ALGO (-23005) | |
2463 | /** Certificate signature algorithm mismatch. */ | |
2464 | #define VERR_CR_X509_CERT_SIGN_ALGO_MISMATCH (-23006) | |
2465 | /** The signature algorithm in the to-be-signed certificate part does not match | |
2466 | * the one associated with the signature. */ | |
2467 | #define VERR_CR_X509_CERT_TBS_SIGN_ALGO_MISMATCH (-23007) | |
2468 | /** Certificate extensions requires certificate version 3 or later. */ | |
2469 | #define VERR_CR_X509_TBSCERT_EXTS_REQ_V3 (-23008) | |
2470 | /** Unique issuer and subject IDs require version certificate 2. */ | |
2471 | #define VERR_CR_X509_TBSCERT_UNIQUE_IDS_REQ_V2 (-23009) | |
2472 | /** Certificate serial number length is out of bounds. */ | |
2473 | #define VERR_CR_X509_TBSCERT_SERIAL_NUMBER_OUT_OF_BOUNDS (-23010) | |
2474 | /** Unsupported X.509 certificate version. */ | |
2475 | #define VERR_CR_X509_TBSCERT_UNSUPPORTED_VERSION (-23011) | |
2476 | /** Public key is too small. */ | |
2477 | #define VERR_CR_X509_PUBLIC_KEY_TOO_SMALL (-23012) | |
2478 | /** Invalid string tag for a X.509 name object. */ | |
2479 | #define VERR_CR_X509_INVALID_NAME_STRING_TAG (-23013) | |
2480 | /** Empty string in X.509 name object. */ | |
2481 | #define VERR_CR_X509_NAME_EMPTY_STRING (-23014) | |
2482 | /** Non-string object inside X.509 name object. */ | |
2483 | #define VERR_CR_X509_NAME_NOT_STRING (-23015) | |
2484 | /** Empty set inside X.509 name. */ | |
2485 | #define VERR_CR_X509_NAME_EMPTY_SET (-23016) | |
2486 | /** Empty sub-string set inside X.509 name. */ | |
2487 | #define VERR_CR_X509_NAME_EMPTY_SUB_SET (-23017) | |
2488 | /** The NotBefore and NotAfter values of an X.509 Validity object seems to | |
2489 | * have been swapped around. */ | |
2490 | #define VERR_CR_X509_VALIDITY_SWAPPED (-23018) | |
2491 | /** Duplicate certificate extension. */ | |
2492 | #define VERR_CR_X509_TBSCERT_DUPLICATE_EXTENSION (-23019) | |
2493 | /** Missing relative distinguished name map entry. */ | |
2494 | #define VERR_CR_X509_NAME_MISSING_RDN_MAP_ENTRY (-23020) | |
2495 | /** Certificate path validator: No trusted certificate paths. */ | |
2496 | #define VERR_CR_X509_CPV_NO_TRUSTED_PATHS (-23021) | |
2497 | /** Certificate path validator: No valid certificate policy. */ | |
2498 | #define VERR_CR_X509_CPV_NO_VALID_POLICY (-23022) | |
2499 | /** Certificate path validator: Unknown critical certificate extension. */ | |
2500 | #define VERR_CR_X509_CPV_UNKNOWN_CRITICAL_EXTENSION (-23023) | |
2501 | /** Certificate path validator: Intermediate certificate is missing the | |
2502 | * KeyCertSign usage flag. */ | |
2503 | #define VERR_CR_X509_CPV_MISSING_KEY_CERT_SIGN (-23024) | |
2504 | /** Certificate path validator: Hit the max certificate path length before | |
2505 | * reaching trust anchor. */ | |
2506 | #define VERR_CR_X509_CPV_MAX_PATH_LENGTH (-23025) | |
2507 | /** Certificate path validator: Intermediate certificate is not marked as a | |
2508 | * certificate authority (CA). */ | |
2509 | #define VERR_CR_X509_CPV_NOT_CA_CERT (-23026) | |
2510 | /** Certificate path validator: Intermediate certificate is not a version 3 | |
2511 | * certificate. */ | |
2512 | #define VERR_CR_X509_CPV_NOT_V3_CERT (-23027) | |
2513 | /** Certificate path validator: Invalid policy mapping (to/from anyPolicy). */ | |
2514 | #define VERR_CR_X509_CPV_INVALID_POLICY_MAPPING (-23028) | |
2515 | /** Certificate path validator: Name constraints permits no names. */ | |
2516 | #define VERR_CR_X509_CPV_NO_PERMITTED_NAMES (-23029) | |
2517 | /** Certificate path validator: Name constraints does not permits the | |
2518 | * certificate name. */ | |
2519 | #define VERR_CR_X509_CPV_NAME_NOT_PERMITTED (-23030) | |
2520 | /** Certificate path validator: Name constraints does not permits the | |
2521 | * alternative certificate name. */ | |
2522 | #define VERR_CR_X509_CPV_ALT_NAME_NOT_PERMITTED (-23031) | |
2523 | /** Certificate path validator: Intermediate certificate subject does not | |
2524 | * match child issuer property. */ | |
2525 | #define VERR_CR_X509_CPV_ISSUER_MISMATCH (-23032) | |
2526 | /** Certificate path validator: The certificate is not valid at the | |
2527 | * specified time. */ | |
2528 | #define VERR_CR_X509_CPV_NOT_VALID_AT_TIME (-23033) | |
2529 | /** Certificate path validator: Unexpected choice found in general subtree | |
2530 | * object (name constraints). */ | |
2531 | #define VERR_CR_X509_CPV_UNEXP_GENERAL_SUBTREE_CHOICE (-23034) | |
2532 | /** Certificate path validator: Unexpected minimum value found in general | |
2533 | * subtree object (name constraints). */ | |
2534 | #define VERR_CR_X509_CPV_UNEXP_GENERAL_SUBTREE_MIN (-23035) | |
2535 | /** Certificate path validator: Unexpected maximum value found in | |
2536 | * general subtree object (name constraints). */ | |
2537 | #define VERR_CR_X509_CPV_UNEXP_GENERAL_SUBTREE_MAX (-23036) | |
2538 | /** Certificate path builder: Encountered bad certificate context. */ | |
2539 | #define VERR_CR_X509_CPB_BAD_CERT_CTX (-23037) | |
2540 | /** OpenSSL d2i_X509 failed. */ | |
2541 | #define VERR_CR_X509_OSSL_D2I_FAILED (-23090) | |
2542 | /** @} */ | |
2543 | ||
2544 | /** @name RTCrPkcs7 status codes. | |
2545 | * @{ */ | |
2546 | /** Generic PKCS \#7 error. */ | |
2547 | #define VERR_CR_PKCS7_GENERIC_ERROR (-23300) | |
2548 | /** Signed data verification failed because there are zero signer infos. */ | |
2549 | #define VERR_CR_PKCS7_NO_SIGNER_INFOS (-23301) | |
2550 | /** Signed data certificate not found. */ | |
2551 | #define VERR_CR_PKCS7_SIGNED_DATA_CERT_NOT_FOUND (-23302) | |
2552 | /** Signed data verification failed due to key usage issues. */ | |
2553 | #define VERR_CR_PKCS7_KEY_USAGE_MISMATCH (-23303) | |
2554 | /** Signed data verification failed because of missing (or duplicate) | |
2555 | * authenticated content-type attribute. */ | |
2556 | #define VERR_CR_PKCS7_MISSING_CONTENT_TYPE_ATTRIB (-23304) | |
2557 | /** Signed data verification failed because of the authenticated content-type | |
2558 | * attribute did not match. */ | |
2559 | #define VERR_CR_PKCS7_CONTENT_TYPE_ATTRIB_MISMATCH (-23305) | |
2560 | /** Signed data verification failed because of a malformed authenticated | |
2561 | * content-type attribute. */ | |
2562 | #define VERR_CR_PKCS7_BAD_CONTENT_TYPE_ATTRIB (-23306) | |
2563 | /** Signed data verification failed because of missing (or duplicate) | |
2564 | * authenticated message-digest attribute. */ | |
2565 | #define VERR_CR_PKCS7_MISSING_MESSAGE_DIGEST_ATTRIB (-23307) | |
2566 | /** Signed data verification failed because the authenticated message-digest | |
2567 | * attribute did not match. */ | |
2568 | #define VERR_CR_PKCS7_MESSAGE_DIGEST_ATTRIB_MISMATCH (-23308) | |
2569 | /** Signed data verification failed because of a malformed authenticated | |
2570 | * message-digest attribute. */ | |
2571 | #define VERR_CR_PKCS7_BAD_MESSAGE_DIGEST_ATTRIB (-23309) | |
2572 | /** Signature verification failed. */ | |
2573 | #define VERR_CR_PKCS7_SIGNATURE_VERIFICATION_FAILED (-23310) | |
2574 | /** Internal PKCS \#7 error. */ | |
2575 | #define VERR_CR_PKCS7_INTERNAL_ERROR (-22311) | |
2576 | /** OpenSSL d2i_PKCS7 failed. */ | |
2577 | #define VERR_CR_PKCS7_OSSL_D2I_FAILED (-22312) | |
2578 | /** OpenSSL PKCS \#7 verification failed. */ | |
2579 | #define VERR_CR_PKCS7_OSSL_VERIFY_FAILED (-22313) | |
2580 | /** Digest algorithm parameters are not supported by the PKCS \#7 code. */ | |
2581 | #define VERR_CR_PKCS7_DIGEST_PARAMS_NOT_IMPL (-22314) | |
2582 | /** The digest algorithm of a signer info entry was not found in the list of | |
2583 | * digest algorithms in the signed data. */ | |
2584 | #define VERR_CR_PKCS7_DIGEST_ALGO_NOT_FOUND_IN_LIST (-22315) | |
2585 | /** The PKCS \#7 content is not signed data. */ | |
2586 | #define VERR_CR_PKCS7_NOT_SIGNED_DATA (-22316) | |
2587 | /** No digest algorithms listed in PKCS \#7 signed data. */ | |
2588 | #define VERR_CR_PKCS7_NO_DIGEST_ALGORITHMS (-22317) | |
2589 | /** Too many digest algorithms used by PKCS \#7 signed data. This is an | |
2590 | * internal limitation of the code that aims at saving kernel stack space. */ | |
2591 | #define VERR_CR_PKCS7_TOO_MANY_DIGEST_ALGORITHMS (-22318) | |
2592 | /** Error creating digest algorithm calculator. */ | |
2593 | #define VERR_CR_PKCS7_DIGEST_CREATE_ERROR (-22319) | |
2594 | /** Error while calculating a digest for a PKCS \#7 verification operation. */ | |
2595 | #define VERR_CR_PKCS7_DIGEST_CALC_ERROR (-22320) | |
2596 | /** Unsupported PKCS \#7 signed data version. */ | |
2597 | #define VERR_CR_PKCS7_SIGNED_DATA_VERSION (-22350) | |
2598 | /** PKCS \#7 signed data has no digest algorithms listed. */ | |
2599 | #define VERR_CR_PKCS7_SIGNED_DATA_NO_DIGEST_ALGOS (-22351) | |
2600 | /** Unknown digest algorithm used by PKCS \#7 object. */ | |
2601 | #define VERR_CR_PKCS7_UNKNOWN_DIGEST_ALGORITHM (-22352) | |
2602 | /** Expected PKCS \#7 object to ship at least one certificate. */ | |
2603 | #define VERR_CR_PKCS7_NO_CERTIFICATES (-22353) | |
2604 | /** Expected PKCS \#7 object to not contain any CRLs. */ | |
2605 | #define VERR_CR_PKCS7_EXPECTED_NO_CRLS (-22354) | |
2606 | /** Expected PKCS \#7 object to contain exactly on signer info entry. */ | |
2607 | #define VERR_CR_PKCS7_EXPECTED_ONE_SIGNER_INFO (-22355) | |
2608 | /** Unsupported PKCS \#7 signer info version. */ | |
2609 | #define VERR_CR_PKCS7_SIGNER_INFO_VERSION (-22356) | |
2610 | /** PKCS \#7 singer info contains no issuer serial number. */ | |
2611 | #define VERR_CR_PKCS7_SIGNER_INFO_NO_ISSUER_SERIAL_NO (-22357) | |
2612 | /** Expected PKCS \#7 object to ship the signer certificate(s). */ | |
2613 | #define VERR_CR_PKCS7_SIGNER_CERT_NOT_SHIPPED (-22358) | |
2614 | /** The encrypted digest algorithm does not match the one in the certificate. */ | |
2615 | #define VERR_CR_PKCS7_SIGNER_INFO_DIGEST_ENCRYPT_MISMATCH (-22359) | |
2616 | /** @} */ | |
2617 | ||
2618 | /** @name RTCrSpc status codes. | |
2619 | * @{ */ | |
2620 | /** Generic SPC error. */ | |
2621 | #define VERR_CR_SPC_GENERIC_ERROR (-23400) | |
2622 | /** SPC requires there to be exactly one SignerInfo entry. */ | |
2623 | #define VERR_CR_SPC_NOT_EXACTLY_ONE_SIGNER_INFOS (-23401) | |
2624 | /** There shall be exactly one digest algorithm to go with the single | |
2625 | * SingerInfo entry required by SPC. */ | |
2626 | #define VERR_CR_SPC_NOT_EXACTLY_ONE_DIGEST_ALGO (-23402) | |
2627 | /** The digest algorithm in the SignerInfo does not match the one in the | |
2628 | * indirect data. */ | |
2629 | #define VERR_CR_SPC_SIGNED_IND_DATA_DIGEST_ALGO_MISMATCH (-23403) | |
2630 | /** The digest algorithm in the indirect data was not found in the list of | |
2631 | * digest algorithms in the signed data structure. */ | |
2632 | #define VERR_CR_SPC_IND_DATA_DIGEST_ALGO_NOT_IN_DIGEST_ALGOS (-23404) | |
2633 | /** The digest algorithm is not known to us. */ | |
2634 | #define VERR_CR_SPC_UNKNOWN_DIGEST_ALGO (-23405) | |
2635 | /** The indirect data digest size does not match the digest algorithm. */ | |
2636 | #define VERR_CR_SPC_IND_DATA_DIGEST_SIZE_MISMATCH (-23406) | |
2637 | /** Expected PE image data inside indirect data object. */ | |
2638 | #define VERR_CR_SPC_EXPECTED_PE_IMAGE_DATA (-23407) | |
2639 | /** Internal SPC error: The PE image data is missing. */ | |
2640 | #define VERR_CR_SPC_PEIMAGE_DATA_NOT_PRESENT (-23408) | |
2641 | /** Bad SPC object moniker UUID field. */ | |
2642 | #define VERR_CR_SPC_BAD_MONIKER_UUID (-23409) | |
2643 | /** Unknown SPC object moniker UUID. */ | |
2644 | #define VERR_CR_SPC_UNKNOWN_MONIKER_UUID (-23410) | |
2645 | /** Internal SPC error: Bad object moniker choice value. */ | |
2646 | #define VERR_CR_SPC_BAD_MONIKER_CHOICE (-23411) | |
2647 | /** Internal SPC error: Bad object moniker data pointer. */ | |
2648 | #define VERR_CR_SPC_MONIKER_BAD_DATA (-23412) | |
2649 | /** Multiple PE image page hash tables. */ | |
2650 | #define VERR_CR_SPC_PEIMAGE_MULTIPLE_HASH_TABS (-23413) | |
2651 | /** Unknown SPC PE image attribute. */ | |
2652 | #define VERR_CR_SPC_PEIMAGE_UNKNOWN_ATTRIBUTE (-23414) | |
2653 | /** URL not expected in SPC PE image data. */ | |
2654 | #define VERR_CR_SPC_PEIMAGE_URL_UNEXPECTED (-23415) | |
2655 | /** PE image data without any valid content was not expected. */ | |
2656 | #define VERR_CR_SPC_PEIMAGE_NO_CONTENT (-23416) | |
2657 | /** @} */ | |
2658 | ||
2659 | /** @name RTCrPkix status codes. | |
2660 | * @{ */ | |
2661 | /** Generic PKCS \#7 error. */ | |
2662 | #define VERR_CR_PKIX_GENERIC_ERROR (-23500) | |
2663 | /** Parameters was presented to a signature schema that does not take any. */ | |
2664 | #define VERR_CR_PKIX_SIGNATURE_TAKES_NO_PARAMETERS (-23501) | |
2665 | /** Unknown hash digest type. */ | |
2666 | #define VERR_CR_PKIX_UNKNOWN_DIGEST_TYPE (-23502) | |
2667 | /** Internal error. */ | |
2668 | #define VERR_CR_PKIX_INTERNAL_ERROR (-23503) | |
2669 | /** The hash is too long for the key used when signing/verifying. */ | |
2670 | #define VERR_CR_PKIX_HASH_TOO_LONG_FOR_KEY (-23504) | |
2671 | /** The signature is too long for the scratch buffer. */ | |
2672 | #define VERR_CR_PKIX_SIGNATURE_TOO_LONG (-23505) | |
2673 | /** The signature is greater than or equal to the key. */ | |
2674 | #define VERR_CR_PKIX_SIGNATURE_GE_KEY (-23506) | |
2675 | /** The signature is negative. */ | |
2676 | #define VERR_CR_PKIX_SIGNATURE_NEGATIVE (-23507) | |
2677 | /** Invalid signature length. */ | |
2678 | #define VERR_CR_PKIX_INVALID_SIGNATURE_LENGTH (-23508) | |
2679 | /** PKIX signature no does not match up to the current data. */ | |
2680 | #define VERR_CR_PKIX_SIGNATURE_MISMATCH (-23509) | |
2681 | /** PKIX cipher algorithm parameters are not implemented. */ | |
2682 | #define VERR_CR_PKIX_CIPHER_ALGO_PARAMS_NOT_IMPL (-23510) | |
2683 | /** Cipher algorithm is not known to us. */ | |
2684 | #define VERR_CR_PKIX_CIPHER_ALGO_NOT_KNOWN (-23511) | |
2685 | /** PKIX cipher algorithm is not known to OpenSSL. */ | |
2686 | #define VERR_CR_PKIX_OSSL_CIPHER_ALGO_NOT_KNOWN (-23512) | |
2687 | /** PKIX cipher algorithm is not known to OpenSSL EVP API. */ | |
2688 | #define VERR_CR_PKIX_OSSL_CIPHER_ALGO_NOT_KNOWN_EVP (-23513) | |
2689 | /** OpenSSL failed to init PKIX cipher algorithm context. */ | |
2690 | #define VERR_CR_PKIX_OSSL_CIPHER_ALOG_INIT_FAILED (-23514) | |
2691 | /** Final OpenSSL PKIX verification failed. */ | |
2692 | #define VERR_CR_PKIX_OSSL_VERIFY_FINAL_FAILED (-23515) | |
2693 | /** OpenSSL failed to decode the public key. */ | |
2694 | #define VERR_CR_PKIX_OSSL_D2I_PUBLIC_KEY_FAILED (-23516) | |
2695 | /** The EVP_PKEY_type API in OpenSSL failed. */ | |
2696 | #define VERR_CR_PKIX_OSSL_EVP_PKEY_TYPE_ERROR (-23517) | |
2697 | /** @} */ | |
2698 | ||
2699 | /** @name RTCrStore status codes. | |
2700 | * @{ */ | |
2701 | /** Generic store error. */ | |
2702 | #define VERR_CR_STORE_GENERIC_ERROR (-23700) | |
2703 | /** @} */ | |
2704 | ||
2705 | /** @name RTCrRsa status codes. | |
2706 | * @{ */ | |
2707 | /** Generic RSA error. */ | |
2708 | #define VERR_CR_RSA_GENERIC_ERROR (-23900) | |
2709 | /** @} */ | |
2710 | ||
2711 | /** @name RTBigNum status codes. | |
2712 | * @{ */ | |
2713 | /** Sensitive input requires the result(s) to be initialized as sensitive. */ | |
2714 | #define VERR_BIGNUM_SENSITIVE_INPUT (-24000) | |
2715 | /** Attempt to divide by zero. */ | |
2716 | #define VERR_BIGNUM_DIV_BY_ZERO (-24001) | |
2717 | /** Negative exponent makes no sense to integer math. */ | |
2718 | #define VERR_BIGNUM_NEGATIVE_EXPONENT (-24002) | |
2719 | ||
2720 | /** @} */ | |
2721 | ||
2722 | /** @name RTCrDigest status codes. | |
2723 | * @{ */ | |
2724 | /** OpenSSL failed to initialize the digest algorithm context. */ | |
2725 | #define VERR_CR_DIGEST_OSSL_DIGEST_INIT_ERROR (-24200) | |
2726 | /** OpenSSL failed to clone the digest algorithm context. */ | |
2727 | #define VERR_CR_DIGEST_OSSL_DIGEST_CTX_COPY_ERROR (-24201) | |
2728 | /** @} */ | |
2729 | ||
2730 | /** @name RTPath status codes. | |
2731 | * @{ */ | |
2732 | /** Unknown glob variable. */ | |
2733 | #define VERR_PATH_MATCH_UNKNOWN_VARIABLE (-24400) | |
2734 | /** The specified glob variable must be first in the pattern. */ | |
2735 | #define VERR_PATH_MATCH_VARIABLE_MUST_BE_FIRST (-24401) | |
2736 | /** Hit unimplemented glob pattern matching feature. */ | |
2737 | #define VERR_PATH_MATCH_FEATURE_NOT_IMPLEMENTED (-24402) | |
2738 | /** Unknown character class in glob pattern. */ | |
2739 | #define VERR_PATH_GLOB_UNKNOWN_CHAR_CLASS (-24403) | |
2740 | /** @} */ | |
2741 | ||
2742 | /** @name RTUri status codes. | |
2743 | * @{ */ | |
2744 | /** The URI is empty */ | |
2745 | #define VERR_URI_EMPTY (-24600) | |
2746 | /** The URI is too short to be a valid URI. */ | |
2747 | #define VERR_URI_TOO_SHORT (-24601) | |
2748 | /** Invalid scheme. */ | |
2749 | #define VERR_URI_INVALID_SCHEME (-24602) | |
2750 | /** Invalid port number. */ | |
2751 | #define VERR_URI_INVALID_PORT_NUMBER (-24603) | |
2752 | /** Invalid escape sequence. */ | |
2753 | #define VERR_URI_INVALID_ESCAPE_SEQ (-24604) | |
2754 | /** Escape URI char decodes as zero (the C string terminator). */ | |
2755 | #define VERR_URI_ESCAPED_ZERO (-24605) | |
2756 | /** Escaped URI characters does not decode to valid UTF-8. */ | |
2757 | #define VERR_URI_ESCAPED_CHARS_NOT_VALID_UTF8 (-24606) | |
2758 | /** Escaped URI character is not a valid UTF-8 lead byte. */ | |
2759 | #define VERR_URI_INVALID_ESCAPED_UTF8_LEAD_BYTE (-24607) | |
2760 | /** Escaped URI character sequence with invalid UTF-8 continutation byte. */ | |
2761 | #define VERR_URI_INVALID_ESCAPED_UTF8_CONTINUATION_BYTE (-24608) | |
2762 | /** Missing UTF-8 continutation in escaped URI character sequence. */ | |
2763 | #define VERR_URI_MISSING_UTF8_CONTINUATION_BYTE (-24609) | |
2764 | /** Expected URI using the 'file:' scheme. */ | |
2765 | #define VERR_URI_NOT_FILE_SCHEME (-24610) | |
2766 | /** @} */ | |
2767 | ||
2768 | /** @name RTJson status codes. | |
2769 | * @{ */ | |
2770 | /** The called method does not work with the value type of the given JSON value. */ | |
2771 | #define VERR_JSON_VALUE_INVALID_TYPE (-24700) | |
2772 | /** The iterator reached the end. */ | |
2773 | #define VERR_JSON_ITERATOR_END (-24701) | |
2774 | /** The JSON document is malformed. */ | |
2775 | #define VERR_JSON_MALFORMED (-24702) | |
2776 | /** @} */ | |
2777 | ||
6d209b23 SF |
2778 | /** @name RTVfs status codes. |
2779 | * @{ */ | |
2780 | /** Unknown file system format. */ | |
2781 | #define VERR_VFS_UNKNOWN_FORMAT (-24800) | |
2782 | /** Found bogus values in the file system. */ | |
2783 | #define VERR_VFS_BOGUS_FORMAT (-24801) | |
2784 | /** Found bogus offset in the file system. */ | |
2785 | #define VERR_VFS_BOGUS_OFFSET (-24802) | |
2786 | /** Unsupported file system format. */ | |
2787 | #define VERR_VFS_UNSUPPORTED_FORMAT (-24803) | |
2788 | /** @} */ | |
2789 | ||
2790 | /** @name RTFsIsoMaker status codes. | |
2791 | * @{ */ | |
2792 | /** No validation entry in the boot catalog. */ | |
2793 | #define VERR_ISOMK_BOOT_CAT_NO_VALIDATION_ENTRY (-25000) | |
2794 | /** No default entry in the boot catalog. */ | |
2795 | #define VERR_ISOMK_BOOT_CAT_NO_DEFAULT_ENTRY (-25001) | |
2796 | /** Expected section header. */ | |
2797 | #define VERR_ISOMK_BOOT_CAT_EXPECTED_SECTION_HEADER (-25002) | |
2798 | /** Entry in a boot catalog section is empty. */ | |
2799 | #define VERR_ISOMK_BOOT_CAT_EMPTY_ENTRY (-25003) | |
2800 | /** Entry in a boot catalog section is another section. */ | |
2801 | #define VERR_ISOMK_BOOT_CAT_INVALID_SECTION_SIZE (-25004) | |
2802 | /** Unsectioned boot catalog entry. */ | |
2803 | #define VERR_ISOMK_BOOT_CAT_ERRATIC_ENTRY (-25005) | |
2804 | /** The file is too big for the current ISO level (4GB+ sized files | |
2805 | * requires ISO level 3). */ | |
2806 | #define VERR_ISOMK_FILE_TOO_BIG_REQ_ISO_LEVEL_3 (-25006) | |
2807 | /** Cannot add symbolic link to namespace which isn't configured to support it. */ | |
2808 | #define VERR_ISOMK_SYMLINK_REQ_ROCK_RIDGE (-25007) | |
2809 | /** Cannot add symbolic link to one of the selected namespaces. */ | |
2810 | #define VINF_ISOMK_SYMLINK_REQ_ROCK_RIDGE (25007) | |
2811 | /** Cannot add symbolic link because no namespace is configured to support it. */ | |
2812 | #define VERR_ISOMK_SYMLINK_SUPPORT_DISABLED (-25008) | |
2813 | /** No space for rock ridge 'CE' entry in directory record. */ | |
2814 | #define VERR_ISOMK_RR_NO_SPACE_FOR_CE (-25009) | |
2815 | /** Internal ISO maker error: Rock ridge read problem. */ | |
2816 | #define VERR_ISOMK_IPE_RR_READ (-25010) | |
2817 | /** Internal ISO maker error: Buggy namespace table. */ | |
2818 | #define VERR_ISOMK_IPE_TABLE (-25011) | |
2819 | /** Internal ISO maker error: Namespace problem \#1. */ | |
2820 | #define VERR_ISOMK_IPE_NAMESPACE_1 (-25012) | |
2821 | /** Internal ISO maker error: Namespace problem \#2. */ | |
2822 | #define VERR_ISOMK_IPE_NAMESPACE_2 (-25013) | |
2823 | /** Internal ISO maker error: Namespace problem \#3. */ | |
2824 | #define VERR_ISOMK_IPE_NAMESPACE_3 (-25014) | |
2825 | /** Internal ISO maker error: Namespace problem \#4. */ | |
2826 | #define VERR_ISOMK_IPE_NAMESPACE_4 (-25015) | |
2827 | /** Internal ISO maker error: Namespace problem \#5. */ | |
2828 | #define VERR_ISOMK_IPE_NAMESPACE_5 (-25016) | |
2829 | /** Internal ISO maker error: Namespace problem \#6. */ | |
2830 | #define VERR_ISOMK_IPE_NAMESPACE_6 (-25017) | |
2831 | /** Internal ISO maker error: Empty path. */ | |
2832 | #define VERR_ISOMK_IPE_EMPTY_PATH (-25018) | |
2833 | /** Internal ISO maker error: Unexpected empty component. */ | |
2834 | #define VERR_ISOMK_IPE_EMPTY_COMPONENT (-25019) | |
2835 | /** Internal ISO maker error: Expected path to start with root slash. */ | |
2836 | #define VERR_ISOMK_IPE_ROOT_SLASH (-25020) | |
2837 | /** Internal ISO maker error: Descriptor miscounting. */ | |
2838 | #define VERR_ISOMK_IPE_DESC_COUNT (-25021) | |
2839 | /** Internal ISO maker error: Buffer size. */ | |
2840 | #define VERR_ISOMK_IPE_BUFFER_SIZE (-25022) | |
2841 | /** Internal ISO maker error: Boot catalog file handle problem. */ | |
2842 | #define VERR_ISOMK_IPE_BOOT_CAT_FILE (-25023) | |
2843 | /** Internal ISO maker error: Inconsistency produing trans.tbl file. */ | |
2844 | #define VERR_ISOMK_IPE_PRODUCE_TRANS_TBL (-25024) | |
2845 | /** Internal ISO maker error: Read file data probem \#1. */ | |
2846 | #define VERR_ISOMK_IPE_READ_FILE_DATA_1 (-25025) | |
2847 | /** Internal ISO maker error: Read file data probem \#2. */ | |
2848 | #define VERR_ISOMK_IPE_READ_FILE_DATA_2 (-25026) | |
2849 | /** Internal ISO maker error: Read file data probem \#3. */ | |
2850 | #define VERR_ISOMK_IPE_READ_FILE_DATA_3 (-25027) | |
2851 | /** Internal ISO maker error: Finalization problem \#1. */ | |
2852 | #define VERR_ISOMK_IPE_FINALIZE_1 (-25028) | |
2853 | /** The spill file grew larger than 4GB. */ | |
2854 | #define VERR_ISOMK_RR_SPILL_FILE_FULL (-25029) | |
2855 | ||
2856 | /** Requested to import an unknown ISO format. */ | |
2857 | #define VERR_ISOMK_IMPORT_UNKNOWN_FORMAT (-25100) | |
2858 | /** Too many volume descriptors in the import ISO. */ | |
2859 | #define VERR_ISOMK_IMPORT_TOO_MANY_VOL_DESCS (-25101) | |
2860 | /** Import ISO contains a bad volume descriptor header. */ | |
2861 | #define VERR_ISOMK_IMPORT_INVALID_VOL_DESC_HDR (-25102) | |
2862 | /** Import ISO contains more than one primary volume descriptor. */ | |
2863 | #define VERR_ISOMK_IMPORT_MULTIPLE_PRIMARY_VOL_DESCS (-25103) | |
2864 | /** Import ISO contains more than one el torito descriptor. */ | |
2865 | #define VERR_ISOMK_IMPORT_MULTIPLE_EL_TORITO_DESCS (-25104) | |
2866 | /** Import ISO contains more than one joliet volume descriptor. */ | |
2867 | #define VERR_ISOMK_IMPORT_MULTIPLE_JOLIET_VOL_DESCS (-25105) | |
2868 | /** Import ISO starts with supplementary volume descriptor before any | |
2869 | * primary ones. */ | |
2870 | #define VERR_ISOMK_IMPORT_SUPPLEMENTARY_BEFORE_PRIMARY (-25106) | |
2871 | /** Import ISO contains an unsupported primary volume descriptor version. */ | |
2872 | #define VERR_IOSMK_IMPORT_PRIMARY_VOL_DESC_VER (-25107) | |
2873 | /** Import ISO contains a bad primary volume descriptor. */ | |
2874 | #define VERR_ISOMK_IMPORT_BAD_PRIMARY_VOL_DESC (-25108) | |
2875 | /** Import ISO contains an unsupported supplementary volume descriptor | |
2876 | * version. */ | |
2877 | #define VERR_IOSMK_IMPORT_SUP_VOL_DESC_VER (-25109) | |
2878 | /** Import ISO contains a bad supplementary volume descriptor. */ | |
2879 | #define VERR_ISOMK_IMPORT_BAD_SUP_VOL_DESC (-25110) | |
2880 | /** Import ISO uses a logical block size other than 2KB. */ | |
2881 | #define VERR_ISOMK_IMPORT_LOGICAL_BLOCK_SIZE_NOT_2KB (-25111) | |
2882 | /** Import ISO contains more than volume. */ | |
2883 | #define VERR_ISOMK_IMPORT_MORE_THAN_ONE_VOLUME_IN_SET (-25112) | |
2884 | /** Import ISO uses invalid volume sequence number. */ | |
2885 | #define VERR_ISOMK_IMPORT_INVALID_VOLUMNE_SEQ_NO (-25113) | |
2886 | /** Import ISO has different volume space sizes of primary and supplementary | |
2887 | * volume descriptors. */ | |
2888 | #define VERR_ISOMK_IMPORT_VOLUME_SPACE_SIZE_MISMATCH (-25114) | |
2889 | /** Import ISO has different volume set sizes of primary and supplementary | |
2890 | * volume descriptors. */ | |
2891 | #define VERR_ISOMK_IMPORT_VOLUME_IN_SET_MISMATCH (-25115) | |
2892 | /** Import ISO contains a bad root directory record. */ | |
2893 | #define VERR_ISOMK_IMPORT_BAD_ROOT_DIR_REC (-25116) | |
2894 | /** Import ISO contains a zero sized root directory. */ | |
2895 | #define VERR_ISOMK_IMPORT_ZERO_SIZED_ROOT_DIR (-25117) | |
2896 | /** Import ISO contains a root directory with a mismatching volume sequence | |
2897 | * number. */ | |
2898 | #define VERR_ISOMK_IMPORT_ROOT_VOLUME_SEQ_NO (-25118) | |
2899 | /** Import ISO contains a root directory with an out of bounds data extent. */ | |
2900 | #define VERR_ISOMK_IMPORT_ROOT_DIR_EXTENT_OUT_OF_BOUNDS (-25119) | |
2901 | /** Import ISO contains a root directory with a bad record length. */ | |
2902 | #define VERR_ISOMK_IMPORT_BAD_ROOT_DIR_REC_LENGTH (-25120) | |
2903 | /** Import ISO contains a root directory without the directory flag set. */ | |
2904 | #define VERR_ISOMK_IMPORT_ROOT_DIR_WITHOUT_DIR_FLAG (-25121) | |
2905 | /** Import ISO contains a root directory with multiple extents. */ | |
2906 | #define VERR_ISOMK_IMPORT_ROOT_DIR_IS_MULTI_EXTENT (-25122) | |
2907 | /** Import ISO contains a too deep directory subtree. */ | |
2908 | #define VERR_ISOMK_IMPORT_TOO_DEEP_DIR_TREE (-25123) | |
2909 | /** Import ISO contains a bad directory record. */ | |
2910 | #define VERR_ISOMK_IMPORT_BAD_DIR_REC (-25124) | |
2911 | /** Import ISO contains a directory record with a mismatching volume sequence | |
2912 | * number. */ | |
2913 | #define VERR_ISOMK_IMPORT_DIR_REC_VOLUME_SEQ_NO (-25125) | |
2914 | /** Import ISO contains a directory with an extent that is out of bounds. */ | |
2915 | #define VERR_ISOMK_IMPORT_DIR_REC_EXTENT_OUT_OF_BOUNDS (-25126) | |
2916 | /** Import ISO contains a directory with a bad record length. */ | |
2917 | #define VERR_ISOMK_IMPORT_BAD_DIR_REC_LENGTH (-25127) | |
2918 | /** Import ISO contains a '.' or '..' directory record with a bad name | |
2919 | * length. */ | |
2920 | #define VERR_ISOMK_IMPORT_DOT_DIR_REC_BAD_NAME_LENGTH (-25128) | |
2921 | /** Import ISO contains a '.' or '..' directory record with a bad name. */ | |
2922 | #define VERR_ISOMK_IMPORT_DOT_DIR_REC_BAD_NAME (-25129) | |
2923 | /** Import ISO contains a directory with a more than one extent, that's | |
2924 | * currently not supported. */ | |
2925 | #define VERR_ISOMK_IMPORT_DIR_WITH_MORE_EXTENTS (-25130) | |
2926 | /** Import ISO contains a multi-extent directory record that differs | |
2927 | * significantly from first record. */ | |
2928 | #define VERR_ISOMK_IMPORT_MISMATCHING_MULTI_EXTENT_REC (-25131) | |
2929 | /** Import ISO contains a non-final multi-extent directory record with a | |
2930 | * size that isn't block aligned. */ | |
2931 | #define VERR_ISOMK_IMPORT_MISALIGNED_MULTI_EXTENT (-25132) | |
2932 | /** Import ISO contains a non-contigiuous multi-extent data, this is | |
2933 | * currently not supported. */ | |
2934 | #define VERR_ISOMK_IMPORT_NON_CONTIGUOUS_MULTI_EXTENT (-25133) | |
2935 | ||
2936 | /** The boot catalog block in the import ISO is out of bounds. */ | |
2937 | #define VERR_ISOMK_IMPORT_BOOT_CAT_BAD_OUT_OF_BOUNDS (-25140) | |
2938 | /** The boot catalog block in the import ISO has an incorrect validation | |
2939 | * header ID. */ | |
2940 | #define VERR_ISOMK_IMPORT_BOOT_CAT_BAD_VALIDATION_HEADER_ID (-25141) | |
2941 | /** The boot catalog validation entry in the import ISO has incorrect keys. */ | |
2942 | #define VERR_ISOMK_IMPORT_BOOT_CAT_BAD_VALIDATION_KEYS (-25142) | |
2943 | /** The boot catalog validation entry in the import ISO has an incorrect checksum. */ | |
2944 | #define VERR_ISOMK_IMPORT_BOOT_CAT_BAD_VALIDATION_CHECKSUM (-25143) | |
2945 | /** A boot catalog entry in the import ISO has an unknown type. */ | |
2946 | #define VERR_ISOMK_IMPORT_BOOT_CAT_UNKNOWN_HEADER_ID (-25144) | |
2947 | /** A boot catalog entry in the import ISO has an invalid boot media type. */ | |
2948 | #define VERR_ISOMK_IMPORT_BOOT_CAT_INVALID_BOOT_MEDIA_TYPE (-25145) | |
2949 | /** The default boot catalog entry in the import ISO has invalid flags set. */ | |
2950 | #define VERR_ISOMK_IMPORT_BOOT_CAT_DEF_ENTRY_INVALID_FLAGS (-25146) | |
2951 | /** A boot catalog entry in the import ISO has reserved flag set. */ | |
2952 | #define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_RESERVED_FLAG (-25147) | |
2953 | /** A boot catalog entry in the import ISO is using the unused field. */ | |
2954 | #define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_USES_UNUSED_FIELD (-25148) | |
2955 | /** A boot catalog entry in the import ISO points to a block after the end of | |
2956 | * the image input file. */ | |
2957 | #define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_IMAGE_OUT_OF_BOUNDS (-25149) | |
2958 | /** A boot catalog entry in the import ISO has an image with an | |
2959 | * indeterminate size. */ | |
2960 | #define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_UNKNOWN_IMAGE_SIZE (-25150) | |
2961 | /** The boot catalog in the import ISO is larger than a sector or it is | |
2962 | * missing the final section header entry. */ | |
2963 | #define VERR_ISOMK_IMPORT_BOOT_CAT_MISSING_FINAL_OR_TOO_BIG (-25151) | |
2964 | /** The default boot catalog entry in the import ISO an invalid boot | |
2965 | * indicator value. */ | |
2966 | #define VERR_ISOMK_IMPORT_BOOT_CAT_DEF_ENTRY_INVALID_BOOT_IND (-25152) | |
2967 | /** A boot catalog extension entry in the import ISO was either flagged | |
2968 | * incorrectly in the previous entry or has an invalid header ID. */ | |
2969 | #define VERR_ISOMK_IMPORT_BOOT_CAT_EXT_ENTRY_INVALID_ID (-25153) | |
2970 | /** A boot catalog extension entry in the import ISO uses undefined flags | |
2971 | * which will be lost. */ | |
2972 | #define VERR_ISOMK_IMPORT_BOOT_CAT_EXT_ENTRY_UNDEFINED_FLAGS (-25154) | |
2973 | /** A boot catalog extension entry in the import ISO indicates more entries when | |
2974 | * we reached the end of the boot catalog sector. */ | |
2975 | #define VERR_ISOMK_IMPORT_BOOT_CAT_EXT_ENTRY_END_OF_SECTOR (-25155) | |
2976 | /** A boot catalog entry in the import ISO sets the continuation flag when using | |
2977 | * NONE as the selection criteria type. */ | |
2978 | #define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_CONTINUATION_WITH_NONE (-25156) | |
2979 | /** A boot catalog entry in the import ISO sets the continuation flag when | |
2980 | * we reached the ned of the boot catalog secotr. */ | |
2981 | #define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_CONTINUATION_EOS (-25157) | |
2982 | ||
2983 | /** @} */ | |
2984 | ||
2985 | ||
2986 | /** @name RTFsIsoVol status codes | |
2987 | * @{ */ | |
2988 | /** Descriptor tag is all zeros. */ | |
2989 | #define VERR_ISOFS_TAG_IS_ALL_ZEROS (-25300) | |
2990 | /** Unsupported descriptor tag version. */ | |
2991 | #define VERR_ISOFS_UNSUPPORTED_TAG_VERSION (-25301) | |
2992 | /** Bad descriptor tag checksum. */ | |
2993 | #define VERR_ISOFS_BAD_TAG_CHECKSUM (-25302) | |
2994 | /** Descriptor tag sector number mismatch. */ | |
2995 | #define VERR_ISOFS_TAG_SECTOR_MISMATCH (-25303) | |
2996 | /** Descriptor CRC mismatch. */ | |
2997 | #define VERR_ISOFS_DESC_CRC_MISMATCH (-25304) | |
2998 | /** Insufficient data to check descriptor CRC. */ | |
2999 | #define VERR_ISOFS_INSUFFICIENT_DATA_FOR_DESC_CRC (-25305) | |
3000 | /** Unexpected/unknown/bad descriptor in volume descriptor sequence. */ | |
3001 | #define VERR_ISOFS_UNEXPECTED_VDS_DESC (-25306) | |
3002 | /** Too many primary volume descriptors. */ | |
3003 | #define VERR_ISOFS_TOO_MANY_PVDS (-25307) | |
3004 | /** Too many logical volume descriptors. */ | |
3005 | #define VERR_ISOFS_TOO_MANY_LVDS (-25308) | |
3006 | /** Too many partition descriptors. */ | |
3007 | #define VERR_ISOFS_TOO_MANY_PDS (-25309) | |
3008 | /** The logical volume descriptor has a too big partition map. */ | |
3009 | #define VERR_ISOFS_TOO_BIT_PARTMAP_IN_LVD (-25310) | |
3010 | /** No primary volume descriptors found. */ | |
3011 | #define VERR_ISOFS_NO_PVD (-25311) | |
3012 | /** No logical volume descriptors found. */ | |
3013 | #define VERR_ISOFS_NO_LVD (-25312) | |
3014 | /** No partition descriptors found. */ | |
3015 | #define VERR_ISOFS_NO_PD (-25313) | |
3016 | /** Multiple primary volume descriptors found, we can only deal with one. */ | |
3017 | #define VERR_ISOFS_MULTIPLE_PVDS (-25314) | |
3018 | /** Multiple logical volume descriptors found, we can only deal with one. */ | |
3019 | #define VERR_ISOFS_MULTIPLE_LVDS (-25315) | |
3020 | /** Too many partition maps in the logical volume descriptor. */ | |
3021 | #define VERR_ISOFS_TOO_MANY_PART_MAPS (-25316) | |
3022 | /** Malformed partition map table in the logical volume descriptor. */ | |
3023 | #define VERR_ISOFS_MALFORMED_PART_MAP_TABLE (-25317) | |
3024 | /** Unable to find partition descriptor for a partition map table entry. */ | |
3025 | #define VERR_ISOFS_PARTITION_NOT_FOUND (-25318) | |
3026 | /** Partition mapping table is shorted than described. */ | |
3027 | #define VERR_ISOFS_INCOMPLETE_PART_MAP_TABLE (-25319) | |
3028 | /** Unknown partition map entry type. */ | |
3029 | #define VERR_ISOFS_UNKNOWN_PART_MAP_ENTRY_TYPE (-25320) | |
3030 | /** Unkonwn paritition ID found in the partition map table. */ | |
3031 | #define VERR_ISOFS_UNKNOWN_PART_MAP_TYPE_ID (-25321) | |
3032 | /** Support for virtual partitions as not yet been implemented. */ | |
3033 | #define VERR_ISOFS_VPM_NOT_SUPPORTED (-25322) | |
3034 | /** Support for sparable partitions as not yet been implemented. */ | |
3035 | #define VERR_ISOFS_SPM_NOT_SUPPORTED (-25323) | |
3036 | /** Support for metadata partitions as not yet been implemented. */ | |
3037 | #define VERR_ISOFS_MPM_NOT_SUPPORTED (-25324) | |
3038 | /** Invalid or unsupported logical block size. */ | |
3039 | #define VERR_ISOFS_UNSUPPORTED_LOGICAL_BLOCK_SIZE (-25325) | |
3040 | /** Unsupported domain ID in logical volume descriptor. */ | |
3041 | #define VERR_ISOFS_BAD_LVD_DOMAIN_ID (-25326) | |
3042 | /** Malformed or invalid file set descriptor location. */ | |
3043 | #define VERR_ISOFS_BAD_LVD_FILE_SET_DESC_LOCATION (-25327) | |
3044 | /** Non-standard descriptor character set in the logical volume descriptor. */ | |
3045 | #define VERR_ISOFS_BAD_LVD_DESC_CHAR_SET (-25329) | |
3046 | /** Invalid partition index in a location. */ | |
3047 | #define VERR_ISOFS_INVALID_PARTITION_INDEX (-25330) | |
3048 | /** Unsupported file system charset. */ | |
3049 | #define VERR_ISOFS_FSD_UNSUPPORTED_CHAR_SET (-25331) | |
3050 | /** File set descriptor has an zero length or invalid root dir extent. */ | |
3051 | #define VERR_ISOFS_FSD_ZERO_ROOT_DIR (-25332) | |
3052 | /** File set descriptor has a next extent member. */ | |
3053 | #define VERR_ISOFS_FSD_NEXT_EXTENT (-25333) | |
3054 | /** The ICB for is too big. */ | |
3055 | #define VERR_ISOFS_ICB_TOO_BIG (-25334) | |
3056 | /** The ICB for is too small. */ | |
3057 | #define VERR_ISOFS_ICB_TOO_SMALL (-25335) | |
3058 | /** No direct ICB entries found. */ | |
3059 | #define VERR_ISOFS_NO_DIRECT_ICB_ENTRIES (-25336) | |
3060 | /** Too many ICB indirections, possibly a loop. */ | |
3061 | #define VERR_ISOFS_TOO_MANY_ICB_INDIRECTIONS (-25337) | |
3062 | /** Too deep ICB recursion. */ | |
3063 | #define VERR_ISOFS_TOO_DEEP_ICB_RECURSION (-25338) | |
3064 | /** ICB is too small to contain anything useful. */ | |
3065 | #define VERR_ISOFS_ICB_ENTRY_TOO_SMALL (-25339) | |
3066 | /** Unsupported tag encountered in ICB. */ | |
3067 | #define VERR_ISOFS_UNSUPPORTED_ICB (-25340) | |
3068 | /** Bad file entry (ICB). */ | |
3069 | #define VERR_ISOFS_BAD_FILE_ENTRY (-25341) | |
3070 | /** Unknown allocation descriptor type. */ | |
3071 | #define VERR_ISO_FS_UNKNOWN_AD_TYPE (-25342) | |
3072 | /** Malformed extended allocation descriptor. */ | |
3073 | #define VERR_ISOFS_BAD_EXTAD (-25343) | |
3074 | /** Wrong file type. */ | |
3075 | #define VERR_ISOFS_WRONG_FILE_TYPE (-25344) | |
3076 | /** Unknow file type. */ | |
3077 | #define VERR_ISOFS_UNKNOWN_FILE_TYPE (-25345) | |
3078 | ||
3079 | /** Not implemented for UDF. */ | |
3080 | #define VERR_ISOFS_UDF_NOT_IMPLEMENTED (-25390) | |
3081 | /** Internal processing error \#1. */ | |
3082 | #define VERR_ISOFS_IPE_1 (-25391) | |
3083 | /** Internal processing error \#2. */ | |
3084 | #define VERR_ISOFS_IPE_2 (-25392) | |
3085 | /** Internal processing error \#3. */ | |
3086 | #define VERR_ISOFS_IPE_3 (-25393) | |
3087 | /** Internal processing error \#4. */ | |
3088 | #define VERR_ISOFS_IPE_4 (-25394) | |
3089 | /** Internal processing error \#5. */ | |
3090 | #define VERR_ISOFS_IPE_5 (-25395) | |
3091 | ||
3092 | /** @} */ | |
3093 | ||
056a1eb7 SF |
3094 | /* SED-END */ |
3095 | ||
3096 | /** @} */ | |
3097 | ||
3098 | #endif | |
3099 |