summaryrefslogtreecommitdiff
path: root/src/systemc/tests/systemc/kernel/dynamic_processes/sc_barrier/test01/test01.cpp
diff options
context:
space:
mode:
authorGabe Black <gabeblack@google.com>2018-05-24 01:37:55 -0700
committerGabe Black <gabeblack@google.com>2018-08-08 10:09:54 +0000
commit16fa8d7cc8c92f5ab879e4cf9c6c0bbb3567860f (patch)
tree7b6faaacb4574a555e561534aa4a8508c0624c32 /src/systemc/tests/systemc/kernel/dynamic_processes/sc_barrier/test01/test01.cpp
parent7235d3b5211d0ba8f528d930a4c1e7ad62eec51a (diff)
downloadgem5-16fa8d7cc8c92f5ab879e4cf9c6c0bbb3567860f.tar.xz
systemc: Import tests from the Accellera systemc distribution.
Change-Id: Iad76b398949a55d768a34d027a2d8e3739953da6 Reviewed-on: https://gem5-review.googlesource.com/10845 Reviewed-by: Giacomo Travaglini <giacomo.travaglini@arm.com> Maintainer: Gabe Black <gabeblack@google.com>
Diffstat (limited to 'src/systemc/tests/systemc/kernel/dynamic_processes/sc_barrier/test01/test01.cpp')
-rw-r--r--src/systemc/tests/systemc/kernel/dynamic_processes/sc_barrier/test01/test01.cpp47
1 files changed, 47 insertions, 0 deletions
diff --git a/src/systemc/tests/systemc/kernel/dynamic_processes/sc_barrier/test01/test01.cpp b/src/systemc/tests/systemc/kernel/dynamic_processes/sc_barrier/test01/test01.cpp
new file mode 100644
index 000000000..5b8c8a8fe
--- /dev/null
+++ b/src/systemc/tests/systemc/kernel/dynamic_processes/sc_barrier/test01/test01.cpp
@@ -0,0 +1,47 @@
+#include "systemc.h"
+#include "sc_barrier.h"
+using sc_dp::sc_barrier;
+
+SC_MODULE(X)
+{
+ SC_CTOR(X)
+ {
+ sc_thread_handle last_thread;
+
+ SC_THREAD(a);
+ SC_THREAD(b);
+ SC_THREAD(c);
+
+ m_barrier.initialize(3);
+ }
+ void a()
+ {
+ wait(5.0, SC_NS);
+ m_barrier.wait();
+ cout << sc_time_stamp() << " - a" << endl;
+ }
+ void b()
+ {
+ wait(11.0, SC_NS);
+ m_barrier.wait();
+ cout << sc_time_stamp() << " - b" << endl;
+ }
+ void c()
+ {
+ m_barrier.wait();
+ cout << sc_time_stamp() << " - c" << endl;
+ }
+ sc_barrier m_barrier;
+};
+
+int sc_main( int argc, char* argv[] )
+{
+ sc_clock clock;
+ X x("x");
+
+ sc_start(1000, SC_NS);
+
+ cerr << "Program completed" << endl;
+ return 0;
+}
+