2016-12-30 10:13:28 -05:00
|
|
|
///////////////////////////////////////////////////////////////////////////////////
|
2023-11-18 23:24:06 -05:00
|
|
|
// Copyright (C) 2016-2019 Edouard Griffiths, F4EXB <f4exb06@gmail.com> //
|
2016-12-30 10:13:28 -05: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 00:39:30 -04:00
|
|
|
// (at your option) any later version. //
|
2016-12-30 10:13:28 -05: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/>. //
|
|
|
|
///////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2018-09-18 17:12:00 -04:00
|
|
|
#include <QtGlobal>
|
|
|
|
|
2016-12-30 10:13:28 -05:00
|
|
|
#include <cstdio>
|
|
|
|
#include <cstring>
|
|
|
|
|
2018-11-16 07:44:58 -05:00
|
|
|
#include "devicebladerf1.h"
|
|
|
|
|
2018-09-18 23:26:18 -04:00
|
|
|
bool DeviceBladeRF1::open_bladerf(struct bladerf **dev, const char *serial)
|
2016-12-30 10:13:28 -05:00
|
|
|
{
|
|
|
|
int fpga_loaded;
|
|
|
|
|
2017-05-25 14:13:34 -04:00
|
|
|
if ((*dev = open_bladerf_from_serial(serial)) == 0)
|
2016-12-30 10:13:28 -05:00
|
|
|
{
|
2019-09-17 13:54:13 -04:00
|
|
|
qCritical("DeviceBladeRF1::open_bladerf: could not open BladeRF");
|
2016-12-30 10:13:28 -05:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
fpga_loaded = bladerf_is_fpga_configured(*dev);
|
|
|
|
|
|
|
|
if (fpga_loaded < 0)
|
|
|
|
{
|
2019-09-17 13:54:13 -04:00
|
|
|
qCritical("DeviceBladeRF1::open_bladerf: failed to check FPGA state: %s",
|
2018-09-18 17:12:00 -04:00
|
|
|
bladerf_strerror(fpga_loaded));
|
2016-12-30 10:13:28 -05:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
else if (fpga_loaded == 0)
|
|
|
|
{
|
2019-09-17 13:54:13 -04:00
|
|
|
qCritical("DeviceBladeRF1::start: the device's FPGA is not loaded.");
|
2016-12-30 10:13:28 -05:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2019-09-17 13:54:13 -04:00
|
|
|
void DeviceBladeRF1::enumOriginDevices(const QString& hardwareId, PluginInterface::OriginDevices& originDevices)
|
|
|
|
{
|
|
|
|
struct bladerf_devinfo *devinfo = nullptr;
|
|
|
|
int count = bladerf_get_device_list(&devinfo);
|
|
|
|
|
|
|
|
if (devinfo)
|
|
|
|
{
|
|
|
|
for(int i = 0; i < count; i++)
|
|
|
|
{
|
|
|
|
struct bladerf *dev;
|
|
|
|
|
|
|
|
int status = bladerf_open_with_devinfo(&dev, &devinfo[i]);
|
|
|
|
|
|
|
|
if (status == BLADERF_ERR_NODEV)
|
|
|
|
{
|
|
|
|
qCritical("DeviceBladeRF1::enumSampleSources: No device at index %d", i);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
else if (status != 0)
|
|
|
|
{
|
|
|
|
qCritical("DeviceBladeRF1::enumSampleSources: Failed to open device at index %d", i);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *boardName = bladerf_get_board_name(dev);
|
|
|
|
|
|
|
|
if (strcmp(boardName, "bladerf1") == 0)
|
|
|
|
{
|
|
|
|
QString displayableName(QString("BladeRF1[%1] %2").arg(devinfo[i].instance).arg(devinfo[i].serial));
|
|
|
|
|
|
|
|
originDevices.append(PluginInterface::OriginDevice(
|
|
|
|
displayableName,
|
|
|
|
hardwareId,
|
|
|
|
devinfo[i].serial,
|
|
|
|
i,
|
|
|
|
1, // nb Rx
|
|
|
|
1 // nb Tx
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
bladerf_close(dev);
|
|
|
|
}
|
|
|
|
|
|
|
|
bladerf_free_device_list(devinfo); // Valgrind memcheck
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-18 23:26:18 -04:00
|
|
|
struct bladerf *DeviceBladeRF1::open_bladerf_from_serial(const char *serial)
|
2016-12-30 10:13:28 -05:00
|
|
|
{
|
|
|
|
int status;
|
|
|
|
struct bladerf *dev;
|
|
|
|
struct bladerf_devinfo info;
|
|
|
|
|
|
|
|
/* Initialize all fields to "don't care" wildcard values.
|
|
|
|
*
|
|
|
|
* Immediately passing this to bladerf_open_with_devinfo() would cause
|
|
|
|
* libbladeRF to open any device on any available backend. */
|
|
|
|
bladerf_init_devinfo(&info);
|
|
|
|
|
|
|
|
/* Specify the desired device's serial number, while leaving all other
|
|
|
|
* fields in the info structure wildcard values */
|
|
|
|
if (serial != 0)
|
|
|
|
{
|
|
|
|
strncpy(info.serial, serial, BLADERF_SERIAL_LENGTH - 1);
|
|
|
|
info.serial[BLADERF_SERIAL_LENGTH - 1] = '\0';
|
|
|
|
}
|
|
|
|
|
|
|
|
status = bladerf_open_with_devinfo(&dev, &info);
|
|
|
|
|
|
|
|
if (status == BLADERF_ERR_NODEV)
|
|
|
|
{
|
2019-09-17 13:54:13 -04:00
|
|
|
qCritical("DeviceBladeRF1::open_bladerf_from_serial: No devices available with serial %s", serial);
|
2016-12-30 10:13:28 -05:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
else if (status != 0)
|
|
|
|
{
|
2019-09-17 13:54:13 -04:00
|
|
|
qCritical("DeviceBladeRF1::open_bladerf_from_serial: Failed to open device with serial %s (%s)",
|
2016-12-30 10:13:28 -05:00
|
|
|
serial, bladerf_strerror(status));
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return dev;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-18 05:55:19 -05:00
|
|
|
const unsigned int BladerfBandwidths::m_nb_halfbw = 16;
|
|
|
|
const unsigned int BladerfBandwidths::m_halfbw[BladerfBandwidths::m_nb_halfbw] = {
|
|
|
|
750,
|
|
|
|
875,
|
|
|
|
1250,
|
|
|
|
1375,
|
|
|
|
1500,
|
|
|
|
1920,
|
|
|
|
2500,
|
|
|
|
2750,
|
|
|
|
3000,
|
|
|
|
3500,
|
|
|
|
4375,
|
|
|
|
5000,
|
|
|
|
6000,
|
|
|
|
7000,
|
|
|
|
10000,
|
|
|
|
14000};
|
2017-01-02 04:39:21 -05:00
|
|
|
|
|
|
|
unsigned int BladerfBandwidths::getBandwidth(unsigned int bandwidth_index)
|
|
|
|
{
|
|
|
|
if (bandwidth_index < m_nb_halfbw)
|
|
|
|
{
|
|
|
|
return m_halfbw[bandwidth_index] * 2;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return m_halfbw[0] * 2;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned int BladerfBandwidths::getBandwidthIndex(unsigned int bandwidth)
|
|
|
|
{
|
|
|
|
for (unsigned int i=0; i < m_nb_halfbw; i++)
|
|
|
|
{
|
|
|
|
if (bandwidth/2000 == m_halfbw[i])
|
|
|
|
{
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned int BladerfBandwidths::getNbBandwidths()
|
|
|
|
{
|
|
|
|
return BladerfBandwidths::m_nb_halfbw;
|
|
|
|
}
|
2016-12-30 10:13:28 -05:00
|
|
|
|