Rename CMK_TLS_THREAD to the more descriptive CMK_HAS_TLS_VARIABLES
[charm.git] / src / QuickThreads / stp.h
1 /*****************************************************************************
2  * $Source$
3  * $Author$
4  * $Date$
5  * $Revision$
6  *****************************************************************************/
7
8 #ifndef STP_H
9 #define STP_H
10
11 /*
12  * QuickThreads -- Threads-building toolkit.
13  * Copyright (c) 1993 by David Keppel
14  *
15  * Permission to use, copy, modify and distribute this software and
16  * its documentation for any purpose and without fee is hereby
17  * granted, provided that the above copyright notice and this notice
18  * appear in all copies.  This software is provided as a
19  * proof-of-concept and for demonstration purposes; there is no
20  * representation about the suitability of this software for any
21  * purpose.
22  */
23
24 typedef struct stp_t stp_t;
25
26 /* Each thread starts by calling a user-supplied function of this
27    type. */
28
29 typedef void (stp_userf_t)(void *p0);
30
31 /* Call this before any other primitives. */
32 extern void stp_init();
33
34 /* When one or more threads are created by the main thread,
35    the system goes multithread when this is called.  It is done
36    (no more runable threads) when this returns. */
37
38 extern void stp_start (void);
39
40 /* Create a thread and make it runable.  When the thread starts
41    running it will call `f' with arguments `p0' and `p1'. */
42
43 extern void stp_create (stp_userf_t *f, void *p0);
44
45 /* The current thread stops running but stays runable.
46    It is an error to call `stp_yield' before `stp_start'
47    is called or after `stp_start' returns. */
48
49 extern void stp_yield (void);
50
51 /* Like `stp_yield' but the thread is discarded.  Any intermediate
52    state is lost.  The thread can also terminate by simply
53    returning. */
54
55 extern void stp_abort (void);
56
57
58 #endif /* ndef STP_H */