sc_join.hh (12943:12c1004709d4) sc_join.hh (13196:4b5ab2c22743)
1/*
2 * Copyright 2018 Google, Inc.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met: redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer;
8 * redistributions in binary form must reproduce the above copyright

--- 16 unchanged lines hidden (view full) ---

25 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 *
27 * Authors: Gabe Black
28 */
29
30#ifndef __SYSTEMC_EXT_CORE_SC_JOIN_HH__
31#define __SYSTEMC_EXT_CORE_SC_JOIN_HH__
32
1/*
2 * Copyright 2018 Google, Inc.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met: redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer;
8 * redistributions in binary form must reproduce the above copyright

--- 16 unchanged lines hidden (view full) ---

25 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 *
27 * Authors: Gabe Black
28 */
29
30#ifndef __SYSTEMC_EXT_CORE_SC_JOIN_HH__
31#define __SYSTEMC_EXT_CORE_SC_JOIN_HH__
32
33#include "sc_event.hh"
33#include "sc_process_handle.hh"
34
35namespace sc_core
36{
37
38// Nonstandard
39typedef sc_process_b *sc_thread_handle;
40
41// Nonstandard
42class sc_join
43{
44 public:
45 sc_join();
34#include "sc_process_handle.hh"
35
36namespace sc_core
37{
38
39// Nonstandard
40typedef sc_process_b *sc_thread_handle;
41
42// Nonstandard
43class sc_join
44{
45 public:
46 sc_join();
47
46 void add_process(sc_process_handle);
47 int process_count();
48 void add_process(sc_process_handle);
49 int process_count();
48 virtual void signal(sc_thread_handle thread_p, int type);
50 void signal();
49 void wait();
50 void wait_clocked();
51 void wait();
52 void wait_clocked();
53
54 private:
55 sc_event joinEvent;
56 int remaining;
51};
52
53} // namespace sc_core
54
55#endif //__SYSTEMC_EXT_CORE_SC_JOIN_HH__
57};
58
59} // namespace sc_core
60
61#endif //__SYSTEMC_EXT_CORE_SC_JOIN_HH__