mirror of
https://github.com/f4exb/sdrangel.git
synced 2024-12-24 19:00:36 -05:00
SDRdaemmon: channel source: allow passing of data address and port at startup
This commit is contained in:
parent
b07277a5e2
commit
5013e77f24
@ -44,9 +44,7 @@ SDRDaemonChannelSource::SDRDaemonChannelSource(DeviceSinkAPI *deviceAPI) :
|
|||||||
m_deviceAPI(deviceAPI),
|
m_deviceAPI(deviceAPI),
|
||||||
m_sourceThread(0),
|
m_sourceThread(0),
|
||||||
m_running(false),
|
m_running(false),
|
||||||
m_samplesCount(0),
|
m_samplesCount(0)
|
||||||
m_dataAddress("127.0.0.1"),
|
|
||||||
m_dataPort(9090)
|
|
||||||
{
|
{
|
||||||
setObjectName(m_channelId);
|
setObjectName(m_channelId);
|
||||||
|
|
||||||
@ -84,7 +82,7 @@ void SDRDaemonChannelSource::start()
|
|||||||
|
|
||||||
m_sourceThread = new SDRDaemonChannelSourceThread(&m_dataQueue);
|
m_sourceThread = new SDRDaemonChannelSourceThread(&m_dataQueue);
|
||||||
m_sourceThread->startStop(true);
|
m_sourceThread->startStop(true);
|
||||||
m_sourceThread->dataBind(m_dataAddress, m_dataPort);
|
m_sourceThread->dataBind(m_settings.m_dataAddress, m_settings.m_dataPort);
|
||||||
m_running = true;
|
m_running = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -102,6 +100,16 @@ void SDRDaemonChannelSource::stop()
|
|||||||
m_running = false;
|
m_running = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SDRDaemonChannelSource::setDataLink(const QString& dataAddress, uint16_t dataPort)
|
||||||
|
{
|
||||||
|
SDRDaemonChannelSourceSettings settings = m_settings;
|
||||||
|
settings.m_dataAddress = dataAddress;
|
||||||
|
settings.m_dataPort = dataPort;
|
||||||
|
|
||||||
|
MsgConfigureSDRDaemonChannelSource *msg = MsgConfigureSDRDaemonChannelSource::create(settings, false);
|
||||||
|
m_inputMessageQueue.push(msg);
|
||||||
|
}
|
||||||
|
|
||||||
bool SDRDaemonChannelSource::handleMessage(const Message& cmd __attribute__((unused)))
|
bool SDRDaemonChannelSource::handleMessage(const Message& cmd __attribute__((unused)))
|
||||||
{
|
{
|
||||||
if (UpChannelizer::MsgChannelizerNotification::match(cmd))
|
if (UpChannelizer::MsgChannelizerNotification::match(cmd))
|
||||||
@ -161,20 +169,16 @@ void SDRDaemonChannelSource::applySettings(const SDRDaemonChannelSourceSettings&
|
|||||||
|
|
||||||
bool change = false;
|
bool change = false;
|
||||||
|
|
||||||
if ((m_settings.m_dataAddress != settings.m_dataAddress) || force)
|
if ((m_settings.m_dataAddress != settings.m_dataAddress) || force) {
|
||||||
{
|
|
||||||
m_dataAddress = settings.m_dataAddress;
|
|
||||||
change = true;
|
change = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((m_settings.m_dataPort != settings.m_dataPort) || force)
|
if ((m_settings.m_dataPort != settings.m_dataPort) || force) {
|
||||||
{
|
|
||||||
m_dataPort = settings.m_dataPort;
|
|
||||||
change = true;
|
change = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (change && m_sourceThread) {
|
if (change && m_sourceThread) {
|
||||||
m_sourceThread->dataBind(m_dataAddress, m_dataPort);
|
m_sourceThread->dataBind(settings.m_dataAddress, settings.m_dataPort);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_settings = settings;
|
m_settings = settings;
|
||||||
|
@ -80,6 +80,8 @@ public:
|
|||||||
virtual QByteArray serialize() const;
|
virtual QByteArray serialize() const;
|
||||||
virtual bool deserialize(const QByteArray& data);
|
virtual bool deserialize(const QByteArray& data);
|
||||||
|
|
||||||
|
void setDataLink(const QString& dataAddress, uint16_t dataPort);
|
||||||
|
|
||||||
static const QString m_channelIdURI;
|
static const QString m_channelIdURI;
|
||||||
static const QString m_channelId;
|
static const QString m_channelId;
|
||||||
|
|
||||||
@ -96,9 +98,6 @@ private:
|
|||||||
SDRDaemonChannelSourceSettings m_settings;
|
SDRDaemonChannelSourceSettings m_settings;
|
||||||
uint64_t m_samplesCount;
|
uint64_t m_samplesCount;
|
||||||
|
|
||||||
QString m_dataAddress;
|
|
||||||
uint16_t m_dataPort;
|
|
||||||
|
|
||||||
CM256::cm256_block m_cm256DescriptorBlocks[2*SDRDaemonNbOrginalBlocks]; //!< CM256 decoder descriptors (block addresses and block indexes)
|
CM256::cm256_block m_cm256DescriptorBlocks[2*SDRDaemonNbOrginalBlocks]; //!< CM256 decoder descriptors (block addresses and block indexes)
|
||||||
SDRDaemonMetaDataFEC m_currentMeta;
|
SDRDaemonMetaDataFEC m_currentMeta;
|
||||||
|
|
||||||
|
@ -107,6 +107,7 @@ SDRDaemonMain::SDRDaemonMain(qtwebapp::LoggerWithFile *logger, const SDRDaemonPa
|
|||||||
info.noquote();
|
info.noquote();
|
||||||
info << msg;
|
info << msg;
|
||||||
m_channelSource = new SDRDaemonChannelSource(m_deviceSinkAPI);
|
m_channelSource = new SDRDaemonChannelSource(m_deviceSinkAPI);
|
||||||
|
m_channelSource->setDataLink(parser.getDataAddress(), parser.getDataPort());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user