Errno.h explained

errno.h is a header file in the standard library of the C programming language. It defines macros for reporting and retrieving error conditions using the symbol errno (short for "error number").[1]

errno acts like an integer variable. A value (the error number) is stored in errno by certain library functions when they detect errors. At program startup, the value stored is zero. Library functions store only values greater than zero. Any library function can alter the value stored before return, whether or not they detect errors.[2] Most functions indicate that they detected an error by returning a special value, typically NULL for functions that return pointers, and -1 for functions that return integers. A few functions require the caller to preset errno to zero and test it afterwards to see if an error was detected.

The errno macro expands to an lvalue with type int, sometimes with the extern and/or volatile type specifiers depending upon the platform.[3] Originally this was a static memory location, but macros are almost always used today to allow for multi-threading, so that each thread will see its own thread-local error number.

The header file also defines macros that expand to integer constants that represent the error codes. The C standard library only requires three to be defined:

EDOM

Results from a parameter outside a function's domain, e.g.

ERANGE

Results from a result outside a function's range, e.g. on systems with a 32-bit wide long

EILSEQ (Required since 1994 Amendment 1 to C89 standard)[4]

Results from an illegal byte sequence, e.g. on systems that use UTF-8.

POSIX compliant operating systems like AIX, Linux or Solaris include many other error values, many of which are used much more often than the above ones, such as EACCES for when a file cannot be opened for reading. C++11 additionally defines many of the same values found within the POSIX specification.[5]

Traditionally, the first page of Unix system manuals, named intro(2), lists all errno.h macros, but this is not the case with Linux, where these macros are instead listed in the errno(3).

An can be translated to a descriptive string using strerror (defined in string.h) or a BSD extension called . The translation can be printed directly to the standard error stream using perror (defined in stdio.h). As in many Unix-like systems is not thread-safe, a thread-safe version is used, but conflicting definitions from POSIX and GNU makes it even less portable than the table.[6]

GLIBC macros

The GNU C library (GLIBC) provides the additional POSIX error values macros in the header file .[7] These are the descriptions of the macros provided by strerror, excluding 41 and 58 as they are not in the POSIX standard:

EPERM (1)

Operation not permittedENOENT (2)

No such file or directoryESRCH (3)

No such processEINTR (4)

Interrupted system callEIO (5)

Input/output errorENXIO (6)

No such device or addressE2BIG (7)

Argument list too longENOEXEC (8)

Exec format errorEBADF (9)

Bad file descriptorECHILD (10)

No child processesEAGAIN (11)

Resource temporarily unavailableENOMEM (12)

Cannot allocate memoryEACCES (13)

Permission deniedEFAULT (14)

Bad addressENOTBLK (15)

Block device requiredEBUSY (16)

Device or resource busyEEXIST (17)

File existsEXDEV (18)

Invalid cross-device linkENODEV (19)

No such deviceENOTDIR (20)

Not a directoryEISDIR (21)

Is a directoryEINVAL (22)

Invalid argumentENFILE (23)

Too many open files in systemEMFILE (24)

Too many open filesENOTTY (25)

Inappropriate ioctl for deviceETXTBSY (26)

Text file busyEFBIG (27)

File too largeENOSPC (28)

No space left on deviceESPIPE (29)

Illegal seekEROFS (30)

Read-only file systemEMLINK (31)

Too many linksEPIPE (32)

Broken pipeEDOM (33)

Numerical argument out of domainERANGE (34)

Numerical result out of rangeEDEADLK (35)

Resource deadlock avoidedENAMETOOLONG (36)

File name too longENOLCK (37)

No locks availableENOSYS (38)

Function not implementedENOTEMPTY (39)

Directory not emptyELOOP (40)

Too many levels of symbolic linksENOMSG (42)

No message of desired typeEIDRM (43)

Identifier removedECHRNG (44)

Channel number out of rangeEL2NSYNC (45)

Level 2 not synchronizedEL3HLT (46)

Level 3 haltedEL3RST (47)

Level 3 resetELNRNG (48)

Link number out of rangeEUNATCH (49)

Protocol driver not attachedENOCSI (50)

No CSI structure availableEL2HLT (51)

Level 2 haltedEBADE (52)

Invalid exchangeEBADR (53)

Invalid request descriptorEXFULL (54)

Exchange fullENOANO (55)

No anodeEBADRQC (56)

Invalid request codeEBADSLT (57)

Invalid slotEBFONT (59)

Bad font file formatENOSTR (60)

Device not a streamENODATA (61)

No data availableETIME (62)

Timer expiredENOSR (63)

Out of streams resourcesENONET (64)

Machine is not on the networkENOPKG (65)

Package not installedEREMOTE (66)

Object is remoteENOLINK (67)

Link has been severedEADV (68)

Advertise errorESRMNT (69)

Srmount errorECOMM (70)

Communication error on sendEPROTO (71)

Protocol errorEMULTIHOP (72)

Multihop attemptedEDOTDOT (73)

RFS specific errorEBADMSG (74)

Bad messageEOVERFLOW (75)

Value too large for defined data typeENOTUNIQ (76)

Name not unique on networkEBADFD (77)

File descriptor in bad stateEREMCHG (78)

Remote address changedELIBACC (79)

Can not access a needed shared libraryELIBBAD (80)

Accessing a corrupted shared libraryELIBSCN (81)

.lib section in a.out corruptedELIBMAX (82)

Attempting to link in too many shared librariesELIBEXEC (83)

Cannot exec a shared library directlyEILSEQ (84)

Invalid or incomplete multibyte or wide characterERESTART (85)

Interrupted system call should be restartedESTRPIPE (86)

Streams pipe errorEUSERS (87)

Too many usersENOTSOCK (88)

Socket operation on non-socketEDESTADDRREQ (89)

Destination address requiredEMSGSIZE (90)

Message too longEPROTOTYPE (91)

Protocol wrong type for socketENOPROTOOPT (92)

Protocol not availableEPROTONOSUPPORT (93)

Protocol not supportedESOCKTNOSUPPORT (94)

Socket type not supportedEOPNOTSUPP (95)

Operation not supportedEPFNOSUPPORT (96)

Protocol family not supportedEAFNOSUPPORT (97)

Address family not supported by protocolEADDRINUSE (98)

Address already in useEADDRNOTAVAIL (99)

Cannot assign requested addressENETDOWN (100)

Network is downENETUNREACH (101)

Network is unreachableENETRESET (102)

Network dropped connection on resetECONNABORTED (103)

Software caused connection abortECONNRESET (104)

Connection reset by peerENOBUFS (105)

No buffer space availableEISCONN (106)

Transport endpoint is already connectedENOTCONN (107)

Transport endpoint is not connectedESHUTDOWN (108)

Cannot send after transport endpoint shutdownETOOMANYREFS (109)

Too many references: cannot spliceETIMEDOUT (110)

Connection timed outECONNREFUSED (111)

Connection refusedEHOSTDOWN (112)

Host is downEHOSTUNREACH (113)

No route to hostEALREADY (114)

Operation already in progressEINPROGRESS (115)

Operation now in progressESTALE (116)

Stale file handleEUCLEAN (117)

Structure needs cleaningENOTNAM (118)

Not a XENIX named type fileENAVAIL (119)

No XENIX semaphores availableEISNAM (120)

Is a named type fileEREMOTEIO (121)

Remote I/O errorEDQUOT (122)

Disk quota exceededENOMEDIUM (123)

No medium foundEMEDIUMTYPE (124)

Wrong medium typeECANCELED (125)

Operation canceledENOKEY (126)

Required key not availableEKEYEXPIRED (127)

Key has expiredEKEYREVOKED (128)

Key has been revokedEKEYREJECTED (129)

Key was rejected by serviceEOWNERDEAD (130)

Owner diedENOTRECOVERABLE (131)

State not recoverableERFKILL (132)

Operation not possible due to RF-killEHWPOISON (133)

Memory page has hardware error

See also

Bibliography

External links

Notes and References

  1. International Standard for Programming Language C (C11), ISO/IEC 9899:2011, p. 205
  2. International Standard for Programming Language C (C99), ISO/IEC 9899:1999, p. 186
  3. Web site: Checking for Errors . 2014-02-08 . The GNU C Library (glibc) . GNU Project . 2014-06-25.
  4. Web site: A brief description of Normative Addendum 1. 2013-09-12.
  5. Web site: Error numbers - cppreference.com . 2015-05-08 .
  6. Web site: McCabe . Colin . The problem with strerror . www.club.cc.cmu.edu.
  7. Web site: Error Codes (The GNU C Library) . 2023-10-21 . www.gnu.org.