summaryrefslogtreecommitdiffstats
path: root/src/server/PreProcessor.cpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2014-01-04 19:06:36 +0000
committerDavid Robillard <d@drobilla.net>2014-01-04 19:06:36 +0000
commitaab0d5e9bfd13dea685614d03f420273678f8f60 (patch)
tree77ba5d538881cca74f37c2eeade25f2a0192ef89 /src/server/PreProcessor.cpp
parent8b97f5537cffdeda2e3d45feddb2d229f3d82ca9 (diff)
downloadingen-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/PreProcessor.cpp')
-rw-r--r--src/server/PreProcessor.cpp17
1 files changed, 7 insertions, 10 deletions
diff --git a/src/server/PreProcessor.cpp b/src/server/PreProcessor.cpp
index 83215bee..aa4f0b06 100644
--- a/src/server/PreProcessor.cpp
+++ b/src/server/PreProcessor.cpp
@@ -39,9 +39,11 @@ PreProcessor::PreProcessor()
PreProcessor::~PreProcessor()
{
- _exit_flag = true;
- _sem.post();
- _thread.join();
+ if (_thread.joinable()) {
+ _exit_flag = true;
+ _sem.post();
+ _thread.join();
+ }
}
void
@@ -71,18 +73,13 @@ PreProcessor::event(Event* const ev)
}
unsigned
-PreProcessor::process(ProcessContext& context, PostProcessor& dest, bool limit)
+PreProcessor::process(ProcessContext& context, PostProcessor& dest, size_t limit)
{
Event* const head = _head.load();
if (!head) {
return 0;
}
- /* Limit the maximum number of events to process each cycle to ensure the
- process callback is real-time safe. TODO: Parameterize this and/or
- figure out a good default value. */
- const size_t MAX_EVENTS_PER_CYCLE = context.nframes() / 4;
-
size_t n_processed = 0;
Event* ev = head;
Event* last = ev;
@@ -95,7 +92,7 @@ PreProcessor::process(ProcessContext& context, PostProcessor& dest, bool limit)
last = ev;
ev = ev->next();
++n_processed;
- if (limit && (n_processed > MAX_EVENTS_PER_CYCLE)) {
+ if (limit && n_processed >= limit) {
break;
}
}