mirror of https://github.com/f4exb/sdrangel.git
LimeSDR input: suspend thread while changing configuration
This commit is contained in:
parent
54f3a51203
commit
763175ab55
|
@ -211,7 +211,6 @@ bool LimeSDRInput::start()
|
||||||
|
|
||||||
m_limeSDRInputThread->startWork();
|
m_limeSDRInputThread->startWork();
|
||||||
|
|
||||||
applySettings(m_settings, true);
|
|
||||||
m_running = true;
|
m_running = true;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -322,6 +321,7 @@ bool LimeSDRInput::applySettings(const LimeSDRInputSettings& settings, bool forc
|
||||||
bool forwardChangeRxDSP = false;
|
bool forwardChangeRxDSP = false;
|
||||||
bool forwardChangeAllDSP = false;
|
bool forwardChangeAllDSP = false;
|
||||||
bool doCalibration = false;
|
bool doCalibration = false;
|
||||||
|
bool threadStopped = false;
|
||||||
// QMutexLocker mutexLocker(&m_mutex);
|
// QMutexLocker mutexLocker(&m_mutex);
|
||||||
|
|
||||||
if ((m_settings.m_dcBlock != settings.m_dcBlock) || force)
|
if ((m_settings.m_dcBlock != settings.m_dcBlock) || force)
|
||||||
|
@ -342,6 +342,12 @@ bool LimeSDRInput::applySettings(const LimeSDRInputSettings& settings, bool forc
|
||||||
|
|
||||||
if (m_deviceShared.m_deviceParams->getDevice() != 0)
|
if (m_deviceShared.m_deviceParams->getDevice() != 0)
|
||||||
{
|
{
|
||||||
|
if (m_limeSDRInputThread && !threadStopped)
|
||||||
|
{
|
||||||
|
m_limeSDRInputThread->stopWork();
|
||||||
|
threadStopped = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (LMS_SetGaindB(m_deviceShared.m_deviceParams->getDevice(),
|
if (LMS_SetGaindB(m_deviceShared.m_deviceParams->getDevice(),
|
||||||
LMS_CH_RX,
|
LMS_CH_RX,
|
||||||
m_deviceShared.m_channel,
|
m_deviceShared.m_channel,
|
||||||
|
@ -368,6 +374,12 @@ bool LimeSDRInput::applySettings(const LimeSDRInputSettings& settings, bool forc
|
||||||
|
|
||||||
if (m_deviceShared.m_deviceParams->getDevice() != 0)
|
if (m_deviceShared.m_deviceParams->getDevice() != 0)
|
||||||
{
|
{
|
||||||
|
if (m_limeSDRInputThread && !threadStopped)
|
||||||
|
{
|
||||||
|
m_limeSDRInputThread->stopWork();
|
||||||
|
threadStopped = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (LMS_SetSampleRateDir(m_deviceShared.m_deviceParams->getDevice(),
|
if (LMS_SetSampleRateDir(m_deviceShared.m_deviceParams->getDevice(),
|
||||||
LMS_CH_RX,
|
LMS_CH_RX,
|
||||||
m_settings.m_devSampleRate,
|
m_settings.m_devSampleRate,
|
||||||
|
@ -395,6 +407,12 @@ bool LimeSDRInput::applySettings(const LimeSDRInputSettings& settings, bool forc
|
||||||
|
|
||||||
if (m_deviceShared.m_deviceParams->getDevice() != 0)
|
if (m_deviceShared.m_deviceParams->getDevice() != 0)
|
||||||
{
|
{
|
||||||
|
if (m_limeSDRInputThread && !threadStopped)
|
||||||
|
{
|
||||||
|
m_limeSDRInputThread->stopWork();
|
||||||
|
threadStopped = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (LMS_SetLPFBW(m_deviceShared.m_deviceParams->getDevice(),
|
if (LMS_SetLPFBW(m_deviceShared.m_deviceParams->getDevice(),
|
||||||
LMS_CH_RX,
|
LMS_CH_RX,
|
||||||
m_deviceShared.m_channel,
|
m_deviceShared.m_channel,
|
||||||
|
@ -418,6 +436,12 @@ bool LimeSDRInput::applySettings(const LimeSDRInputSettings& settings, bool forc
|
||||||
|
|
||||||
if (m_deviceShared.m_deviceParams->getDevice() != 0)
|
if (m_deviceShared.m_deviceParams->getDevice() != 0)
|
||||||
{
|
{
|
||||||
|
if (m_limeSDRInputThread && !threadStopped)
|
||||||
|
{
|
||||||
|
m_limeSDRInputThread->stopWork();
|
||||||
|
threadStopped = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (LMS_SetGFIRLPF(m_deviceShared.m_deviceParams->getDevice(),
|
if (LMS_SetGFIRLPF(m_deviceShared.m_deviceParams->getDevice(),
|
||||||
LMS_CH_RX,
|
LMS_CH_RX,
|
||||||
m_deviceShared.m_channel,
|
m_deviceShared.m_channel,
|
||||||
|
@ -457,6 +481,12 @@ bool LimeSDRInput::applySettings(const LimeSDRInputSettings& settings, bool forc
|
||||||
|
|
||||||
if (m_deviceShared.m_deviceParams->getDevice() != 0)
|
if (m_deviceShared.m_deviceParams->getDevice() != 0)
|
||||||
{
|
{
|
||||||
|
if (m_limeSDRInputThread && !threadStopped)
|
||||||
|
{
|
||||||
|
m_limeSDRInputThread->stopWork();
|
||||||
|
threadStopped = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (LMS_SetLOFrequency(m_deviceShared.m_deviceParams->getDevice(),
|
if (LMS_SetLOFrequency(m_deviceShared.m_deviceParams->getDevice(),
|
||||||
LMS_CH_RX,
|
LMS_CH_RX,
|
||||||
m_deviceShared.m_channel, // same for both channels anyway but switches antenna port automatically
|
m_deviceShared.m_channel, // same for both channels anyway but switches antenna port automatically
|
||||||
|
@ -488,6 +518,12 @@ bool LimeSDRInput::applySettings(const LimeSDRInputSettings& settings, bool forc
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (threadStopped)
|
||||||
|
{
|
||||||
|
m_limeSDRInputThread->startWork();
|
||||||
|
threadStopped = false;
|
||||||
|
}
|
||||||
|
|
||||||
if (forwardChangeAllDSP)
|
if (forwardChangeAllDSP)
|
||||||
{
|
{
|
||||||
const std::vector<DeviceSourceAPI*>& sourceBuddies = m_deviceAPI->getSourceBuddies();
|
const std::vector<DeviceSourceAPI*>& sourceBuddies = m_deviceAPI->getSourceBuddies();
|
||||||
|
|
|
@ -25,15 +25,15 @@ LimeSDRInputSettings::LimeSDRInputSettings()
|
||||||
void LimeSDRInputSettings::resetToDefaults()
|
void LimeSDRInputSettings::resetToDefaults()
|
||||||
{
|
{
|
||||||
m_centerFrequency = 435000*1000;
|
m_centerFrequency = 435000*1000;
|
||||||
m_devSampleRate = 6000000;
|
m_devSampleRate = 5000000;
|
||||||
m_log2HardDecim = 2;
|
m_log2HardDecim = 3;
|
||||||
m_dcBlock = false;
|
m_dcBlock = false;
|
||||||
m_iqCorrection = false;
|
m_iqCorrection = false;
|
||||||
m_log2SoftDecim = 0;
|
m_log2SoftDecim = 0;
|
||||||
m_fcPos = FC_POS_CENTER;
|
m_fcPos = FC_POS_CENTER;
|
||||||
m_lpfBW = 1.5e6f;
|
m_lpfBW = 4.5e6f;
|
||||||
m_lpfFIREnable = false;
|
m_lpfFIREnable = false;
|
||||||
m_lpfFIRBW = 1.5e6f;
|
m_lpfFIRBW = 2.5e6f;
|
||||||
m_gain = 0;
|
m_gain = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue