mirror of
https://github.com/f4exb/sdrangel.git
synced 2024-11-25 17:28:50 -05:00
385 lines
12 KiB
C++
385 lines
12 KiB
C++
///////////////////////////////////////////////////////////////////////////////////////
|
|
// Copyright (C) 2012 maintech GmbH, Otto-Hahn-Str. 15, 97204 Hoechberg, Germany //
|
|
// written by Christian Daniel //
|
|
// Copyright (C) 2015-2021 Edouard Griffiths, F4EXB <f4exb06@gmail.com> //
|
|
// Copyright (C) 2020, 2022 Jon Beniston, M7RCE <jon@beniston.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/>. //
|
|
///////////////////////////////////////////////////////////////////////////////////////
|
|
#ifndef INCLUDE_PLUGININTERFACE_H
|
|
#define INCLUDE_PLUGININTERFACE_H
|
|
|
|
#include <QtPlugin>
|
|
#include <QString>
|
|
|
|
#include "export.h"
|
|
|
|
struct SDRBASE_API PluginDescriptor {
|
|
const QString hardwareId;
|
|
// general plugin description
|
|
const QString displayedName;
|
|
const QString version;
|
|
const QString copyright;
|
|
const QString website;
|
|
bool licenseIsGPL;
|
|
const QString sourceCodeURL;
|
|
};
|
|
|
|
class PluginAPI;
|
|
class DeviceAPI;
|
|
class DeviceSet;
|
|
class DeviceUISet;
|
|
class FeatureUISet;
|
|
class WebAPIAdapterInterface;
|
|
class DeviceGUI;
|
|
class QWidget;
|
|
class DeviceSampleSource;
|
|
class DeviceSampleSink;
|
|
class DeviceSampleMIMO;
|
|
class BasebandSampleSink;
|
|
class BasebandSampleSource;
|
|
class MIMOChannel;
|
|
class ChannelAPI;
|
|
class ChannelGUI;
|
|
class ChannelWebAPIAdapter;
|
|
class DeviceWebAPIAdapter;
|
|
class FeatureWebAPIAdapter;
|
|
class Feature;
|
|
class FeatureGUI;
|
|
|
|
class SDRBASE_API PluginInterface {
|
|
public:
|
|
struct SamplingDevice
|
|
{
|
|
enum SamplingDeviceType
|
|
{
|
|
PhysicalDevice,
|
|
BuiltInDevice
|
|
};
|
|
|
|
enum StreamType
|
|
{
|
|
StreamSingleRx, //!< Exposes a single input stream that can be one of the streams of a physical device
|
|
StreamSingleTx, //!< Exposes a single output stream that can be one of the streams of a physical device
|
|
StreamMIMO //!< May expose any number of input and/or output streams
|
|
};
|
|
|
|
QString displayedName; //!< The human readable name
|
|
QString hardwareId; //!< The internal id that identifies the type of hardware (i.e. HackRF, BladeRF, ...)
|
|
QString id; //!< The internal plugin ID corresponding to the device (i.e. for HackRF input, for HackRF output ...)
|
|
QString serial; //!< The device serial number defined by the vendor or a fake one (SDRplay)
|
|
int sequence; //!< The device sequence. >0 when more than one device of the same type is connected
|
|
SamplingDeviceType type; //!< The sampling device type for behavior information
|
|
StreamType streamType; //!< This is the type of stream supported
|
|
int deviceNbItems; //!< Number of items (or streams) in the device. >1 for composite devices.
|
|
int deviceItemIndex; //!< For composite devices this is the Rx or Tx stream index. -1 if not initialized
|
|
int claimed = -1; //!< This is the device set index if claimed else -1
|
|
bool removed = false; //!< Set if device has been removed
|
|
|
|
SamplingDevice(const QString& _displayedName,
|
|
const QString& _hardwareId,
|
|
const QString& _id,
|
|
const QString& _serial,
|
|
int _sequence,
|
|
SamplingDeviceType _type,
|
|
StreamType _streamType,
|
|
int _deviceNbItems,
|
|
int _deviceItemIndex) :
|
|
displayedName(_displayedName),
|
|
hardwareId(_hardwareId),
|
|
id(_id),
|
|
serial(_serial),
|
|
sequence(_sequence),
|
|
type(_type),
|
|
streamType(_streamType),
|
|
deviceNbItems(_deviceNbItems),
|
|
deviceItemIndex(_deviceItemIndex)
|
|
{ }
|
|
|
|
bool operator==(const SamplingDevice& rhs) const
|
|
{
|
|
return displayedName == rhs.displayedName
|
|
&& hardwareId == rhs.hardwareId
|
|
&& id == rhs.id
|
|
&& serial == rhs.serial;
|
|
}
|
|
};
|
|
using SamplingDevices = QList<SamplingDevice>;
|
|
|
|
/** This is the device from which the sampling devices are derived. For physical devices this represents
|
|
* a single physical unit (a LimeSDR, HackRF, BladeRF, RTL-SDR dongle, ...) that is enumerated once and
|
|
* reported in the system so that the "sampling devices" used in the system can be registered
|
|
*/
|
|
struct OriginDevice
|
|
{
|
|
QString displayableName; //!< A human readable name
|
|
QString hardwareId; //!< The internal id that identifies the type of hardware (i.e. HackRF, BladeRF, ...)
|
|
QString serial; //!< The device serial number defined by the vendor or a fake one (SDRplay)
|
|
int sequence; //!< The device sequence in order of enumeration
|
|
int nbRxStreams; //!< Number of receiver streams
|
|
int nbTxStreams; //!< Number of transmitter streams
|
|
|
|
OriginDevice(
|
|
const QString& _displayableName,
|
|
const QString& _hardwareId,
|
|
const QString& _serial,
|
|
int _sequence,
|
|
int _nbRxStreams,
|
|
int _nbTxStreams
|
|
) :
|
|
displayableName(_displayableName),
|
|
hardwareId(_hardwareId),
|
|
serial(_serial),
|
|
sequence(_sequence),
|
|
nbRxStreams(_nbRxStreams),
|
|
nbTxStreams(_nbTxStreams)
|
|
{}
|
|
};
|
|
using OriginDevices = QList<OriginDevice>;
|
|
|
|
virtual ~PluginInterface() = default;
|
|
|
|
virtual const PluginDescriptor& getPluginDescriptor() const = 0;
|
|
virtual void initPlugin(PluginAPI* pluginAPI) = 0;
|
|
|
|
// channel Rx plugins
|
|
|
|
virtual void createRxChannel(DeviceAPI *deviceAPI, BasebandSampleSink **bs, ChannelAPI **cs) const
|
|
{
|
|
(void) deviceAPI;
|
|
(void) bs;
|
|
(void) cs;
|
|
}
|
|
|
|
virtual ChannelGUI* createRxChannelGUI(
|
|
DeviceUISet *deviceUISet,
|
|
BasebandSampleSink *rxChannel) const
|
|
{
|
|
(void) deviceUISet;
|
|
(void) rxChannel;
|
|
return nullptr;
|
|
}
|
|
|
|
// channel Tx plugins
|
|
|
|
virtual void createTxChannel(DeviceAPI *deviceAPI, BasebandSampleSource **bs, ChannelAPI **cs) const
|
|
{
|
|
(void) deviceAPI;
|
|
(void) bs;
|
|
(void) cs;
|
|
}
|
|
|
|
virtual ChannelGUI* createTxChannelGUI(
|
|
DeviceUISet *deviceUISet,
|
|
BasebandSampleSource *txChannel) const
|
|
{
|
|
(void) deviceUISet;
|
|
(void) txChannel;
|
|
return nullptr;
|
|
}
|
|
|
|
// channel MIMO plugins
|
|
|
|
virtual void createMIMOChannel(DeviceAPI *deviceAPI, MIMOChannel **bs, ChannelAPI **cs) const
|
|
{
|
|
(void) deviceAPI;
|
|
(void) bs;
|
|
(void) cs;
|
|
}
|
|
|
|
virtual ChannelGUI* createMIMOChannelGUI(
|
|
DeviceUISet *deviceUISet,
|
|
MIMOChannel *mimoChannel) const
|
|
{
|
|
(void) deviceUISet;
|
|
(void) mimoChannel;
|
|
return nullptr;
|
|
}
|
|
|
|
// any channel
|
|
|
|
virtual ChannelWebAPIAdapter* createChannelWebAPIAdapter() const
|
|
{
|
|
return nullptr;
|
|
}
|
|
|
|
// any feature
|
|
|
|
virtual FeatureWebAPIAdapter* createFeatureWebAPIAdapter() const
|
|
{
|
|
return nullptr;
|
|
}
|
|
|
|
// any device
|
|
|
|
virtual void enumOriginDevices(QStringList& listedHwIds, OriginDevices& originDevices)
|
|
{
|
|
(void) listedHwIds;
|
|
(void) originDevices;
|
|
}
|
|
|
|
virtual SamplingDevice::SamplingDeviceType getSamplingDeviceType() const {
|
|
return SamplingDevice::SamplingDeviceType::PhysicalDevice;
|
|
}
|
|
|
|
virtual QString getDeviceTypeId() const {
|
|
return QString("");
|
|
}
|
|
|
|
// device source plugins only
|
|
|
|
virtual SamplingDevices enumSampleSources(const OriginDevices& originDevices)
|
|
{
|
|
(void) originDevices;
|
|
return SamplingDevices();
|
|
}
|
|
|
|
virtual DeviceGUI* createSampleSourcePluginInstanceGUI(
|
|
const QString& sourceId,
|
|
QWidget **widget,
|
|
DeviceUISet *deviceUISet)
|
|
{
|
|
(void) sourceId;
|
|
(void) widget;
|
|
(void) deviceUISet;
|
|
return nullptr;
|
|
}
|
|
|
|
virtual DeviceSampleSource* createSampleSourcePluginInstance( // creates the input "core"
|
|
const QString& sourceId,
|
|
DeviceAPI *deviceAPI)
|
|
{
|
|
(void) sourceId;
|
|
(void) deviceAPI;
|
|
return nullptr;
|
|
}
|
|
virtual void deleteSampleSourcePluginInstanceInput(DeviceSampleSource *source);
|
|
|
|
virtual int getDefaultRxNbItems() const {
|
|
return 1;
|
|
}
|
|
|
|
// device sink plugins only
|
|
|
|
virtual SamplingDevices enumSampleSinks(const OriginDevices& originDevices)
|
|
{
|
|
(void) originDevices;
|
|
return SamplingDevices();
|
|
}
|
|
|
|
virtual DeviceGUI* createSampleSinkPluginInstanceGUI(
|
|
const QString& sinkId,
|
|
QWidget **widget,
|
|
DeviceUISet *deviceUISet)
|
|
{
|
|
(void) sinkId;
|
|
(void) widget;
|
|
(void) deviceUISet;
|
|
return nullptr;
|
|
}
|
|
|
|
virtual DeviceSampleSink* createSampleSinkPluginInstance( // creates the output "core"
|
|
const QString& sinkId,
|
|
DeviceAPI *deviceAPI)
|
|
{
|
|
(void) sinkId;
|
|
(void) deviceAPI;
|
|
return nullptr;
|
|
}
|
|
|
|
virtual void deleteSampleSinkPluginInstanceOutput(DeviceSampleSink *sink);
|
|
|
|
virtual int getDefaultTxNbItems() const {
|
|
return 1;
|
|
}
|
|
|
|
// device MIMO plugins only
|
|
|
|
virtual SamplingDevices enumSampleMIMO(const OriginDevices& originDevices)
|
|
{
|
|
(void) originDevices;
|
|
return SamplingDevices();
|
|
}
|
|
|
|
virtual DeviceGUI* createSampleMIMOPluginInstanceGUI(
|
|
const QString& mimoId,
|
|
QWidget **widget,
|
|
DeviceUISet *deviceUISet)
|
|
{
|
|
(void) mimoId;
|
|
(void) widget;
|
|
(void) deviceUISet;
|
|
return nullptr;
|
|
}
|
|
|
|
virtual DeviceSampleMIMO* createSampleMIMOPluginInstance( // creates the MIMO "core"
|
|
const QString& mimoId,
|
|
DeviceAPI *deviceAPI)
|
|
{
|
|
(void) mimoId;
|
|
(void) deviceAPI;
|
|
return nullptr;
|
|
}
|
|
|
|
virtual void deleteSampleMIMOPluginInstanceMIMO(DeviceSampleMIMO *mimo);
|
|
|
|
virtual int getDefaultMIMONbItems() const {
|
|
return 1;
|
|
}
|
|
|
|
// Callback to allow plugin to add elements to top-level GUI (such as menu items)
|
|
virtual bool createTopLevelGUI()
|
|
{
|
|
return true;
|
|
}
|
|
|
|
// Serialise global plugin settings (i.e. settings that are not per-instance)
|
|
virtual QByteArray serializeGlobalSettings() const
|
|
{
|
|
QByteArray empty;
|
|
return empty;
|
|
}
|
|
|
|
virtual bool deserializeGlobalSettings(const QByteArray& data)
|
|
{
|
|
(void) data;
|
|
return true;
|
|
}
|
|
|
|
// all devices
|
|
|
|
virtual DeviceWebAPIAdapter* createDeviceWebAPIAdapter() const {
|
|
return nullptr;
|
|
}
|
|
|
|
// Features
|
|
|
|
virtual FeatureGUI* createFeatureGUI(FeatureUISet *featureUISet, Feature *feature) const
|
|
{
|
|
(void) featureUISet;
|
|
(void) feature;
|
|
return nullptr;
|
|
}
|
|
|
|
virtual Feature* createFeature(WebAPIAdapterInterface *webAPIAdapterInterface) const
|
|
{
|
|
(void) webAPIAdapterInterface;
|
|
return nullptr;
|
|
}
|
|
};
|
|
|
|
Q_DECLARE_INTERFACE(PluginInterface, "SDRangel.PluginInterface/0.1")
|
|
|
|
#endif // INCLUDE_PLUGININTERFACE_H
|