mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-31 13:00:26 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			187 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			187 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| ///////////////////////////////////////////////////////////////////////////////////
 | |
| // Copyright (C) 2016-2019 Edouard Griffiths, F4EXB <f4exb06@gmail.com>          //
 | |
| //                                                                               //
 | |
| // 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 <http://www.gnu.org/licenses/>.          //
 | |
| ///////////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #include <QtGlobal>
 | |
| 
 | |
| #include <cstdio>
 | |
| #include <cstring>
 | |
| 
 | |
| #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;
 | |
| }
 | |
| 
 |