From: Johnathan Corgan Date: Tue, 4 Aug 2009 17:22:15 +0000 (-0700) Subject: Notify derived class when post()ed X-Git-Url: https://git.gag.com/?a=commitdiff_plain;h=3d47afffbf216f5ab0fa036de2b70cdc7a1981da;p=debian%2Fgnuradio Notify derived class when post()ed --- diff --git a/gnuradio-core/src/lib/runtime/gr_msg_accepter.cc b/gnuradio-core/src/lib/runtime/gr_msg_accepter.cc index b07f447c..ebe11870 100644 --- a/gnuradio-core/src/lib/runtime/gr_msg_accepter.cc +++ b/gnuradio-core/src/lib/runtime/gr_msg_accepter.cc @@ -24,6 +24,8 @@ #endif #include +#include +#include using namespace pmt; @@ -40,5 +42,15 @@ gr_msg_accepter::~gr_msg_accepter() void gr_msg_accepter::post(pmt_t msg) { - d_msg_queue->insert_tail(msg); + // Let parent class do whatever it would have + gruel::msg_accepter_msgq::post(msg); + + // Notify this block's scheduler a message is pending + gr_block *p = dynamic_cast(this); + if (p) + p->detail()->d_tpb.notify_msg(); + else { + // got here somehow with a non-gr_block + throw std::runtime_error("gr_msg_accepter::post() - invalid derived class"); + } } diff --git a/gnuradio-core/src/lib/runtime/gr_tpb_detail.h b/gnuradio-core/src/lib/runtime/gr_tpb_detail.h index ab955240..29101d73 100644 --- a/gnuradio-core/src/lib/runtime/gr_tpb_detail.h +++ b/gnuradio-core/src/lib/runtime/gr_tpb_detail.h @@ -35,10 +35,10 @@ struct gr_tpb_detail { gruel::condition_variable input_cond; bool output_changed; gruel::condition_variable output_cond; + bool msg_pending; gr_tpb_detail() - : input_changed(false), output_changed(false) {} - + : input_changed(false), output_changed(false), msg_pending(false) { } //! Called by us to tell all our upstream blocks that their output may have changed. void notify_upstream(gr_block_detail *d); @@ -57,6 +57,15 @@ struct gr_tpb_detail { output_changed = false; } + //! Called to notify us that a message is pending in the queue + void notify_msg() + { + gruel::scoped_lock guard(mutex); + msg_pending = true; + input_cond.notify_one(); + output_cond.notify_one(); + } + private: //! Used by notify_downstream @@ -74,7 +83,6 @@ private: output_changed = true; output_cond.notify_one(); } - }; #endif /* INCLUDED_GR_TPB_DETAIL_H */