/////////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2016-2019 Edouard Griffiths, F4EXB // // // // 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 // // (at your option) any later version. // // // // 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 . // /////////////////////////////////////////////////////////////////////////////////// #include #include #include #include "devicebladerf1.h" bool DeviceBladeRF1::open_bladerf(struct bladerf **dev, const char *serial) { int fpga_loaded; if ((*dev = open_bladerf_from_serial(serial)) == 0) { qCritical("DeviceBladeRF1::open_bladerf: could not open BladeRF"); return false; } fpga_loaded = bladerf_is_fpga_configured(*dev); if (fpga_loaded < 0) { qCritical("DeviceBladeRF1::open_bladerf: failed to check FPGA state: %s", bladerf_strerror(fpga_loaded)); return false; } else if (fpga_loaded == 0) { qCritical("DeviceBladeRF1::start: the device's FPGA is not loaded."); return false; } return true; } 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 } } struct bladerf *DeviceBladeRF1::open_bladerf_from_serial(const char *serial) { 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) { qCritical("DeviceBladeRF1::open_bladerf_from_serial: No devices available with serial %s", serial); return 0; } else if (status != 0) { qCritical("DeviceBladeRF1::open_bladerf_from_serial: Failed to open device with serial %s (%s)", serial, bladerf_strerror(status)); return 0; } else { return dev; } } 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}; 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; }