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