summaryrefslogtreecommitdiff
path: root/libs/ardour/midi_source.cc
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2014-12-28 15:14:47 -0500
committerDavid Robillard <d@drobilla.net>2014-12-28 16:06:44 -0500
commitec947ff8fd2cf229284f757b8bd6b0f96cbd6383 (patch)
tree4e75e57f37e3b3539abb12908e6fc50e078c7e6e /libs/ardour/midi_source.cc
parentdbc2f59453af4d22532360393c0fa858d257f5a6 (diff)
Fix occasional MIDI read crash.
Locking should prevent this from being a problem, but taking a reference to the cached iterator and mutating it directly causes occasional crashes for me for reasons I can't quite figure out. This fixes the issue and is arguably more sane anyway, so whatever.
Diffstat (limited to 'libs/ardour/midi_source.cc')
-rw-r--r--libs/ardour/midi_source.cc7
1 files changed, 4 insertions, 3 deletions
diff --git a/libs/ardour/midi_source.cc b/libs/ardour/midi_source.cc
index 1b1cf20c68..c63a262a53 100644
--- a/libs/ardour/midi_source.cc
+++ b/libs/ardour/midi_source.cc
@@ -200,11 +200,10 @@ MidiSource::midi_read (const Lock& lm,
if (_model) {
// Find appropriate model iterator
- Evoral::Sequence<Evoral::MusicalTime>::const_iterator& i = _model_iter;
+ Evoral::Sequence<Evoral::MusicalTime>::const_iterator i = _model_iter;
if (_last_read_end == 0 || start != _last_read_end || !_model_iter_valid) {
// Cached iterator is invalid, search for the first event past start
- i = _model->begin(converter.from(start), false, filtered);
- _model_iter_valid = true;
+ i = _model->begin(converter.from(start), false, filtered);
}
_last_read_end = start + cnt;
@@ -230,6 +229,8 @@ MidiSource::midi_read (const Lock& lm,
break;
}
}
+ _model_iter = i;
+ _model_iter_valid = true;
return cnt;
} else {
return read_unlocked (lm, dst, source_start, start, cnt, tracker);