[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Commit-gnuradio] [gnuradio] 04/15: runtime: addresses issue #713.
From: |
git |
Subject: |
[Commit-gnuradio] [gnuradio] 04/15: runtime: addresses issue #713. |
Date: |
Wed, 10 Feb 2016 15:44:47 +0000 (UTC) |
This is an automated email from the git hooks/post-receive script.
jcorgan pushed a commit to branch master
in repository gnuradio.
commit cf95377ae162c6145e954d7c29c9814e6465f9fc
Author: Tom Rondeau <address@hidden>
Date: Wed Jan 27 06:46:16 2016 -0500
runtime: addresses issue #713.
When disconnecting and reconnecting, buffers can change and new
buffers will have their item counters zeroed out. Buffers held over
will keep their current item counters at some value >> 0. In the case
of the pfb_arb_resampler of issue #713, the rate update in the
scheduler was getting confusing numbers and setting the rates to
ridiculous values. Also, tags emitted from these new blocks will have
offsets meaningless to the other blocks that held on to their buffers.
This patch tells the scheduler to reset all buffer item counters (read
and write) to 0 when connections are merged and also makes sure all
tags are cleared from each block's input buffers. So upon a
lock/unlock and reset event, all buffers' counters and tag containers
are reset/cleared.
---
gnuradio-runtime/include/gnuradio/block_detail.h | 7 +++++++
gnuradio-runtime/include/gnuradio/buffer.h | 4 ++++
gnuradio-runtime/lib/block_detail.cc | 20 ++++++++++++++++++++
gnuradio-runtime/lib/flat_flowgraph.cc | 6 +++++-
4 files changed, 36 insertions(+), 1 deletion(-)
diff --git a/gnuradio-runtime/include/gnuradio/block_detail.h
b/gnuradio-runtime/include/gnuradio/block_detail.h
index 916c0a4..a71030b 100644
--- a/gnuradio-runtime/include/gnuradio/block_detail.h
+++ b/gnuradio-runtime/include/gnuradio/block_detail.h
@@ -100,6 +100,13 @@ namespace gr {
// Return the number of items written on output stream which_output
uint64_t nitems_written(unsigned int which_output);
+ // sets nitems_read and nitems_written to 0 for all input/output
+ // buffers.
+ void reset_nitem_counters();
+
+ // Clears all tags from the input buffers.
+ void clear_tags();
+
/*!
* \brief Adds a new tag to the given output stream.
*
diff --git a/gnuradio-runtime/include/gnuradio/buffer.h
b/gnuradio-runtime/include/gnuradio/buffer.h
index 5da383d..914661b 100644
--- a/gnuradio-runtime/include/gnuradio/buffer.h
+++ b/gnuradio-runtime/include/gnuradio/buffer.h
@@ -100,6 +100,8 @@ namespace gr {
uint64_t nitems_written() { return d_abs_write_offset; }
+ void reset_nitem_counter() { d_abs_write_offset = 0; }
+
size_t get_sizeof_item() { return d_sizeof_item; }
/*!
@@ -288,6 +290,8 @@ namespace gr {
uint64_t nitems_read() { return d_abs_read_offset; }
+ void reset_nitem_counter() { d_abs_read_offset = 0; }
+
size_t get_sizeof_item() { return d_buffer->get_sizeof_item(); }
/*!
diff --git a/gnuradio-runtime/lib/block_detail.cc
b/gnuradio-runtime/lib/block_detail.cc
index 9463e8d..484d849 100644
--- a/gnuradio-runtime/lib/block_detail.cc
+++ b/gnuradio-runtime/lib/block_detail.cc
@@ -162,6 +162,26 @@ namespace gr {
}
void
+ block_detail::reset_nitem_counters()
+ {
+ for(unsigned int i = 0; i < d_ninputs; i++) {
+ d_input[i]->reset_nitem_counter();
+ }
+ for(unsigned int o = 0; o < d_noutputs; o++) {
+ d_output[o]->reset_nitem_counter();
+ }
+ }
+
+ void
+ block_detail::clear_tags()
+ {
+ for(unsigned int i = 0; i < d_ninputs; i++) {
+ uint64_t max_time = 0xFFFFFFFFFFFFFFFF; // from now to the end of time
+ d_input[i]->buffer()->prune_tags(max_time);
+ }
+ }
+
+ void
block_detail::add_item_tag(unsigned int which_output, const tag_t &tag)
{
if(!pmt::is_symbol(tag.key)) {
diff --git a/gnuradio-runtime/lib/flat_flowgraph.cc
b/gnuradio-runtime/lib/flat_flowgraph.cc
index 4799433..1e9a682 100644
--- a/gnuradio-runtime/lib/flat_flowgraph.cc
+++ b/gnuradio-runtime/lib/flat_flowgraph.cc
@@ -225,9 +225,10 @@ namespace gr {
std::cout << "merge: allocating new detail for block " << (*p) <<
std::endl;
block->set_detail(allocate_block_detail(block));
}
- else
+ else {
if(FLAT_FLOWGRAPH_DEBUG)
std::cout << "merge: reusing original detail for block " << (*p) <<
std::endl;
+ }
}
// Calculate the old edges that will be going away, and clear the
@@ -311,6 +312,9 @@ namespace gr {
// Now deal with the fact that the block details might have
// changed numbers of inputs and outputs vs. in the old
// flowgraph.
+
+ block->detail()->reset_nitem_counters();
+ block->detail()->clear_tags();
}
}
- [Commit-gnuradio] [gnuradio] 03/15: blocks: adding QA code to test max_noutput_items., (continued)
- [Commit-gnuradio] [gnuradio] 03/15: blocks: adding QA code to test max_noutput_items., git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 07/15: grc: user-selectable transparent bg screen shots, git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 05/15: grc: #fff as canvas bg color, git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 13/15: Merge remote-tracking branch 'tom/issue713', git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 09/15: Merge branch 'maint_grcwg' into docstring_gui_fixes, git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 12/15: Merge remote-tracking branch 'gnuradio-wg-grc/master_grcwg', git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 14/15: Merge remote-tracking branch 'tom/set_max_noutput_items', git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 08/15: grc: remove [] around categories in the block library, git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 06/15: grc: optional transparent bg in screen shots, git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 02/15: filter: Uses last commit to make a better fix for issue #882., git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 04/15: runtime: addresses issue #713.,
git <=
- [Commit-gnuradio] [gnuradio] 01/15: runtime: always set max_noutput_items., git, 2016/02/10
- [Commit-gnuradio] [gnuradio] 10/15: grc: nicer block documentation tooltip and properties dialog tab, git, 2016/02/10