mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-11-03 20:53:13 +03:00 
			
		
		
		
	1998-06-25 19:27 Ulrich Drepper <drepper@cygnus.com> * attr.c: Finish user stack support. Change locking code to be safe in situations with different priorities. * cancel.c: Likewise. * condvar.c: Likewise. * internals.h: Likewise. * join.c: Likewise. * manager.c: Likewise. * mutex.c: Likewise. * pthread.c: Likewise. * ptlongjmp.c: Likewise. * queue.h: Likewise. * rwlock.c: Likewise. * semaphore.c: Likewise. * semaphore.h: Likewise. * signals.c: Likewise. * spinlock.c: Likewise. * spinlock.h: Likewise. Patches by Xavier leroy. 1998-06-25 Ulrich Drepper <drepper@cygnus.com> * sysdeps/pthread/pthread.h: Make [sg]et_stacksize and [sg]et_stackaddr prototypes always available. * sysdeps/unix/sysv/linux/bits/posix_opt.h: Define _POSIX_THREAD_ATTR_STACKSIZE and _POSIX_THREAD_ATTR_STACKADDR.
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* Linuxthreads - a simple clone()-based implementation of Posix        */
 | 
						|
/* threads for Linux.                                                   */
 | 
						|
/* Copyright (C) 1996 Xavier Leroy (Xavier.Leroy@inria.fr)              */
 | 
						|
/*                                                                      */
 | 
						|
/* This program is free software; you can redistribute it and/or        */
 | 
						|
/* modify it under the terms of the GNU Library General Public License  */
 | 
						|
/* as published by the Free Software Foundation; either version 2       */
 | 
						|
/* of the License, or (at your option) any later version.               */
 | 
						|
/*                                                                      */
 | 
						|
/* This program is distributed in the hope that it will be useful,      */
 | 
						|
/* but WITHOUT ANY WARRANTY; without even the implied warranty of       */
 | 
						|
/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the        */
 | 
						|
/* GNU Library General Public License for more details.                 */
 | 
						|
 | 
						|
/* Waiting queues */
 | 
						|
 | 
						|
/* Waiting queues are represented by lists of thread descriptors
 | 
						|
   linked through their p_nextwaiting field.  The lists are kept
 | 
						|
   sorted by decreasing priority, and then decreasing waiting time. */
 | 
						|
 | 
						|
static inline void enqueue(pthread_descr * q, pthread_descr th)
 | 
						|
{
 | 
						|
  int prio = th->p_priority;
 | 
						|
  ASSERT(th->p_nextwaiting == NULL);
 | 
						|
  for (; *q != NULL; q = &((*q)->p_nextwaiting)) {
 | 
						|
    if (prio > (*q)->p_priority) {
 | 
						|
      th->p_nextwaiting = *q;
 | 
						|
      *q = th;
 | 
						|
      return;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  *q = th;
 | 
						|
}
 | 
						|
 | 
						|
static inline pthread_descr dequeue(pthread_descr * q)
 | 
						|
{
 | 
						|
  pthread_descr th;
 | 
						|
  th = *q;
 | 
						|
  if (th != NULL) {
 | 
						|
    *q = th->p_nextwaiting;
 | 
						|
    th->p_nextwaiting = NULL;
 | 
						|
  }
 | 
						|
  return th;
 | 
						|
}
 | 
						|
 | 
						|
static inline void remove_from_queue(pthread_descr * q, pthread_descr th)
 | 
						|
{
 | 
						|
  for (; *q != NULL; q = &((*q)->p_nextwaiting)) {
 | 
						|
    if (*q == th) {
 | 
						|
      *q = th->p_nextwaiting;
 | 
						|
      th->p_nextwaiting = NULL;
 | 
						|
      return;
 | 
						|
    }
 | 
						|
  }
 | 
						|
}
 |