projects
/
pulseview.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
DecodeSignal: Allow muxed logic data to be cached
[pulseview.git]
/
pv
/
data
/
decodesignal.hpp
diff --git
a/pv/data/decodesignal.hpp
b/pv/data/decodesignal.hpp
index 747a16dcd16b9865e94fd70162a218eddd784f99..29e8441a83785ee62628959d4676791f90456b27 100644
(file)
--- a/
pv/data/decodesignal.hpp
+++ b/
pv/data/decodesignal.hpp
@@
-110,9
+110,9
@@
public:
* i.e. the number of samples where samples are available
* for all connected channels.
*/
* i.e. the number of samples where samples are available
* for all connected channels.
*/
- int64_t get_working_sample_count() const;
+ int64_t get_working_sample_count(
uint32_t segment_id
) const;
- int64_t get_decoded_sample_count() const;
+ int64_t get_decoded_sample_count(
uint32_t segment_id
) const;
vector<decode::Row> visible_rows() const;
vector<decode::Row> visible_rows() const;
@@
-148,10
+148,12
@@
private:
void connect_input_notifiers();
void connect_input_notifiers();
+ void create_new_annotation_segment();
static void annotation_callback(srd_proto_data *pdata, void *decode_signal);
Q_SIGNALS:
static void annotation_callback(srd_proto_data *pdata, void *decode_signal);
Q_SIGNALS:
- void new_annotations();
+ void new_annotations(); // TODO Supply segment for which they belong to
+ void decode_reset();
void decode_finished();
void channels_updated();
void decode_finished();
void channels_updated();
@@
-175,11
+177,17
@@
private:
double samplerate_;
int64_t samples_decoded_;
double samplerate_;
int64_t samples_decoded_;
+ uint32_t currently_processed_segment_;
vector< shared_ptr<decode::Decoder> > stack_;
vector< shared_ptr<decode::Decoder> > stack_;
- map<const decode::Row, decode::RowData> rows_;
map<pair<const srd_decoder*, int>, decode::Row> class_rows_;
map<pair<const srd_decoder*, int>, decode::Row> class_rows_;
+ /// Annotations for all segments
+ vector< map<const decode::Row, decode::RowData>> segmented_rows_;
+
+ /// Set of annotations for current segment
+ map<const decode::Row, decode::RowData> *current_rows_;
+
mutable mutex input_mutex_, output_mutex_, logic_mux_mutex_;
mutable condition_variable decode_input_cond_, logic_mux_cond_;
bool frame_complete_;
mutable mutex input_mutex_, output_mutex_, logic_mux_mutex_;
mutable condition_variable decode_input_cond_, logic_mux_cond_;
bool frame_complete_;