summaryrefslogtreecommitdiff
path: root/mblock/src/lib/mb_runtime_thread_per_block.h
blob: 74ed6073a41b5793579535caa333f58f6cdf9c92 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/* -*- c++ -*- */
/*
 * Copyright 2007,2009 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.
 */
#ifndef INCLUDED_MB_RUNTIME_THREAD_PER_BLOCK_H
#define INCLUDED_MB_RUNTIME_THREAD_PER_BLOCK_H

#include <mb_runtime_base.h>
#include <mb_worker.h>
#include <mblock/msg_queue.h>
#include <mb_timer_queue.h>

/*!
 * \brief Concrete runtime that uses a thread per mblock
 * \internal
 *
 * These are all implementation details.
 */
class mb_runtime_thread_per_block : public mb_runtime_base
{
public:
  omni_mutex		      d_workers_mutex;	// hold while manipulating d_workers
  std::vector<mb_worker*>     d_workers;
  bool			      d_shutdown_in_progress;
  pmt::pmt_t		      d_shutdown_result;
  mb_msg_queue		      d_msgq;
  mb_timer_queue	      d_timer_queue;

  typedef std::vector<mb_worker*>::iterator  worker_iter_t;

  mb_runtime_thread_per_block();
  ~mb_runtime_thread_per_block();

  bool run(const std::string &instance_name,
	   const std::string &class_name,
	   pmt::pmt_t user_arg,
	   pmt::pmt_t *result);

  void request_shutdown(pmt::pmt_t result);

protected:
  mb_mblock_sptr
  create_component(const std::string &instance_name,
		   const std::string &class_name,
		   pmt::pmt_t user_arg);

  pmt::pmt_t
  schedule_one_shot_timeout(const mb_time &abs_time, pmt::pmt_t user_data,
			    mb_msg_accepter_sptr accepter);

  pmt::pmt_t
  schedule_periodic_timeout(const mb_time &first_abs_time,
			    const mb_time &delta_time,
			    pmt::pmt_t user_data,
			    mb_msg_accepter_sptr accepter);
  void
  cancel_timeout(pmt::pmt_t handle);

private:
  void reap_dead_workers();
  void run_loop();

  void send_all_sys_msg(pmt::pmt_t signal, pmt::pmt_t data = pmt::PMT_F,
			pmt::pmt_t metadata = pmt::PMT_F,
			mb_pri_t priority = MB_PRI_BEST);
};

#endif /* INCLUDED_MB_RUNTIME_THREAD_PER_BLOCK_H */