| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 | /* Copyright (C) 2003, 2007 Free Software Foundation, Inc.   This file is part of the GNU C Library.   Contributed by Ulrich Drepper <drepper@redhat.com>, 2003.   The GNU C Library is free software; you can redistribute it and/or   modify it under the terms of the GNU Lesser General Public License as   published by the Free Software Foundation; either version 2.1 of the   License, or (at your option) any later version.   The GNU C Library 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   Lesser General Public License for more details.   You should have received a copy of the GNU Lesser General Public   License along with the GNU C Library; see the file COPYING.LIB.  If   not, see <http://www.gnu.org/licenses/>.  */#include <errno.h>#include <stdlib.h>#include <time.h>#include <sysdep.h>#include <bits/kernel-features.h>#include "kernel-posix-timers.h"#ifdef __NR_timer_delete# ifndef __ASSUME_POSIX_TIMERSstatic int compat_timer_delete (timer_t timerid);#  define timer_delete static compat_timer_delete#  include <nptl/sysdeps/pthread/timer_delete.c>#  undef timer_delete# endif# ifdef timer_delete_alias#  define timer_delete timer_delete_alias# endifinttimer_delete (     timer_t timerid){# undef timer_delete# ifndef __ASSUME_POSIX_TIMERS  if (__no_posix_timers >= 0)# endif    {      struct timer *kt = (struct timer *) timerid;      /* Delete the kernel timer object.  */      int res = INLINE_SYSCALL (timer_delete, 1, kt->ktimerid);      if (res == 0)	{	  if (kt->sigev_notify == SIGEV_THREAD)	    {	      /* Remove the timer from the list.  */	      pthread_mutex_lock (&__active_timer_sigev_thread_lock);	      if (__active_timer_sigev_thread == kt)		__active_timer_sigev_thread = kt->next;	      else		{		  struct timer *prevp = __active_timer_sigev_thread;		  while (prevp->next != NULL)		    if (prevp->next == kt)		      {			prevp->next = kt->next;			break;		      }		    else		      prevp = prevp->next;		}	      pthread_mutex_unlock (&__active_timer_sigev_thread_lock);	    }# ifndef __ASSUME_POSIX_TIMERS	  /* We know the syscall support is available.  */	  __no_posix_timers = 1;# endif	  /* Free the memory.  */	  (void) free (kt);	  return 0;	}      /* The kernel timer is not known or something else bad happened.	 Return the error.  */# ifndef __ASSUME_POSIX_TIMERS      if (errno != ENOSYS)	{	  __no_posix_timers = 1;# endif	  return -1;# ifndef __ASSUME_POSIX_TIMERS	}      __no_posix_timers = -1;# endif    }# ifndef __ASSUME_POSIX_TIMERS  return compat_timer_delete (timerid);# endif}#else# ifdef timer_delete_alias#  define timer_delete timer_delete_alias# endif/* The new system calls are not available.  Use the userlevel   implementation.  */# include <nptl/sysdeps/pthread/timer_delete.c>#endif
 |