Include stdlib.h rather than malloc.h
[people/meteger/gpxe.git] / src / hci / strerror.c
1 #include <errno.h>
2 #include <string.h>
3 #include <vsprintf.h>
4 #include <gpxe/errortab.h>
5
6 /** @file
7  *
8  * Error descriptions.
9  *
10  * The error numbers used by Etherboot are a superset of those defined
11  * by the PXE specification version 2.1.  See errno.h for a listing of
12  * the error values.
13  *
14  * To save space in ROM images, error string tables are optional.  Use
15  * the ERRORMSG_XXX options in config.h to select which error string
16  * tables you want to include.  If an error string table is omitted,
17  * strerror() will simply return the text "Error 0x<errno>".
18  *
19  */
20
21 static struct errortab errortab_start[0]
22         __table_start ( struct errortab, errortab );
23 static struct errortab errortab_end[0]
24         __table_end ( struct errortab, errortab );
25
26 /**
27  * Retrieve string representation of error number.
28  *
29  * @v errno             Error number
30  * @ret strerror        Pointer to error text
31  *
32  * If the error is not found in the linked-in error tables, generates
33  * a generic "Error 0x<errno>" message.
34  *
35  * The pointer returned by strerror() is valid only until the next
36  * call to strerror().
37  *
38  */
39 const char * strerror ( int errno ) {
40         static char *generic_message = "Error 0x0000";
41         struct errortab *errortab;
42
43         /* Allow for strerror(rc) as well as strerror(errno) */
44         if ( errno < 0 )
45                 errno = -errno;
46
47         for ( errortab = errortab_start ; errortab < errortab_end ;
48               errortab++ ) {
49                 if ( errortab->errno == errno )
50                         return errortab->text;
51         }
52
53         sprintf ( generic_message + 8, "%hx", errno );
54         return generic_message;
55 }
56
57 /** The most common errors */
58 struct errortab common_errors[] __errortab = {
59         { 0, "No error" },
60         { ENOMEM, "Out of memory" },
61         { EINVAL, "Invalid argument" },
62         { ENOSPC, "No space left on device" },
63         { EIO, "Input/output error" },
64         { EACCES, "Permission denied" },
65         { ENOENT, "File not found" },
66         { ENETUNREACH, "Network unreachable" },
67         { ETIMEDOUT, "Connection timed out" },
68 };