diff options
| author | Mike Frysinger <vapier@gentoo.org> | 2006-02-27 05:36:31 +0000 | 
|---|---|---|
| committer | Mike Frysinger <vapier@gentoo.org> | 2006-02-27 05:36:31 +0000 | 
| commit | b60f4837e3f0cb276b00fed5d3c860285a8d9589 (patch) | |
| tree | 0607e552afeaea8934b85a788dec70a44163e717 /libpthread/linuxthreads.old/manager.c | |
| parent | 26f156d58b89bf148efdf98a015b6d677cfb5cc2 (diff) | |
| download | uClibc-alpine-b60f4837e3f0cb276b00fed5d3c860285a8d9589.tar.bz2 uClibc-alpine-b60f4837e3f0cb276b00fed5d3c860285a8d9589.tar.xz | |
import ia64 linuxthreads files
Diffstat (limited to 'libpthread/linuxthreads.old/manager.c')
| -rw-r--r-- | libpthread/linuxthreads.old/manager.c | 14 | 
1 files changed, 14 insertions, 0 deletions
| diff --git a/libpthread/linuxthreads.old/manager.c b/libpthread/linuxthreads.old/manager.c index df26344e7..e57080d17 100644 --- a/libpthread/linuxthreads.old/manager.c +++ b/libpthread/linuxthreads.old/manager.c @@ -583,9 +583,16 @@ static int pthread_handle_create(pthread_t *thread, const pthread_attr_t *attr,  	  __pthread_lock(new_thread->p_lock, NULL);  	  /* We have to report this event.  */ +#ifdef __ia64__ +	  pid = __clone2(pthread_start_thread_event, (void **) new_thread, +			(char *)new_thread - new_thread_bottom, +			CLONE_VM | CLONE_FS | CLONE_FILES | CLONE_SIGHAND | +			__pthread_sig_cancel, new_thread); +#else  	  pid = clone(pthread_start_thread_event, (void **) new_thread,  			CLONE_VM | CLONE_FS | CLONE_FILES | CLONE_SIGHAND |  			__pthread_sig_cancel, new_thread); +#endif  	  saved_errno = errno;  	  if (pid != -1) @@ -614,9 +621,16 @@ static int pthread_handle_create(pthread_t *thread, const pthread_attr_t *attr,    if (pid == 0)      {        PDEBUG("cloning new_thread = %p\n", new_thread); +#ifdef __ia64__ +      pid = __clone2(pthread_start_thread, (void **) new_thread, +			(char *)new_thread - new_thread_bottom, +		    CLONE_VM | CLONE_FS | CLONE_FILES | CLONE_SIGHAND | +		    __pthread_sig_cancel, new_thread); +#else        pid = clone(pthread_start_thread, (void **) new_thread,  		    CLONE_VM | CLONE_FS | CLONE_FILES | CLONE_SIGHAND |  		    __pthread_sig_cancel, new_thread); +#endif        saved_errno = errno;      }    /* Check if cloning succeeded */ | 
