/** @file
* IPRT - Status Codes.
*/
/*
* Copyright (C) 2006-2015 Oracle Corporation
*
* This file is part of VirtualBox Open Source Edition (OSE), as
* available from http://www.virtualbox.org. This file is free software;
* General Public License (GPL) as published by the Free Software
* Foundation, in version 2 as it comes in the "COPYING" file of the
* VirtualBox OSE distribution. VirtualBox OSE is distributed in the
* hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
*
* The contents of this file may alternatively be used under the terms
* of the Common Development and Distribution License Version 1.0
* (CDDL) only, as it comes in the "COPYING.CDDL" file of the
* VirtualBox OSE distribution, in which case the provisions of the
* CDDL are applicable instead of those of the GPL.
*
* You may elect to license modified versions of this file under the
* terms and conditions of either the GPL or the CDDL or both.
*/
#ifndef ___iprt_err_h
#define ___iprt_err_h
/** @defgroup grp_rt_err RTErr - Status Codes
* @ingroup grp_rt
*
* The IPRT status codes are in two ranges: {0..999} and {22000..32766}. The
* IPRT users are free to use the range {1000..21999}. See RTERR_RANGE1_FIRST,
* RTERR_RANGE1_LAST, RTERR_RANGE2_FIRST, RTERR_RANGE2_LAST, RTERR_USER_FIRST
* and RTERR_USER_LAST.
*
* @{
*/
/** @defgroup grp_rt_err_hlp Status Code Helpers
* @{
*/
#ifdef __cplusplus
/**
* Strict type validation class.
*
* This is only really useful for type checking the arguments to RT_SUCCESS,
* RT_SUCCESS_NP, RT_FAILURE and RT_FAILURE_NP. The RTErrStrictType2
* constructor is for integration with external status code strictness regimes.
*/
{
/**
* Constructor for interaction with external status code strictness regimes.
*
* This is a special constructor for helping external return code validator
* classes interact cleanly with RT_SUCCESS, RT_SUCCESS_NP, RT_FAILURE and
* RT_FAILURE_NP while barring automatic cast to integer.
*
* @param rcObj IPRT status code object from an automatic cast.
*/
{
}
/**
* Integer constructor used by RT_SUCCESS_NP.
*
* @param rc IPRT style status code.
*/
{
}
#if 0 /** @todo figure where int32_t is long instead of int. */
/**
* Integer constructor used by RT_SUCCESS_NP.
*
* @param rc IPRT style status code.
*/
RTErrStrictType(signed int rc)
{
}
#endif
/**
* Test for success.
*/
bool success() const
{
return m_rc >= 0;
}
/** @name Try ban a number of wrong types.
* @{ */
/** @} */
};
#endif /* __cplusplus */
/** @def RTERR_STRICT_RC
* Indicates that RT_SUCCESS_NP, RT_SUCCESS, RT_FAILURE_NP and RT_FAILURE should
* make type enforcing at compile time.
*
* @remarks Only define this for C++ code.
*/
#if defined(__cplusplus) \
&& !defined(RTERR_STRICT_RC) \
&& ( defined(DOXYGEN_RUNNING) \
|| defined(DEBUG) \
|| defined(RT_STRICT) )
#endif
/** @def RT_SUCCESS
* Check for success. We expect success in normal cases, that is the code path depending on
* this check is normally taken. To prevent any prediction use RT_SUCCESS_NP instead.
*
* @returns true if rc indicates success.
* @returns false if rc indicates failure.
*
* @param rc The iprt status code to test.
*/
/** @def RT_SUCCESS_NP
* Check for success. Don't predict the result.
*
* @returns true if rc indicates success.
* @returns false if rc indicates failure.
*
* @param rc The iprt status code to test.
*/
#ifdef RTERR_STRICT_RC
#else
#endif
/** @def RT_FAILURE
* Check for failure. We don't expect in normal cases, that is the code path depending on
* this check is normally NOT taken. To prevent any prediction use RT_FAILURE_NP instead.
*
* @returns true if rc indicates failure.
* @returns false if rc indicates success.
*
* @param rc The iprt status code to test.
*/
/** @def RT_FAILURE_NP
* Check for failure. Don't predict the result.
*
* @returns true if rc indicates failure.
* @returns false if rc indicates success.
*
* @param rc The iprt status code to test.
*/
/**
* Converts a Darwin HRESULT error to an iprt status code.
*
* @returns iprt status code.
* @param iNativeCode HRESULT error code.
* @remark Darwin ring-3 only.
*/
/**
* Converts a Darwin IOReturn error to an iprt status code.
*
* @returns iprt status code.
* @param iNativeCode IOReturn error code.
* @remark Darwin only.
*/
/**
* Converts a Darwin kern_return_t error to an iprt status code.
*
* @returns iprt status code.
* @param iNativeCode kern_return_t error code.
* @remark Darwin only.
*/
/**
* Converts a Darwin error to an iprt status code.
*
* This will consult RTErrConvertFromDarwinKern, RTErrConvertFromDarwinIO
* and RTErrConvertFromDarwinCOM in this order. The latter is ring-3 only as it
* doesn't apply elsewhere.
*
* @returns iprt status code.
* @param iNativeCode Darwin error code.
* @remarks Darwin only.
* @remarks This is recommended over RTErrConvertFromDarwinKern and RTErrConvertFromDarwinIO
* since these are really just subsets of the same error space.
*/
/**
* Converts errno to iprt status code.
*
* @returns iprt status code.
* @param uNativeCode errno code.
*/
/**
* Converts a L4 errno to a iprt status code.
*
* @returns iprt status code.
* @param uNativeCode l4 errno.
* @remark L4 only.
*/
/**
* Converts NT status code to iprt status code.
*
* Needless to say, this is only available on NT and winXX targets.
*
* @returns iprt status code.
* @param lNativeCode NT status code.
* @remark Windows only.
*/
/**
* Converts OS/2 error code to iprt status code.
*
* @returns iprt status code.
* @param uNativeCode OS/2 error code.
* @remark OS/2 only.
*/
/**
* Converts Win32 error code to iprt status code.
*
* @returns iprt status code.
* @param uNativeCode Win32 error code.
* @remark Windows only.
*/
/**
* Converts an iprt status code to a errno status code.
*
* @returns errno status code.
* @param iErr iprt status code.
*/
#ifdef IN_RING3
/**
* iprt status code message.
*/
typedef struct RTSTATUSMSG
{
/** Pointer to the short message string. */
const char *pszMsgShort;
/** Pointer to the full message string. */
const char *pszMsgFull;
/** Pointer to the define string. */
const char *pszDefine;
/** Status code number. */
int iCode;
} RTSTATUSMSG;
/** Pointer to iprt status code message. */
/** Pointer to const iprt status code message. */
/**
* Get the message structure corresponding to a given iprt status code.
*
* @returns Pointer to read-only message description.
* @param rc The status code.
*/
/**
* Get the define corresponding to a given iprt status code.
*
* @returns Pointer to read-only string with the \#define identifier.
* @param rc The status code.
*/
/**
* Get the short description corresponding to a given iprt status code.
*
* @returns Pointer to read-only string with the description.
* @param rc The status code.
*/
/**
* Get the full description corresponding to a given iprt status code.
*
* @returns Pointer to read-only string with the description.
* @param rc The status code.
*/
#ifdef RT_OS_WINDOWS
/**
* Windows error code message.
*/
typedef struct RTWINERRMSG
{
/** Pointer to the full message string. */
const char *pszMsgFull;
/** Pointer to the define string. */
const char *pszDefine;
/** Error code number. */
long iCode;
} RTWINERRMSG;
/** Pointer to Windows error code message. */
/** Pointer to const Windows error code message. */
/**
* Get the message structure corresponding to a given Windows error code.
*
* @returns Pointer to read-only message description.
* @param rc The status code.
*/
/** On windows COM errors are part of the Windows error database. */
#else /* !RT_OS_WINDOWS */
/**
*/
typedef struct RTCOMERRMSG
{
/** Pointer to the full message string. */
const char *pszMsgFull;
/** Pointer to the define string. */
const char *pszDefine;
/** Error code number. */
} RTCOMERRMSG;
#endif /* !RT_OS_WINDOWS */
/**
*
* @returns Pointer to read-only message description.
* @param rc The status code.
*/
#endif /* IN_RING3 */
/** @defgroup RTERRINFO_FLAGS_XXX RTERRINFO::fFlags
* @{ */
/** Custom structure (the default). */
/** Static structure (RTERRINFOSTATIC). */
/** Allocated structure (RTErrInfoAlloc). */
/** Reserved type. */
/** Type mask. */
/** Error info is set. */
/** Fixed flags (magic). */
/** The bit mask for the magic value. */
/** @} */
/**
* Initializes an error info structure.
*
* @returns @a pErrInfo.
* @param pErrInfo The error info structure to init.
* @param pszMsg The message buffer. Must be at least one byte.
* @param cbMsg The size of the message buffer.
*/
{
*pszMsg = '\0';
return pErrInfo;
}
/**
* Initialize a static error info structure.
*
* @returns Pointer to the core error info structure.
* @param pStaticErrInfo The static error info structure to init.
*/
{
return &pStaticErrInfo->Core;
}
/**
* Allocates a error info structure with a buffer at least the given size.
*
* @returns Pointer to an error info structure on success, NULL on failure.
*
* @param cbMsg The minimum message buffer size. Use 0 to get
* the default buffer size.
*/
/**
* Same as RTErrInfoAlloc, except that an IPRT status code is returned.
*
* @returns IPRT status code.
*
* @param cbMsg The minimum message buffer size. Use 0 to get
* the default buffer size.
* @param ppErrInfo Where to store the pointer to the allocated
* error info structure on success. This is
* always set to NULL.
*/
/**
* Frees an error info structure allocated by RTErrInfoAlloc or
* RTErrInfoAllocEx.
*
* @param pErrInfo The error info structure.
*/
/**
* Fills in the error info details.
*
* @returns @a rc.
*
* @param pErrInfo The error info structure to fill in.
* @param rc The status code to return.
* @param pszMsg The error message string.
*/
/**
* Fills in the error info details, with a sprintf style message.
*
* @returns @a rc.
*
* @param pErrInfo The error info structure to fill in.
* @param rc The status code to return.
* @param pszFormat The format string.
* @param ... The format arguments.
*/
/**
* Fills in the error info details, with a vsprintf style message.
*
* @returns @a rc.
*
* @param pErrInfo The error info structure to fill in.
* @param rc The status code to return.
* @param pszFormat The format string.
* @param va The format arguments.
*/
/**
* Adds more error info details.
*
* @returns @a rc.
*
* @param pErrInfo The error info structure to fill in.
* @param rc The status code to return.
* @param pszMsg The error message string to add.
*/
/**
* Adds more error info details, with a sprintf style message.
*
* @returns @a rc.
*
* @param pErrInfo The error info structure to fill in.
* @param rc The status code to return.
* @param pszFormat The format string to add.
* @param ... The format arguments.
*/
/**
* Adds more error info details, with a vsprintf style message.
*
* @returns @a rc.
*
* @param pErrInfo The error info structure to fill in.
* @param rc The status code to return.
* @param pszFormat The format string to add.
* @param va The format arguments.
*/
/**
* Checks if the error info is set.
*
* @returns true if set, false if not.
* @param pErrInfo The error info structure. NULL is OK.
*/
{
if (!pErrInfo)
return false;
}
/**
* Clears the error info structure.
*
* @param pErrInfo The error info structure. NULL is OK.
*/
{
if (pErrInfo)
{
}
}
/**
* Storage for error variables.
*
* @remarks Do NOT touch the members! They are platform specific and what's
* where may change at any time!
*/
typedef union RTERRVARS
{
} RTERRVARS;
/** Pointer to an error variable storage union. */
/** Pointer to a const error variable storage union. */
/**
* Saves the error variables.
*
* @returns @a pVars.
* @param pVars The variable storage union.
*/
/**
* Restores the error variables.
*
* @param pVars The variable storage union.
*/
/**
* Checks if the first variable set equals the second.
*
* @returns true if they are equal, false if not.
* @param pVars1 The first variable storage union.
* @param pVars2 The second variable storage union.
*/
/**
* Checks if the (live) error variables have changed since we saved them.
*
* @returns @c true if they have changed, @c false if not.
* @param pVars The saved variables to compare the current state
* against.
*/
/** @} */
/** @name Status Code Ranges
* @{ */
/** The first status code in the primary IPRT range. */
#define RTERR_RANGE1_FIRST 0
/** The last status code in the primary IPRT range. */
/** The first status code in the secondary IPRT range. */
/** The last status code in the secondary IPRT range. */
/** The first status code in the user range. */
/** The last status code in the user range. */
/** @} */
/* SED-START */
/** @name Misc. Status Codes
* @{
*/
/** Success. */
#define VINF_SUCCESS 0
/** General failure - DON'T USE THIS!!! */
/** Invalid parameter. */
/** Invalid parameter. */
/** Invalid magic or cookie. */
/** Invalid magic or cookie. */
/** Invalid loader handle. */
/** Invalid loader handle. */
/** Failed to lock the address range. */
/** Invalid memory pointer. */
/** Failed to patch the IDT. */
/** Memory allocation failed. */
/** Already loaded. */
/** Permission denied. */
/** Permission denied. */
/** Version mismatch. */
/** The request function is not implemented. */
/** Invalid flags was given. */
/** Not equal. */
/** The specified path does not point at a symbolic link. */
/** Failed to allocate temporary memory. */
/** Invalid file mode mask (RTFMODE). */
/** Incorrect call order. */
/** There is no TLS (thread local storage) available for storing the current thread. */
/** Failed to set the TLS (thread local storage) entry which points to our thread structure. */
/** Not able to allocate contiguous memory. */
/** No memory available for page table or page directory. */
/** Already initialized. */
/** The specified thread is dead. */
/** The specified thread is not waitable. */
/** Pagetable not present. */
/** Invalid context.
* Typically an API was used by the wrong thread. */
/** The per process timer is busy. */
/** Address conflict. */
/** Unresolved (unknown) host platform error. */
/** Invalid function. */
/** Not supported. */
/** Not supported. */
/** Access denied. */
/** Call interrupted. */
/** Call interrupted. */
/** Timeout. */
/** Timeout. */
/** Buffer too small to save result. */
/** Buffer too small to save result. */
/** Data size overflow. */
/** Max threads number reached. */
/** Max process number reached. */
/** The recipient process has refused the signal. */
/** A signal is already pending. */
/** The signal being posted is not correct. */
/** The state changed.
* This is a generic error message and needs a context to make sense. */
/** Warning, the state changed.
* This is a generic error message and needs a context to make sense. */
/** Error while parsing UUID string */
/** The specified process was not found. */
/** The process specified to a non-block wait had not exited. */
/** Retry the operation. */
/** Retry the operation. */
/** Generic parse error. */
/** Value out of range. */
/** A numeric conversion encountered a value which was too big for the target. */
/** A numeric conversion encountered a value which was too big for the target. */
/** The number begin converted (string) contained no digits. */
/** The number begin converted (string) contained no digits. */
/** Encountered a '-' during conversion to an unsigned value. */
/** Encountered a '-' during conversion to an unsigned value. */
/** Error while characters translation (unicode and so). */
/** Error while characters translation (unicode and so). */
/** Encountered unicode code point which is reserved for use as endian indicator (0xffff or 0xfffe). */
/** Encountered unicode code point in the surrogate range (0xd800 to 0xdfff). */
/** A string claiming to be UTF-8 is incorrectly encoded. */
/** Ad string claiming to be in UTF-16 is incorrectly encoded. */
/** Encountered a unicode code point which cannot be represented as UTF-16. */
/** Got an out of memory condition trying to allocate a string. */
/** Got an out of memory condition trying to allocate a UTF-16 (/UCS-2) string. */
/** Get an out of memory condition trying to allocate a code point array. */
/** Can't free the memory because it's used in mapping. */
/** The timer can't be started because it's already active. */
/** The timer can't be stopped because i's already suspended. */
/** The operation was cancelled by the user (copy) or another thread (local ipc). */
/** Failed to initialize a memory object.
* Exactly what this means is OS specific. */
/** Out of memory condition when allocating memory with low physical backing. */
/** Out of memory condition when allocating physical memory (without mapping). */
/** The address (virtual or physical) is too big. */
/** Failed to map a memory object. */
/** Trailing characters. */
/** Trailing characters. */
/** Trailing spaces. */
/** Trailing spaces. */
/** Generic not found error. */
/** Generic not found warning. */
/** Generic invalid state error. */
/** Generic invalid state warning. */
/** Generic out of resources error. */
/** Generic out of resources warning. */
/** No more handles available, too many open handles. */
/** Preemption is disabled.
* The requested operation can only be performed when preemption is enabled. */
/** End of string. */
/** End of string. */
/** A page count is out of range. */
/** Generic object destroyed status. */
/** Generic object was destroyed by the call status. */
/** Generic dangling objects status. */
/** Generic dangling objects status. */
/** Invalid Base64 encoding. */
/** Return instigated by a callback or similar. */
/** Return instigated by a callback or similar. */
/** Authentication failure. */
/** Not a power of two. */
/** Status code, typically given as a parameter, that isn't supposed to be used. */
/** Concurrent access to the object is not allowed. */
/** The caller does not have a reference to the object.
* This status is used when two threads is caught sharing the same object
* reference. */
/** Generic no change error. */
/** Generic no change info. */
/** Out of memory condition when allocating executable memory. */
/** The alignment is not supported. */
/** The alignment is not really supported, however we got lucky with this
* allocation. */
/** Duplicate something. */
/** Something is missing. */
/** An unexpected (/unknown) exception was caught. */
/** Buffer underflow. */
/** Buffer underflow. */
/** Uneven input. */
/** Something is not available or not working properly. */
/** The RTPROC_FLAGS_DETACHED flag isn't supported. */
/** An account is restricted in a certain way. */
/** An account is restricted in a certain way. */
/** Not able satisfy all the requirements of the request. */
/** Not able satisfy all the requirements of the request. */
/** The requested allocation is too big. */
/** Mismatch. */
/** Wrong type. */
/** @} */
* @{
*/
/** Unresolved (unknown) file i/o error. */
/** File not found. */
/** Path not found. */
/** The object in question already exists. */
/** The object in question already exists. */
/** Too many open files. */
/** Seek error. */
/** Seek below file start. */
/** Trying to seek on device. */
/** Reached the end of the file. */
/** Reached the end of the file. */
/** Generic file read error. */
/** Generic file write error. */
/** Write protect error. */
/** Sharing violation, file is being used by another process. */
/** Unable to lock a region of a file. */
/** File access error, another process has locked a portion of the file. */
/** File or directory can't be created. */
/** Directory can't be deleted. */
/** Can't move file to another disk. */
/** The filename or extension is too long. */
/** Media not present in drive. */
/** The type of media was not recognized. Not formatted? */
/** Can't unlock - region was not locked. */
/** Unrecoverable error: lock was lost. */
/** Can't delete directory with files. */
/** A directory operation was attempted on a non-directory object. */
/** A non-directory operation was attempted on a directory object. */
/** Tried to grow a file beyond the limit imposed by the process or the filesystem. */
/** No pending request the aio context has to wait for completion. */
/** The request could not be canceled or prepared for another transfer
* because it is still in progress. */
/** The request could not be canceled because it already completed. */
/** The I/O context couldn't be destroyed because there are still pending requests. */
/** The requests couldn't be submitted because that would exceed the capacity of the context. */
/** The request was canceled. */
/** The request wasn't submitted so it can't be canceled. */
/** A request was not prepared and thus could not be submitted. */
/** Not all requests could be submitted due to resource shortage. */
/** Device or resource is busy. */
/** A file operation was attempted on a non-file object. */
/** A non-file operation was attempted on a file object. */
/** Unexpected filesystem object type. */
/** A path does not start with a root specification. */
/** A path is relative, expected an absolute path. */
/** A path is not relative (start with root), expected an relative path. */
/** Zero length path. */
/** There are not enough events available on the host to create the I/O context.
* This exact meaning is host platform dependent. */
/** @} */
/** @name Generic Filesystem I/O Status Codes
* @{
*/
/** Unresolved (unknown) disk i/o error. */
/** Invalid drive number. */
/** Disk is full. */
/** Disk was changed. */
/** Drive is locked. */
/** The specified disk or diskette cannot be accessed. */
/** Too many symbolic links. */
/** The OS does not support setting the time stamps on a symbolic link. */
/** The OS does not support changing the owner of a symbolic link. */
/** @} */
/** @name Generic Directory Enumeration Status Codes
* @{
*/
/** Unresolved (unknown) search error. */
/** No more files found. */
/** No more search handles available. */
/** RTDirReadEx() failed to retrieve the extra data which was requested. */
/** @} */
/** @name Internal Processing Errors
* @{
*/
/** Internal error - this should never happen. */
/** Internal error no. 2. */
/** Internal error no. 3. */
/** Internal error no. 4. */
/** Internal error no. 5. */
/** Internal error: Unexpected status code. */
/** Internal error: Unexpected status code. */
/** Internal error: Unexpected status code. */
/** Internal error: Uninitialized status code.
* @remarks This is used by value elsewhere. */
/** Internal error: Supposedly unreachable default case in a switch. */
/** @} */
/** @name Generic Device I/O Status Codes
* @{
*/
/** Unresolved (unknown) device i/o error. */
/** Device i/o: Bad unit. */
/** Device i/o: Not ready. */
/** Device i/o: Bad command. */
/** Device i/o: CRC error. */
/** Device i/o: Bad length. */
/** Device i/o: Sector not found. */
/** Device i/o: General failure. */
/** @} */
/** @name Generic Pipe I/O Status Codes
* @{
*/
/** Unresolved (unknown) pipe i/o error. */
/** Broken pipe. */
/** Bad pipe. */
/** Pipe is busy. */
/** No data in pipe. */
/** Pipe is not connected. */
/** More data available in pipe. */
/** Expected read pipe, got a write pipe instead. */
/** Expected write pipe, got a read pipe instead. */
/** @} */
/** @name Generic Semaphores Status Codes
* @{
*/
/** Unresolved (unknown) semaphore error. */
/** Too many semaphores. */
/** Exclusive semaphore is owned by another process. */
/** The semaphore is set and cannot be closed. */
/** The semaphore cannot be set again. */
/** Attempt to release mutex not owned by caller. */
/** The semaphore has been opened too many times. */
/** The maximum posts for the event semaphore has been reached. */
/** The event semaphore has already been posted. */
/** The event semaphore has already been reset. */
/** The semaphore is in use. */
/** The previous ownership of this semaphore has ended. */
/** Failed to open semaphore by name - not found. */
/** Semaphore destroyed while waiting. */
/** Nested ownership requests are not permitted for this semaphore type. */
/** The release call only release a semaphore nesting, i.e. the caller is still
* holding the semaphore. */
/** Deadlock detected. */
/** Ping-Pong listen or speak out of turn error. */
/** Tried to take a semaphore in a bad context. */
/** Don't spin for the semaphore, but it is safe to try grab it. */
/** Wrong locking order detected. */
/** Wrong release order detected. */
/** Attempt to recursively enter a non-recurisve lock. */
/** Invalid parameters passed to the lock validator. */
/** The lock validator detected a deadlock. */
/** The lock validator detected an existing deadlock.
* The deadlock was not caused by the current operation, but existed already. */
/** Not the lock owner according our records. */
/** An illegal lock upgrade was attempted. */
/** The thread is not a valid signaller of the event. */
/** Internal error in the lock validator or related components. */
/** @} */
/** @name Generic Network I/O Status Codes
* @{
*/
/** Unresolved (unknown) network error. */
/** The network is busy or is out of resources. */
/** Net host name not found. */
/** Network path not found. */
/** General network printing error. */
/** The machine is not on the network. */
/** Name is not unique on the network. */
/* These are BSD networking error codes - numbers correspond, don't mess! */
/** Operation in progress. */
/** Operation already in progress. */
/** Attempted socket operation with a non-socket handle.
* (This includes closed handles.) */
/** Destination address required. */
/** Message too long. */
/** Protocol wrong type for socket. */
/** Protocol not available. */
/** Protocol not supported. */
/** Socket type not supported. */
/** Operation not supported. */
/** Protocol family not supported. */
/** Address family not supported by protocol family. */
/** Address already in use. */
/** Can't assign requested address. */
/** Network is down. */
/** Network is unreachable. */
/** Network dropped connection on reset. */
/** Software caused connection abort. */
/** Connection reset by peer. */
/** No buffer space available. */
/** Socket is already connected. */
/** Socket is not connected. */
/** Can't send after socket shutdown. */
/** Too many references: can't splice. */
/** Too many references: can't splice. */
/** Connection refused. */
/* ELOOP is not net. */
/* ENAMETOOLONG is not net. */
/** Host is down. */
/** No route to host. */
/** Protocol error. */
/** Incomplete packet was submitted by guest. */
/** @} */
/** @name TCP Status Codes
* @{
*/
/** Stop the TCP server. */
/** The server was stopped. */
/** The TCP server was shut down using RTTcpServerShutdown. */
/** The TCP server was destroyed. */
/** The TCP server has no client associated with it. */
/** @} */
/** @name UDP Status Codes
* @{
*/
/** Stop the UDP server. */
/** The server was stopped. */
/** The UDP server was shut down using RTUdpServerShutdown. */
/** The UDP server was destroyed. */
/** The UDP server has no client associated with it. */
/** @} */
/** @name L4 Specific Status Codes
* @{
*/
/** Invalid offset in an L4 dataspace */
/** IPC error */
/** Item already used */
/** Source/destination not found */
/** Receive timeout */
/** Send timeout */
/** Receive cancelled */
/** Send cancelled */
/** Receive aborted */
/** Send aborted */
/** Couldn't map pages during receive */
/** Couldn't map pages during send */
/** Send pagefault timeout in receive */
/** Send pagefault timeout in send */
/** (One) receive buffer was too small, or too few buffers */
/** (One) send buffer was too small, or too few buffers */
/** Dataspace manager server not found */
/** @} */
/** @name Loader Status Codes.
* @{
*/
/** Invalid executable signature. */
/** The iprt loader recognized a ELF image, but doesn't support loading it. */
/** The iprt loader recognized a PE image, but doesn't support loading it. */
/** The iprt loader recognized a LX image, but doesn't support loading it. */
/** The iprt loader recognized a LE image, but doesn't support loading it. */
/** The iprt loader recognized a NE image, but doesn't support loading it. */
/** The iprt loader recognized a MZ image, but doesn't support loading it. */
/** The iprt loader recognized an a.out image, but doesn't support loading it. */
/** Bad executable. */
/** Symbol (export) not found. */
/** Module not found. */
/** The loader resolved an external symbol to an address to big for the image format. */
/** The image is too big. */
/** The image base address is to high for this image type. */
/** Mismatching architecture. */
/** Mismatch between IPRT and native loader. */
/** Failed to resolve an imported (external) symbol. */
/** Generic loader failure. */
/** Code signing error. */
/** The PE loader encountered delayed imports, a feature which hasn't been implemented yet. */
/** The PE loader encountered a malformed certificate. */
/** The PE loader encountered a certificate with an unsupported type or structure revision. */
/** The PE loader doesn't know how to deal with the global pointer data directory entry yet. */
/** The PE loader doesn't support the TLS data directory yet. */
/** The PE loader doesn't grok the COM descriptor data directory entry. */
/** The PE loader encountered a lock prefix table, a feature which hasn't been implemented yet. */
/** The ELF loader doesn't handle foreign endianness. */
/** The ELF image is 'dynamic', the ELF loader can only deal with 'relocatable' images at present. */
/** The ELF image is 'executable', the ELF loader can only deal with 'relocatable' images at present. */
/** The ELF image was created for an unsupported target machine type. */
/** The ELF version is not supported. */
/** The ELF loader cannot handle multiple SYMTAB sections. */
/** The ELF loader encountered a relocation type which is not implemented. */
/** The ELF loader encountered a bad symbol index. */
/** The ELF loader encountered an invalid symbol name offset. */
/** The ELF loader encountered an invalid relocation offset. */
/** Invalid link address. */
/** Invalid image relative virtual address. */
/** Invalid segment:offset address. */
/** @}*/
/** @name Debug Info Reader Status Codes.
* @{
*/
/** The module contains no line number information. */
/** The module contains no symbol information. */
/** The specified segment:offset address was invalid. Typically an attempt at
* addressing outside the segment boundary. */
/** Invalid segment index. */
/** Invalid segment offset. */
/** Invalid image relative virtual address. */
/** Invalid image relative virtual address. */
* Attempted to add a segment, symbol or line number that fully or partially
* overlaps with an existing one. */
/** Duplicate symbol within the module.
* Attempted to add a symbol which name already exists within the module. */
/** The segment index specified when adding a new segment is already in use. */
/** The length of the symbol name is out of range.
* This means it is an empty string or that it's greater or equal to
* RTDBG_SYMBOL_NAME_LENGTH. */
/** The length of the file name is out of range.
* This means it is an empty string or that it's greater or equal to
* RTDBG_FILE_NAME_LENGTH. */
/** The length of the segment name is out of range.
* This means it is an empty string or that it is greater or equal to
* RTDBG_SEGMENT_NAME_LENGTH. */
/** The specified address range wraps around. */
/** The file is not a valid NM map file. */
/** No debug module interpreter matching the debug info. */
/** Bad DWARF line number header. */
/** Unexpected end of DWARF unit. */
/** DWARF LEB value overflows the decoder type. */
/** Bad DWARF extended line number opcode. */
/** Bad DWARF string. */
/** Bad DWARF position. */
/** Bad DWARF info. */
/** Bad DWARF abbreviation data. */
/** A DWARF abbreviation was not found. */
/** Encountered an unknown attribute form. */
/** Encountered an unexpected attribute form. */
/** Unfinished code. */
/** Unknown location opcode. */
/** Expression stack overflow. */
/** Expression stack underflow. */
/** Internal processing error in the DWARF code. */
/** Invalid configuration property value. */
/** Not an integer property. */
/** Deferred loading of information failed. */
/** Unfinished debug info reader code. */
/** Found file, but it didn't match the search criteria. */
/** Internal processing error in the debug module reader code. */
/** The symbol size was adjusted while adding it. */
/** Unable to parse the CodeView debug information. */
/** Unfinished CodeView debug information feature. */
/** Internal processing error the CodeView debug information reader. */
/** @} */
/** @name Request Packet Status Codes.
* @{
*/
/** Invalid RT request type.
* For the RTReqAlloc() case, the caller just specified an illegal enmType. For
* all the other occurrences it means indicates corruption, broken logic, or stupid
* interface user. */
/** Invalid RT request state.
* The state of the request packet was not the expected and accepted one(s). Either
* the interface user screwed up, or we've got corruption/broken logic. */
/** Invalid RT request packet.
* One or more of the RT controlled packet members didn't contain the correct
* values. Some thing's broken. */
/** The status field has not been updated yet as the request is still
* pending completion. Someone queried the iStatus field before the request
* has been fully processed. */
/** The request has been freed, don't read the status now.
* Someone is reading the iStatus field of a freed request packet. */
/** @} */
/** @name Environment Status Code
* @{
*/
/** The specified environment variable was not found. (RTEnvGetEx) */
/** The specified environment variable was not found. (RTEnvUnsetEx) */
/** Unable to translate all the variables in the default environment due to
* codeset issues (LANG / LC_ALL / LC_CTYPE). */
/** @} */
/** @name Multiprocessor Status Codes.
* @{
*/
/** The specified cpu is offline. */
/** The specified cpu was not found. */
/** Not all of the requested CPUs showed up in the PFNRTMPWORKER. */
/** Internal processing error in the RTMp code.*/
/** @} */
/** @name RTGetOpt status codes
* @{ */
/** RTGetOpt: Command line option not recognized. */
/** RTGetOpt: Command line option needs argument. */
/** RTGetOpt: Command line option has argument with bad format. */
/** RTGetOpt: Not an option. */
/** RTGetOpt: Command line option needs an index. */
/** @} */
/** @name RTCache status codes
* @{ */
/** RTCache: cache is full. */
/** RTCache: cache is empty. */
/** @} */
/** @name RTMemCache status codes
* @{ */
/** Reached the max cache size. */
/** @} */
/** @name RTS3 status codes
* @{ */
/** Access denied error. */
/** Bucket already exists. */
/** Can't delete bucket with keys. */
/** The current operation was canceled. */
/** @} */
/** @name HTTP status codes
* @{ */
/** HTTP initialization failed. */
/** The server has not found anything matching the URI given. */
/** The request is for something forbidden. Authorization will not help. */
/** The server did not understand the request due to bad syntax. */
/** Couldn't connect to the server (proxy?). */
/** SSL connection error. */
/** CAcert is missing or has the wrong format. */
/** Certificate cannot be authenticated with the given CA certificates. */
/** The current HTTP request was forcefully aborted */
/** Request was redirected. */
/** @} */
/** @name RTManifest status codes
* @{ */
/** A digest type used in the manifest file isn't supported. */
/** An entry in the manifest file couldn't be interpreted correctly. */
/** A digest doesn't match the corresponding file. */
/** The file list doesn't match to the content of the manifest file. */
/** The specified attribute (name) was not found in the manifest. */
/** The attribute type did not match. */
/** No attribute of the specified types was found. */
/** @} */
/** @name RTTar status codes
* @{ */
/** The checksum of a tar header record doesn't match. */
/** The tar end of file record was read. */
/** The tar file ended unexpectedly. */
/** The tar termination records was encountered without reaching the end of
* the input stream. */
/** A number tar header field was malformed. */
/** A numeric tar header field was not terminated correctly. */
/** A number tar header field was encoded using base-256 which this
* tar implementation currently does not support. */
/** A number tar header field yielded a value too large for the internal
* variable of the tar interpreter. */
/** The combined minor and major device number type is too small to hold the
* value stored in the tar header. */
/** The mode field in a tar header is bad. */
/** The mode field should not include the type. */
/** The size field should be zero for links and symlinks. */
/** Encountered an unknown type flag. */
/** The tar header is all zeros. */
/** Not a uniform standard tape v0.0 archive header. */
/** The name is empty. */
/** A non-directory entry has a name ending with a slash. */
/** Encountered an unsupported portable archive exchange (pax) header. */
/** Encountered an unsupported Solaris Tar extension. */
/** Encountered an unsupported GNU Tar extension. */
/** Malformed checksum field in the tar header. */
/** Malformed checksum field in the tar header. */
/** Too long name or link string. */
/** A directory entry in the archive. */
/** @} */
/** @name RTPoll status codes
* @{ */
/** The handle is not pollable. */
/** The handle ID is already present in the poll set. */
/** The handle ID was not found in the set. */
/** The poll set is full. */
/** @} */
/** @name Pkzip status codes
* @{ */
/** No end of central directory record found. */
/** Too long name string. */
/** Local file header corrupt. */
/** Central directory file header corrupt. */
/** Encountered an unknown type flag. */
/** Found a ZIP64 Extra Information Field in a ZIP32 file. */
/** @name RTZip status codes
* @{ */
/** Generic zip error. */
/** The compressed data was corrupted. */
/** Ran out of memory while compressing or uncompressing. */
/** The compression format version is unsupported. */
/** The compression method is unsupported. */
/** The compressed data started with a bad header. */
/** @} */
/** @name RTVfs status codes
* @{ */
/** The VFS chain specification does not have a valid prefix. */
/** The VFS chain specification is empty. */
/** Expected an element. */
/** The VFS object type is not known. */
/** Expected a left paranthese. */
/** Expected a right paranthese. */
/** Expected a provider name. */
/** Expected an action (> or |). */
/** Only one action element is currently supported. */
/** Expected to find a driving action (>), but there is none. */
/** Expected pipe action. */
/** Unexpected action type. */
/** @} */
/** @name RTDvm status codes
* @{ */
/** The volume map doesn't contain any valid volume. */
/** There is no volume behind the current one. */
/** @} */
/** @name Logger status codes
* @{ */
/** The internal logger revision did not match. */
/** @} */
/* see above, 22400..22499 is used for misc codes! */
/** @name Logger status codes
* @{ */
/** Power off is not supported by the hardware or the OS. */
/** The halt action was requested, but the OS may actually power
* off the machine. */
/** Shutdown failed. */
/** @} */
/** @name Filesystem status codes
* @{ */
/** Filesystem can't be opened because it is corrupt. */
/** @} */
/** @name RTZipXar status codes.
* @{ */
/** Wrong magic value. */
/** Bad header size. */
/** Unsupported version. */
/** Unsupported hashing function. */
/** The table of content (TOC) is too small and therefore can't be valid. */
/** The table of content (TOC) is too big. */
/** The compressed table of content is too big. */
/** The uncompressed table of content size in the header didn't match what
* ZLib returned. */
/** The table of content string length didn't match the size specified in the
* header. */
/** The table of content isn't valid UTF-8. */
/** XML error while parsing the table of content. */
/** The table of content XML document does not have a toc element. */
/** The table of content XML element (toc) has sibilings, we expected it to be
* an only child or the root element (xar). */
/** The XAR table of content digest doesn't match. */
/** Bad or missing XAR checksum element. */
/** The hash function in the header doesn't match the one in the table of
* content. */
/** Bad digest length encountered in the table of content. */
/** The order of elements in the XAR file does not lend it self to expansion
* from via an I/O stream. */
/** Missing offset element in table of content sub-element. */
/** Bad offset element in table of content sub-element. */
/** Missing size element in table of content sub-element. */
/** Bad size element in table of content sub-element. */
/** Missing length element in table of content sub-element. */
/** Bad length element in table of content sub-element. */
/** Bad file element in XAR table of content. */
/** Missing data element for XAR file. */
/** Unknown XAR file type value. */
/** Missing encoding element for XAR data stream. */
/** Bad timestamp for XAR file. */
/** Bad file mode for XAR file. */
/** Bad file user id for XAR file. */
/** Bad file group id for XAR file. */
/** Bad file inode device number for XAR file. */
/** Bad file inode number for XAR file. */
/** Invalid name for XAR file. */
/** The message digest of the extracted data does not match the one supplied. */
/** The extracted data has exceeded the expected size. */
/** The message digest of the archived data does not match the one supplied. */
/** The decompressor completed without using all the input data. */
/** Expected the archived and extracted XAR data sizes to be the same for
* uncompressed data. */
/** @} */
/** @name RTX509 status codes
* @{ */
/** Error reading a certificate in PEM format from BIO. */
/** Error extracting a public key from the certificate. */
/** Error extracting RSA from the public key. */
/** Signature verification failed. */
/** Basic constraints were not found. */
/** Error getting extensions from the certificate. */
/** Error getting a data from the extension. */
/** Error formatting an extension. */
/** X509 certificate verification error. */
/** X509 certificate isn't self signed. */
/** Warning X509 certificate isn't self signed. */
/** @} */
/** @name RTAsn1 status codes
* @{ */
/** Temporary place holder. */
/** Encountered an ASN.1 string type that is not supported. */
/** Invalid ASN.1 UTF-8 STRING encoding. */
/** Invalid ASN.1 NUMERIC STRING encoding. */
/** Invalid ASN.1 PRINTABLE STRING encoding. */
/** Invalid ASN.1 VIDEOTEX STRING encoding. */
/** Invalid ASN.1 IA5 STRING encoding. */
/** Invalid ASN.1 GRAPHIC STRING encoding. */
/** Invalid ASN.1 GENERAL STRING encoding. */
/** Invalid ASN.1 UNIVERSAL STRING encoding. */
/** Invalid ASN.1 BMP STRING encoding. */
/** Invalid ASN.1 OBJECT IDENTIFIER encoding. */
/** A component value of an ASN.1 OBJECT IDENTIFIER is too big for our
* internal representation (32-bits). */
/** Too many components in an ASN.1 OBJECT IDENTIFIER for our internal
* representation. */
/** The dotted-string representation of an ASN.1 OBJECT IDENTIFIER would be too
* long for our internal representation. */
/** Invalid dotted string. */
/** Constructed string type not implemented. */
/** Expected a different string tag. */
/** Expected a different time tag. */
/** More unconsumed data available. */
/** RTAsnEncodeWriteHeader return code indicating that nothing was written
* and the content should be skipped as well. */
/** Unknown escape sequence encountered in TeletexString. */
/** Unsupported escape sequence encountered in TeletexString. */
/** Unsupported character set. */
/** ASN.1 object has no virtual method table. */
/** ASN.1 object has no pfnCheckSanity method. */
/** ASN.1 object is not present */
/** There are unconsumed bytes after decoding an ASN.1 object. */
/** Long ASN.1 tag form is not implemented. */
/** Bad ASN.1 object length encoding. */
/** Indefinite length form is against the rules. */
/** Indefinite length form is not implemented. */
/** ASN.1 object length goes beyond the end of the byte stream being decoded. */
/** Not more data in ASN.1 byte stream. */
/** Too little data in ASN.1 byte stream. */
/** Constructed string is not according to the encoding rules. */
/** Unexpected ASN.1 tag encountered while decoding. */
/** ASN.1 bit string object is out of bounds. */
/** Bad ASN.1 time object. */
/** Failed to normalize ASN.1 time object. */
/** Normalization of ASN.1 time object didn't work out. */
/** Invalid ASN.1 UTC TIME encoding. */
/** Invalid ASN.1 GENERALIZED TIME encoding. */
/** Invalid ASN.1 BOOLEAN encoding. */
/** Invalid ASN.1 NULL encoding. */
/** Invalid ASN.1 BIT STRING encoding. */
/** Unimplemented ASN.1 tag reached the RTAsn1DynType code. */
/** ASN.1 object is too long. */
/** Expected primitive ASN.1 object. */
/** Expected valid data pointer for ASN.1 object. */
/** The ASN.1 encoding is too deeply nested for the decoder. */
/** ANS.1 internal error 1. */
/** ANS.1 internal error 2. */
/** ANS.1 internal error 3. */
/** ANS.1 internal error 4. */
/** ANS.1 internal error 5. */
/** @} */
/** @name More RTLdr status codes.
* @{ */
/** Image Verficiation Failure: No Authenticode Signature. */
/** Image Verficiation Warning: No Authenticode Signature, but on whitelist. */
/** Image Verficiation Failure: Error reading image headers. */
/** Image Verficiation Failure: Error reading section headers. */
/** Image Verficiation Failure: Error reading authenticode signature data. */
/** Image Verficiation Failure: Error reading file for hashing. */
/** Image Verficiation Failure: Error determining the file length. */
/** Image Verficiation Failure: Error allocating memory for state data. */
/** Image Verficiation Failure: Error allocating memory for authenticode
* signature data. */
/** Image Verficiation Failure: Error allocating memory for section headers. */
/** Image Verficiation Failure: Authenticode parsing output. */
/** Image Verficiation Failure: Invalid security directory entry. */
/** Image Verficiation Failure: */
/** Image Verficiation Failure: */
/** Image Verficiation Failure: */
/** Image Verficiation Failure: More than one certificate table entry. */
/** Image Verficiation Failure: */
/** Image Verficiation Failure: Invalid section count. */
/** Image Verficiation Failure: Raw data offsets and sizes are out of range. */
/** Optional header magic and target machine does not match. */
/** Unsupported image target architecture. */
/** Image Verification Failure: Internal error in signature parser. */
/** Generic BER parse error. Will be refined later. */
/** Expected the signed data content to be the object ID of
* SpcIndirectDataContent, found something else instead. */
/** Page hash table size overflow. */
/** Page hash table is too long (covers signature data, i.e. itself). */
/** The page hash table is not strictly ordered by offset. */
/** The page hash table hashes data outside the defined and implict sections. */
/** Page hash mismatch. */
/** Image hash mismatch. */
/** Cannot resolve symbol because it's a forwarder. */
/** The symbol is not a forwarder. */
/** Malformed forwarder entry. */
/** Too long forwarder chain or there is a loop. */
/** Support for forwarders has not been implemented. */
/** @} */
/** @name RTCrX509 status codes.
* @{ */
/** Generic X.509 error. */
/** Internal error in the X.509 code. */
/** Internal error in the X.509 certificate path building and verification
* code. */
/** Path not verified yet. */
/** The certificate path has no trust anchor. */
/** Unknown X.509 certificate signature algorithm. */
/** Certificate signature algorithm mismatch. */
/** The signature algorithm in the to-be-signed certifcate part does not match
* the one assoicated with the signature. */
/** Certificate extensions requires certificate version 3 or later. */
/** Unique issuer and subject IDs require version certificate 2. */
/** Certificate serial number length is out of bounds. */
/** Unsupported X.509 certificate version. */
/** Public key is too small. */
/** Invalid strnig tag for a X.509 name object. */
/** Empty string in X.509 name object. */
/** Non-string object inside X.509 name object. */
/** Empty set inside X.509 name. */
/** Empty sub-string set inside X.509 name. */
/** The NotBefore and NotAfter values of an X.509 Validity object seems to
* have been swapped around. */
/** Duplicate certificate extension. */
/** Missing relative distinguished name map entry. */
/** Certificate path validator: No trusted certificate paths. */
/** Certificate path validator: No valid certificate policy. */
/** Certificate path validator: Unknown critical certificate extension. */
/** Certificate path validator: Intermediate certificate is missing the
* KeyCertSign usage flag. */
/** Certificate path validator: Hit the max certificate path length before
* reaching trust anchor. */
/** Certificate path validator: Intermediate certificate is not marked as a
* certificate authority (CA). */
/** Certificate path validator: Intermeidate certificate is not a version 3
* certificate. */
/** Certificate path validator: Name constraints permits no names. */
/** Certificate path validator: Name constraints does not permits the
* certificate name. */
/** Certificate path validator: Name constraints does not permits the
* alternative certificate name. */
/** Certificate path validator: Intermediate certificate subject does not
* match child issuer property. */
/** Certificate path validator: The certificate is not valid at the
* specificed time. */
/** Certificate path validator: Unexpected choice found in general subtree
* object (name constraints). */
/** Certificate path validator: Unexpected minimum value found in general
* subtree object (name constraints). */
/** Certificate path validator: Unexpected maximum value found in
* general subtree object (name constraints). */
/** Certificate path builder: Encountered bad certificate context. */
/** OpenSSL d2i_X509 failed. */
/** @} */
/** @name RTCrPkcs7 status codes.
* @{ */
/** Generic PKCS \#7 error. */
/** Signed data verfication failed because there are zero signer infos. */
/** Signed data certificate not found. */
/** Signed data verification failed due to key usage issues. */
/** Signed data verification failed because of missing (or duplicate)
* authenticated content-type attribute. */
/** Signed data verification failed because of the authenticated content-type
* attribute did not match. */
/** Signed data verification failed because of a malformed authenticated
* content-type attribute. */
/** Signed data verification failed because of missing (or duplicate)
* authenticated message-digest attribute. */
/** Signed data verification failed because the authenticated message-digest
* attribute did not match. */
/** Signed data verification failed because of a malformed authenticated
* message-digest attribute. */
/** Signature verification failed. */
/** Internal PKCS \#7 error. */
/** OpenSSL d2i_PKCS7 failed. */
/** OpenSSL PKCS \#7 verification failed. */
/** Digest algorithm parameters are not supported by the PKCS \#7 code. */
/** The digest algorithm of a signer info entry was not found in the list of
* digest algorithms in the signed data. */
/** The PKCS \#7 content is not signed data. */
/** No digest algorithms listed in PKCS \#7 signed data. */
/** Too many digest algorithms used by PKCS \#7 signed data. This is an
* internal limitation of the code that aims at saving kernel stack space. */
/** Error creating digest algorithm calculator. */
/** Error while calculating a digest for a PKCS \#7 verficiation operation. */
/** Unsupported PKCS \#7 signed data version. */
/** PKCS \#7 signed data has no digest algorithms listed. */
/** Unknown digest algorithm used by PKCS \#7 object. */
/** Expected PKCS \#7 object to ship at least one certificate. */
/** Expected PKCS \#7 object to not contain any CRLs. */
/** Expected PKCS \#7 object to contain exactly on signer info entry. */
/** Unsupported PKCS \#7 signer info version. */
/** PKCS \#7 singer info contains no issuer serial number. */
/** Expected PKCS \#7 object to ship the signer certificate(s). */
/** The encrypted digest algorithm does not match the one in the certificate. */
/** @} */
/** @name RTCrSpc status codes.
* @{ */
/** Generic SPC error. */
/** SPC requires there to be exactly one SignerInfo entry. */
/** There shall be exactly one digest algorithm to go with the single
* SingerInfo entry required by SPC. */
/** The digest algorithm in the SignerInfo does not match the one in the
* indirect data. */
/** The digest algorithm in the indirect data was not found in the list of
* digest algorithms in the signed data structure. */
/** The digest algorithm is not known to us. */
/** The indirect data digest size does not match the digest algorithm. */
/** Exptected PE image data inside indirect data object. */
/** Internal SPC error: The PE image data is missing. */
/** Bad SPC object moniker UUID field. */
/** Unknown SPC object moniker UUID. */
/** Internal SPC error: Bad object monker choice value. */
/** Internal SPC error: Bad object moniker data pointer. */
/** Multiple PE image page hash tables. */
/** Unknown SPC PE image attribute. */
/** URL not expected in SPC PE image data. */
/** PE image data without any valid content was not expected. */
/** @} */
/** @name RTCrPkix status codes.
* @{ */
/** Generic PKCS \#7 error. */
/** Parameters was presented to a signature schema that does not take any. */
/** Unknown hash digest type. */
/** Internal error. */
/** The signature is too long for the scratch buffer. */
/** The signature is greater than or equal to the key. */
/** The signature is negative. */
/** Invalid signature length. */
/** PKIX signature no does not match up to the current data. */
/** PKIX cipher algorithm parameters are not implemented. */
/** ipher algorithm is not known to us. */
/** PKIX cipher algorithm is not known to OpenSSL. */
/** PKIX cipher algorithm is not known to OpenSSL EVP API. */
/** OpenSSL failed to init PKIX cipher algorithm context. */
/** Final OpenSSL PKIX verification failed. */
/** OpenSSL failed to decode the public key. */
/** The EVP_PKEY_type API in OpenSSL failed. */
/** @} */
/** @name RTCrStore status codes.
* @{ */
/** Generic store error. */
/** @} */
/** @name RTCrRsa status codes.
* @{ */
/** Generic RSA error. */
/** @} */
/** @name RTBigNum status codes.
* @{ */
/** Sensitive input requires the result(s) to be initialized as sensitive. */
/** Attempt to divide by zero. */
/** Negative exponent makes no sense to integer math. */
/** @} */
/** @name RTCrDigest status codes.
* @{ */
/** OpenSSL failed to initialize the digest algorithm contextn. */
/** OpenSSL failed to clone the digest algorithm contextn. */
/** @} */
/* SED-END */
/** @} */
#endif