From f3e2e07201c50033bf6c9d0c6a6f068557b4f17f Mon Sep 17 00:00:00 2001
From: Tom Rondeau <trondeau@vt.edu>
Date: Wed, 17 Apr 2013 13:43:52 -0400
Subject: runtime: converting runtime core to gr namespace, gnuradio include
 dir.

---
 gnuradio-runtime/lib/scheduler_sts.cc | 90 +++++++++++++++++++++++++++++++++++
 1 file changed, 90 insertions(+)
 create mode 100644 gnuradio-runtime/lib/scheduler_sts.cc

(limited to 'gnuradio-runtime/lib/scheduler_sts.cc')

diff --git a/gnuradio-runtime/lib/scheduler_sts.cc b/gnuradio-runtime/lib/scheduler_sts.cc
new file mode 100644
index 0000000000..cc60b55f02
--- /dev/null
+++ b/gnuradio-runtime/lib/scheduler_sts.cc
@@ -0,0 +1,90 @@
+/* -*- c++ -*- */
+/*
+ * Copyright 2008,2013 Free Software Foundation, Inc.
+ *
+ * This file is part of GNU Radio
+ *
+ * GNU Radio is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3, or (at your option)
+ * any later version.
+ *
+ * GNU Radio is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include "scheduler_sts.h"
+#include <gnuradio/single_threaded_scheduler.h>
+#include <gnuradio/thread/thread_body_wrapper.h>
+
+namespace gr {
+
+  class sts_container
+  {
+    block_vector_t d_blocks;
+
+  public:
+    sts_container(block_vector_t blocks)
+      : d_blocks(blocks) {}
+
+    void operator()()
+    {
+      make_single_threaded_scheduler(d_blocks)->run();
+    }
+  };
+
+  scheduler_sptr
+  scheduler_sts::make(flat_flowgraph_sptr ffg, int max_noutput_items)
+  {
+    return scheduler_sptr(new scheduler_sts(ffg, max_noutput_items));
+  }
+
+  scheduler_sts::scheduler_sts(flat_flowgraph_sptr ffg, int max_noutput_items)
+    : scheduler(ffg, max_noutput_items)
+  {
+    // Split the flattened flow graph into discrete partitions, each
+    // of which is topologically sorted.
+
+    std::vector<basic_block_vector_t> graphs = ffg->partition();
+
+    // For each partition, create a thread to evaluate it using
+    // an instance of the gr_single_threaded_scheduler
+
+    for(std::vector<basic_block_vector_t>::iterator p = graphs.begin();
+        p != graphs.end(); p++) {
+
+      block_vector_t blocks = flat_flowgraph::make_block_vector(*p);
+      d_threads.create_thread(
+        gr::thread::thread_body_wrapper<sts_container>(sts_container(blocks),
+						  "single-threaded-scheduler"));
+    }
+  }
+
+  scheduler_sts::~scheduler_sts()
+  {
+    stop();
+  }
+
+  void
+  scheduler_sts::stop()
+  {
+    d_threads.interrupt_all();
+  }
+
+  void
+  scheduler_sts::wait()
+  {
+    d_threads.join_all();
+  }
+
+} /* namespace gr */
-- 
cgit v1.2.3