diff options
author | Josh Blum | 2012-10-14 21:06:43 -0700 |
---|---|---|
committer | Josh Blum | 2012-10-14 21:06:43 -0700 |
commit | 5b924be64e1ada926c514058b97e3f7528c8ac7d (patch) | |
tree | 3b0a5076f53d11de1a11621508d5c3a90b9c6e22 /lib/block_task.cpp | |
parent | abc6715098cc5ca4d83d1227b2c9ca98e33b4a86 (diff) | |
download | sandhi-5b924be64e1ada926c514058b97e3f7528c8ac7d.tar.gz sandhi-5b924be64e1ada926c514058b97e3f7528c8ac7d.tar.bz2 sandhi-5b924be64e1ada926c514058b97e3f7528c8ac7d.zip |
added input fail logic to conditionally accumulate
Diffstat (limited to 'lib/block_task.cpp')
-rw-r--r-- | lib/block_task.cpp | 24 |
1 files changed, 17 insertions, 7 deletions
diff --git a/lib/block_task.cpp b/lib/block_task.cpp index 69e99a3..a291c01 100644 --- a/lib/block_task.cpp +++ b/lib/block_task.cpp @@ -73,6 +73,19 @@ void BlockActor::mark_done(void) << std::flush; } +GRAS_FORCE_INLINE void BlockActor::input_fail(const size_t i) +{ + //input failed, accumulate and try again + if (not this->input_queues.is_accumulated(i)) + { + this->input_queues.accumulate(i, this->input_items_sizes[i]); + this->Push(SelfKickMessage(), Theron::Address()); + return; + } + //otherwise check for done, else wait for more + if (this->inputs_done[i]) this->mark_done(); +} + void BlockActor::handle_task(void) { #ifdef WORK_DEBUG @@ -104,7 +117,7 @@ void BlockActor::handle_task(void) this->sort_tags(i); ASSERT(this->input_queues.ready(i)); - this->input_queues.accumulate(i, this->input_items_sizes[i]); + //this->input_queues.accumulate(i, this->input_items_sizes[i]); const SBuffer &buff = this->input_queues.front(i); void *mem = buff.get(); size_t items = buff.length/this->input_items_sizes[i]; @@ -119,8 +132,7 @@ void BlockActor::handle_task(void) { if (items <= this->input_configs[i].lookahead_items) { - if (this->inputs_done[i]) this->mark_done(); - return; + this->input_fail(i); return; } items -= this->input_configs[i].lookahead_items; } @@ -198,12 +210,10 @@ void BlockActor::handle_task(void) { if (fcast_ninput_items[i] <= work_ninput_items[i]) continue; + //handle the case of forecast failing if (work_noutput_items <= this->output_multiple_items) { - //handle the case of forecast failing - //TODO accumulate input here, only done if inputs done and already accumulated - if (this->inputs_done[i]) this->mark_done(); - return; + this->input_fail(i); return; } work_noutput_items = work_noutput_items/2; //backoff regime |