summaryrefslogtreecommitdiffstats
path: root/src/libs/engine/OSCEngineReceiver.cpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2007-10-05 19:41:24 +0000
committerDavid Robillard <d@drobilla.net>2007-10-05 19:41:24 +0000
commit9fe19152570b6388fc518bda6ccd422d14cff37a (patch)
treea29a7632dc3b43f439a558907b150a5a85740746 /src/libs/engine/OSCEngineReceiver.cpp
parent9d8f4248b0686b165c6ad0a4f6d653f4bf9cae3b (diff)
downloadingen-9fe19152570b6388fc518bda6ccd422d14cff37a.tar.gz
ingen-9fe19152570b6388fc518bda6ccd422d14cff37a.tar.bz2
ingen-9fe19152570b6388fc518bda6ccd422d14cff37a.zip
Fix OSC receiving thread chewing CPU (xrun problem on single core systems).
git-svn-id: http://svn.drobilla.net/lad/ingen@827 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/libs/engine/OSCEngineReceiver.cpp')
-rw-r--r--src/libs/engine/OSCEngineReceiver.cpp23
1 files changed, 12 insertions, 11 deletions
diff --git a/src/libs/engine/OSCEngineReceiver.cpp b/src/libs/engine/OSCEngineReceiver.cpp
index 3fb9e189..1c59a437 100644
--- a/src/libs/engine/OSCEngineReceiver.cpp
+++ b/src/libs/engine/OSCEngineReceiver.cpp
@@ -48,6 +48,8 @@ OSCEngineReceiver::OSCEngineReceiver(Engine& engine, size_t queue_size, uint16_t
: QueuedEngineInterface(engine, queue_size, queue_size) // FIXME
, _server(NULL)
{
+ _receive_thread = new ReceiveThread(*this);
+
char port_str[6];
snprintf(port_str, 6, "%u", port);
@@ -131,6 +133,8 @@ OSCEngineReceiver::~OSCEngineReceiver()
{
deactivate();
stop();
+ _receive_thread->stop();
+ delete _receive_thread;
if (_server != NULL) {
lo_server_free(_server);
@@ -143,7 +147,8 @@ void
OSCEngineReceiver::activate()
{
QueuedEventSource::activate();
- set_scheduling(SCHED_FIFO, 10);
+ set_scheduling(SCHED_FIFO, 5); // Jack default appears to be 10
+ _receive_thread->start();
}
@@ -159,30 +164,26 @@ OSCEngineReceiver::deactivate()
* to wait on OSC messages and prepare them right away in the same thread.
*/
void
-OSCEngineReceiver::_run()
+OSCEngineReceiver::ReceiveThread::_run()
{
/* get a timestamp here and stamp all the events with the same time so
* they all get executed in the same cycle */
while (true) {
- assert(_server);
+ assert(_receiver._server);
/*if ( ! _server) {
cout << "[OSCEngineReceiver] Server is NULL, exiting" << endl;
break;
}*/
- assert( ! unprepared_events());
-
// Wait on a message and enqueue it
- lo_server_recv(_server);
+ lo_server_recv(_receiver._server);
// Enqueue every other message that is here "now"
// (would this provide truly atomic bundles?)
- while (lo_server_recv_noblock(_server, 0) > 0) ;
-
- // Process them all
- while (unprepared_events())
- _whipped(); // Whip our slave self
+ while (lo_server_recv_noblock(_receiver._server, 0) > 0)
+ if (_receiver.unprepared_events())
+ _receiver.whip();
// No more unprepared events
}