diff options
author | Roland McGrath <roland@gnu.org> | 1995-11-07 21:46:52 +0000 |
---|---|---|
committer | Roland McGrath <roland@gnu.org> | 1995-11-07 21:46:52 +0000 |
commit | 86d2c878acad4d2f16d0af6fe6a030b90815362d (patch) | |
tree | 69e150aefd1002c3411b34da02bf852525c01ff7 /sysdeps/generic/_strerror.c | |
parent | 51093422b2ea7d61c17e4ac55af61ba9558d18d4 (diff) | |
download | glibc-86d2c878acad4d2f16d0af6fe6a030b90815362d.tar glibc-86d2c878acad4d2f16d0af6fe6a030b90815362d.tar.gz glibc-86d2c878acad4d2f16d0af6fe6a030b90815362d.tar.bz2 glibc-86d2c878acad4d2f16d0af6fe6a030b90815362d.zip |
Tue Nov 7 12:29:46 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu>
* elf/linux-compat.c: New file.
* elf/Makefile (distribute): Add linux-compat.c.
(generated): Add librtld.so.
[$(config-os)=linux*] (extra-objs): Add linux-compat.so.
[$(config-os)=linux*] (extra-objs): Add ld-linux.so.1.
(librtld.so): New target.
(ld.so, ld-linux.so.1): Make from librtld.so.
* elf/rtld.c (dl_main): Instead of weak call to _dl_compat_init,
call our own DT_INIT if we have one (and then clear it).
(__dgettext): New weak function.
* intl/localealias.c (read_alias_file): Avoid sprintf; use memcpy
by hand instead.
* sysdeps/generic/_strerror.c (_strerror_internal): Use _itoa
instead of snprintf.
* sysdeps/mach/_strerror.c (_strerror_internal): Don't write
BUF[BUFLEN].
* elf/rtld.c (rtld_map): New static variable.
(_dl_start): Use a differently named local BOOTSTRAP_MAP for the
bootstrapping. Then copy data into `rtld_map'.
(dl_main): Finish filling in rtld_map and link it into the chain,
instead of allocating a new structure.
(dl_main): Call _dl_compat_init if it is defined (use weak ref).
* elf/dlsym.c: Fix last change: move REF out of `doit'.
control.
using it.
and cwdir ports.
functions.
these.
$(libdir)(rtld-installed-name).
leading zeroes.
in the rhs.
pattern rule.
never know.
(fork): Use symbol_set_* macros for _hurd_fork_locks.
* sysdeps/unix/sysv/sysv4/linux/i386/sysdep.S (__syscall_error):
instead of unix/sysv.
-dynamic-linker.
(__printf_fp): Last arg ARGS is now `const void **const';
locale/C-ctype.c.
* sysdeps/mach/hurd/sigsuspend.c: Likewise.
* sysdeps/mach/hurd/mips/sigreturn.c: Likewise.
alias gethostname.
setitmr
setpgrp
(_S_msg_get_exec_flags, _S_msg_set_exec_flags,
(abort_thread, abort_rpcs): Take same new arg and pass it through.
Diffstat (limited to 'sysdeps/generic/_strerror.c')
-rw-r--r-- | sysdeps/generic/_strerror.c | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/sysdeps/generic/_strerror.c b/sysdeps/generic/_strerror.c index 72ebb216bf..569f7018e5 100644 --- a/sysdeps/generic/_strerror.c +++ b/sysdeps/generic/_strerror.c @@ -18,6 +18,7 @@ Cambridge, MA 02139, USA. */ #include <stdio.h> #include <string.h> +#include "../stdio-common/_itoa.h" #ifndef HAVE_GNU_LD #define _sys_errlist sys_errlist @@ -31,13 +32,14 @@ _strerror_internal (errnum, buf, buflen) char *buf; size_t buflen; { - if (errnum < 0 || errnum > _sys_nerr) + if (errnum < 0 || errnum >= _sys_nerr) { - int len = __snprintf (buf, buflen, _("Unknown error %d"), errnum); - if (len < 0) - return NULL; - buf[len - 1] = '\0'; - return buf; + const char *unk = _("Unknown error "); + const size_t unklen = strlen (unk); + char *p = buf + buflen; + *--p = '\0'; + p = _itoa (errnum, p, 10, 0); + return memcpy (p - unklen, unk, unklen); } return (char *) _(_sys_errlist[errnum]); |