X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fsession.cpp;h=22e0428d94abf26a5421c540377dc9e55c6ddccf;hp=56ac89975f65e97c47d4f28a2de96142b4f6316d;hb=e7216ae0a66fe1563514cbd3f67f2e240d010315;hpb=ff4bf6bd8141b9e7518b7bf431e45beff671e764 diff --git a/pv/session.cpp b/pv/session.cpp index 56ac8997..22e0428d 100644 --- a/pv/session.cpp +++ b/pv/session.cpp @@ -419,6 +419,8 @@ void Session::sample_thread_proc(shared_ptr device, cur_samplerate_ = device_->read_config(ConfigKey::SAMPLERATE); + out_of_memory_ = false; + try { device_->start(); } catch(Error e) { @@ -438,6 +440,9 @@ void Session::sample_thread_proc(shared_ptr device, qDebug("SR_DF_END was not received."); assert(0); } + + if (out_of_memory_) + error_handler(tr("Out of memory, acquisition stopped.")); } void Session::feed_in_header() @@ -590,11 +595,21 @@ void Session::data_feed_in(shared_ptr device, break; case SR_DF_LOGIC: - feed_in_logic(dynamic_pointer_cast(packet->payload())); + try { + feed_in_logic(dynamic_pointer_cast(packet->payload())); + } catch (std::bad_alloc) { + out_of_memory_ = true; + device_->stop(); + } break; case SR_DF_ANALOG: - feed_in_analog(dynamic_pointer_cast(packet->payload())); + try { + feed_in_analog(dynamic_pointer_cast(packet->payload())); + } catch (std::bad_alloc) { + out_of_memory_ = true; + device_->stop(); + } break; case SR_DF_END: