2
0
mirror of https://github.com/xcat2/xNBA.git synced 2024-12-15 15:51:44 +00:00
xNBA/src/core/errno.c

62 lines
1.6 KiB
C
Raw Normal View History

2005-05-18 14:44:38 +00:00
#include "etherboot.h"
#include "errno.h"
#include "vsprintf.h"
2005-05-18 14:44:38 +00:00
/** @file
*
* Error codes and descriptions.
*
2005-05-18 15:28:33 +00:00
* This file provides the global variable #errno and the function
* strerror(). These function much like their standard C library
* equivalents.
*
* The error numbers used by Etherboot are a superset of those defined
* by the PXE specification version 2.1. See errno.h for a listing of
* the error values.
*
* To save space in ROM images, error string tables are optional. Use
* the ERRORMSG_XXX options in config.h to select which error string
* tables you want to include. If an error string table is omitted,
* strerror() will simply return the text "Error 0x<errno>".
2005-05-18 14:44:38 +00:00
*
*/
/**
* Global "last error" number.
*
* This is valid only when a function has just returned indicating a
* failure.
*
*/
int errno;
static struct errortab errortab_start[0] __table_start(errortab);
static struct errortab errortab_end[0] __table_end(errortab);
2005-05-18 14:44:38 +00:00
/**
* Retrieve string representation of error number.
*
2005-05-18 14:44:38 +00:00
* @v errno Error number
* @ret strerror Pointer to error text
*
* If the error is not found in the linked-in error tables, generates
2005-05-18 15:28:33 +00:00
* a generic "Error 0x<errno>" message.
2005-05-18 14:44:38 +00:00
*
* The pointer returned by strerror() is valid only until the next
* call to strerror().
*
*/
const char * strerror ( int errno ) {
static char *generic_message = "Error 0x0000";
struct errortab *errortab;
for ( errortab = errortab_start ; errortab < errortab_end ;
errortab++ ) {
if ( errortab->errno == errno )
return errortab->text;
}
sprintf ( generic_message + 8, "%hx", errno );
return generic_message;
}