From: Soeren Apel Date: Thu, 16 Mar 2017 20:40:33 +0000 (+0100) Subject: LogicSegment: Make constructor and append_payload() more generic X-Git-Tag: pulseview-0.4.0~138 X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=commitdiff_plain;h=9d22929c3588b994771e8db8f3be5b013fd35040;ds=sidebyside LogicSegment: Make constructor and append_payload() more generic --- diff --git a/pv/data/logicsegment.cpp b/pv/data/logicsegment.cpp index 6350682f..fcf57229 100644 --- a/pv/data/logicsegment.cpp +++ b/pv/data/logicsegment.cpp @@ -58,6 +58,15 @@ LogicSegment::LogicSegment(pv::data::Logic& owner, shared_ptr dat append_payload(data); } +LogicSegment::LogicSegment(pv::data::Logic& owner, unsigned int unit_size, + uint64_t samplerate) : + Segment(samplerate, unit_size), + owner_(owner), + last_append_sample_(0) +{ + memset(mip_map_, 0, sizeof(mip_map_)); +} + LogicSegment::~LogicSegment() { lock_guard lock(mutex_); @@ -144,12 +153,19 @@ void LogicSegment::append_payload(shared_ptr logic) assert(unit_size_ == logic->unit_size()); assert((logic->data_length() % unit_size_) == 0); + append_payload(logic->data_pointer(), logic->data_length()); +} + +void LogicSegment::append_payload(void *data, uint64_t data_size) +{ + assert((data_size % unit_size_) == 0); + lock_guard lock(mutex_); uint64_t prev_sample_count = sample_count_; - uint64_t sample_count = logic->data_length() / unit_size_; + uint64_t sample_count = data_size / unit_size_; - append_samples(logic->data_pointer(), sample_count); + append_samples(data, sample_count); // Generate the first mip-map from the data append_payload_to_mipmap(); diff --git a/pv/data/logicsegment.hpp b/pv/data/logicsegment.hpp index b8e41835..c7971726 100644 --- a/pv/data/logicsegment.hpp +++ b/pv/data/logicsegment.hpp @@ -78,10 +78,12 @@ public: public: LogicSegment(pv::data::Logic& owner, shared_ptr data, uint64_t samplerate); + LogicSegment(pv::data::Logic& owner, unsigned int unit_size, uint64_t samplerate); virtual ~LogicSegment(); void append_payload(shared_ptr logic); + void append_payload(void *data, uint64_t data_size); const uint8_t* get_samples(int64_t start_sample, int64_t end_sample) const;