HackRF output: suspend thread when baseband sample rate changes

pull/60/head
f4exb 2017-08-08 21:30:04 +02:00
rodzic 287bf8120d
commit 7b851e8326
2 zmienionych plików z 27 dodań i 1 usunięć

Wyświetl plik

@ -214,11 +214,31 @@ bool HackRFOutput::applySettings(const HackRFOutputSettings& settings, bool forc
{
// QMutexLocker mutexLocker(&m_mutex);
bool forwardChange = false;
bool forwardChange = false;
bool suspendThread = false;
bool threadWasRunning = false;
hackrf_error rc;
qDebug() << "HackRFOutput::applySettings";
if ((m_settings.m_devSampleRate != settings.m_devSampleRate) ||
(m_settings.m_log2Interp != settings.m_log2Interp) || force)
{
suspendThread = true;
}
if (suspendThread)
{
if (m_hackRFThread)
{
if (m_hackRFThread->isRunning())
{
m_hackRFThread->stopWork();
threadWasRunning = true;
}
}
}
if ((m_settings.m_devSampleRate != settings.m_devSampleRate) || (m_settings.m_log2Interp != settings.m_log2Interp) || force)
{
forwardChange = true;
@ -339,6 +359,11 @@ bool HackRFOutput::applySettings(const HackRFOutputSettings& settings, bool forc
}
}
if (threadWasRunning)
{
m_hackRFThread->startWork();
}
m_settings.m_devSampleRate = settings.m_devSampleRate;
m_settings.m_log2Interp = settings.m_log2Interp;
m_settings.m_centerFrequency = settings.m_centerFrequency;

Wyświetl plik

@ -47,6 +47,7 @@ void HackRFOutputThread::startWork()
void HackRFOutputThread::stopWork()
{
if (!m_running) return;
qDebug("HackRFOutputThread::stopWork");
m_running = false;
wait();