VirtualBox

source: vbox/trunk/include/iprt/err.h@ 70286

Last change on this file since 70286 was 69892, checked in by vboxsync, 7 years ago

Runtime: Start on a platform independent serial port access API which will be more advanced and cleaner than the code in DrvHostSerial. DrvHostSerial will be converted to use this API later on when it is mature. Additionally it will be used by a serial port test utility for automatic serial port testing in the validation kit

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 137.5 KB
Line 
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 */
57class RTErrStrictType
58{
59protected:
60 int32_t m_rc;
61
62public:
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
107private:
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
191RT_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 */
200RTDECL(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 */
209RTDECL(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 */
218RTDECL(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 */
233RTDECL(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 */
241RTDECL(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 */
250RTDECL(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 */
261RTDECL(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 */
270RTDECL(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 */
279RTDECL(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 */
287RTDECL(int) RTErrConvertToErrno(int iErr);
288
289#ifdef IN_RING3
290
291/**
292 * iprt status code message.
293 */
294typedef 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. */
306typedef RTSTATUSMSG *PRTSTATUSMSG;
307/** Pointer to const iprt status code message. */
308typedef 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 */
316RTDECL(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 */
346typedef 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. */
356typedef RTWINERRMSG *PRTWINERRMSG;
357/** Pointer to const Windows error code message. */
358typedef 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 */
366RTDECL(PCRTWINERRMSG) RTErrWinGet(long rc);
367
368/** On windows COM errors are part of the Windows error database. */
369typedef RTWINERRMSG RTCOMERRMSG;
370
371#else /* !RT_OS_WINDOWS */
372
373/**
374 * COM/XPCOM error code message.
375 */
376typedef 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. */
387typedef RTCOMERRMSG *PRTCOMERRMSG;
388/** Pointer to const a XPCOM/COM error code message. */
389typedef 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 */
397RTDECL(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 */
429DECLINLINE(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 */
449DECLINLINE(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 */
464RTDECL(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 */
477RTDECL(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 */
485RTDECL(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 */
496RTDECL(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 */
508RTDECL(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 */
520RTDECL(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 */
531RTDECL(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 */
543RTDECL(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 */
555RTDECL(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 */
574RTDECL(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 */
588RTDECL(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 */
602RTDECL(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 */
615RTDECL(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 */
629RTDECL(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 */
643RTDECL(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 */
676DECLINLINE(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 */
689DECLINLINE(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 */
705typedef 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. */
713typedef RTERRVARS *PRTERRVARS;
714/** Pointer to a const error variable storage union. */
715typedef RTERRVARS const *PCRTERRVARS;
716
717/**
718 * Saves the error variables.
719 *
720 * @returns @a pVars.
721 * @param pVars The variable storage union.
722 */
723RTDECL(PRTERRVARS) RTErrVarsSave(PRTERRVARS pVars);
724
725/**
726 * Restores the error variables.
727 *
728 * @param pVars The variable storage union.
729 */
730RTDECL(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 */
739RTDECL(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 */
748RTDECL(bool) RTErrVarsHaveChanged(PCRTERRVARS pVars);
749
750RT_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/** Is a symbolic link. */
1201#define VERR_IS_A_SYMLINK (-160)
1202/** Is a FIFO. */
1203#define VERR_IS_A_FIFO (-161)
1204/** Is a socket. */
1205#define VERR_IS_A_SOCKET (-162)
1206/** Is a block device. */
1207#define VERR_IS_A_BLOCK_DEVICE (-163)
1208/** Is a character device. */
1209#define VERR_IS_A_CHAR_DEVICE (-164)
1210/** @} */
1211
1212
1213/** @name Generic Directory Enumeration Status Codes
1214 * @{
1215 */
1216/** Unresolved (unknown) search error. */
1217#define VERR_SEARCH_ERROR (-200)
1218/** No more files found. */
1219#define VERR_NO_MORE_FILES (-201)
1220/** No more search handles available. */
1221#define VERR_NO_MORE_SEARCH_HANDLES (-202)
1222/** RTDirReadEx() failed to retrieve the extra data which was requested. */
1223#define VWRN_NO_DIRENT_INFO 203
1224/** @} */
1225
1226
1227/** @name Internal Processing Errors
1228 * @{
1229 */
1230/** Internal error - this should never happen. */
1231#define VERR_INTERNAL_ERROR (-225)
1232/** Internal error no. 2. */
1233#define VERR_INTERNAL_ERROR_2 (-226)
1234/** Internal error no. 3. */
1235#define VERR_INTERNAL_ERROR_3 (-227)
1236/** Internal error no. 4. */
1237#define VERR_INTERNAL_ERROR_4 (-228)
1238/** Internal error no. 5. */
1239#define VERR_INTERNAL_ERROR_5 (-229)
1240/** Internal error: Unexpected status code. */
1241#define VERR_IPE_UNEXPECTED_STATUS (-230)
1242/** Internal error: Unexpected status code. */
1243#define VERR_IPE_UNEXPECTED_INFO_STATUS (-231)
1244/** Internal error: Unexpected status code. */
1245#define VERR_IPE_UNEXPECTED_ERROR_STATUS (-232)
1246/** Internal error: Uninitialized status code.
1247 * @remarks This is used by value elsewhere. */
1248#define VERR_IPE_UNINITIALIZED_STATUS (-233)
1249/** Internal error: Supposedly unreachable default case in a switch. */
1250#define VERR_IPE_NOT_REACHED_DEFAULT_CASE (-234)
1251/** @} */
1252
1253
1254/** @name Generic Device I/O Status Codes
1255 * @{
1256 */
1257/** Unresolved (unknown) device i/o error. */
1258#define VERR_DEV_IO_ERROR (-250)
1259/** Device i/o: Bad unit. */
1260#define VERR_IO_BAD_UNIT (-251)
1261/** Device i/o: Not ready. */
1262#define VERR_IO_NOT_READY (-252)
1263/** Device i/o: Bad command. */
1264#define VERR_IO_BAD_COMMAND (-253)
1265/** Device i/o: CRC error. */
1266#define VERR_IO_CRC (-254)
1267/** Device i/o: Bad length. */
1268#define VERR_IO_BAD_LENGTH (-255)
1269/** Device i/o: Sector not found. */
1270#define VERR_IO_SECTOR_NOT_FOUND (-256)
1271/** Device i/o: General failure. */
1272#define VERR_IO_GEN_FAILURE (-257)
1273/** @} */
1274
1275
1276/** @name Generic Pipe I/O Status Codes
1277 * @{
1278 */
1279/** Unresolved (unknown) pipe i/o error. */
1280#define VERR_PIPE_IO_ERROR (-300)
1281/** Broken pipe. */
1282#define VERR_BROKEN_PIPE (-301)
1283/** Bad pipe. */
1284#define VERR_BAD_PIPE (-302)
1285/** Pipe is busy. */
1286#define VERR_PIPE_BUSY (-303)
1287/** No data in pipe. */
1288#define VERR_NO_DATA (-304)
1289/** Pipe is not connected. */
1290#define VERR_PIPE_NOT_CONNECTED (-305)
1291/** More data available in pipe. */
1292#define VERR_MORE_DATA (-306)
1293/** Expected read pipe, got a write pipe instead. */
1294#define VERR_PIPE_NOT_READ (-307)
1295/** Expected write pipe, got a read pipe instead. */
1296#define VERR_PIPE_NOT_WRITE (-308)
1297/** @} */
1298
1299
1300/** @name Generic Semaphores Status Codes
1301 * @{
1302 */
1303/** Unresolved (unknown) semaphore error. */
1304#define VERR_SEM_ERROR (-350)
1305/** Too many semaphores. */
1306#define VERR_TOO_MANY_SEMAPHORES (-351)
1307/** Exclusive semaphore is owned by another process. */
1308#define VERR_EXCL_SEM_ALREADY_OWNED (-352)
1309/** The semaphore is set and cannot be closed. */
1310#define VERR_SEM_IS_SET (-353)
1311/** The semaphore cannot be set again. */
1312#define VERR_TOO_MANY_SEM_REQUESTS (-354)
1313/** Attempt to release mutex not owned by caller. */
1314#define VERR_NOT_OWNER (-355)
1315/** The semaphore has been opened too many times. */
1316#define VERR_TOO_MANY_OPENS (-356)
1317/** The maximum posts for the event semaphore has been reached. */
1318#define VERR_TOO_MANY_POSTS (-357)
1319/** The event semaphore has already been posted. */
1320#define VERR_ALREADY_POSTED (-358)
1321/** The event semaphore has already been reset. */
1322#define VERR_ALREADY_RESET (-359)
1323/** The semaphore is in use. */
1324#define VERR_SEM_BUSY (-360)
1325/** The previous ownership of this semaphore has ended. */
1326#define VERR_SEM_OWNER_DIED (-361)
1327/** Failed to open semaphore by name - not found. */
1328#define VERR_SEM_NOT_FOUND (-362)
1329/** Semaphore destroyed while waiting. */
1330#define VERR_SEM_DESTROYED (-363)
1331/** Nested ownership requests are not permitted for this semaphore type. */
1332#define VERR_SEM_NESTED (-364)
1333/** The release call only release a semaphore nesting, i.e. the caller is still
1334 * holding the semaphore. */
1335#define VINF_SEM_NESTED (364)
1336/** Deadlock detected. */
1337#define VERR_DEADLOCK (-365)
1338/** Ping-Pong listen or speak out of turn error. */
1339#define VERR_SEM_OUT_OF_TURN (-366)
1340/** Tried to take a semaphore in a bad context. */
1341#define VERR_SEM_BAD_CONTEXT (-367)
1342/** Don't spin for the semaphore, but it is safe to try grab it. */
1343#define VINF_SEM_BAD_CONTEXT (367)
1344/** Wrong locking order detected. */
1345#define VERR_SEM_LV_WRONG_ORDER (-368)
1346/** Wrong release order detected. */
1347#define VERR_SEM_LV_WRONG_RELEASE_ORDER (-369)
1348/** Attempt to recursively enter a non-recursive lock. */
1349#define VERR_SEM_LV_NESTED (-370)
1350/** Invalid parameters passed to the lock validator. */
1351#define VERR_SEM_LV_INVALID_PARAMETER (-371)
1352/** The lock validator detected a deadlock. */
1353#define VERR_SEM_LV_DEADLOCK (-372)
1354/** The lock validator detected an existing deadlock.
1355 * The deadlock was not caused by the current operation, but existed already. */
1356#define VERR_SEM_LV_EXISTING_DEADLOCK (-373)
1357/** Not the lock owner according our records. */
1358#define VERR_SEM_LV_NOT_OWNER (-374)
1359/** An illegal lock upgrade was attempted. */
1360#define VERR_SEM_LV_ILLEGAL_UPGRADE (-375)
1361/** The thread is not a valid signaller of the event. */
1362#define VERR_SEM_LV_NOT_SIGNALLER (-376)
1363/** Internal error in the lock validator or related components. */
1364#define VERR_SEM_LV_INTERNAL_ERROR (-377)
1365/** @} */
1366
1367
1368/** @name Generic Network I/O Status Codes
1369 * @{
1370 */
1371/** Unresolved (unknown) network error. */
1372#define VERR_NET_IO_ERROR (-400)
1373/** The network is busy or is out of resources. */
1374#define VERR_NET_OUT_OF_RESOURCES (-401)
1375/** Net host name not found. */
1376#define VERR_NET_HOST_NOT_FOUND (-402)
1377/** Network path not found. */
1378#define VERR_NET_PATH_NOT_FOUND (-403)
1379/** General network printing error. */
1380#define VERR_NET_PRINT_ERROR (-404)
1381/** The machine is not on the network. */
1382#define VERR_NET_NO_NETWORK (-405)
1383/** Name is not unique on the network. */
1384#define VERR_NET_NOT_UNIQUE_NAME (-406)
1385
1386/* These are BSD networking error codes - numbers correspond, don't mess! */
1387/** Operation in progress. */
1388#define VERR_NET_IN_PROGRESS (-436)
1389/** Operation already in progress. */
1390#define VERR_NET_ALREADY_IN_PROGRESS (-437)
1391/** Attempted socket operation with a non-socket handle.
1392 * (This includes closed handles.) */
1393#define VERR_NET_NOT_SOCKET (-438)
1394/** Destination address required. */
1395#define VERR_NET_DEST_ADDRESS_REQUIRED (-439)
1396/** Message too long. */
1397#define VERR_NET_MSG_SIZE (-440)
1398/** Protocol wrong type for socket. */
1399#define VERR_NET_PROTOCOL_TYPE (-441)
1400/** Protocol not available. */
1401#define VERR_NET_PROTOCOL_NOT_AVAILABLE (-442)
1402/** Protocol not supported. */
1403#define VERR_NET_PROTOCOL_NOT_SUPPORTED (-443)
1404/** Socket type not supported. */
1405#define VERR_NET_SOCKET_TYPE_NOT_SUPPORTED (-444)
1406/** Operation not supported. */
1407#define VERR_NET_OPERATION_NOT_SUPPORTED (-445)
1408/** Protocol family not supported. */
1409#define VERR_NET_PROTOCOL_FAMILY_NOT_SUPPORTED (-446)
1410/** Address family not supported by protocol family. */
1411#define VERR_NET_ADDRESS_FAMILY_NOT_SUPPORTED (-447)
1412/** Address already in use. */
1413#define VERR_NET_ADDRESS_IN_USE (-448)
1414/** Can't assign requested address. */
1415#define VERR_NET_ADDRESS_NOT_AVAILABLE (-449)
1416/** Network is down. */
1417#define VERR_NET_DOWN (-450)
1418/** Network is unreachable. */
1419#define VERR_NET_UNREACHABLE (-451)
1420/** Network dropped connection on reset. */
1421#define VERR_NET_CONNECTION_RESET (-452)
1422/** Software caused connection abort. */
1423#define VERR_NET_CONNECTION_ABORTED (-453)
1424/** Connection reset by peer. */
1425#define VERR_NET_CONNECTION_RESET_BY_PEER (-454)
1426/** No buffer space available. */
1427#define VERR_NET_NO_BUFFER_SPACE (-455)
1428/** Socket is already connected. */
1429#define VERR_NET_ALREADY_CONNECTED (-456)
1430/** Socket is not connected. */
1431#define VERR_NET_NOT_CONNECTED (-457)
1432/** Can't send after socket shutdown. */
1433#define VERR_NET_SHUTDOWN (-458)
1434/** Too many references: can't splice. */
1435#define VERR_NET_TOO_MANY_REFERENCES (-459)
1436/** Too many references: can't splice. */
1437#define VERR_NET_CONNECTION_TIMED_OUT (-460)
1438/** Connection refused. */
1439#define VERR_NET_CONNECTION_REFUSED (-461)
1440/* ELOOP is not net. */
1441/* ENAMETOOLONG is not net. */
1442/** Host is down. */
1443#define VERR_NET_HOST_DOWN (-464)
1444/** No route to host. */
1445#define VERR_NET_HOST_UNREACHABLE (-465)
1446/** Protocol error. */
1447#define VERR_NET_PROTOCOL_ERROR (-466)
1448/** Incomplete packet was submitted by guest. */
1449#define VERR_NET_INCOMPLETE_TX_PACKET (-467)
1450/** @} */
1451
1452
1453/** @name TCP Status Codes
1454 * @{
1455 */
1456/** Stop the TCP server. */
1457#define VERR_TCP_SERVER_STOP (-500)
1458/** The server was stopped. */
1459#define VINF_TCP_SERVER_STOP 500
1460/** The TCP server was shut down using RTTcpServerShutdown. */
1461#define VERR_TCP_SERVER_SHUTDOWN (-501)
1462/** The TCP server was destroyed. */
1463#define VERR_TCP_SERVER_DESTROYED (-502)
1464/** The TCP server has no client associated with it. */
1465#define VINF_TCP_SERVER_NO_CLIENT 503
1466/** @} */
1467
1468
1469/** @name UDP Status Codes
1470 * @{
1471 */
1472/** Stop the UDP server. */
1473#define VERR_UDP_SERVER_STOP (-520)
1474/** The server was stopped. */
1475#define VINF_UDP_SERVER_STOP 520
1476/** The UDP server was shut down using RTUdpServerShutdown. */
1477#define VERR_UDP_SERVER_SHUTDOWN (-521)
1478/** The UDP server was destroyed. */
1479#define VERR_UDP_SERVER_DESTROYED (-522)
1480/** The UDP server has no client associated with it. */
1481#define VINF_UDP_SERVER_NO_CLIENT 523
1482/** @} */
1483
1484
1485/** @name L4 Specific Status Codes
1486 * @{
1487 */
1488/** Invalid offset in an L4 dataspace */
1489#define VERR_L4_INVALID_DS_OFFSET (-550)
1490/** IPC error */
1491#define VERR_IPC (-551)
1492/** Item already used */
1493#define VERR_RESOURCE_IN_USE (-552)
1494/** Source/destination not found */
1495#define VERR_IPC_PROCESS_NOT_FOUND (-553)
1496/** Receive timeout */
1497#define VERR_IPC_RECEIVE_TIMEOUT (-554)
1498/** Send timeout */
1499#define VERR_IPC_SEND_TIMEOUT (-555)
1500/** Receive cancelled */
1501#define VERR_IPC_RECEIVE_CANCELLED (-556)
1502/** Send cancelled */
1503#define VERR_IPC_SEND_CANCELLED (-557)
1504/** Receive aborted */
1505#define VERR_IPC_RECEIVE_ABORTED (-558)
1506/** Send aborted */
1507#define VERR_IPC_SEND_ABORTED (-559)
1508/** Couldn't map pages during receive */
1509#define VERR_IPC_RECEIVE_MAP_FAILED (-560)
1510/** Couldn't map pages during send */
1511#define VERR_IPC_SEND_MAP_FAILED (-561)
1512/** Send pagefault timeout in receive */
1513#define VERR_IPC_RECEIVE_SEND_PF_TIMEOUT (-562)
1514/** Send pagefault timeout in send */
1515#define VERR_IPC_SEND_SEND_PF_TIMEOUT (-563)
1516/** (One) receive buffer was too small, or too few buffers */
1517#define VINF_IPC_RECEIVE_MSG_CUT 564
1518/** (One) send buffer was too small, or too few buffers */
1519#define VINF_IPC_SEND_MSG_CUT 565
1520/** Dataspace manager server not found */
1521#define VERR_L4_DS_MANAGER_NOT_FOUND (-566)
1522/** @} */
1523
1524
1525/** @name Loader Status Codes.
1526 * @{
1527 */
1528/** Invalid executable signature. */
1529#define VERR_INVALID_EXE_SIGNATURE (-600)
1530/** The iprt loader recognized a ELF image, but doesn't support loading it. */
1531#define VERR_ELF_EXE_NOT_SUPPORTED (-601)
1532/** The iprt loader recognized a PE image, but doesn't support loading it. */
1533#define VERR_PE_EXE_NOT_SUPPORTED (-602)
1534/** The iprt loader recognized a LX image, but doesn't support loading it. */
1535#define VERR_LX_EXE_NOT_SUPPORTED (-603)
1536/** The iprt loader recognized a LE image, but doesn't support loading it. */
1537#define VERR_LE_EXE_NOT_SUPPORTED (-604)
1538/** The iprt loader recognized a NE image, but doesn't support loading it. */
1539#define VERR_NE_EXE_NOT_SUPPORTED (-605)
1540/** The iprt loader recognized a MZ image, but doesn't support loading it. */
1541#define VERR_MZ_EXE_NOT_SUPPORTED (-606)
1542/** The iprt loader recognized an a.out image, but doesn't support loading it. */
1543#define VERR_AOUT_EXE_NOT_SUPPORTED (-607)
1544/** Bad executable. */
1545#define VERR_BAD_EXE_FORMAT (-608)
1546/** Symbol (export) not found. */
1547#define VERR_SYMBOL_NOT_FOUND (-609)
1548/** Module not found. */
1549#define VERR_MODULE_NOT_FOUND (-610)
1550/** The loader resolved an external symbol to an address to big for the image format. */
1551#define VERR_SYMBOL_VALUE_TOO_BIG (-611)
1552/** The image is too big. */
1553#define VERR_IMAGE_TOO_BIG (-612)
1554/** The image base address is to high for this image type. */
1555#define VERR_IMAGE_BASE_TOO_HIGH (-614)
1556/** Mismatching architecture. */
1557#define VERR_LDR_ARCH_MISMATCH (-615)
1558/** Mismatch between IPRT and native loader. */
1559#define VERR_LDR_MISMATCH_NATIVE (-616)
1560/** Failed to resolve an imported (external) symbol. */
1561#define VERR_LDR_IMPORTED_SYMBOL_NOT_FOUND (-617)
1562/** Generic loader failure. */
1563#define VERR_LDR_GENERAL_FAILURE (-618)
1564/** Code signing error. */
1565#define VERR_LDR_IMAGE_HASH (-619)
1566/** The PE loader encountered delayed imports, a feature which hasn't been implemented yet. */
1567#define VERR_LDRPE_DELAY_IMPORT (-620)
1568/** The PE loader encountered a malformed certificate. */
1569#define VERR_LDRPE_CERT_MALFORMED (-621)
1570/** The PE loader encountered a certificate with an unsupported type or structure revision. */
1571#define VERR_LDRPE_CERT_UNSUPPORTED (-622)
1572/** The PE loader doesn't know how to deal with the global pointer data directory entry yet. */
1573#define VERR_LDRPE_GLOBALPTR (-623)
1574/** The PE loader doesn't support the TLS data directory yet. */
1575#define VERR_LDRPE_TLS (-624)
1576/** The PE loader doesn't grok the COM descriptor data directory entry. */
1577#define VERR_LDRPE_COM_DESCRIPTOR (-625)
1578/** The PE loader encountered an unknown load config directory/header size. */
1579#define VERR_LDRPE_LOAD_CONFIG_SIZE (-626)
1580/** The PE loader encountered a lock prefix table, a feature which hasn't been implemented yet. */
1581#define VERR_LDRPE_LOCK_PREFIX_TABLE (-627)
1582/** The PE loader encountered some Guard CF stuff in the load config. */
1583#define VERR_LDRPE_GUARD_CF_STUFF (-628)
1584/** The ELF loader doesn't handle foreign endianness. */
1585#define VERR_LDRELF_ODD_ENDIAN (-630)
1586/** The ELF image is 'dynamic', the ELF loader can only deal with 'relocatable' images at present. */
1587#define VERR_LDRELF_DYN (-631)
1588/** The ELF image is 'executable', the ELF loader can only deal with 'relocatable' images at present. */
1589#define VERR_LDRELF_EXEC (-632)
1590/** The ELF image was created for an unsupported target machine type. */
1591#define VERR_LDRELF_MACHINE (-633)
1592/** The ELF version is not supported. */
1593#define VERR_LDRELF_VERSION (-634)
1594/** The ELF loader cannot handle multiple SYMTAB sections. */
1595#define VERR_LDRELF_MULTIPLE_SYMTABS (-635)
1596/** The ELF loader encountered a relocation type which is not implemented. */
1597#define VERR_LDRELF_RELOCATION_NOT_SUPPORTED (-636)
1598/** The ELF loader encountered a bad symbol index. */
1599#define VERR_LDRELF_INVALID_SYMBOL_INDEX (-637)
1600/** The ELF loader encountered an invalid symbol name offset. */
1601#define VERR_LDRELF_INVALID_SYMBOL_NAME_OFFSET (-638)
1602/** The ELF loader encountered an invalid relocation offset. */
1603#define VERR_LDRELF_INVALID_RELOCATION_OFFSET (-639)
1604/** The ELF loader didn't find the symbol/string table for the image. */
1605#define VERR_LDRELF_NO_SYMBOL_OR_NO_STRING_TABS (-640)
1606/** Invalid link address. */
1607#define VERR_LDR_INVALID_LINK_ADDRESS (-647)
1608/** Invalid image relative virtual address. */
1609#define VERR_LDR_INVALID_RVA (-648)
1610/** Invalid segment:offset address. */
1611#define VERR_LDR_INVALID_SEG_OFFSET (-649)
1612/** @}*/
1613
1614/** @name Debug Info Reader Status Codes.
1615 * @{
1616 */
1617/** The module contains no line number information. */
1618#define VERR_DBG_NO_LINE_NUMBERS (-650)
1619/** The module contains no symbol information. */
1620#define VERR_DBG_NO_SYMBOLS (-651)
1621/** The specified segment:offset address was invalid. Typically an attempt at
1622 * addressing outside the segment boundary. */
1623#define VERR_DBG_INVALID_ADDRESS (-652)
1624/** Invalid segment index. */
1625#define VERR_DBG_INVALID_SEGMENT_INDEX (-653)
1626/** Invalid segment offset. */
1627#define VERR_DBG_INVALID_SEGMENT_OFFSET (-654)
1628/** Invalid image relative virtual address. */
1629#define VERR_DBG_INVALID_RVA (-655)
1630/** Invalid image relative virtual address. */
1631#define VERR_DBG_SPECIAL_SEGMENT (-656)
1632/** Address conflict within a module/segment.
1633 * Attempted to add a segment, symbol or line number that fully or partially
1634 * overlaps with an existing one. */
1635#define VERR_DBG_ADDRESS_CONFLICT (-657)
1636/** Duplicate symbol within the module.
1637 * Attempted to add a symbol which name already exists within the module. */
1638#define VERR_DBG_DUPLICATE_SYMBOL (-658)
1639/** The segment index specified when adding a new segment is already in use. */
1640#define VERR_DBG_SEGMENT_INDEX_CONFLICT (-659)
1641/** No line number was found for the specified address/ordinal/whatever. */
1642#define VERR_DBG_LINE_NOT_FOUND (-660)
1643/** The length of the symbol name is out of range.
1644 * This means it is an empty string or that it's greater or equal to
1645 * RTDBG_SYMBOL_NAME_LENGTH. */
1646#define VERR_DBG_SYMBOL_NAME_OUT_OF_RANGE (-661)
1647/** The length of the file name is out of range.
1648 * This means it is an empty string or that it's greater or equal to
1649 * RTDBG_FILE_NAME_LENGTH. */
1650#define VERR_DBG_FILE_NAME_OUT_OF_RANGE (-662)
1651/** The length of the segment name is out of range.
1652 * This means it is an empty string or that it is greater or equal to
1653 * RTDBG_SEGMENT_NAME_LENGTH. */
1654#define VERR_DBG_SEGMENT_NAME_OUT_OF_RANGE (-663)
1655/** The specified address range wraps around. */
1656#define VERR_DBG_ADDRESS_WRAP (-664)
1657/** The file is not a valid NM map file. */
1658#define VERR_DBG_NOT_NM_MAP_FILE (-665)
1659/** The file is not a valid /proc/kallsyms file. */
1660#define VERR_DBG_NOT_LINUX_KALLSYMS (-666)
1661/** No debug module interpreter matching the debug info. */
1662#define VERR_DBG_NO_MATCHING_INTERPRETER (-667)
1663/** Bad DWARF line number header. */
1664#define VERR_DWARF_BAD_LINE_NUMBER_HEADER (-668)
1665/** Unexpected end of DWARF unit. */
1666#define VERR_DWARF_UNEXPECTED_END (-669)
1667/** DWARF LEB value overflows the decoder type. */
1668#define VERR_DWARF_LEB_OVERFLOW (-670)
1669/** Bad DWARF extended line number opcode. */
1670#define VERR_DWARF_BAD_LNE (-671)
1671/** Bad DWARF string. */
1672#define VERR_DWARF_BAD_STRING (-672)
1673/** Bad DWARF position. */
1674#define VERR_DWARF_BAD_POS (-673)
1675/** Bad DWARF info. */
1676#define VERR_DWARF_BAD_INFO (-674)
1677/** Bad DWARF abbreviation data. */
1678#define VERR_DWARF_BAD_ABBREV (-675)
1679/** A DWARF abbreviation was not found. */
1680#define VERR_DWARF_ABBREV_NOT_FOUND (-676)
1681/** Encountered an unknown attribute form. */
1682#define VERR_DWARF_UNKNOWN_FORM (-677)
1683/** Encountered an unexpected attribute form. */
1684#define VERR_DWARF_UNEXPECTED_FORM (-678)
1685/** Unfinished code. */
1686#define VERR_DWARF_TODO (-679)
1687/** Unknown location opcode. */
1688#define VERR_DWARF_UNKNOWN_LOC_OPCODE (-680)
1689/** Expression stack overflow. */
1690#define VERR_DWARF_STACK_OVERFLOW (-681)
1691/** Expression stack underflow. */
1692#define VERR_DWARF_STACK_UNDERFLOW (-682)
1693/** Internal processing error in the DWARF code. */
1694#define VERR_DWARF_IPE (-683)
1695/** Invalid configuration property value. */
1696#define VERR_DBG_CFG_INVALID_VALUE (-684)
1697/** Not an integer property. */
1698#define VERR_DBG_CFG_NOT_UINT_PROP (-685)
1699/** Deferred loading of information failed. */
1700#define VERR_DBG_DEFERRED_LOAD_FAILED (-686)
1701/** Unfinished debug info reader code. */
1702#define VERR_DBG_TODO (-687)
1703/** Found file, but it didn't match the search criteria. */
1704#define VERR_DBG_FILE_MISMATCH (-688)
1705/** Internal processing error in the debug module reader code. */
1706#define VERR_DBG_MOD_IPE (-689)
1707/** The symbol size was adjusted while adding it. */
1708#define VINF_DBG_ADJUSTED_SYM_SIZE 690
1709/** Unable to parse the CodeView debug information. */
1710#define VERR_CV_BAD_FORMAT (-691)
1711/** Unfinished CodeView debug information feature. */
1712#define VERR_CV_TODO (-692)
1713/** Internal processing error the CodeView debug information reader. */
1714#define VERR_CV_IPE (-693)
1715/** @} */
1716
1717/** @name Request Packet Status Codes.
1718 * @{
1719 */
1720/** Invalid RT request type.
1721 * For the RTReqAlloc() case, the caller just specified an illegal enmType. For
1722 * all the other occurrences it means indicates corruption, broken logic, or stupid
1723 * interface user. */
1724#define VERR_RT_REQUEST_INVALID_TYPE (-700)
1725/** Invalid RT request state.
1726 * The state of the request packet was not the expected and accepted one(s). Either
1727 * the interface user screwed up, or we've got corruption/broken logic. */
1728#define VERR_RT_REQUEST_STATE (-701)
1729/** Invalid RT request packet.
1730 * One or more of the RT controlled packet members didn't contain the correct
1731 * values. Some thing's broken. */
1732#define VERR_RT_REQUEST_INVALID_PACKAGE (-702)
1733/** The status field has not been updated yet as the request is still
1734 * pending completion. Someone queried the iStatus field before the request
1735 * has been fully processed. */
1736#define VERR_RT_REQUEST_STATUS_STILL_PENDING (-703)
1737/** The request has been freed, don't read the status now.
1738 * Someone is reading the iStatus field of a freed request packet. */
1739#define VERR_RT_REQUEST_STATUS_FREED (-704)
1740/** @} */
1741
1742/** @name Environment Status Code
1743 * @{
1744 */
1745/** The specified environment variable was not found. (RTEnvGetEx) */
1746#define VERR_ENV_VAR_NOT_FOUND (-750)
1747/** The specified environment variable was not found. (RTEnvUnsetEx) */
1748#define VINF_ENV_VAR_NOT_FOUND (750)
1749/** Unable to translate all the variables in the default environment due to
1750 * codeset issues (LANG / LC_ALL / LC_CTYPE). */
1751#define VWRN_ENV_NOT_FULLY_TRANSLATED (751)
1752/** Invalid environment variable name. */
1753#define VERR_ENV_INVALID_VAR_NAME (-752)
1754/** The environment variable is an unset record. */
1755#define VINF_ENV_VAR_UNSET (753)
1756/** The environment variable has been recorded as being unset. */
1757#define VERR_ENV_VAR_UNSET (-753)
1758/** @} */
1759
1760/** @name Multiprocessor Status Codes.
1761 * @{
1762 */
1763/** The specified cpu is offline. */
1764#define VERR_CPU_OFFLINE (-800)
1765/** The specified cpu was not found. */
1766#define VERR_CPU_NOT_FOUND (-801)
1767/** Not all of the requested CPUs showed up in the PFNRTMPWORKER. */
1768#define VERR_NOT_ALL_CPUS_SHOWED (-802)
1769/** Internal processing error in the RTMp code.*/
1770#define VERR_CPU_IPE_1 (-803)
1771/** @} */
1772
1773/** @name RTGetOpt status codes
1774 * @{ */
1775/** RTGetOpt: Command line option not recognized. */
1776#define VERR_GETOPT_UNKNOWN_OPTION (-825)
1777/** RTGetOpt: Command line option needs argument. */
1778#define VERR_GETOPT_REQUIRED_ARGUMENT_MISSING (-826)
1779/** RTGetOpt: Command line option has argument with bad format. */
1780#define VERR_GETOPT_INVALID_ARGUMENT_FORMAT (-827)
1781/** RTGetOpt: Not an option. */
1782#define VINF_GETOPT_NOT_OPTION 828
1783/** RTGetOpt: Command line option needs an index. */
1784#define VERR_GETOPT_INDEX_MISSING (-829)
1785/** @} */
1786
1787/** @name RTCache status codes
1788 * @{ */
1789/** RTCache: cache is full. */
1790#define VERR_CACHE_FULL (-850)
1791/** RTCache: cache is empty. */
1792#define VERR_CACHE_EMPTY (-851)
1793/** @} */
1794
1795/** @name RTMemCache status codes
1796 * @{ */
1797/** Reached the max cache size. */
1798#define VERR_MEM_CACHE_MAX_SIZE (-855)
1799/** @} */
1800
1801/** @name RTS3 status codes
1802 * @{ */
1803/** Access denied error. */
1804#define VERR_S3_ACCESS_DENIED (-875)
1805/** The bucket/key wasn't found. */
1806#define VERR_S3_NOT_FOUND (-876)
1807/** Bucket already exists. */
1808#define VERR_S3_BUCKET_ALREADY_EXISTS (-877)
1809/** Can't delete bucket with keys. */
1810#define VERR_S3_BUCKET_NOT_EMPTY (-878)
1811/** The current operation was canceled. */
1812#define VERR_S3_CANCELED (-879)
1813/** @} */
1814
1815/** @name HTTP status codes
1816 * @{ */
1817/** HTTP initialization failed. */
1818#define VERR_HTTP_INIT_FAILED (-885)
1819/** The server has not found anything matching the URI given. */
1820#define VERR_HTTP_NOT_FOUND (-886)
1821/** The request is for something forbidden. Authorization will not help. */
1822#define VERR_HTTP_ACCESS_DENIED (-887)
1823/** The server did not understand the request due to bad syntax. */
1824#define VERR_HTTP_BAD_REQUEST (-888)
1825/** Couldn't connect to the server (proxy?). */
1826#define VERR_HTTP_COULDNT_CONNECT (-889)
1827/** SSL connection error. */
1828#define VERR_HTTP_SSL_CONNECT_ERROR (-890)
1829/** CAcert is missing or has the wrong format. */
1830#define VERR_HTTP_CACERT_WRONG_FORMAT (-891)
1831/** Certificate cannot be authenticated with the given CA certificates. */
1832#define VERR_HTTP_CACERT_CANNOT_AUTHENTICATE (-892)
1833/** The current HTTP request was forcefully aborted */
1834#define VERR_HTTP_ABORTED (-893)
1835/** Request was redirected. */
1836#define VERR_HTTP_REDIRECTED (-894)
1837/** Proxy couldn't be resolved. */
1838#define VERR_HTTP_PROXY_NOT_FOUND (-895)
1839/** The remote host couldn't be resolved. */
1840#define VERR_HTTP_HOST_NOT_FOUND (-896)
1841/** Unexpected cURL error configure the proxy. */
1842#define VERR_HTTP_CURL_PROXY_CONFIG (-897)
1843/** Generic CURL error. */
1844#define VERR_HTTP_CURL_ERROR (-899)
1845/** @} */
1846
1847/** @name RTManifest status codes
1848 * @{ */
1849/** A digest type used in the manifest file isn't supported. */
1850#define VERR_MANIFEST_UNSUPPORTED_DIGEST_TYPE (-900)
1851/** An entry in the manifest file couldn't be interpreted correctly. */
1852#define VERR_MANIFEST_WRONG_FILE_FORMAT (-901)
1853/** A digest doesn't match the corresponding file. */
1854#define VERR_MANIFEST_DIGEST_MISMATCH (-902)
1855/** The file list doesn't match to the content of the manifest file. */
1856#define VERR_MANIFEST_FILE_MISMATCH (-903)
1857/** The specified attribute (name) was not found in the manifest. */
1858#define VERR_MANIFEST_ATTR_NOT_FOUND (-904)
1859/** The attribute type did not match. */
1860#define VERR_MANIFEST_ATTR_TYPE_MISMATCH (-905)
1861/** No attribute of the specified types was found. */
1862#define VERR_MANIFEST_ATTR_TYPE_NOT_FOUND (-906)
1863/** @} */
1864
1865/** @name RTTar status codes
1866 * @{ */
1867/** The checksum of a tar header record doesn't match. */
1868#define VERR_TAR_CHKSUM_MISMATCH (-925)
1869/** The tar end of file record was read. */
1870#define VERR_TAR_END_OF_FILE (-926)
1871/** The tar file ended unexpectedly. */
1872#define VERR_TAR_UNEXPECTED_EOS (-927)
1873/** The tar termination records was encountered without reaching the end of
1874 * the input stream. */
1875#define VERR_TAR_EOS_MORE_INPUT (-928)
1876/** A number tar header field was malformed. */
1877#define VERR_TAR_BAD_NUM_FIELD (-929)
1878/** A numeric tar header field was not terminated correctly. */
1879#define VERR_TAR_BAD_NUM_FIELD_TERM (-930)
1880/** A number tar header field was encoded using base-256 which this
1881 * tar implementation currently does not support. */
1882#define VERR_TAR_BASE_256_NOT_SUPPORTED (-931)
1883/** A number tar header field yielded a value too large for the internal
1884 * variable of the tar interpreter. */
1885#define VERR_TAR_NUM_VALUE_TOO_LARGE (-932)
1886/** The combined minor and major device number type is too small to hold the
1887 * value stored in the tar header. */
1888#define VERR_TAR_DEV_VALUE_TOO_LARGE (-933)
1889/** The mode field in a tar header is bad. */
1890#define VERR_TAR_BAD_MODE_FIELD (-934)
1891/** The mode field should not include the type. */
1892#define VERR_TAR_MODE_WITH_TYPE (-935)
1893/** The size field should be zero for links and symlinks. */
1894#define VERR_TAR_SIZE_NOT_ZERO (-936)
1895/** Encountered an unknown type flag. */
1896#define VERR_TAR_UNKNOWN_TYPE_FLAG (-937)
1897/** The tar header is all zeros. */
1898#define VERR_TAR_ZERO_HEADER (-938)
1899/** Not a uniform standard tape v0.0 archive header. */
1900#define VERR_TAR_NOT_USTAR_V00 (-939)
1901/** The name is empty. */
1902#define VERR_TAR_EMPTY_NAME (-940)
1903/** A non-directory entry has a name ending with a slash. */
1904#define VERR_TAR_NON_DIR_ENDS_WITH_SLASH (-941)
1905/** Encountered an unsupported portable archive exchange (pax) header. */
1906#define VERR_TAR_UNSUPPORTED_PAX_TYPE (-942)
1907/** Encountered an unsupported Solaris Tar extension. */
1908#define VERR_TAR_UNSUPPORTED_SOLARIS_HDR_TYPE (-943)
1909/** Encountered an unsupported GNU Tar extension. */
1910#define VERR_TAR_UNSUPPORTED_GNU_HDR_TYPE (-944)
1911/** Malformed checksum field in the tar header. */
1912#define VERR_TAR_BAD_CHKSUM_FIELD (-945)
1913/** Malformed checksum field in the tar header. */
1914#define VERR_TAR_MALFORMED_GNU_LONGXXXX (-946)
1915/** Too long name or link string. */
1916#define VERR_TAR_NAME_TOO_LONG (-947)
1917/** A directory entry in the archive. */
1918#define VINF_TAR_DIR_PATH (948)
1919/** @} */
1920
1921/** @name RTPoll status codes
1922 * @{ */
1923/** The handle is not pollable. */
1924#define VERR_POLL_HANDLE_NOT_POLLABLE (-950)
1925/** The handle ID is already present in the poll set. */
1926#define VERR_POLL_HANDLE_ID_EXISTS (-951)
1927/** The handle ID was not found in the set. */
1928#define VERR_POLL_HANDLE_ID_NOT_FOUND (-952)
1929/** The poll set is full. */
1930#define VERR_POLL_SET_IS_FULL (-953)
1931/** @} */
1932
1933/** @name Pkzip status codes
1934 * @{ */
1935/** No end of central directory record found. */
1936#define VERR_PKZIP_NO_EOCB (-960)
1937/** Too long name string. */
1938#define VERR_PKZIP_NAME_TOO_LONG (-961)
1939/** Local file header corrupt. */
1940#define VERR_PKZIP_BAD_LF_HEADER (-962)
1941/** Central directory file header corrupt. */
1942#define VERR_PKZIP_BAD_CDF_HEADER (-963)
1943/** Encountered an unknown type flag. */
1944#define VERR_PKZIP_UNKNOWN_TYPE_FLAG (-964)
1945/** Found a ZIP64 Extra Information Field in a ZIP32 file. */
1946#define VERR_PKZIP_ZIP64EX_IN_ZIP32 (-965)
1947
1948
1949/** @name RTZip status codes
1950 * @{ */
1951/** Generic zip error. */
1952#define VERR_ZIP_ERROR (-22000)
1953/** The compressed data was corrupted. */
1954#define VERR_ZIP_CORRUPTED (-22001)
1955/** Ran out of memory while compressing or uncompressing. */
1956#define VERR_ZIP_NO_MEMORY (-22002)
1957/** The compression format version is unsupported. */
1958#define VERR_ZIP_UNSUPPORTED_VERSION (-22003)
1959/** The compression method is unsupported. */
1960#define VERR_ZIP_UNSUPPORTED_METHOD (-22004)
1961/** The compressed data started with a bad header. */
1962#define VERR_ZIP_BAD_HEADER (-22005)
1963/** @} */
1964
1965/** @name RTVfs status codes
1966 * @{ */
1967/** The VFS chain specification does not have a valid prefix. */
1968#define VERR_VFS_CHAIN_NO_PREFIX (-22100)
1969/** The VFS chain specification is empty. */
1970#define VERR_VFS_CHAIN_EMPTY (-22101)
1971/** Expected an element. */
1972#define VERR_VFS_CHAIN_EXPECTED_ELEMENT (-22102)
1973/** The VFS object type is not known. */
1974#define VERR_VFS_CHAIN_UNKNOWN_TYPE (-22103)
1975/** Expected a left parentheses. */
1976#define VERR_VFS_CHAIN_EXPECTED_LEFT_PARENTHESES (-22104)
1977/** Expected a right parentheses. */
1978#define VERR_VFS_CHAIN_EXPECTED_RIGHT_PARENTHESES (-22105)
1979/** Expected a provider name. */
1980#define VERR_VFS_CHAIN_EXPECTED_PROVIDER_NAME (-22106)
1981/** Expected an element separator (| or :). */
1982#define VERR_VFS_CHAIN_EXPECTED_SEPARATOR (-22107)
1983/** Leading element separator not permitted. */
1984#define VERR_VFS_CHAIN_LEADING_SEPARATOR (-22108)
1985/** Trailing element separator not permitted. */
1986#define VERR_VFS_CHAIN_TRAILING_SEPARATOR (-22109)
1987/** The provider is only allowed as the first element. */
1988#define VERR_VFS_CHAIN_MUST_BE_FIRST_ELEMENT (-22110)
1989/** The provider cannot be the first element. */
1990#define VERR_VFS_CHAIN_CANNOT_BE_FIRST_ELEMENT (-22111)
1991/** VFS object cast failed. */
1992#define VERR_VFS_CHAIN_CAST_FAILED (-22112)
1993/** Internal error in the VFS chain code. */
1994#define VERR_VFS_CHAIN_IPE (-22113)
1995/** VFS chain element provider not found. */
1996#define VERR_VFS_CHAIN_PROVIDER_NOT_FOUND (-22114)
1997/** VFS chain does not terminate with the desired object type. */
1998#define VERR_VFS_CHAIN_FINAL_TYPE_MISMATCH (-22115)
1999/** VFS chain element takes no arguments. */
2000#define VERR_VFS_CHAIN_NO_ARGS (-22116)
2001/** VFS chain element takes exactly one argument. */
2002#define VERR_VFS_CHAIN_ONE_ARG (-22117)
2003/** VFS chain element expected at most one argument. */
2004#define VERR_VFS_CHAIN_AT_MOST_ONE_ARG (-22118)
2005/** VFS chain element expected at least one argument. */
2006#define VERR_VFS_CHAIN_AT_LEAST_ONE_ARG (-22119)
2007/** VFS chain element takes exactly two arguments. */
2008#define VERR_VFS_CHAIN_TWO_ARGS (-22120)
2009/** VFS chain element expected at least two arguments. */
2010#define VERR_VFS_CHAIN_AT_LEAST_TWO_ARGS (-22121)
2011/** VFS chain element expected at most two arguments. */
2012#define VERR_VFS_CHAIN_AT_MOST_TWO_ARGS (-22122)
2013/** VFS chain element takes exactly three arguments. */
2014#define VERR_VFS_CHAIN_THREE_ARGS (-22123)
2015/** VFS chain element expected at least three arguments. */
2016#define VERR_VFS_CHAIN_AT_LEAST_THREE_ARGS (-22124)
2017/** VFS chain element expected at most three arguments. */
2018#define VERR_VFS_CHAIN_AT_MOST_THREE_ARGS (-22125)
2019/** VFS chain element takes exactly four arguments. */
2020#define VERR_VFS_CHAIN_FOUR_ARGS (-22126)
2021/** VFS chain element expected at least four arguments. */
2022#define VERR_VFS_CHAIN_AT_LEAST_FOUR_ARGS (-22127)
2023/** VFS chain element expected at most four arguments. */
2024#define VERR_VFS_CHAIN_AT_MOST_FOUR_ARGS (-22128)
2025/** VFS chain element takes exactly five arguments. */
2026#define VERR_VFS_CHAIN_FIVE_ARGS (-22129)
2027/** VFS chain element expected at least five arguments. */
2028#define VERR_VFS_CHAIN_AT_LEAST_FIVE_ARGS (-22130)
2029/** VFS chain element expected at most five arguments. */
2030#define VERR_VFS_CHAIN_AT_MOST_FIVE_ARGS (-22131)
2031/** VFS chain element takes exactly six arguments. */
2032#define VERR_VFS_CHAIN_SIX_ARGS (-22132)
2033/** VFS chain element expected at least six arguments. */
2034#define VERR_VFS_CHAIN_AT_LEAST_SIX_ARGS (-22133)
2035/** VFS chain element expected at most six arguments. */
2036#define VERR_VFS_CHAIN_AT_MOST_SIX_ARGS (-22134)
2037/** VFS chain element expected at most six arguments. */
2038#define VERR_VFS_CHAIN_TOO_FEW_ARGS (-22135)
2039/** VFS chain element expected at most six arguments. */
2040#define VERR_VFS_CHAIN_TOO_MANY_ARGS (-22136)
2041/** VFS chain element expected non-empty argument. */
2042#define VERR_VFS_CHAIN_EMPTY_ARG (-22137)
2043/** Invalid argument to VFS chain element. */
2044#define VERR_VFS_CHAIN_INVALID_ARGUMENT (-22138)
2045/** VFS chain element only provides file and I/O stream (ios) objects. */
2046#define VERR_VFS_CHAIN_ONLY_FILE_OR_IOS (-22139)
2047/** VFS chain element only provides I/O stream (ios) objects. */
2048#define VERR_VFS_CHAIN_ONLY_IOS (-22140)
2049/** VFS chain element only provides directory (dir) objects. */
2050#define VERR_VFS_CHAIN_ONLY_DIR (-22141)
2051/** VFS chain element only provides file system stream (fss) objects. */
2052#define VERR_VFS_CHAIN_ONLY_FSS (-22142)
2053/** VFS chain element only provides file system (vfs) objects. */
2054#define VERR_VFS_CHAIN_ONLY_VFS (-22143)
2055/** VFS chain element only provides file, I/O stream (ios), or
2056 * directory (dir) objects. */
2057#define VERR_VFS_CHAIN_ONLY_FILE_OR_IOS_OR_DIR (-22144)
2058/** VFS chain element only provides file, I/O stream (ios), or
2059 * directory (dir) objects. */
2060#define VERR_VFS_CHAIN_ONLY_DIR_OR_VFS (-22145)
2061/** VFS chain element takes a file object as input. */
2062#define VERR_VFS_CHAIN_TAKES_FILE (-22146)
2063/** VFS chain element takes a file or I/O stream (ios) object as input. */
2064#define VERR_VFS_CHAIN_TAKES_FILE_OR_IOS (-22147)
2065/** VFS chain element takes a directory (dir) object as input. */
2066#define VERR_VFS_CHAIN_TAKES_DIR (-22148)
2067/** VFS chain element takes a file system stream (fss) object as input. */
2068#define VERR_VFS_CHAIN_TAKES_FSS (-22149)
2069/** VFS chain element takes a file system (vfs) object as input. */
2070#define VERR_VFS_CHAIN_TAKES_VFS (-22150)
2071/** VFS chain element takes a directory (dir) or file system (vfs)
2072 * object as input. */
2073#define VERR_VFS_CHAIN_TAKES_DIR_OR_VFS (-22151)
2074/** VFS chain element takes a directory (dir), file system stream (fss),
2075 * or file system (vfs) object as input. */
2076#define VERR_VFS_CHAIN_TAKES_DIR_OR_FSS_OR_VFS (-22152)
2077/** VFS chain element only provides a read-only I/O stream, while the chain
2078 * requires write access. */
2079#define VERR_VFS_CHAIN_READ_ONLY_IOS (-22153)
2080/** VFS chain element only provides a read-only I/O stream, while the chain
2081 * read access. */
2082#define VERR_VFS_CHAIN_WRITE_ONLY_IOS (-22154)
2083/** VFS chain only has a single element and it is just a path, need to be
2084 * treated as a normal file system request. */
2085#define VERR_VFS_CHAIN_PATH_ONLY (-22155)
2086/** VFS chain element preceding the final path needs to be a directory, file
2087 * system or file system stream. */
2088#define VERR_VFS_CHAIN_TYPE_MISMATCH_PATH_ONLY (-22156)
2089/** VFS chain doesn't end with a path only element. */
2090#define VERR_VFS_CHAIN_NOT_PATH_ONLY (-22157)
2091/** The path only element at the end of the VFS chain is too short to make out
2092 * the parent directory. */
2093#define VERR_VFS_CHAIN_TOO_SHORT_FOR_PARENT (-22158)
2094/** @} */
2095
2096/** @name RTDvm status codes
2097 * @{ */
2098/** The volume map doesn't contain any valid volume. */
2099#define VERR_DVM_MAP_EMPTY (-22200)
2100/** There is no volume behind the current one. */
2101#define VERR_DVM_MAP_NO_VOLUME (-22201)
2102/** @} */
2103
2104/** @name Logger status codes
2105 * @{ */
2106/** The internal logger revision did not match. */
2107#define VERR_LOG_REVISION_MISMATCH (-22300)
2108/** @} */
2109
2110/* see above, 22400..22499 is used for misc codes! */
2111
2112/** @name Logger status codes
2113 * @{ */
2114/** Power off is not supported by the hardware or the OS. */
2115#define VERR_SYS_CANNOT_POWER_OFF (-22500)
2116/** The halt action was requested, but the OS may actually power
2117 * off the machine. */
2118#define VINF_SYS_MAY_POWER_OFF (22501)
2119/** Shutdown failed. */
2120#define VERR_SYS_SHUTDOWN_FAILED (-22502)
2121/** @} */
2122
2123/** @name Filesystem status codes
2124 * @{ */
2125/** Filesystem can't be opened because it is corrupt. */
2126#define VERR_FILESYSTEM_CORRUPT (-22600)
2127/** @} */
2128
2129/** @name RTZipXar status codes.
2130 * @{ */
2131/** Wrong magic value. */
2132#define VERR_XAR_WRONG_MAGIC (-22700)
2133/** Bad header size. */
2134#define VERR_XAR_BAD_HDR_SIZE (-22701)
2135/** Unsupported version. */
2136#define VERR_XAR_UNSUPPORTED_VERSION (-22702)
2137/** Unsupported hashing function. */
2138#define VERR_XAR_UNSUPPORTED_HASH_FUNCTION (-22703)
2139/** The table of content (TOC) is too small and therefore can't be valid. */
2140#define VERR_XAR_TOC_TOO_SMALL (-22704)
2141/** The table of content (TOC) is too big. */
2142#define VERR_XAR_TOC_TOO_BIG (-22705)
2143/** The compressed table of content is too big. */
2144#define VERR_XAR_TOC_TOO_BIG_COMPRESSED (-22706)
2145/** The uncompressed table of content size in the header didn't match what
2146 * ZLib returned. */
2147#define VERR_XAR_TOC_UNCOMP_SIZE_MISMATCH (-22707)
2148/** The table of content string length didn't match the size specified in the
2149 * header. */
2150#define VERR_XAR_TOC_STRLEN_MISMATCH (-22708)
2151/** The table of content isn't valid UTF-8. */
2152#define VERR_XAR_TOC_UTF8_ENCODING (-22709)
2153/** XML error while parsing the table of content. */
2154#define VERR_XAR_TOC_XML_PARSE_ERROR (-22710)
2155/** The table of content XML document does not have a toc element. */
2156#define VERR_XML_TOC_ELEMENT_MISSING (-22711)
2157/** The table of content XML element (toc) has siblings, we expected it to be
2158 * an only child or the root element (xar). */
2159#define VERR_XML_TOC_ELEMENT_HAS_SIBLINGS (-22712)
2160/** The XAR table of content digest doesn't match. */
2161#define VERR_XAR_TOC_DIGEST_MISMATCH (-22713)
2162/** Bad or missing XAR checksum element. */
2163#define VERR_XAR_BAD_CHECKSUM_ELEMENT (-22714)
2164/** The hash function in the header doesn't match the one in the table of
2165 * content. */
2166#define VERR_XAR_HASH_FUNCTION_MISMATCH (-22715)
2167/** Bad digest length encountered in the table of content. */
2168#define VERR_XAR_BAD_DIGEST_LENGTH (-22716)
2169/** The order of elements in the XAR file does not lend it self to expansion
2170 * from via an I/O stream. */
2171#define VERR_XAR_NOT_STREAMBLE_ELEMENT_ORDER (-22717)
2172/** Missing offset element in table of content sub-element. */
2173#define VERR_XAR_MISSING_OFFSET_ELEMENT (-22718)
2174/** Bad offset element in table of content sub-element. */
2175#define VERR_XAR_BAD_OFFSET_ELEMENT (-22719)
2176/** Missing size element in table of content sub-element. */
2177#define VERR_XAR_MISSING_SIZE_ELEMENT (-22720)
2178/** Bad size element in table of content sub-element. */
2179#define VERR_XAR_BAD_SIZE_ELEMENT (-22721)
2180/** Missing length element in table of content sub-element. */
2181#define VERR_XAR_MISSING_LENGTH_ELEMENT (-22722)
2182/** Bad length element in table of content sub-element. */
2183#define VERR_XAR_BAD_LENGTH_ELEMENT (-22723)
2184/** Bad file element in XAR table of content. */
2185#define VERR_XAR_BAD_FILE_ELEMENT (-22724)
2186/** Missing data element for XAR file. */
2187#define VERR_XAR_MISSING_DATA_ELEMENT (-22725)
2188/** Unknown XAR file type value. */
2189#define VERR_XAR_UNKNOWN_FILE_TYPE (-22726)
2190/** Missing encoding element for XAR data stream. */
2191#define VERR_XAR_NO_ENCODING (-22727)
2192/** Bad timestamp for XAR file. */
2193#define VERR_XAR_BAD_FILE_TIMESTAMP (-22728)
2194/** Bad file mode for XAR file. */
2195#define VERR_XAR_BAD_FILE_MODE (-22729)
2196/** Bad file user id for XAR file. */
2197#define VERR_XAR_BAD_FILE_UID (-22730)
2198/** Bad file group id for XAR file. */
2199#define VERR_XAR_BAD_FILE_GID (-22731)
2200/** Bad file inode device number for XAR file. */
2201#define VERR_XAR_BAD_FILE_DEVICE_NO (-22732)
2202/** Bad file inode number for XAR file. */
2203#define VERR_XAR_BAD_FILE_INODE (-22733)
2204/** Invalid name for XAR file. */
2205#define VERR_XAR_INVALID_FILE_NAME (-22734)
2206/** The message digest of the extracted data does not match the one supplied. */
2207#define VERR_XAR_EXTRACTED_HASH_MISMATCH (-22735)
2208/** The extracted data has exceeded the expected size. */
2209#define VERR_XAR_EXTRACTED_SIZE_EXCEEDED (-22736)
2210/** The message digest of the archived data does not match the one supplied. */
2211#define VERR_XAR_ARCHIVED_HASH_MISMATCH (-22737)
2212/** The decompressor completed without using all the input data. */
2213#define VERR_XAR_UNUSED_ARCHIVED_DATA (-22738)
2214/** Expected the archived and extracted XAR data sizes to be the same for
2215 * uncompressed data. */
2216#define VERR_XAR_ARCHIVED_AND_EXTRACTED_SIZES_MISMATCH (-22739)
2217/** @} */
2218
2219/** @name RTX509 status codes
2220 * @{ */
2221/** Error reading a certificate in PEM format from BIO. */
2222#define VERR_X509_READING_CERT_FROM_BIO (-23100)
2223/** Error extracting a public key from the certificate. */
2224#define VERR_X509_EXTRACT_PUBKEY_FROM_CERT (-23101)
2225/** Error extracting RSA from the public key. */
2226#define VERR_X509_EXTRACT_RSA_FROM_PUBLIC_KEY (-23102)
2227/** Signature verification failed. */
2228#define VERR_X509_RSA_VERIFICATION_FUILURE (-23103)
2229/** Basic constraints were not found. */
2230#define VERR_X509_NO_BASIC_CONSTARAINTS (-23104)
2231/** Error getting extensions from the certificate. */
2232#define VERR_X509_GETTING_EXTENSION_FROM_CERT (-23105)
2233/** Error getting a data from the extension. */
2234#define VERR_X509_GETTING_DATA_FROM_EXTENSION (-23106)
2235/** Error formatting an extension. */
2236#define VERR_X509_PRINT_EXTENSION_TO_BIO (-23107)
2237/** X509 certificate verification error. */
2238#define VERR_X509_CERTIFICATE_VERIFICATION_FAILURE (-23108)
2239/** X509 certificate isn't self signed. */
2240#define VERR_X509_NOT_SELFSIGNED_CERTIFICATE (-23109)
2241/** Warning X509 certificate isn't self signed. */
2242#define VINF_X509_NOT_SELFSIGNED_CERTIFICATE 23109
2243/** @} */
2244
2245/** @name RTAsn1 status codes
2246 * @{ */
2247/** Temporary place holder. */
2248#define VERR_ASN1_ERROR (-22800)
2249/** Encountered an ASN.1 string type that is not supported. */
2250#define VERR_ASN1_STRING_TYPE_NOT_IMPLEMENTED (-22801)
2251/** Invalid ASN.1 UTF-8 STRING encoding. */
2252#define VERR_ASN1_INVALID_UTF8_STRING_ENCODING (-22802)
2253/** Invalid ASN.1 NUMERIC STRING encoding. */
2254#define VERR_ASN1_INVALID_NUMERIC_STRING_ENCODING (-22803)
2255/** Invalid ASN.1 PRINTABLE STRING encoding. */
2256#define VERR_ASN1_INVALID_PRINTABLE_STRING_ENCODING (-22804)
2257/** Invalid ASN.1 T61/TELETEX STRING encoding. */
2258#define VERR_ASN1_INVALID_T61_STRING_ENCODING (-22805)
2259/** Invalid ASN.1 VIDEOTEX STRING encoding. */
2260#define VERR_ASN1_INVALID_VIDEOTEX_STRING_ENCODING (-22806)
2261/** Invalid ASN.1 IA5 STRING encoding. */
2262#define VERR_ASN1_INVALID_IA5_STRING_ENCODING (-22807)
2263/** Invalid ASN.1 GRAPHIC STRING encoding. */
2264#define VERR_ASN1_INVALID_GRAPHIC_STRING_ENCODING (-22808)
2265/** Invalid ASN.1 ISO-646/VISIBLE STRING encoding. */
2266#define VERR_ASN1_INVALID_VISIBLE_STRING_ENCODING (-22809)
2267/** Invalid ASN.1 GENERAL STRING encoding. */
2268#define VERR_ASN1_INVALID_GENERAL_STRING_ENCODING (-22810)
2269/** Invalid ASN.1 UNIVERSAL STRING encoding. */
2270#define VERR_ASN1_INVALID_UNIVERSAL_STRING_ENCODING (-22811)
2271/** Invalid ASN.1 BMP STRING encoding. */
2272#define VERR_ASN1_INVALID_BMP_STRING_ENCODING (-22812)
2273/** Invalid ASN.1 OBJECT IDENTIFIER encoding. */
2274#define VERR_ASN1_INVALID_OBJID_ENCODING (-22813)
2275/** A component value of an ASN.1 OBJECT IDENTIFIER is too big for our
2276 * internal representation (32-bits). */
2277#define VERR_ASN1_OBJID_COMPONENT_TOO_BIG (-22814)
2278/** Too many components in an ASN.1 OBJECT IDENTIFIER for our internal
2279 * representation. */
2280#define VERR_ASN1_OBJID_TOO_MANY_COMPONENTS (-22815)
2281/** The dotted-string representation of an ASN.1 OBJECT IDENTIFIER would be too
2282 * long for our internal representation. */
2283#define VERR_ASN1_OBJID_TOO_LONG_STRING_FORM (-22816)
2284/** Invalid dotted string. */
2285#define VERR_ASN1_OBJID_INVALID_DOTTED_STRING (-22817)
2286/** Constructed string type not implemented. */
2287#define VERR_ASN1_CONSTRUCTED_STRING_NOT_IMPL (-22818)
2288/** Expected a different string tag. */
2289#define VERR_ASN1_STRING_TAG_MISMATCH (-22819)
2290/** Expected a different time tag. */
2291#define VERR_ASN1_TIME_TAG_MISMATCH (-22820)
2292/** More unconsumed data available. */
2293#define VINF_ASN1_MORE_DATA (22821)
2294/** RTAsnEncodeWriteHeader return code indicating that nothing was written
2295 * and the content should be skipped as well. */
2296#define VINF_ASN1_NOT_ENCODED (22822)
2297/** Unknown escape sequence encountered in TeletexString. */
2298#define VERR_ASN1_TELETEX_UNKNOWN_ESC_SEQ (-22823)
2299/** Unsupported escape sequence encountered in TeletexString. */
2300#define VERR_ASN1_TELETEX_UNSUPPORTED_ESC_SEQ (-22824)
2301/** Unsupported character set. */
2302#define VERR_ASN1_TELETEX_UNSUPPORTED_CHARSET (-22825)
2303/** ASN.1 object has no virtual method table. */
2304#define VERR_ASN1_NO_VTABLE (-22826)
2305/** ASN.1 object has no pfnCheckSanity method. */
2306#define VERR_ASN1_NO_CHECK_SANITY_METHOD (-22827)
2307/** ASN.1 object is not present */
2308#define VERR_ASN1_NOT_PRESENT (-22828)
2309/** There are unconsumed bytes after decoding an ASN.1 object. */
2310#define VERR_ASN1_CURSOR_NOT_AT_END (-22829)
2311/** Long ASN.1 tag form is not implemented. */
2312#define VERR_ASN1_CURSOR_LONG_TAG (-22830)
2313/** Bad ASN.1 object length encoding. */
2314#define VERR_ASN1_CURSOR_BAD_LENGTH_ENCODING (-22831)
2315/** Indefinite length form is against the rules. */
2316#define VERR_ASN1_CURSOR_ILLEGAL_IDEFINITE_LENGTH (-22832)
2317/** Indefinite length form is not implemented. */
2318#define VERR_ASN1_CURSOR_IDEFINITE_LENGTH_NOT_SUP (-22833)
2319/** ASN.1 object length goes beyond the end of the byte stream being decoded. */
2320#define VERR_ASN1_CURSOR_BAD_LENGTH (-22834)
2321/** Not more data in ASN.1 byte stream. */
2322#define VERR_ASN1_CURSOR_NO_MORE_DATA (-22835)
2323/** Too little data in ASN.1 byte stream. */
2324#define VERR_ASN1_CURSOR_TOO_LITTLE_DATA_LEFT (-22836)
2325/** Constructed string is not according to the encoding rules. */
2326#define VERR_ASN1_CURSOR_ILLEGAL_CONSTRUCTED_STRING (-22837)
2327/** Unexpected ASN.1 tag encountered while decoding. */
2328#define VERR_ASN1_CURSOR_TAG_MISMATCH (-22838)
2329/** Unexpected ASN.1 tag class/flag encountered while decoding. */
2330#define VERR_ASN1_CURSOR_TAG_FLAG_CLASS_MISMATCH (-22839)
2331/** ASN.1 bit string object is out of bounds. */
2332#define VERR_ASN1_BITSTRING_OUT_OF_BOUNDS (-22840)
2333/** Bad ASN.1 time object. */
2334#define VERR_ASN1_TIME_BAD_NORMALIZE_INPUT (-22841)
2335/** Failed to normalize ASN.1 time object. */
2336#define VERR_ASN1_TIME_NORMALIZE_ERROR (-22842)
2337/** Normalization of ASN.1 time object didn't work out. */
2338#define VERR_ASN1_TIME_NORMALIZE_MISMATCH (-22843)
2339/** Invalid ASN.1 UTC TIME encoding. */
2340#define VERR_ASN1_INVALID_UTC_TIME_ENCODING (-22844)
2341/** Invalid ASN.1 GENERALIZED TIME encoding. */
2342#define VERR_ASN1_INVALID_GENERALIZED_TIME_ENCODING (-22845)
2343/** Invalid ASN.1 BOOLEAN encoding. */
2344#define VERR_ASN1_INVALID_BOOLEAN_ENCODING (-22846)
2345/** Invalid ASN.1 NULL encoding. */
2346#define VERR_ASN1_INVALID_NULL_ENCODING (-22847)
2347/** Invalid ASN.1 BIT STRING encoding. */
2348#define VERR_ASN1_INVALID_BITSTRING_ENCODING (-22848)
2349/** Unimplemented ASN.1 tag reached the RTAsn1DynType code. */
2350#define VERR_ASN1_DYNTYPE_TAG_NOT_IMPL (-22849)
2351/** ASN.1 tag and flags/class mismatch in RTAsn1DynType code. */
2352#define VERR_ASN1_DYNTYPE_BAD_TAG (-22850)
2353/** Unexpected ASN.1 fake/dummy object. */
2354#define VERR_ASN1_DUMMY_OBJECT (-22851)
2355/** ASN.1 object is too long. */
2356#define VERR_ASN1_TOO_LONG (-22852)
2357/** Expected primitive ASN.1 object. */
2358#define VERR_ASN1_EXPECTED_PRIMITIVE (-22853)
2359/** Expected valid data pointer for ASN.1 object. */
2360#define VERR_ASN1_INVALID_DATA_POINTER (-22854)
2361/** The ASN.1 encoding is too deeply nested for the decoder. */
2362#define VERR_ASN1_TOO_DEEPLY_NESTED (-22855)
2363/** Generic unexpected object ID error. */
2364#define VERR_ASN1_UNEXPECTED_OBJ_ID (-22856)
2365
2366/** ANS.1 internal error 1. */
2367#define VERR_ASN1_INTERNAL_ERROR_1 (-22895)
2368/** ANS.1 internal error 2. */
2369#define VERR_ASN1_INTERNAL_ERROR_2 (-22896)
2370/** ANS.1 internal error 3. */
2371#define VERR_ASN1_INTERNAL_ERROR_3 (-22897)
2372/** ANS.1 internal error 4. */
2373#define VERR_ASN1_INTERNAL_ERROR_4 (-22898)
2374/** ANS.1 internal error 5. */
2375#define VERR_ASN1_INTERNAL_ERROR_5 (-22899)
2376/** @} */
2377
2378/** @name More RTLdr status codes.
2379 * @{ */
2380/** Image Verification Failure: No Authenticode Signature. */
2381#define VERR_LDRVI_NOT_SIGNED (-22900)
2382/** Image Verification Warning: No Authenticode Signature, but on whitelist. */
2383#define VINF_LDRVI_NOT_SIGNED (22900)
2384/** Image Verification Failure: Error reading image headers. */
2385#define VERR_LDRVI_READ_ERROR_HDR (-22901)
2386/** Image Verification Failure: Error reading section headers. */
2387#define VERR_LDRVI_READ_ERROR_SHDRS (-22902)
2388/** Image Verification Failure: Error reading authenticode signature data. */
2389#define VERR_LDRVI_READ_ERROR_SIGNATURE (-22903)
2390/** Image Verification Failure: Error reading file for hashing. */
2391#define VERR_LDRVI_READ_ERROR_HASH (-22904)
2392/** Image Verification Failure: Error determining the file length. */
2393#define VERR_LDRVI_FILE_LENGTH_ERROR (-22905)
2394/** Image Verification Failure: Error allocating memory for state data. */
2395#define VERR_LDRVI_NO_MEMORY_STATE (-22906)
2396/** Image Verification Failure: Error allocating memory for authenticode
2397 * signature data. */
2398#define VERR_LDRVI_NO_MEMORY_SIGNATURE (-22907)
2399/** Image Verification Failure: Error allocating memory for section headers. */
2400#define VERR_LDRVI_NO_MEMORY_SHDRS (-22908)
2401/** Image Verification Failure: Authenticode parsing output. */
2402#define VERR_LDRVI_NO_MEMORY_PARSE_OUTPUT (-22909)
2403/** Image Verification Failure: Invalid security directory entry. */
2404#define VERR_LDRVI_INVALID_SECURITY_DIR_ENTRY (-22910)
2405/** Image Verification Failure: */
2406#define VERR_LDRVI_BAD_CERT_HDR_LENGTH (-22911)
2407/** Image Verification Failure: */
2408#define VERR_LDRVI_BAD_CERT_HDR_REVISION (-22912)
2409/** Image Verification Failure: */
2410#define VERR_LDRVI_BAD_CERT_HDR_TYPE (-22913)
2411/** Image Verification Failure: More than one certificate table entry. */
2412#define VERR_LDRVI_BAD_CERT_MULTIPLE (-22914)
2413
2414/** Image Verification Failure: */
2415#define VERR_LDRVI_BAD_MZ_OFFSET (-22915)
2416/** Image Verification Failure: Invalid section count. */
2417#define VERR_LDRVI_INVALID_SECTION_COUNT (-22916)
2418/** Image Verification Failure: Raw data offsets and sizes are out of range. */
2419#define VERR_LDRVI_SECTION_RAW_DATA_VALUES (-22917)
2420/** Optional header magic and target machine does not match. */
2421#define VERR_LDRVI_MACHINE_OPT_HDR_MAGIC_MISMATCH (-22918)
2422/** Unsupported image target architecture. */
2423#define VERR_LDRVI_UNSUPPORTED_ARCH (-22919)
2424
2425/** Image Verification Failure: Internal error in signature parser. */
2426#define VERR_LDRVI_PARSE_IPE (-22921)
2427/** Generic BER parse error. Will be refined later. */
2428#define VERR_LDRVI_PARSE_BER_ERROR (-22922)
2429
2430/** Expected the signed data content to be the object ID of
2431 * SpcIndirectDataContent, found something else instead. */
2432#define VERR_LDRVI_EXPECTED_INDIRECT_DATA_CONTENT_OID (-22923)
2433/** Page hash table size overflow. */
2434#define VERR_LDRVI_PAGE_HASH_TAB_SIZE_OVERFLOW (-22924)
2435/** Page hash table is too long (covers signature data, i.e. itself). */
2436#define VERR_LDRVI_PAGE_HASH_TAB_TOO_LONG (-22925)
2437/** The page hash table is not strictly ordered by offset. */
2438#define VERR_LDRVI_PAGE_HASH_TAB_NOT_STRICTLY_SORTED (-22926)
2439/** The page hash table hashes data outside the defined and implicit sections. */
2440#define VERR_PAGE_HASH_TAB_HASHES_NON_SECTION_DATA (-22927)
2441/** Page hash mismatch. */
2442#define VERR_LDRVI_PAGE_HASH_MISMATCH (-22928)
2443/** Image hash mismatch. */
2444#define VERR_LDRVI_IMAGE_HASH_MISMATCH (-22929)
2445
2446/** Cannot resolve symbol because it's a forwarder. */
2447#define VERR_LDR_FORWARDER (-22950)
2448/** The symbol is not a forwarder. */
2449#define VERR_LDR_NOT_FORWARDER (-22951)
2450/** Malformed forwarder entry. */
2451#define VERR_LDR_BAD_FORWARDER (-22952)
2452/** Too long forwarder chain or there is a loop. */
2453#define VERR_LDR_FORWARDER_CHAIN_TOO_LONG (-22953)
2454/** Support for forwarders has not been implemented. */
2455#define VERR_LDR_FORWARDERS_NOT_SUPPORTED (-22954)
2456/** @} */
2457
2458/** @name RTCrX509 status codes.
2459 * @{ */
2460/** Generic X.509 error. */
2461#define VERR_CR_X509_GENERIC_ERROR (-23000)
2462/** Internal error in the X.509 code. */
2463#define VERR_CR_X509_INTERNAL_ERROR (-23001)
2464/** Internal error in the X.509 certificate path building and verification
2465 * code. */
2466#define VERR_CR_X509_CERTPATHS_INTERNAL_ERROR (-23002)
2467/** Path not verified yet. */
2468#define VERR_CR_X509_NOT_VERIFIED (-23003)
2469/** The certificate path has no trust anchor. */
2470#define VERR_CR_X509_NO_TRUST_ANCHOR (-23004)
2471/** Unknown X.509 certificate signature algorithm. */
2472#define VERR_CR_X509_UNKNOWN_CERT_SIGN_ALGO (-23005)
2473/** Certificate signature algorithm mismatch. */
2474#define VERR_CR_X509_CERT_SIGN_ALGO_MISMATCH (-23006)
2475/** The signature algorithm in the to-be-signed certificate part does not match
2476 * the one associated with the signature. */
2477#define VERR_CR_X509_CERT_TBS_SIGN_ALGO_MISMATCH (-23007)
2478/** Certificate extensions requires certificate version 3 or later. */
2479#define VERR_CR_X509_TBSCERT_EXTS_REQ_V3 (-23008)
2480/** Unique issuer and subject IDs require version certificate 2. */
2481#define VERR_CR_X509_TBSCERT_UNIQUE_IDS_REQ_V2 (-23009)
2482/** Certificate serial number length is out of bounds. */
2483#define VERR_CR_X509_TBSCERT_SERIAL_NUMBER_OUT_OF_BOUNDS (-23010)
2484/** Unsupported X.509 certificate version. */
2485#define VERR_CR_X509_TBSCERT_UNSUPPORTED_VERSION (-23011)
2486/** Public key is too small. */
2487#define VERR_CR_X509_PUBLIC_KEY_TOO_SMALL (-23012)
2488/** Invalid string tag for a X.509 name object. */
2489#define VERR_CR_X509_INVALID_NAME_STRING_TAG (-23013)
2490/** Empty string in X.509 name object. */
2491#define VERR_CR_X509_NAME_EMPTY_STRING (-23014)
2492/** Non-string object inside X.509 name object. */
2493#define VERR_CR_X509_NAME_NOT_STRING (-23015)
2494/** Empty set inside X.509 name. */
2495#define VERR_CR_X509_NAME_EMPTY_SET (-23016)
2496/** Empty sub-string set inside X.509 name. */
2497#define VERR_CR_X509_NAME_EMPTY_SUB_SET (-23017)
2498/** The NotBefore and NotAfter values of an X.509 Validity object seems to
2499 * have been swapped around. */
2500#define VERR_CR_X509_VALIDITY_SWAPPED (-23018)
2501/** Duplicate certificate extension. */
2502#define VERR_CR_X509_TBSCERT_DUPLICATE_EXTENSION (-23019)
2503/** Missing relative distinguished name map entry. */
2504#define VERR_CR_X509_NAME_MISSING_RDN_MAP_ENTRY (-23020)
2505/** Certificate path validator: No trusted certificate paths. */
2506#define VERR_CR_X509_CPV_NO_TRUSTED_PATHS (-23021)
2507/** Certificate path validator: No valid certificate policy. */
2508#define VERR_CR_X509_CPV_NO_VALID_POLICY (-23022)
2509/** Certificate path validator: Unknown critical certificate extension. */
2510#define VERR_CR_X509_CPV_UNKNOWN_CRITICAL_EXTENSION (-23023)
2511/** Certificate path validator: Intermediate certificate is missing the
2512 * KeyCertSign usage flag. */
2513#define VERR_CR_X509_CPV_MISSING_KEY_CERT_SIGN (-23024)
2514/** Certificate path validator: Hit the max certificate path length before
2515 * reaching trust anchor. */
2516#define VERR_CR_X509_CPV_MAX_PATH_LENGTH (-23025)
2517/** Certificate path validator: Intermediate certificate is not marked as a
2518 * certificate authority (CA). */
2519#define VERR_CR_X509_CPV_NOT_CA_CERT (-23026)
2520/** Certificate path validator: Intermediate certificate is not a version 3
2521 * certificate. */
2522#define VERR_CR_X509_CPV_NOT_V3_CERT (-23027)
2523/** Certificate path validator: Invalid policy mapping (to/from anyPolicy). */
2524#define VERR_CR_X509_CPV_INVALID_POLICY_MAPPING (-23028)
2525/** Certificate path validator: Name constraints permits no names. */
2526#define VERR_CR_X509_CPV_NO_PERMITTED_NAMES (-23029)
2527/** Certificate path validator: Name constraints does not permits the
2528 * certificate name. */
2529#define VERR_CR_X509_CPV_NAME_NOT_PERMITTED (-23030)
2530/** Certificate path validator: Name constraints does not permits the
2531 * alternative certificate name. */
2532#define VERR_CR_X509_CPV_ALT_NAME_NOT_PERMITTED (-23031)
2533/** Certificate path validator: Intermediate certificate subject does not
2534 * match child issuer property. */
2535#define VERR_CR_X509_CPV_ISSUER_MISMATCH (-23032)
2536/** Certificate path validator: The certificate is not valid at the
2537 * specified time. */
2538#define VERR_CR_X509_CPV_NOT_VALID_AT_TIME (-23033)
2539/** Certificate path validator: Unexpected choice found in general subtree
2540 * object (name constraints). */
2541#define VERR_CR_X509_CPV_UNEXP_GENERAL_SUBTREE_CHOICE (-23034)
2542/** Certificate path validator: Unexpected minimum value found in general
2543 * subtree object (name constraints). */
2544#define VERR_CR_X509_CPV_UNEXP_GENERAL_SUBTREE_MIN (-23035)
2545/** Certificate path validator: Unexpected maximum value found in
2546 * general subtree object (name constraints). */
2547#define VERR_CR_X509_CPV_UNEXP_GENERAL_SUBTREE_MAX (-23036)
2548/** Certificate path builder: Encountered bad certificate context. */
2549#define VERR_CR_X509_CPB_BAD_CERT_CTX (-23037)
2550/** OpenSSL d2i_X509 failed. */
2551#define VERR_CR_X509_OSSL_D2I_FAILED (-23090)
2552/** @} */
2553
2554/** @name RTCrPkcs7 status codes.
2555 * @{ */
2556/** Generic PKCS \#7 error. */
2557#define VERR_CR_PKCS7_GENERIC_ERROR (-23300)
2558/** Signed data verification failed because there are zero signer infos. */
2559#define VERR_CR_PKCS7_NO_SIGNER_INFOS (-23301)
2560/** Signed data certificate not found. */
2561#define VERR_CR_PKCS7_SIGNED_DATA_CERT_NOT_FOUND (-23302)
2562/** Signed data verification failed due to key usage issues. */
2563#define VERR_CR_PKCS7_KEY_USAGE_MISMATCH (-23303)
2564/** Signed data verification failed because of missing (or duplicate)
2565 * authenticated content-type attribute. */
2566#define VERR_CR_PKCS7_MISSING_CONTENT_TYPE_ATTRIB (-23304)
2567/** Signed data verification failed because of the authenticated content-type
2568 * attribute did not match. */
2569#define VERR_CR_PKCS7_CONTENT_TYPE_ATTRIB_MISMATCH (-23305)
2570/** Signed data verification failed because of a malformed authenticated
2571 * content-type attribute. */
2572#define VERR_CR_PKCS7_BAD_CONTENT_TYPE_ATTRIB (-23306)
2573/** Signed data verification failed because of missing (or duplicate)
2574 * authenticated message-digest attribute. */
2575#define VERR_CR_PKCS7_MISSING_MESSAGE_DIGEST_ATTRIB (-23307)
2576/** Signed data verification failed because the authenticated message-digest
2577 * attribute did not match. */
2578#define VERR_CR_PKCS7_MESSAGE_DIGEST_ATTRIB_MISMATCH (-23308)
2579/** Signed data verification failed because of a malformed authenticated
2580 * message-digest attribute. */
2581#define VERR_CR_PKCS7_BAD_MESSAGE_DIGEST_ATTRIB (-23309)
2582/** Signature verification failed. */
2583#define VERR_CR_PKCS7_SIGNATURE_VERIFICATION_FAILED (-23310)
2584/** Internal PKCS \#7 error. */
2585#define VERR_CR_PKCS7_INTERNAL_ERROR (-22311)
2586/** OpenSSL d2i_PKCS7 failed. */
2587#define VERR_CR_PKCS7_OSSL_D2I_FAILED (-22312)
2588/** OpenSSL PKCS \#7 verification failed. */
2589#define VERR_CR_PKCS7_OSSL_VERIFY_FAILED (-22313)
2590/** Digest algorithm parameters are not supported by the PKCS \#7 code. */
2591#define VERR_CR_PKCS7_DIGEST_PARAMS_NOT_IMPL (-22314)
2592/** The digest algorithm of a signer info entry was not found in the list of
2593 * digest algorithms in the signed data. */
2594#define VERR_CR_PKCS7_DIGEST_ALGO_NOT_FOUND_IN_LIST (-22315)
2595/** The PKCS \#7 content is not signed data. */
2596#define VERR_CR_PKCS7_NOT_SIGNED_DATA (-22316)
2597/** No digest algorithms listed in PKCS \#7 signed data. */
2598#define VERR_CR_PKCS7_NO_DIGEST_ALGORITHMS (-22317)
2599/** Too many digest algorithms used by PKCS \#7 signed data. This is an
2600 * internal limitation of the code that aims at saving kernel stack space. */
2601#define VERR_CR_PKCS7_TOO_MANY_DIGEST_ALGORITHMS (-22318)
2602/** Error creating digest algorithm calculator. */
2603#define VERR_CR_PKCS7_DIGEST_CREATE_ERROR (-22319)
2604/** Error while calculating a digest for a PKCS \#7 verification operation. */
2605#define VERR_CR_PKCS7_DIGEST_CALC_ERROR (-22320)
2606/** Unsupported PKCS \#7 signed data version. */
2607#define VERR_CR_PKCS7_SIGNED_DATA_VERSION (-22350)
2608/** PKCS \#7 signed data has no digest algorithms listed. */
2609#define VERR_CR_PKCS7_SIGNED_DATA_NO_DIGEST_ALGOS (-22351)
2610/** Unknown digest algorithm used by PKCS \#7 object. */
2611#define VERR_CR_PKCS7_UNKNOWN_DIGEST_ALGORITHM (-22352)
2612/** Expected PKCS \#7 object to ship at least one certificate. */
2613#define VERR_CR_PKCS7_NO_CERTIFICATES (-22353)
2614/** Expected PKCS \#7 object to not contain any CRLs. */
2615#define VERR_CR_PKCS7_EXPECTED_NO_CRLS (-22354)
2616/** Expected PKCS \#7 object to contain exactly on signer info entry. */
2617#define VERR_CR_PKCS7_EXPECTED_ONE_SIGNER_INFO (-22355)
2618/** Unsupported PKCS \#7 signer info version. */
2619#define VERR_CR_PKCS7_SIGNER_INFO_VERSION (-22356)
2620/** PKCS \#7 singer info contains no issuer serial number. */
2621#define VERR_CR_PKCS7_SIGNER_INFO_NO_ISSUER_SERIAL_NO (-22357)
2622/** Expected PKCS \#7 object to ship the signer certificate(s). */
2623#define VERR_CR_PKCS7_SIGNER_CERT_NOT_SHIPPED (-22358)
2624/** The encrypted digest algorithm does not match the one in the certificate. */
2625#define VERR_CR_PKCS7_SIGNER_INFO_DIGEST_ENCRYPT_MISMATCH (-22359)
2626/** @} */
2627
2628/** @name RTCrSpc status codes.
2629 * @{ */
2630/** Generic SPC error. */
2631#define VERR_CR_SPC_GENERIC_ERROR (-23400)
2632/** SPC requires there to be exactly one SignerInfo entry. */
2633#define VERR_CR_SPC_NOT_EXACTLY_ONE_SIGNER_INFOS (-23401)
2634/** There shall be exactly one digest algorithm to go with the single
2635 * SingerInfo entry required by SPC. */
2636#define VERR_CR_SPC_NOT_EXACTLY_ONE_DIGEST_ALGO (-23402)
2637/** The digest algorithm in the SignerInfo does not match the one in the
2638 * indirect data. */
2639#define VERR_CR_SPC_SIGNED_IND_DATA_DIGEST_ALGO_MISMATCH (-23403)
2640/** The digest algorithm in the indirect data was not found in the list of
2641 * digest algorithms in the signed data structure. */
2642#define VERR_CR_SPC_IND_DATA_DIGEST_ALGO_NOT_IN_DIGEST_ALGOS (-23404)
2643/** The digest algorithm is not known to us. */
2644#define VERR_CR_SPC_UNKNOWN_DIGEST_ALGO (-23405)
2645/** The indirect data digest size does not match the digest algorithm. */
2646#define VERR_CR_SPC_IND_DATA_DIGEST_SIZE_MISMATCH (-23406)
2647/** Expected PE image data inside indirect data object. */
2648#define VERR_CR_SPC_EXPECTED_PE_IMAGE_DATA (-23407)
2649/** Internal SPC error: The PE image data is missing. */
2650#define VERR_CR_SPC_PEIMAGE_DATA_NOT_PRESENT (-23408)
2651/** Bad SPC object moniker UUID field. */
2652#define VERR_CR_SPC_BAD_MONIKER_UUID (-23409)
2653/** Unknown SPC object moniker UUID. */
2654#define VERR_CR_SPC_UNKNOWN_MONIKER_UUID (-23410)
2655/** Internal SPC error: Bad object moniker choice value. */
2656#define VERR_CR_SPC_BAD_MONIKER_CHOICE (-23411)
2657/** Internal SPC error: Bad object moniker data pointer. */
2658#define VERR_CR_SPC_MONIKER_BAD_DATA (-23412)
2659/** Multiple PE image page hash tables. */
2660#define VERR_CR_SPC_PEIMAGE_MULTIPLE_HASH_TABS (-23413)
2661/** Unknown SPC PE image attribute. */
2662#define VERR_CR_SPC_PEIMAGE_UNKNOWN_ATTRIBUTE (-23414)
2663/** URL not expected in SPC PE image data. */
2664#define VERR_CR_SPC_PEIMAGE_URL_UNEXPECTED (-23415)
2665/** PE image data without any valid content was not expected. */
2666#define VERR_CR_SPC_PEIMAGE_NO_CONTENT (-23416)
2667/** @} */
2668
2669/** @name RTCrPkix status codes.
2670 * @{ */
2671/** Generic PKCS \#7 error. */
2672#define VERR_CR_PKIX_GENERIC_ERROR (-23500)
2673/** Parameters was presented to a signature schema that does not take any. */
2674#define VERR_CR_PKIX_SIGNATURE_TAKES_NO_PARAMETERS (-23501)
2675/** Unknown hash digest type. */
2676#define VERR_CR_PKIX_UNKNOWN_DIGEST_TYPE (-23502)
2677/** Internal error. */
2678#define VERR_CR_PKIX_INTERNAL_ERROR (-23503)
2679/** The hash is too long for the key used when signing/verifying. */
2680#define VERR_CR_PKIX_HASH_TOO_LONG_FOR_KEY (-23504)
2681/** The signature is too long for the scratch buffer. */
2682#define VERR_CR_PKIX_SIGNATURE_TOO_LONG (-23505)
2683/** The signature is greater than or equal to the key. */
2684#define VERR_CR_PKIX_SIGNATURE_GE_KEY (-23506)
2685/** The signature is negative. */
2686#define VERR_CR_PKIX_SIGNATURE_NEGATIVE (-23507)
2687/** Invalid signature length. */
2688#define VERR_CR_PKIX_INVALID_SIGNATURE_LENGTH (-23508)
2689/** PKIX signature no does not match up to the current data. */
2690#define VERR_CR_PKIX_SIGNATURE_MISMATCH (-23509)
2691/** PKIX cipher algorithm parameters are not implemented. */
2692#define VERR_CR_PKIX_CIPHER_ALGO_PARAMS_NOT_IMPL (-23510)
2693/** Cipher algorithm is not known to us. */
2694#define VERR_CR_PKIX_CIPHER_ALGO_NOT_KNOWN (-23511)
2695/** PKIX cipher algorithm is not known to OpenSSL. */
2696#define VERR_CR_PKIX_OSSL_CIPHER_ALGO_NOT_KNOWN (-23512)
2697/** PKIX cipher algorithm is not known to OpenSSL EVP API. */
2698#define VERR_CR_PKIX_OSSL_CIPHER_ALGO_NOT_KNOWN_EVP (-23513)
2699/** OpenSSL failed to init PKIX cipher algorithm context. */
2700#define VERR_CR_PKIX_OSSL_CIPHER_ALOG_INIT_FAILED (-23514)
2701/** Final OpenSSL PKIX verification failed. */
2702#define VERR_CR_PKIX_OSSL_VERIFY_FINAL_FAILED (-23515)
2703/** OpenSSL failed to decode the public key. */
2704#define VERR_CR_PKIX_OSSL_D2I_PUBLIC_KEY_FAILED (-23516)
2705/** The EVP_PKEY_type API in OpenSSL failed. */
2706#define VERR_CR_PKIX_OSSL_EVP_PKEY_TYPE_ERROR (-23517)
2707/** @} */
2708
2709/** @name RTCrStore status codes.
2710 * @{ */
2711/** Generic store error. */
2712#define VERR_CR_STORE_GENERIC_ERROR (-23700)
2713/** @} */
2714
2715/** @name RTCrRsa status codes.
2716 * @{ */
2717/** Generic RSA error. */
2718#define VERR_CR_RSA_GENERIC_ERROR (-23900)
2719/** @} */
2720
2721/** @name RTBigNum status codes.
2722 * @{ */
2723/** Sensitive input requires the result(s) to be initialized as sensitive. */
2724#define VERR_BIGNUM_SENSITIVE_INPUT (-24000)
2725/** Attempt to divide by zero. */
2726#define VERR_BIGNUM_DIV_BY_ZERO (-24001)
2727/** Negative exponent makes no sense to integer math. */
2728#define VERR_BIGNUM_NEGATIVE_EXPONENT (-24002)
2729
2730/** @} */
2731
2732/** @name RTCrDigest status codes.
2733 * @{ */
2734/** OpenSSL failed to initialize the digest algorithm context. */
2735#define VERR_CR_DIGEST_OSSL_DIGEST_INIT_ERROR (-24200)
2736/** OpenSSL failed to clone the digest algorithm context. */
2737#define VERR_CR_DIGEST_OSSL_DIGEST_CTX_COPY_ERROR (-24201)
2738/** @} */
2739
2740/** @name RTPath status codes.
2741 * @{ */
2742/** Unknown glob variable. */
2743#define VERR_PATH_MATCH_UNKNOWN_VARIABLE (-24400)
2744/** The specified glob variable must be first in the pattern. */
2745#define VERR_PATH_MATCH_VARIABLE_MUST_BE_FIRST (-24401)
2746/** Hit unimplemented glob pattern matching feature. */
2747#define VERR_PATH_MATCH_FEATURE_NOT_IMPLEMENTED (-24402)
2748/** Unknown character class in glob pattern. */
2749#define VERR_PATH_GLOB_UNKNOWN_CHAR_CLASS (-24403)
2750/** @} */
2751
2752/** @name RTUri status codes.
2753 * @{ */
2754/** The URI is empty */
2755#define VERR_URI_EMPTY (-24600)
2756/** The URI is too short to be a valid URI. */
2757#define VERR_URI_TOO_SHORT (-24601)
2758/** Invalid scheme. */
2759#define VERR_URI_INVALID_SCHEME (-24602)
2760/** Invalid port number. */
2761#define VERR_URI_INVALID_PORT_NUMBER (-24603)
2762/** Invalid escape sequence. */
2763#define VERR_URI_INVALID_ESCAPE_SEQ (-24604)
2764/** Escape URI char decodes as zero (the C string terminator). */
2765#define VERR_URI_ESCAPED_ZERO (-24605)
2766/** Escaped URI characters does not decode to valid UTF-8. */
2767#define VERR_URI_ESCAPED_CHARS_NOT_VALID_UTF8 (-24606)
2768/** Escaped URI character is not a valid UTF-8 lead byte. */
2769#define VERR_URI_INVALID_ESCAPED_UTF8_LEAD_BYTE (-24607)
2770/** Escaped URI character sequence with invalid UTF-8 continutation byte. */
2771#define VERR_URI_INVALID_ESCAPED_UTF8_CONTINUATION_BYTE (-24608)
2772/** Missing UTF-8 continutation in escaped URI character sequence. */
2773#define VERR_URI_MISSING_UTF8_CONTINUATION_BYTE (-24609)
2774/** Expected URI using the 'file:' scheme. */
2775#define VERR_URI_NOT_FILE_SCHEME (-24610)
2776/** @} */
2777
2778/** @name RTJson status codes.
2779 * @{ */
2780/** The called method does not work with the value type of the given JSON value. */
2781#define VERR_JSON_VALUE_INVALID_TYPE (-24700)
2782/** The iterator reached the end. */
2783#define VERR_JSON_ITERATOR_END (-24701)
2784/** The JSON document is malformed. */
2785#define VERR_JSON_MALFORMED (-24702)
2786/** @} */
2787
2788/** @name RTVfs status codes.
2789 * @{ */
2790/** Unknown file system format. */
2791#define VERR_VFS_UNKNOWN_FORMAT (-24800)
2792/** Found bogus values in the file system. */
2793#define VERR_VFS_BOGUS_FORMAT (-24801)
2794/** Found bogus offset in the file system. */
2795#define VERR_VFS_BOGUS_OFFSET (-24802)
2796/** Unsupported file system format. */
2797#define VERR_VFS_UNSUPPORTED_FORMAT (-24803)
2798/** Unsupported create type in an RTVfsObjOpen or RTVfsDirOpenObj call. */
2799#define VERR_VFS_UNSUPPORTED_CREATE_TYPE (-24804)
2800/** @} */
2801
2802/** @name RTFsIsoMaker status codes.
2803 * @{ */
2804/** No validation entry in the boot catalog. */
2805#define VERR_ISOMK_BOOT_CAT_NO_VALIDATION_ENTRY (-25000)
2806/** No default entry in the boot catalog. */
2807#define VERR_ISOMK_BOOT_CAT_NO_DEFAULT_ENTRY (-25001)
2808/** Expected section header. */
2809#define VERR_ISOMK_BOOT_CAT_EXPECTED_SECTION_HEADER (-25002)
2810/** Entry in a boot catalog section is empty. */
2811#define VERR_ISOMK_BOOT_CAT_EMPTY_ENTRY (-25003)
2812/** Entry in a boot catalog section is another section. */
2813#define VERR_ISOMK_BOOT_CAT_INVALID_SECTION_SIZE (-25004)
2814/** Unsectioned boot catalog entry. */
2815#define VERR_ISOMK_BOOT_CAT_ERRATIC_ENTRY (-25005)
2816/** The file is too big for the current ISO level (4GB+ sized files
2817 * requires ISO level 3). */
2818#define VERR_ISOMK_FILE_TOO_BIG_REQ_ISO_LEVEL_3 (-25006)
2819/** Cannot add symbolic link to namespace which isn't configured to support it. */
2820#define VERR_ISOMK_SYMLINK_REQ_ROCK_RIDGE (-25007)
2821/** Cannot add symbolic link to one of the selected namespaces. */
2822#define VINF_ISOMK_SYMLINK_REQ_ROCK_RIDGE (25007)
2823/** Cannot add symbolic link because no namespace is configured to support it. */
2824#define VERR_ISOMK_SYMLINK_SUPPORT_DISABLED (-25008)
2825/** No space for rock ridge 'CE' entry in directory record. */
2826#define VERR_ISOMK_RR_NO_SPACE_FOR_CE (-25009)
2827/** Internal ISO maker error: Rock ridge read problem. */
2828#define VERR_ISOMK_IPE_RR_READ (-25010)
2829/** Internal ISO maker error: Buggy namespace table. */
2830#define VERR_ISOMK_IPE_TABLE (-25011)
2831/** Internal ISO maker error: Namespace problem \#1. */
2832#define VERR_ISOMK_IPE_NAMESPACE_1 (-25012)
2833/** Internal ISO maker error: Namespace problem \#2. */
2834#define VERR_ISOMK_IPE_NAMESPACE_2 (-25013)
2835/** Internal ISO maker error: Namespace problem \#3. */
2836#define VERR_ISOMK_IPE_NAMESPACE_3 (-25014)
2837/** Internal ISO maker error: Namespace problem \#4. */
2838#define VERR_ISOMK_IPE_NAMESPACE_4 (-25015)
2839/** Internal ISO maker error: Namespace problem \#5. */
2840#define VERR_ISOMK_IPE_NAMESPACE_5 (-25016)
2841/** Internal ISO maker error: Namespace problem \#6. */
2842#define VERR_ISOMK_IPE_NAMESPACE_6 (-25017)
2843/** Internal ISO maker error: Empty path. */
2844#define VERR_ISOMK_IPE_EMPTY_PATH (-25018)
2845/** Internal ISO maker error: Unexpected empty component. */
2846#define VERR_ISOMK_IPE_EMPTY_COMPONENT (-25019)
2847/** Internal ISO maker error: Expected path to start with root slash. */
2848#define VERR_ISOMK_IPE_ROOT_SLASH (-25020)
2849/** Internal ISO maker error: Descriptor miscounting. */
2850#define VERR_ISOMK_IPE_DESC_COUNT (-25021)
2851/** Internal ISO maker error: Buffer size. */
2852#define VERR_ISOMK_IPE_BUFFER_SIZE (-25022)
2853/** Internal ISO maker error: Boot catalog file handle problem. */
2854#define VERR_ISOMK_IPE_BOOT_CAT_FILE (-25023)
2855/** Internal ISO maker error: Inconsistency produing trans.tbl file. */
2856#define VERR_ISOMK_IPE_PRODUCE_TRANS_TBL (-25024)
2857/** Internal ISO maker error: Read file data probem \#1. */
2858#define VERR_ISOMK_IPE_READ_FILE_DATA_1 (-25025)
2859/** Internal ISO maker error: Read file data probem \#2. */
2860#define VERR_ISOMK_IPE_READ_FILE_DATA_2 (-25026)
2861/** Internal ISO maker error: Read file data probem \#3. */
2862#define VERR_ISOMK_IPE_READ_FILE_DATA_3 (-25027)
2863/** Internal ISO maker error: Finalization problem \#1. */
2864#define VERR_ISOMK_IPE_FINALIZE_1 (-25028)
2865/** The spill file grew larger than 4GB. */
2866#define VERR_ISOMK_RR_SPILL_FILE_FULL (-25029)
2867
2868/** Requested to import an unknown ISO format. */
2869#define VERR_ISOMK_IMPORT_UNKNOWN_FORMAT (-25100)
2870/** Too many volume descriptors in the import ISO. */
2871#define VERR_ISOMK_IMPORT_TOO_MANY_VOL_DESCS (-25101)
2872/** Import ISO contains a bad volume descriptor header. */
2873#define VERR_ISOMK_IMPORT_INVALID_VOL_DESC_HDR (-25102)
2874/** Import ISO contains more than one primary volume descriptor. */
2875#define VERR_ISOMK_IMPORT_MULTIPLE_PRIMARY_VOL_DESCS (-25103)
2876/** Import ISO contains more than one el torito descriptor. */
2877#define VERR_ISOMK_IMPORT_MULTIPLE_EL_TORITO_DESCS (-25104)
2878/** Import ISO contains more than one joliet volume descriptor. */
2879#define VERR_ISOMK_IMPORT_MULTIPLE_JOLIET_VOL_DESCS (-25105)
2880/** Import ISO starts with supplementary volume descriptor before any
2881 * primary ones. */
2882#define VERR_ISOMK_IMPORT_SUPPLEMENTARY_BEFORE_PRIMARY (-25106)
2883/** Import ISO contains an unsupported primary volume descriptor version. */
2884#define VERR_IOSMK_IMPORT_PRIMARY_VOL_DESC_VER (-25107)
2885/** Import ISO contains a bad primary volume descriptor. */
2886#define VERR_ISOMK_IMPORT_BAD_PRIMARY_VOL_DESC (-25108)
2887/** Import ISO contains an unsupported supplementary volume descriptor
2888 * version. */
2889#define VERR_IOSMK_IMPORT_SUP_VOL_DESC_VER (-25109)
2890/** Import ISO contains a bad supplementary volume descriptor. */
2891#define VERR_ISOMK_IMPORT_BAD_SUP_VOL_DESC (-25110)
2892/** Import ISO uses a logical block size other than 2KB. */
2893#define VERR_ISOMK_IMPORT_LOGICAL_BLOCK_SIZE_NOT_2KB (-25111)
2894/** Import ISO contains more than volume. */
2895#define VERR_ISOMK_IMPORT_MORE_THAN_ONE_VOLUME_IN_SET (-25112)
2896/** Import ISO uses invalid volume sequence number. */
2897#define VERR_ISOMK_IMPORT_INVALID_VOLUMNE_SEQ_NO (-25113)
2898/** Import ISO has different volume space sizes of primary and supplementary
2899 * volume descriptors. */
2900#define VERR_ISOMK_IMPORT_VOLUME_SPACE_SIZE_MISMATCH (-25114)
2901/** Import ISO has different volume set sizes of primary and supplementary
2902 * volume descriptors. */
2903#define VERR_ISOMK_IMPORT_VOLUME_IN_SET_MISMATCH (-25115)
2904/** Import ISO contains a bad root directory record. */
2905#define VERR_ISOMK_IMPORT_BAD_ROOT_DIR_REC (-25116)
2906/** Import ISO contains a zero sized root directory. */
2907#define VERR_ISOMK_IMPORT_ZERO_SIZED_ROOT_DIR (-25117)
2908/** Import ISO contains a root directory with a mismatching volume sequence
2909 * number. */
2910#define VERR_ISOMK_IMPORT_ROOT_VOLUME_SEQ_NO (-25118)
2911/** Import ISO contains a root directory with an out of bounds data extent. */
2912#define VERR_ISOMK_IMPORT_ROOT_DIR_EXTENT_OUT_OF_BOUNDS (-25119)
2913/** Import ISO contains a root directory with a bad record length. */
2914#define VERR_ISOMK_IMPORT_BAD_ROOT_DIR_REC_LENGTH (-25120)
2915/** Import ISO contains a root directory without the directory flag set. */
2916#define VERR_ISOMK_IMPORT_ROOT_DIR_WITHOUT_DIR_FLAG (-25121)
2917/** Import ISO contains a root directory with multiple extents. */
2918#define VERR_ISOMK_IMPORT_ROOT_DIR_IS_MULTI_EXTENT (-25122)
2919/** Import ISO contains a too deep directory subtree. */
2920#define VERR_ISOMK_IMPORT_TOO_DEEP_DIR_TREE (-25123)
2921/** Import ISO contains a bad directory record. */
2922#define VERR_ISOMK_IMPORT_BAD_DIR_REC (-25124)
2923/** Import ISO contains a directory record with a mismatching volume sequence
2924 * number. */
2925#define VERR_ISOMK_IMPORT_DIR_REC_VOLUME_SEQ_NO (-25125)
2926/** Import ISO contains a directory with an extent that is out of bounds. */
2927#define VERR_ISOMK_IMPORT_DIR_REC_EXTENT_OUT_OF_BOUNDS (-25126)
2928/** Import ISO contains a directory with a bad record length. */
2929#define VERR_ISOMK_IMPORT_BAD_DIR_REC_LENGTH (-25127)
2930/** Import ISO contains a '.' or '..' directory record with a bad name
2931 * length. */
2932#define VERR_ISOMK_IMPORT_DOT_DIR_REC_BAD_NAME_LENGTH (-25128)
2933/** Import ISO contains a '.' or '..' directory record with a bad name. */
2934#define VERR_ISOMK_IMPORT_DOT_DIR_REC_BAD_NAME (-25129)
2935/** Import ISO contains a directory with a more than one extent, that's
2936 * currently not supported. */
2937#define VERR_ISOMK_IMPORT_DIR_WITH_MORE_EXTENTS (-25130)
2938/** Import ISO contains a multi-extent directory record that differs
2939 * significantly from first record. */
2940#define VERR_ISOMK_IMPORT_MISMATCHING_MULTI_EXTENT_REC (-25131)
2941/** Import ISO contains a non-final multi-extent directory record with a
2942 * size that isn't block aligned. */
2943#define VERR_ISOMK_IMPORT_MISALIGNED_MULTI_EXTENT (-25132)
2944/** Import ISO contains a non-contigiuous multi-extent data, this is
2945 * currently not supported. */
2946#define VERR_ISOMK_IMPORT_NON_CONTIGUOUS_MULTI_EXTENT (-25133)
2947
2948/** The boot catalog block in the import ISO is out of bounds. */
2949#define VERR_ISOMK_IMPORT_BOOT_CAT_BAD_OUT_OF_BOUNDS (-25140)
2950/** The boot catalog block in the import ISO has an incorrect validation
2951 * header ID. */
2952#define VERR_ISOMK_IMPORT_BOOT_CAT_BAD_VALIDATION_HEADER_ID (-25141)
2953/** The boot catalog validation entry in the import ISO has incorrect keys. */
2954#define VERR_ISOMK_IMPORT_BOOT_CAT_BAD_VALIDATION_KEYS (-25142)
2955/** The boot catalog validation entry in the import ISO has an incorrect checksum. */
2956#define VERR_ISOMK_IMPORT_BOOT_CAT_BAD_VALIDATION_CHECKSUM (-25143)
2957/** A boot catalog entry in the import ISO has an unknown type. */
2958#define VERR_ISOMK_IMPORT_BOOT_CAT_UNKNOWN_HEADER_ID (-25144)
2959/** A boot catalog entry in the import ISO has an invalid boot media type. */
2960#define VERR_ISOMK_IMPORT_BOOT_CAT_INVALID_BOOT_MEDIA_TYPE (-25145)
2961/** The default boot catalog entry in the import ISO has invalid flags set. */
2962#define VERR_ISOMK_IMPORT_BOOT_CAT_DEF_ENTRY_INVALID_FLAGS (-25146)
2963/** A boot catalog entry in the import ISO has reserved flag set. */
2964#define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_RESERVED_FLAG (-25147)
2965/** A boot catalog entry in the import ISO is using the unused field. */
2966#define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_USES_UNUSED_FIELD (-25148)
2967/** A boot catalog entry in the import ISO points to a block after the end of
2968 * the image input file. */
2969#define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_IMAGE_OUT_OF_BOUNDS (-25149)
2970/** A boot catalog entry in the import ISO has an image with an
2971 * indeterminate size. */
2972#define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_UNKNOWN_IMAGE_SIZE (-25150)
2973/** The boot catalog in the import ISO is larger than a sector or it is
2974 * missing the final section header entry. */
2975#define VERR_ISOMK_IMPORT_BOOT_CAT_MISSING_FINAL_OR_TOO_BIG (-25151)
2976/** The default boot catalog entry in the import ISO an invalid boot
2977 * indicator value. */
2978#define VERR_ISOMK_IMPORT_BOOT_CAT_DEF_ENTRY_INVALID_BOOT_IND (-25152)
2979/** A boot catalog extension entry in the import ISO was either flagged
2980 * incorrectly in the previous entry or has an invalid header ID. */
2981#define VERR_ISOMK_IMPORT_BOOT_CAT_EXT_ENTRY_INVALID_ID (-25153)
2982/** A boot catalog extension entry in the import ISO uses undefined flags
2983 * which will be lost. */
2984#define VERR_ISOMK_IMPORT_BOOT_CAT_EXT_ENTRY_UNDEFINED_FLAGS (-25154)
2985/** A boot catalog extension entry in the import ISO indicates more entries when
2986 * we reached the end of the boot catalog sector. */
2987#define VERR_ISOMK_IMPORT_BOOT_CAT_EXT_ENTRY_END_OF_SECTOR (-25155)
2988/** A boot catalog entry in the import ISO sets the continuation flag when using
2989 * NONE as the selection criteria type. */
2990#define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_CONTINUATION_WITH_NONE (-25156)
2991/** A boot catalog entry in the import ISO sets the continuation flag when
2992 * we reached the ned of the boot catalog secotr. */
2993#define VERR_ISOMK_IMPORT_BOOT_CAT_ENTRY_CONTINUATION_EOS (-25157)
2994
2995/** @} */
2996
2997
2998/** @name RTFsIsoVol status codes
2999 * @{ */
3000/** Descriptor tag is all zeros. */
3001#define VERR_ISOFS_TAG_IS_ALL_ZEROS (-25300)
3002/** Unsupported descriptor tag version. */
3003#define VERR_ISOFS_UNSUPPORTED_TAG_VERSION (-25301)
3004/** Bad descriptor tag checksum. */
3005#define VERR_ISOFS_BAD_TAG_CHECKSUM (-25302)
3006/** Descriptor tag sector number mismatch. */
3007#define VERR_ISOFS_TAG_SECTOR_MISMATCH (-25303)
3008/** Descriptor CRC mismatch. */
3009#define VERR_ISOFS_DESC_CRC_MISMATCH (-25304)
3010/** Insufficient data to check descriptor CRC. */
3011#define VERR_ISOFS_INSUFFICIENT_DATA_FOR_DESC_CRC (-25305)
3012/** Unexpected/unknown/bad descriptor in volume descriptor sequence. */
3013#define VERR_ISOFS_UNEXPECTED_VDS_DESC (-25306)
3014/** Too many primary volume descriptors. */
3015#define VERR_ISOFS_TOO_MANY_PVDS (-25307)
3016/** Too many logical volume descriptors. */
3017#define VERR_ISOFS_TOO_MANY_LVDS (-25308)
3018/** Too many partition descriptors. */
3019#define VERR_ISOFS_TOO_MANY_PDS (-25309)
3020/** The logical volume descriptor has a too big partition map. */
3021#define VERR_ISOFS_TOO_BIT_PARTMAP_IN_LVD (-25310)
3022/** No primary volume descriptors found. */
3023#define VERR_ISOFS_NO_PVD (-25311)
3024/** No logical volume descriptors found. */
3025#define VERR_ISOFS_NO_LVD (-25312)
3026/** No partition descriptors found. */
3027#define VERR_ISOFS_NO_PD (-25313)
3028/** Multiple primary volume descriptors found, we can only deal with one. */
3029#define VERR_ISOFS_MULTIPLE_PVDS (-25314)
3030/** Multiple logical volume descriptors found, we can only deal with one. */
3031#define VERR_ISOFS_MULTIPLE_LVDS (-25315)
3032/** Too many partition maps in the logical volume descriptor. */
3033#define VERR_ISOFS_TOO_MANY_PART_MAPS (-25316)
3034/** Malformed partition map table in the logical volume descriptor. */
3035#define VERR_ISOFS_MALFORMED_PART_MAP_TABLE (-25317)
3036/** Unable to find partition descriptor for a partition map table entry. */
3037#define VERR_ISOFS_PARTITION_NOT_FOUND (-25318)
3038/** Partition mapping table is shorted than described. */
3039#define VERR_ISOFS_INCOMPLETE_PART_MAP_TABLE (-25319)
3040/** Unknown partition map entry type. */
3041#define VERR_ISOFS_UNKNOWN_PART_MAP_ENTRY_TYPE (-25320)
3042/** Unkonwn paritition ID found in the partition map table. */
3043#define VERR_ISOFS_UNKNOWN_PART_MAP_TYPE_ID (-25321)
3044/** Support for virtual partitions as not yet been implemented. */
3045#define VERR_ISOFS_VPM_NOT_SUPPORTED (-25322)
3046/** Support for sparable partitions as not yet been implemented. */
3047#define VERR_ISOFS_SPM_NOT_SUPPORTED (-25323)
3048/** Support for metadata partitions as not yet been implemented. */
3049#define VERR_ISOFS_MPM_NOT_SUPPORTED (-25324)
3050/** Invalid or unsupported logical block size. */
3051#define VERR_ISOFS_UNSUPPORTED_LOGICAL_BLOCK_SIZE (-25325)
3052/** Unsupported domain ID in logical volume descriptor. */
3053#define VERR_ISOFS_BAD_LVD_DOMAIN_ID (-25326)
3054/** Malformed or invalid file set descriptor location. */
3055#define VERR_ISOFS_BAD_LVD_FILE_SET_DESC_LOCATION (-25327)
3056/** Non-standard descriptor character set in the logical volume descriptor. */
3057#define VERR_ISOFS_BAD_LVD_DESC_CHAR_SET (-25329)
3058/** Invalid partition index in a location. */
3059#define VERR_ISOFS_INVALID_PARTITION_INDEX (-25330)
3060/** Unsupported file system charset. */
3061#define VERR_ISOFS_FSD_UNSUPPORTED_CHAR_SET (-25331)
3062/** File set descriptor has an zero length or invalid root dir extent. */
3063#define VERR_ISOFS_FSD_ZERO_ROOT_DIR (-25332)
3064/** File set descriptor has a next extent member. */
3065#define VERR_ISOFS_FSD_NEXT_EXTENT (-25333)
3066/** The ICB for is too big. */
3067#define VERR_ISOFS_ICB_TOO_BIG (-25334)
3068/** The ICB for is too small. */
3069#define VERR_ISOFS_ICB_TOO_SMALL (-25335)
3070/** No direct ICB entries found. */
3071#define VERR_ISOFS_NO_DIRECT_ICB_ENTRIES (-25336)
3072/** Too many ICB indirections, possibly a loop. */
3073#define VERR_ISOFS_TOO_MANY_ICB_INDIRECTIONS (-25337)
3074/** Too deep ICB recursion. */
3075#define VERR_ISOFS_TOO_DEEP_ICB_RECURSION (-25338)
3076/** ICB is too small to contain anything useful. */
3077#define VERR_ISOFS_ICB_ENTRY_TOO_SMALL (-25339)
3078/** Unsupported tag encountered in ICB. */
3079#define VERR_ISOFS_UNSUPPORTED_ICB (-25340)
3080/** Bad file entry (ICB). */
3081#define VERR_ISOFS_BAD_FILE_ENTRY (-25341)
3082/** Unknown allocation descriptor type. */
3083#define VERR_ISO_FS_UNKNOWN_AD_TYPE (-25342)
3084/** Malformed extended allocation descriptor. */
3085#define VERR_ISOFS_BAD_EXTAD (-25343)
3086/** Wrong file type. */
3087#define VERR_ISOFS_WRONG_FILE_TYPE (-25344)
3088/** Unknow file type. */
3089#define VERR_ISOFS_UNKNOWN_FILE_TYPE (-25345)
3090
3091/** Not implemented for UDF. */
3092#define VERR_ISOFS_UDF_NOT_IMPLEMENTED (-25390)
3093/** Internal processing error \#1. */
3094#define VERR_ISOFS_IPE_1 (-25391)
3095/** Internal processing error \#2. */
3096#define VERR_ISOFS_IPE_2 (-25392)
3097/** Internal processing error \#3. */
3098#define VERR_ISOFS_IPE_3 (-25393)
3099/** Internal processing error \#4. */
3100#define VERR_ISOFS_IPE_4 (-25394)
3101/** Internal processing error \#5. */
3102#define VERR_ISOFS_IPE_5 (-25395)
3103
3104/** @} */
3105
3106
3107/** @name RTSerialPort status codes
3108 * @{ */
3109/** A break was detected until all requested data could be received. */
3110#define VERR_SERIALPORT_BREAK_DETECTED (-25500)
3111/** The chosen baudrate is invalid or not supported by the given serial port. */
3112#define VERR_SERIALPORT_INVALID_BAUDRATE (-25501)
3113
3114/** @} */
3115
3116/* SED-END */
3117
3118/** @} */
3119
3120#endif
3121
Note: See TracBrowser for help on using the repository browser.

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