X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fsession.cpp;h=56ac89975f65e97c47d4f28a2de96142b4f6316d;hp=bbfb7d2437b1c3380d955e8ef3ce3301797a2882;hb=ff4bf6bd8141b9e7518b7bf431e45beff671e764;hpb=f32905530347e1020d5ce7959123cf797c9a4829 diff --git a/pv/session.cpp b/pv/session.cpp index bbfb7d24..56ac8997 100644 --- a/pv/session.cpp +++ b/pv/session.cpp @@ -180,8 +180,7 @@ void Session::start_capture(function error_handler) } // Clear signal data - const set< shared_ptr > signal_data = get_data(); - for (const shared_ptr d : signal_data) + for (const shared_ptr d : get_data()) d->clear(); // Begin the session @@ -472,6 +471,8 @@ void Session::feed_in_logic(shared_ptr logic) { lock_guard lock(data_mutex_); + const size_t sample_count = logic->data_length() / logic->unit_size(); + if (!logic_data_) { // The only reason logic_data_ would not have been created is @@ -485,14 +486,10 @@ void Session::feed_in_logic(shared_ptr logic) // This could be the first packet after a trigger set_capture_state(Running); - // Get sample limit. - const uint64_t sample_limit = device_->read_config( - ConfigKey::LIMIT_SAMPLES); - // Create a new data segment cur_logic_segment_ = shared_ptr( new data::LogicSegment( - logic, cur_samplerate_, sample_limit)); + logic, cur_samplerate_, sample_count)); logic_data_->push_segment(cur_logic_segment_); // @todo Putting this here means that only listeners querying @@ -536,26 +533,13 @@ void Session::feed_in_analog(shared_ptr analog) // in the sweep containing this segment. sweep_beginning = true; - // Get sample limit. - uint64_t sample_limit; - try { - assert(device_); - const std::shared_ptr device = - device_->device(); - assert(device); - sample_limit = VariantBase::cast_dynamic>( - device->config_get(ConfigKey::LIMIT_SAMPLES)).get(); - } catch (Error) { - sample_limit = 0; - } - // Create a segment, keep it in the maps of channels segment = shared_ptr( new data::AnalogSegment( - cur_samplerate_, sample_limit)); + cur_samplerate_, sample_count)); cur_analog_segments_[channel] = segment; - // Find the annalog data associated with the channel + // Find the analog data associated with the channel shared_ptr sig = dynamic_pointer_cast( signal_from_channel(channel));