summaryrefslogtreecommitdiffstats
path: root/mdk-stage1/dietlibc/lib/perror.c
diff options
context:
space:
mode:
authorGwenolé Beauchesne <gbeauchesne@mandriva.org>2003-06-04 18:31:57 +0000
committerGwenolé Beauchesne <gbeauchesne@mandriva.org>2003-06-04 18:31:57 +0000
commit09e967c2d732783b2579e4e120cd9b608404cb00 (patch)
tree8d2783a6a7e33608c6012efd6a88b8f5694df81d /mdk-stage1/dietlibc/lib/perror.c
parent18fcff49d3c836697d3b75a3d01d31c700e69974 (diff)
downloaddrakx-backup-do-not-use-09e967c2d732783b2579e4e120cd9b608404cb00.tar
drakx-backup-do-not-use-09e967c2d732783b2579e4e120cd9b608404cb00.tar.gz
drakx-backup-do-not-use-09e967c2d732783b2579e4e120cd9b608404cb00.tar.bz2
drakx-backup-do-not-use-09e967c2d732783b2579e4e120cd9b608404cb00.tar.xz
drakx-backup-do-not-use-09e967c2d732783b2579e4e120cd9b608404cb00.zip
Merge from R9_0-AMD64, most notably:
- AMD64 support to insmod-busybox, minilibc, et al. - Sync with insmod-modutils 2.4.19 something but everyone should use dietlibc nowadays - Factor out compilation and prefix with $(DIET) for dietlibc builds - 64-bit & varargs fixes
Diffstat (limited to 'mdk-stage1/dietlibc/lib/perror.c')
-rw-r--r--mdk-stage1/dietlibc/lib/perror.c32
1 files changed, 17 insertions, 15 deletions
diff --git a/mdk-stage1/dietlibc/lib/perror.c b/mdk-stage1/dietlibc/lib/perror.c
index ecab7250b..0a45fb9d6 100644
--- a/mdk-stage1/dietlibc/lib/perror.c
+++ b/mdk-stage1/dietlibc/lib/perror.c
@@ -1,22 +1,24 @@
#include "dietfeatures.h"
#include <unistd.h>
#include <string.h>
+#include <stdio.h>
+
+#define _BSD_SOURCE
#include <errno.h>
-extern char *sys_errlist[];
-extern int sys_nerr;
-extern int errno;
+extern const char __sys_err_unknown [];
+
+void perror ( const char* prepend )
+{
+ register const char* message = __sys_err_unknown;
+
+ if ( (unsigned int) errno < (unsigned int) __SYS_NERR )
+ message = sys_errlist [errno];
-void perror(const char *s) {
- register char *message="[unknown error]";
- write(2,s,strlen(s));
- write(2,": ",2);
- if (errno>=0 && errno<sys_nerr)
-#ifdef WANT_THREAD_SAFE
- message=sys_errlist[*__errno_location()];
-#else
- message=sys_errlist[errno];
-#endif
- write(2,message,strlen(message));
- write(2,"\n",1);
+ if (prepend) {
+ write ( 2, prepend, strlen(prepend) );
+ write ( 2, ": ", 2 );
+ }
+ write ( 2, message, strlen(message) );
+ write ( 2, "\n", 1 );
}