summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog10
-rw-r--r--conform/data/stdlib.h-data22
-rw-r--r--linuxthreads/ChangeLog3
-rw-r--r--stdlib/random.c2
-rw-r--r--stdlib/stdlib.h11
-rw-r--r--sysdeps/generic/setenv.c16
6 files changed, 54 insertions, 10 deletions
diff --git a/ChangeLog b/ChangeLog
index 3fc613a333..09cc0f2092 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,15 @@
 2001-01-26  Ulrich Drepper  <drepper@redhat.com>
 
+	* conform/data/stdlib.h-data: Account for XPG6 changes.
+	* stdlib/stdlib.h (__random): Change return value type to long.
+	(posix_memalign): Cleanup parameter names.
+	(setenv, unsetenv): Make available for __USE_XOPEN2K.
+	Change return type of unsetenv to int.
+	(qecvt, qgcvt, qfcvt): Declare only if __USE_MISC.
+	* sysdeps/generic/setenv.c (unsetenv): Change return type to int.
+	Return -1 and set errno if parameter is invalid.
+	* stdlib/random.c (__random): Change return value type to long.
+
 	* conform/data/stdio.h-data: Account for changes in XPG6.
 
 	* conform/data/spawn.h-data: Correct posix_spawnattr_setflags
diff --git a/conform/data/stdlib.h-data b/conform/data/stdlib.h-data
index f4998716df..aee04465e9 100644
--- a/conform/data/stdlib.h-data
+++ b/conform/data/stdlib.h-data
@@ -5,7 +5,16 @@ constant RAND_MAX >= 32767
 macro MB_CUR_MAX
 
 type div_t
+element div_t int quot
+element div_t int rem
 type ldiv_t
+element ldiv_t long quot
+element ldiv_t long rem
+#ifdef XOPEN2K
+type lldiv_t
+element lldiv_t {long long} quot
+element lldiv_t {long long} rem
+#endif
 type size_t
 type wchar_t
 
@@ -13,7 +22,6 @@ constant WNOHANG
 constant WUNTRACED
 
 macro WEXITSTATUS
-macro WIFCONTINUED
 macro WIFEXITED
 macro WIFSIGNALED
 macro WIFSTOPPED
@@ -27,6 +35,9 @@ function int atexit (void(*)(void))
 function double atof (const char*)
 function int atoi (const char*)
 function {long int} atol (const char*)
+#ifdef XOPEN2K
+function {long long} atoll (const char*)
+#endif
 function {void*} bsearch (const void*, const void*, size_t, size_t, int(*)(const void*, const void*))
 function {void*} calloc (size_t, size_t)
 function div_t div (int, int)
@@ -46,6 +57,10 @@ function {char*} l64a (long)
 function {long int} labs (long int)
 function void lcong48 (unsigned short int[7])
 function ldiv_t ldiv (long int, long int)
+#ifdef XOPEN2K
+function {long long} llabs (long long)
+function lldiv_t lldiv (long long, long long)
+#endif
 function {long int} lrand48 (void)
 function {void*} malloc (size_t)
 function int mblen (const char*, size_t)
@@ -56,6 +71,9 @@ function int mkstemp (char*)
 function {long int} mrand48 (void)
 function {long int} nrand48 (unsigned short int[3])
 function int posix_memalign (void**, size_t, size_t)
+#ifdef XOPEN2K
+function int posix_openpt (int)
+#endif
 function {char*} ptsname (int)
 function int putenv (char*)
 function void qsort (void*, size_t, size_t, int(*)(const void*, const void*))
@@ -75,7 +93,9 @@ function double strtod (const char*, char**)
 function {long int} strtol (const char*, char**, int)
 function {unsigned long int} strtoul (const char*, char**, int)
 function int system (const char*)
+#ifndef XOPEN2K
 function int ttyslot (void)
+#endif
 function int unlockpt (int)
 function int unsetenv (const char*)
 function {void*} valloc (size_t)
diff --git a/linuxthreads/ChangeLog b/linuxthreads/ChangeLog
index 0ba72795d3..cad3fda18c 100644
--- a/linuxthreads/ChangeLog
+++ b/linuxthreads/ChangeLog
@@ -1,5 +1,8 @@
 2001-01-26  Ulrich Drepper  <drepper@redhat.com>
 
+	* sysdeps/pthread/bits/pthreadtypes.h: Define pthread_attr_t also
+	as struct __pthread_attr_s.
+
 	* semaphore.h (sem_t): Cleanup namespace, rename status and
 	spinlock elements.
 
diff --git a/stdlib/random.c b/stdlib/random.c
index 06a4c97829..afd0a1a516 100644
--- a/stdlib/random.c
+++ b/stdlib/random.c
@@ -259,7 +259,7 @@ weak_alias (__setstate, setstate)
    rear pointers can't wrap on the same call by not testing the rear
    pointer if the front one has wrapped.  Returns a 31-bit random number.  */
 
-int32_t
+long int
 __random ()
 {
   int32_t retval;
diff --git a/stdlib/stdlib.h b/stdlib/stdlib.h
index 17f19ac8d6..9b5d187558 100644
--- a/stdlib/stdlib.h
+++ b/stdlib/stdlib.h
@@ -395,7 +395,7 @@ extern long int a64l (__const char *__s) __THROW __attribute_pure__;
    The `rand' and `srand' functions are required by the ANSI standard.
    We provide both interfaces to the same random number generator.  */
 /* Return a random long integer between 0 and RAND_MAX inclusive.  */
-extern int32_t random (void) __THROW;
+extern long int random (void) __THROW;
 
 /* Seed the random number generator with the given number.  */
 extern void srandom (unsigned int __seed) __THROW;
@@ -554,7 +554,7 @@ extern void *valloc (size_t __size) __THROW __attribute_malloc__;
 
 #ifdef __USE_XOPEN2K
 /* Allocate memory of SIZE bytes with an alignment of ALIGNMENT.  */
-extern int posix_memalign (void **memptr, size_t alignment, size_t size)
+extern int posix_memalign (void **__memptr, size_t __alignment, size_t __size)
      __THROW __attribute_malloc__;
 #endif
 
@@ -600,14 +600,14 @@ extern char *__secure_getenv (__const char *__name) __THROW;
 extern int putenv (char *__string) __THROW;
 #endif
 
-#ifdef	__USE_BSD
+#if defined __USE_BSD || defined __USE_XOPEN2K
 /* Set NAME to VALUE in the environment.
    If REPLACE is nonzero, overwrite an existing value.  */
 extern int setenv (__const char *__name, __const char *__value, int __replace)
      __THROW;
 
 /* Remove the variable NAME from the environment.  */
-extern void unsetenv (__const char *__name) __THROW;
+extern int unsetenv (__const char *__name) __THROW;
 #endif
 
 #ifdef	__USE_MISC
@@ -742,6 +742,8 @@ extern char *fcvt (double __value, int __ndigit, int *__restrict __decpt,
    be written to BUF.  */
 extern char *gcvt (double __value, int __ndigit, char *__buf) __THROW;
 
+
+# ifdef __USE_MISC
 /* Long double versions of above functions.  */
 extern char *qecvt (long double __value, int __ndigit,
 		    int *__restrict __decpt, int *__restrict __sign) __THROW;
@@ -750,7 +752,6 @@ extern char *qfcvt (long double __value, int __ndigit,
 extern char *qgcvt (long double __value, int __ndigit, char *__buf) __THROW;
 
 
-# ifdef __USE_MISC
 /* Reentrant version of the functions above which provide their own
    buffers.  */
 extern int ecvt_r (double __value, int __ndigit, int *__restrict __decpt,
diff --git a/sysdeps/generic/setenv.c b/sysdeps/generic/setenv.c
index b8d234929f..6f871a65c7 100644
--- a/sysdeps/generic/setenv.c
+++ b/sysdeps/generic/setenv.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1992, 95, 96, 97, 98, 99, 2000 Free Software Foundation, Inc.
+/* Copyright (C) 1992,95,96,97,98,99,2000,2001 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -263,13 +263,21 @@ setenv (name, value, replace)
   return __add_to_environ (name, value, NULL, replace);
 }
 
-void
+int
 unsetenv (name)
      const char *name;
 {
-  const size_t len = strlen (name);
+  const size_t len;
   char **ep;
 
+  if (name == NULL || *name == '\0' || strchr (name, '=') != NULL)
+    {
+      __set_errno (EINVAL);
+      return -1;
+    }
+
+  len = strlen (name);
+
   LOCK;
 
   ep = __environ;
@@ -288,6 +296,8 @@ unsetenv (name)
       ++ep;
 
   UNLOCK;
+
+  return 0;
 }
 
 /* The `clearenv' was planned to be added to POSIX.1 but probably