1
0
mirror of https://github.com/f4exb/sdrangel.git synced 2025-11-10 08:10:25 -05:00

221 lines
7.7 KiB
C
Raw Normal View History

2015-01-11 00:12:58 +00:00
///////////////////////////////////////////////////////////////////////////////////
// Copyright (C) 2012 maintech GmbH, Otto-Hahn-Str. 15, 97204 Hoechberg, Germany //
// (C) 2015 John Greb //
// (C) 2020 Edouard Griffiths, F4EXB //
2015-01-11 00:12:58 +00:00
// //
// This program is free software; you can redistribute it and/or modify //
// it under the terms of the GNU General Public License as published by //
// the Free Software Foundation as version 3 of the License, or //
2019-04-11 06:39:30 +02:00
// (at your option) any later version. //
2015-01-11 00:12:58 +00:00
// //
// This program is distributed in the hope that it will be useful, //
// but WITHOUT ANY WARRANTY; without even the implied warranty of //
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
// GNU General Public License V3 for more details. //
// //
// You should have received a copy of the GNU General Public License //
// along with this program. If not, see <http://www.gnu.org/licenses/>. //
///////////////////////////////////////////////////////////////////////////////////
2019-12-03 18:49:52 +01:00
#ifndef INCLUDE_LORADEMOD_H
#define INCLUDE_LORADEMOD_H
2015-01-11 00:12:58 +00:00
#include <vector>
2017-10-08 01:42:18 +02:00
#include "dsp/basebandsamplesink.h"
2019-05-09 17:27:12 +02:00
#include "channel/channelapi.h"
2015-01-11 00:12:58 +00:00
#include "util/message.h"
2019-12-03 18:49:52 +01:00
#include "lorademodbaseband.h"
#include "lorademoddecoder.h"
2015-01-11 19:30:48 +00:00
2019-05-08 22:11:53 +02:00
class DeviceAPI;
2019-12-03 18:49:52 +01:00
class QThread;
2017-10-08 01:42:18 +02:00
2019-05-09 17:27:12 +02:00
class LoRaDemod : public BasebandSampleSink, public ChannelAPI {
2015-01-11 00:12:58 +00:00
public:
2017-10-08 01:42:18 +02:00
class MsgConfigureLoRaDemod : public Message {
MESSAGE_CLASS_DECLARATION
public:
const LoRaDemodSettings& getSettings() const { return m_settings; }
bool getForce() const { return m_force; }
static MsgConfigureLoRaDemod* create(const LoRaDemodSettings& settings, bool force)
{
return new MsgConfigureLoRaDemod(settings, force);
}
private:
LoRaDemodSettings m_settings;
bool m_force;
MsgConfigureLoRaDemod(const LoRaDemodSettings& settings, bool force) :
Message(),
m_settings(settings),
m_force(force)
{ }
};
class MsgReportDecodeBytes : public Message {
MESSAGE_CLASS_DECLARATION
public:
const QByteArray& getBytes() const { return m_bytes; }
unsigned int getSyncWord() const { return m_syncWord; }
float getSingalDb() const { return m_signalDb; }
float getNoiseDb() const { return m_noiseDb; }
2020-02-19 09:26:42 +01:00
unsigned int getPacketSize() const { return m_packetSize; }
unsigned int getNbParityBits() const { return m_nbParityBits; }
bool getHasCRC() const { return m_hasCRC; }
bool getHeaderParityStatus() const { return m_headerParityStatus; }
bool getHeaderCRCStatus() const { return m_headerCRCStatus; }
bool getPayloadParityStatus() const { return m_payloadParityStatus; }
bool getPayloadCRCStatus() const { return m_payloadCRCStatus; }
static MsgReportDecodeBytes* create(const QByteArray& bytes) {
return new MsgReportDecodeBytes(bytes);
}
void setSyncWord(unsigned int syncWord) {
m_syncWord = syncWord;
}
void setSignalDb(float db) {
m_signalDb = db;
}
void setNoiseDb(float db) {
m_noiseDb = db;
}
2020-02-19 09:26:42 +01:00
void setPacketSize(unsigned int packetSize) {
m_packetSize = packetSize;
}
void setNbParityBits(unsigned int nbParityBits) {
m_nbParityBits = nbParityBits;
}
void setHasCRC(bool hasCRC) {
m_hasCRC = hasCRC;
}
void setHeaderParityStatus(bool headerParityStatus) {
m_headerParityStatus = headerParityStatus;
}
void setHeaderCRCStatus(bool headerCRCStatus) {
m_headerCRCStatus = headerCRCStatus;
}
void setPayloadParityStatus(bool payloadParityStatus) {
m_payloadParityStatus = payloadParityStatus;
}
void setPayloadCRCStatus(bool payloadCRCStatus) {
m_payloadCRCStatus = payloadCRCStatus;
}
private:
QByteArray m_bytes;
unsigned int m_syncWord;
float m_signalDb;
float m_noiseDb;
2020-02-19 09:26:42 +01:00
unsigned int m_packetSize;
unsigned int m_nbParityBits;
bool m_hasCRC;
bool m_headerParityStatus;
bool m_headerCRCStatus;
bool m_payloadParityStatus;
bool m_payloadCRCStatus;
MsgReportDecodeBytes(const QByteArray& bytes) :
Message(),
m_bytes(bytes),
m_syncWord(0),
m_signalDb(0.0),
2020-02-19 09:26:42 +01:00
m_noiseDb(0.0),
m_packetSize(0),
m_nbParityBits(0),
m_hasCRC(false),
m_headerParityStatus(false),
m_headerCRCStatus(false),
m_payloadParityStatus(false),
m_payloadCRCStatus(false)
{ }
};
class MsgReportDecodeString : public Message {
MESSAGE_CLASS_DECLARATION
public:
const QString& getString() const { return m_str; }
unsigned int getSyncWord() const { return m_syncWord; }
float getSingalDb() const { return m_signalDb; }
float getNoiseDb() const { return m_noiseDb; }
static MsgReportDecodeString* create(const QString& str)
{
return new MsgReportDecodeString(str);
}
void setSyncWord(unsigned int syncWord) {
m_syncWord = syncWord;
}
void setSignalDb(float db) {
m_signalDb = db;
}
void setNoiseDb(float db) {
m_noiseDb = db;
}
private:
QString m_str;
unsigned int m_syncWord;
float m_signalDb;
float m_noiseDb;
MsgReportDecodeString(const QString& str) :
Message(),
m_str(str),
m_syncWord(0),
m_signalDb(0.0),
m_noiseDb(0.0)
{ }
};
2019-05-08 22:11:53 +02:00
LoRaDemod(DeviceAPI* deviceAPI);
2015-08-17 08:29:34 +02:00
virtual ~LoRaDemod();
2017-12-17 23:15:42 +01:00
virtual void destroy() { delete this; }
2019-12-03 18:49:52 +01:00
void setSpectrumSink(BasebandSampleSink* sampleSink) { m_basebandSink->setSpectrumSink(sampleSink); }
2015-01-11 00:12:58 +00:00
virtual void feed(const SampleVector::const_iterator& begin, const SampleVector::const_iterator& end, bool pO);
2015-08-17 08:29:34 +02:00
virtual void start();
virtual void stop();
virtual bool handleMessage(const Message& cmd);
2015-01-11 00:12:58 +00:00
virtual void getIdentifier(QString& id) { id = objectName(); }
virtual void getTitle(QString& title) { title = m_settings.m_title; }
2017-12-17 23:15:42 +01:00
virtual qint64 getCenterFrequency() const { return 0; }
virtual QByteArray serialize() const;
virtual bool deserialize(const QByteArray& data);
2019-05-09 17:27:12 +02:00
virtual int getNbSinkStreams() const { return 1; }
virtual int getNbSourceStreams() const { return 0; }
virtual qint64 getStreamCenterFrequency(int streamIndex, bool sinkElseSource) const
{
(void) streamIndex;
(void) sinkElseSource;
return 0;
}
bool getDemodActive() const;
static const QString m_channelIdURI;
static const QString m_channelId;
2015-01-11 00:12:58 +00:00
private:
2019-05-08 22:11:53 +02:00
DeviceAPI *m_deviceAPI;
2019-12-03 18:49:52 +01:00
QThread *m_thread;
LoRaDemodBaseband* m_basebandSink;
LoRaDemodDecoder m_decoder;
2017-10-08 01:42:18 +02:00
LoRaDemodSettings m_settings;
int m_basebandSampleRate; //!< stored from device message used when starting baseband sink
2015-01-11 00:12:58 +00:00
2019-12-03 18:49:52 +01:00
void applySettings(const LoRaDemodSettings& settings, bool force = false);
2015-01-11 00:12:58 +00:00
};
2019-12-03 18:49:52 +01:00
#endif // INCLUDE_LORADEMOD_H