X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fsession.cpp;h=a44ceb99b669aec396c97d92c19c733a6f489698;hp=b022bd02c0c02681bd576a06fff085b89f27e0c8;hb=00c518d66a61f28609b0eeddd0ce375d0002da94;hpb=f5a5b019c5679dbe6b4bc6f956c3820f47869bc1 diff --git a/pv/session.cpp b/pv/session.cpp index b022bd02..a44ceb99 100644 --- a/pv/session.cpp +++ b/pv/session.cpp @@ -91,6 +91,9 @@ using sigrok::Session; using Glib::VariantBase; namespace pv { + +shared_ptr Session::sr_context; + Session::Session(DeviceManager &device_manager, QString name) : device_manager_(device_manager), default_name_(name), @@ -316,9 +319,9 @@ void Session::restore_settings(QSettings &settings) int decode_signals = settings.value("decode_signals").toInt(); for (int i = 0; i < decode_signals; i++) { - settings.beginGroup("decode_signal" + QString::number(i++)); - // TODO Split up add_decoder() into add_decode_signal() and add_decoder(), - // then call add_decode_signal() and signal->restore_settings() here + settings.beginGroup("decode_signal" + QString::number(i)); + shared_ptr signal = add_decode_signal(); + signal->restore_settings(settings); settings.endGroup(); } #endif @@ -619,8 +622,6 @@ void Session::register_view(shared_ptr view) switch (signalbase->type()) { case data::SignalBase::AnalogChannel: case data::SignalBase::LogicChannel: - case data::SignalBase::A2LChannel: - break; case data::SignalBase::DecodeChannel: #ifdef ENABLE_DECODE trace_view->add_decode_signal( @@ -676,37 +677,44 @@ double Session::get_samplerate() const return samplerate; } +int Session::get_segment_count() const +{ + int min_val = INT_MAX; + + for (shared_ptr data : all_signal_data_) + if (data->get_segment_count() < min_val) + min_val = data->get_segment_count(); + + return min_val; +} + const unordered_set< shared_ptr > Session::signalbases() const { return signalbases_; } #ifdef ENABLE_DECODE -bool Session::add_decoder(srd_decoder *const dec) +shared_ptr Session::add_decode_signal() { - if (!dec) - return false; + shared_ptr signal; try { // Create the decode signal - shared_ptr signal = - make_shared(*this); + signal = make_shared(*this); signalbases_.insert(signal); // Add the decode signal to all views for (shared_ptr view : views_) view->add_decode_signal(signal); - - // Add decoder - signal->stack_decoder(dec); } catch (runtime_error e) { - return false; + remove_decode_signal(signal); + return nullptr; } signals_changed(); - return true; + return signal; } void Session::remove_decode_signal(shared_ptr signal) @@ -993,10 +1001,26 @@ void Session::feed_in_trigger() void Session::feed_in_frame_begin() { + frame_began_ = true; + if (cur_logic_segment_ || !cur_analog_segments_.empty()) frame_began(); } +void Session::feed_in_frame_end() +{ + { + lock_guard lock(data_mutex_); + cur_logic_segment_.reset(); + cur_analog_segments_.clear(); + } + + if (frame_began_) { + frame_began_ = false; + frame_ended(); + } +} + void Session::feed_in_logic(shared_ptr logic) { lock_guard lock(data_mutex_); @@ -1093,8 +1117,6 @@ void Session::feed_in_analog(shared_ptr analog) void Session::data_feed_in(shared_ptr device, shared_ptr packet) { - static bool frame_began = false; - (void)device; assert(device); @@ -1114,11 +1136,6 @@ void Session::data_feed_in(shared_ptr device, feed_in_trigger(); break; - case SR_DF_FRAME_BEGIN: - feed_in_frame_begin(); - frame_began = true; - break; - case SR_DF_LOGIC: try { feed_in_logic(dynamic_pointer_cast(packet->payload())); @@ -1137,20 +1154,25 @@ void Session::data_feed_in(shared_ptr device, } break; + case SR_DF_FRAME_BEGIN: + feed_in_frame_begin(); + break; + case SR_DF_FRAME_END: + feed_in_frame_end(); + break; + case SR_DF_END: - { + // Strictly speaking, this is performed when a frame end marker was + // received, so there's no point doing this again. However, not all + // devices use frames, and for those devices, we need to do it here. { lock_guard lock(data_mutex_); cur_logic_segment_.reset(); cur_analog_segments_.clear(); } - if (frame_began) { - frame_began = false; - frame_ended(); - } break; - } + default: break; }