aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2003-02-18 03:46:54 +0000
committerUlrich Drepper <drepper@redhat.com>2003-02-18 03:46:54 +0000
commit46d7e2ba2235768df3d633109451fd2bee5f9291 (patch)
treea5add2d0cab28324e2c97f855959143dd9374ae9
parenta5e34e047dcc6709d994949389eb6e91709b3266 (diff)
downloadglibc-46d7e2ba2235768df3d633109451fd2bee5f9291.zip
glibc-46d7e2ba2235768df3d633109451fd2bee5f9291.tar.gz
glibc-46d7e2ba2235768df3d633109451fd2bee5f9291.tar.bz2
Update.
2003-02-17 Ulrich Drepper <drepper@redhat.com> * sysdeps/posix/sysconf.c (__sysconf): Test for LOGIN_NAME_MAX and TTY_NAME_MAX and not the _POSIX_* minimal value macros. * sysdeps/unix/sysv/linux/bits/local_lim.h: Define TTY_NAME_MAX and LOGIN_NAME_MAX.
-rw-r--r--ChangeLog7
-rw-r--r--nptl/sysdeps/unix/sysv/linux/pthread_kill.c6
-rw-r--r--sysdeps/posix/sysconf.c8
3 files changed, 16 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index 5ca66fe..fcaa26c 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+2003-02-17 Ulrich Drepper <drepper@redhat.com>
+
+ * sysdeps/posix/sysconf.c (__sysconf): Test for LOGIN_NAME_MAX and
+ TTY_NAME_MAX and not the _POSIX_* minimal value macros.
+ * sysdeps/unix/sysv/linux/bits/local_lim.h: Define TTY_NAME_MAX
+ and LOGIN_NAME_MAX.
+
2003-02-17 Kevin B. Hendricks <kevin.hendricks@sympatico.ca>
Franz Sirl <Franz.Sirl-kernel@lauterbach.com>
diff --git a/nptl/sysdeps/unix/sysv/linux/pthread_kill.c b/nptl/sysdeps/unix/sysv/linux/pthread_kill.c
index 0fce02a..e1c79e7 100644
--- a/nptl/sysdeps/unix/sysv/linux/pthread_kill.c
+++ b/nptl/sysdeps/unix/sysv/linux/pthread_kill.c
@@ -34,7 +34,11 @@ __pthread_kill (threadid, signo)
/* We have a special syscall to do the work. */
INTERNAL_SYSCALL_DECL (err);
- int val = INTERNAL_SYSCALL (tkill, err, 2, pd->tid, signo);
+ /* The kernel returns EINVAL for PIDs <= 0. This is not nice since
+ the user would expect ESRCH. Correct it here. */
+ int val = (pd->tid > 0
+ ? INTERNAL_SYSCALL (tkill, err, 2, pd->tid, signo)
+ : ESRCH);
return (INTERNAL_SYSCALL_ERROR_P (val, err)
? INTERNAL_SYSCALL_ERRNO (val, err) : 0);
diff --git a/sysdeps/posix/sysconf.c b/sysdeps/posix/sysconf.c
index 1700ed0..7ad8ac7 100644
--- a/sysdeps/posix/sysconf.c
+++ b/sysdeps/posix/sysconf.c
@@ -515,15 +515,15 @@ __sysconf (name)
return NSS_BUFLEN_PASSWD;
case _SC_LOGIN_NAME_MAX:
-#ifdef _POSIX_LOGIN_NAME_MAX
- return _POSIX_LOGIN_NAME_MAX;
+#ifdef LOGIN_NAME_MAX
+ return LOGIN_NAME_MAX;
#else
return -1;
#endif
case _SC_TTY_NAME_MAX:
-#ifdef _POSIX_TTY_NAME_MAX
- return _POSIX_TTY_NAME_MAX;
+#ifdef TTY_NAME_MAX
+ return TTY_NAME_MAX;
#else
return -1;
#endif