diff options
author | David Robillard <d@drobilla.net> | 2014-01-04 19:06:36 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2014-01-04 19:06:36 +0000 |
commit | aab0d5e9bfd13dea685614d03f420273678f8f60 (patch) | |
tree | 77ba5d538881cca74f37c2eeade25f2a0192ef89 /src/server/Engine.cpp | |
parent | 8b97f5537cffdeda2e3d45feddb2d229f3d82ca9 (diff) | |
download | ingen-aab0d5e9bfd13dea685614d03f420273678f8f60.tar.gz ingen-aab0d5e9bfd13dea685614d03f420273678f8f60.tar.bz2 ingen-aab0d5e9bfd13dea685614d03f420273678f8f60.zip |
More attempts at fixing deadlocks on exit.
git-svn-id: http://svn.drobilla.net/lad/trunk/ingen@5260 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/server/Engine.cpp')
-rw-r--r-- | src/server/Engine.cpp | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/src/server/Engine.cpp b/src/server/Engine.cpp index 922935c9..4c258d54 100644 --- a/src/server/Engine.cpp +++ b/src/server/Engine.cpp @@ -100,9 +100,10 @@ Engine::~Engine() // Process all pending events const FrameTime end = std::numeric_limits<FrameTime>::max(); _process_context.locate(_process_context.end(), end - _process_context.end()); + _post_processor->set_end_time(end); + _post_processor->process(); while (!_pre_processor->empty()) { - _post_processor->set_end_time(end); - _pre_processor->process(_process_context, *_post_processor, false); + _pre_processor->process(_process_context, *_post_processor, 1); _post_processor->process(); } @@ -356,15 +357,15 @@ Engine::pending_events() void Engine::enqueue_event(Event* ev) { - if (!_quit_flag) { - _pre_processor->event(ev); - } + _pre_processor->event(ev); } unsigned Engine::process_events() { - return _pre_processor->process(_process_context, *_post_processor); + const size_t MAX_EVENTS_PER_CYCLE = 4;//_process_context.nframes() / 4; + return _pre_processor->process( + _process_context, *_post_processor, MAX_EVENTS_PER_CYCLE); } void |