source: rtems/cpukit/posix/src/testcancel.c @ e7bd66a7

4.104.114.84.95
Last change on this file since e7bd66a7 was f845e96e, checked in by Joel Sherrill <joel.sherrill@…>, on 07/05/02 at 18:13:18

2002-07-05 Joel Sherrill <joel@…>

  • include/rtems/posix/cancel.h, src/cancel.c, src/cancelrun.c, src/mqueue.c, src/pthread.c, src/semaphore.c, src/setcancelstate.c, src/setcanceltype.c, src/testcancel.c: Per PR164, corrected the behavior of thread cancellation and did some cleanup as a side-effect.
  • Property mode set to 100644
File size: 1.0 KB
Line 
1/*
2 *  $Id$
3 */
4
5#if HAVE_CONFIG_H
6#include "config.h"
7#endif
8
9#include <pthread.h>
10#include <errno.h>
11
12#include <rtems/system.h>
13#include <rtems/score/chain.h>
14#include <rtems/score/isr.h>
15#include <rtems/score/thread.h>
16#include <rtems/score/wkspace.h>
17#include <rtems/posix/cancel.h>
18#include <rtems/posix/pthread.h>
19#include <rtems/posix/threadsup.h>
20
21/*PAGE
22 *
23 *  18.2.2 Setting Cancelability State, P1003.1c/Draft 10, p. 183
24 */
25
26void pthread_testcancel( void )
27{
28  POSIX_API_Control                 *thread_support;
29
30  /*
31   *  Don't even think about deleting a resource from an ISR.
32   *  Besides this request is supposed to be for _Thread_Executing
33   *  and the ISR context is not a thread.
34   */
35
36  if ( _ISR_Is_in_progress() )
37    return;
38
39  thread_support = _Thread_Executing->API_Extensions[ THREAD_API_POSIX ];
40 
41  _Thread_Disable_dispatch();
42    if ( thread_support->cancelability_state == PTHREAD_CANCEL_ENABLE &&
43         thread_support->cancelation_requested )
44      _POSIX_Threads_cancel_run( _Thread_Executing );
45  _Thread_Enable_dispatch();
46}
Note: See TracBrowser for help on using the repository browser.