mirror of
https://github.com/f4exb/sdrangel.git
synced 2024-11-13 20:01:46 -05:00
BladeRF2 input: fix MI start/stop
This commit is contained in:
parent
464a9fde0a
commit
96979e0c37
@ -119,24 +119,6 @@ bool BladeRF2Input::openDevice()
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_deviceShared.m_dev = device;
|
m_deviceShared.m_dev = device;
|
||||||
int requestedChannel = m_deviceAPI->getItemIndex();
|
|
||||||
|
|
||||||
if (requestedChannel == deviceBladeRF2Shared->m_channel)
|
|
||||||
{
|
|
||||||
qCritical("BladeRF2Input::openDevice: channel %u already in use", requestedChannel);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!device->openRx(requestedChannel))
|
|
||||||
{
|
|
||||||
qCritical("BladeRF2Input::openDevice: channel %u cannot be enabled", requestedChannel);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_deviceShared.m_channel = requestedChannel;
|
|
||||||
qDebug("BladeRF2Input::openDevice: channel %u enabled", requestedChannel);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
// look for Tx buddies and get reference to the device object
|
// look for Tx buddies and get reference to the device object
|
||||||
// allocate the Rx channel unconditionally
|
// allocate the Rx channel unconditionally
|
||||||
@ -162,18 +144,6 @@ bool BladeRF2Input::openDevice()
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_deviceShared.m_dev = device;
|
m_deviceShared.m_dev = device;
|
||||||
int requestedChannel = m_deviceAPI->getItemIndex();
|
|
||||||
|
|
||||||
if (!device->openRx(requestedChannel))
|
|
||||||
{
|
|
||||||
qCritical("BladeRF2Input::openDevice: channel %u cannot be enabled", requestedChannel);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_deviceShared.m_channel = requestedChannel;
|
|
||||||
qDebug("BladeRF2Input::openDevice: channel %u enabled", requestedChannel);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
// There are no buddies then create the first BladeRF2 device
|
// There are no buddies then create the first BladeRF2 device
|
||||||
// allocate the Rx channel unconditionally
|
// allocate the Rx channel unconditionally
|
||||||
@ -190,21 +160,9 @@ bool BladeRF2Input::openDevice()
|
|||||||
qCritical("BladeRF2Input::openDevice: cannot open BladeRF2 device");
|
qCritical("BladeRF2Input::openDevice: cannot open BladeRF2 device");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int requestedChannel = m_deviceAPI->getItemIndex();
|
|
||||||
|
|
||||||
if (!m_deviceShared.m_dev->openRx(requestedChannel))
|
|
||||||
{
|
|
||||||
qCritical("BladeRF2Input::openDevice: channel %u cannot be enabled", requestedChannel);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_deviceShared.m_channel = requestedChannel;
|
|
||||||
qDebug("BladeRF2Input::openDevice: channel %u enabled", requestedChannel);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_deviceShared.m_channel = m_deviceAPI->getItemIndex(); // publicly allocate channel
|
||||||
m_deviceShared.m_source = this;
|
m_deviceShared.m_source = this;
|
||||||
m_deviceAPI->setBuddySharedPtr(&m_deviceShared); // propagate common parameters to API
|
m_deviceAPI->setBuddySharedPtr(&m_deviceShared); // propagate common parameters to API
|
||||||
return true;
|
return true;
|
||||||
@ -224,7 +182,7 @@ void BladeRF2Input::closeDevice()
|
|||||||
moveThreadToBuddy();
|
moveThreadToBuddy();
|
||||||
}
|
}
|
||||||
|
|
||||||
m_deviceShared.m_channel = -1;
|
m_deviceShared.m_channel = -1; // publicly release channel
|
||||||
m_deviceShared.m_source = 0;
|
m_deviceShared.m_source = 0;
|
||||||
|
|
||||||
// No buddies so effectively close the device
|
// No buddies so effectively close the device
|
||||||
@ -305,7 +263,7 @@ bool BladeRF2Input::start()
|
|||||||
|
|
||||||
if (bladerf2InputThread) // if thread is already allocated
|
if (bladerf2InputThread) // if thread is already allocated
|
||||||
{
|
{
|
||||||
qDebug("BladerfInput::start: thread is owned by a buddy");
|
qDebug("BladerfInput::start: thread is already allocated");
|
||||||
|
|
||||||
int nbOriginalChannels = bladerf2InputThread->getNbChannels();
|
int nbOriginalChannels = bladerf2InputThread->getNbChannels();
|
||||||
|
|
||||||
@ -363,7 +321,19 @@ bool BladeRF2Input::start()
|
|||||||
bladerf2InputThread->setLog2Decimation(requestedChannel, m_settings.m_log2Decim);
|
bladerf2InputThread->setLog2Decimation(requestedChannel, m_settings.m_log2Decim);
|
||||||
bladerf2InputThread->setFcPos(requestedChannel, (int) m_settings.m_fcPos);
|
bladerf2InputThread->setFcPos(requestedChannel, (int) m_settings.m_fcPos);
|
||||||
|
|
||||||
if (needsStart) {
|
if (needsStart)
|
||||||
|
{
|
||||||
|
qDebug("BladerfInput::start: enabling channel(s) and (re)sart buddy thread");
|
||||||
|
|
||||||
|
int nbChannels = bladerf2InputThread->getNbChannels();
|
||||||
|
|
||||||
|
for (int i = 0; i < nbChannels; i++)
|
||||||
|
{
|
||||||
|
if (!m_deviceShared.m_dev->openRx(i)) {
|
||||||
|
qCritical("BladeRF2Input::start: channel %u cannot be enabled", i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bladerf2InputThread->startWork();
|
bladerf2InputThread->startWork();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -384,8 +354,7 @@ void BladeRF2Input::stop()
|
|||||||
int requestedChannel = m_deviceAPI->getItemIndex();
|
int requestedChannel = m_deviceAPI->getItemIndex();
|
||||||
BladeRF2InputThread *bladerf2InputThread = findThread();
|
BladeRF2InputThread *bladerf2InputThread = findThread();
|
||||||
|
|
||||||
if (bladerf2InputThread == 0) // no thread allocated
|
if (bladerf2InputThread == 0) { // no thread allocated
|
||||||
{
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -405,6 +374,8 @@ void BladeRF2Input::stop()
|
|||||||
for (; it != sourceBuddies.end(); ++it) {
|
for (; it != sourceBuddies.end(); ++it) {
|
||||||
((DeviceBladeRF2Shared*) (*it)->getBuddySharedPtr())->m_source->setThread(0);
|
((DeviceBladeRF2Shared*) (*it)->getBuddySharedPtr())->m_source->setThread(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_deviceShared.m_dev->closeRx(0); // close the unique channel
|
||||||
}
|
}
|
||||||
else if (requestedChannel == nbOriginalChannels - 1) // remove last MI channel => reduce by deleting and re-creating the thread
|
else if (requestedChannel == nbOriginalChannels - 1) // remove last MI channel => reduce by deleting and re-creating the thread
|
||||||
{
|
{
|
||||||
@ -440,6 +411,7 @@ void BladeRF2Input::stop()
|
|||||||
((DeviceBladeRF2Shared*) (*it)->getBuddySharedPtr())->m_source->setThread(0);
|
((DeviceBladeRF2Shared*) (*it)->getBuddySharedPtr())->m_source->setThread(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_deviceShared.m_dev->closeRx(requestedChannel); // close the last channel
|
||||||
bladerf2InputThread->startWork();
|
bladerf2InputThread->startWork();
|
||||||
}
|
}
|
||||||
else // remove channel from existing thread
|
else // remove channel from existing thread
|
||||||
|
Loading…
Reference in New Issue
Block a user