stp.h 1.5 KB

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