#include "signaldata.h"
+#include <atomic>
+#include <condition_variable>
#include <list>
+#include <map>
+#include <memory>
+#include <thread>
-#include <boost/shared_ptr.hpp>
-#include <boost/thread.hpp>
+#include <boost/optional.hpp>
#include <QObject>
#include <QString>
struct srd_decoder;
struct srd_decoder_annotation_row;
-struct srd_probe;
+struct srd_channel;
struct srd_proto_data;
+struct srd_session;
namespace DecoderStackTest {
-class TwoDecoderStack;
+struct TwoDecoderStack;
}
namespace pv {
namespace data {
+class LogicSnapshot;
+
namespace decode {
class Annotation;
class Decoder;
static const double DecodeMargin;
static const double DecodeThreshold;
static const int64_t DecodeChunkLength;
+ static const unsigned int DecodeNotifyPeriod;
public:
DecoderStack(pv::SigSession &_session,
virtual ~DecoderStack();
- const std::list< boost::shared_ptr<decode::Decoder> >& stack() const;
- void push(boost::shared_ptr<decode::Decoder> decoder);
+ const std::list< std::shared_ptr<decode::Decoder> >& stack() const;
+ void push(std::shared_ptr<decode::Decoder> decoder);
void remove(int index);
int64_t samples_decoded() const;
void begin_decode();
private:
- void decode_proc(boost::shared_ptr<data::Logic> data);
+ boost::optional<int64_t> wait_for_data() const;
+
+ void decode_data(const int64_t sample_count,
+ const unsigned int unit_size, srd_session *const session);
+
+ void decode_proc();
static void annotation_callback(srd_proto_data *pdata,
void *decoder);
-private slots:
+private Q_SLOTS:
void on_new_frame();
-signals:
+ void on_data_received();
+
+ void on_frame_ended();
+
+Q_SIGNALS:
void new_decode_data();
private:
* @todo A proper solution should be implemented to allow multiple
* decode operations.
*/
- static boost::mutex _global_decode_mutex;
+ static std::mutex _global_decode_mutex;
+
+ std::list< std::shared_ptr<decode::Decoder> > _stack;
+
+ std::shared_ptr<pv::data::LogicSnapshot> _snapshot;
- std::list< boost::shared_ptr<decode::Decoder> > _stack;
+ mutable std::mutex _input_mutex;
+ mutable std::condition_variable _input_cond;
+ int64_t _sample_count;
+ bool _frame_complete;
- mutable boost::mutex _mutex;
+ mutable std::mutex _output_mutex;
int64_t _samples_decoded;
std::map<const decode::Row, decode::RowData> _rows;
QString _error_message;
- boost::thread _decode_thread;
+ std::thread _decode_thread;
+ std::atomic<bool> _interrupt;
- friend class DecoderStackTest::TwoDecoderStack;
+ friend struct DecoderStackTest::TwoDecoderStack;
};
} // namespace data