]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blob - ubuntu/vbox/vboxguest/include/iprt/err.h
UBUNTU: ubuntu: vbox -- update to 5.2.2-dfsg-2
[mirror_ubuntu-bionic-kernel.git] / ubuntu / vbox / vboxguest / include / iprt / err.h
1 /** @file
2 * IPRT - Status Codes.
3 */
4
5 /*
6 * Copyright (C) 2006-2017 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26 #ifndef ___iprt_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
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
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)
1198 /** Symbolic link not allowed. */
1199 #define VERR_SYMLINK_NOT_ALLOWED (-159)
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)
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)
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)
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
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
3094 /* SED-END */
3095
3096 /** @} */
3097
3098 #endif
3099