diff options
author | Christopher Faylor <me@cgf.cx> | 2001-04-12 00:05:57 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2001-04-12 00:05:57 +0000 |
commit | 74f8cc634aea79eaa918dd426a846b699075c9c8 (patch) | |
tree | 2b78e89338bc7f817da5c8f28ff1e06aa4de7786 | |
parent | fc672fb26c42cc18eb0729236b221943d7bf25b3 (diff) | |
download | newlib-74f8cc634aea79eaa918dd426a846b699075c9c8.zip newlib-74f8cc634aea79eaa918dd426a846b699075c9c8.tar.gz newlib-74f8cc634aea79eaa918dd426a846b699075c9c8.tar.bz2 |
* libc/include/sys/features.h: Add appropriate defines for Cygwin pthread
support.
* libc/include/sys/signal.h: Remove unneeded __CYGWIN__ protection.
* libc/include/sys/types.h: Protect __CYGWIN__ from the rtems pthreads types.
Include <cygwin/types.h> for the cygwin specific typedefs.
-rw-r--r-- | newlib/ChangeLog | 8 | ||||
-rw-r--r-- | newlib/libc/include/sys/features.h | 5 | ||||
-rw-r--r-- | newlib/libc/include/sys/signal.h | 2 | ||||
-rw-r--r-- | newlib/libc/include/sys/types.h | 17 |
4 files changed, 28 insertions, 4 deletions
diff --git a/newlib/ChangeLog b/newlib/ChangeLog index 46746a4..01c94e1 100644 --- a/newlib/ChangeLog +++ b/newlib/ChangeLog @@ -1,3 +1,11 @@ +2001-04-12 Robert Collins <rbtcollins@hotmail.com> + + * libc/include/sys/features.h: Add appropriate defines for Cygwin + pthread support. + * libc/include/sys/signal.h: Remove unneeded __CYGWIN__ protection. + * libc/include/sys/types.h: Protect __CYGWIN__ from the rtems pthreads + types. Include <cygwin/types.h> for the cygwin specific typedefs. + 2001-04-04 Richard Sandiford <rsandifo@redhat.com> * libc/include/machine/ieeefp.h: Comment about new configuration diff --git a/newlib/libc/include/sys/features.h b/newlib/libc/include/sys/features.h index f492556..e86ce13 100644 --- a/newlib/libc/include/sys/features.h +++ b/newlib/libc/include/sys/features.h @@ -81,6 +81,11 @@ extern "C" { # define _POSIX_JOB_CONTROL 1 # define _POSIX_SAVED_IDS 0 # define _POSIX_VERSION 199009L +# define _POSIX_THREADS 1 +# define _POSIX_THREAD_PROCESS_SHARED 1 +# define _POSIX_THREAD_SAFE_FUNCTIONS 1 +# define _POSIX_THREAD_PRIORITY_SCHEDULING 1 +# define _POSIX_THREAD_ATTR_STACKSIZE 1 #endif #ifdef __cplusplus diff --git a/newlib/libc/include/sys/signal.h b/newlib/libc/include/sys/signal.h index 53987af..e590ae3 100644 --- a/newlib/libc/include/sys/signal.h +++ b/newlib/libc/include/sys/signal.h @@ -12,7 +12,7 @@ extern "C" { /* #ifndef __STRICT_ANSI__*/ -#if defined(_POSIX_THREADS) || defined(__CYGWIN__) +#if defined(_POSIX_THREADS) #include <sys/types.h> /* for pthread data types */ #endif diff --git a/newlib/libc/include/sys/types.h b/newlib/libc/include/sys/types.h index 7ec35ae..e4fcef2 100644 --- a/newlib/libc/include/sys/types.h +++ b/newlib/libc/include/sys/types.h @@ -206,7 +206,7 @@ typedef struct _types_fd_set { condition variables, and keys. But since RTEMS is currently the only newlib user of these, the ifdef is just on RTEMS. */ -#if defined(__rtems__) +#if defined(__rtems__) || defined(__CYGWIN__) #ifndef __clockid_t_defined typedef _CLOCKID_T_ clockid_t; @@ -220,7 +220,15 @@ typedef _TIMER_T_ timer_t; #include <sys/features.h> -#if defined(_POSIX_THREADS) + +/* Cygwin will probably never have full posix compliance due to little things + * like an inability to set the stackaddress. Cygwin is also using void * + * pointers rather than structs to ensure maximum binary compatability with + * previous releases. + * This means that we don't use the types defined here, but rather in + * <cygwin/types.h> + */ +#if defined(_POSIX_THREADS) && !defined(__CYGWIN__) #include <sys/sched.h> @@ -313,7 +321,10 @@ typedef struct { int is_initialized; /* is this structure initialized? */ int init_executed; /* has the initialization routine been run? */ } pthread_once_t; /* dynamic package initialization */ - +#else +#if defined (__CYGWIN__) +#include <cygwin/types.h> +#endif #endif /* defined(_POSIX_THREADS) */ #endif /* defined(__rtems__) */ |