mirror of
https://github.com/AlexandreRouma/SDRPlusPlus.git
synced 2025-01-30 19:34:45 +01:00
add support for new models (in a bad way) and start the rewrite process
This commit is contained in:
parent
11f87e0fe2
commit
3c1d0c7422
@ -8,6 +8,7 @@
|
|||||||
#include <config.h>
|
#include <config.h>
|
||||||
#include <sdrplay_api.h>
|
#include <sdrplay_api.h>
|
||||||
#include <gui/smgui.h>
|
#include <gui/smgui.h>
|
||||||
|
#include <utils/optionlist.h>
|
||||||
|
|
||||||
#define CONCAT(a, b) ((std::string(a) + b).c_str())
|
#define CONCAT(a, b) ((std::string(a) + b).c_str())
|
||||||
|
|
||||||
@ -15,69 +16,12 @@ SDRPP_MOD_INFO{
|
|||||||
/* Name: */ "sdrplay_source",
|
/* Name: */ "sdrplay_source",
|
||||||
/* Description: */ "SDRplay source module for SDR++",
|
/* Description: */ "SDRplay source module for SDR++",
|
||||||
/* Author: */ "Ryzerth",
|
/* Author: */ "Ryzerth",
|
||||||
/* Version: */ 0, 1, 0,
|
/* Version: */ 0, 2, 0,
|
||||||
/* Max instances */ 1
|
/* Max instances */ 1
|
||||||
};
|
};
|
||||||
|
|
||||||
ConfigManager config;
|
ConfigManager config;
|
||||||
|
|
||||||
unsigned int sampleRates[] = {
|
|
||||||
2000000,
|
|
||||||
3000000,
|
|
||||||
4000000,
|
|
||||||
5000000,
|
|
||||||
6000000,
|
|
||||||
7000000,
|
|
||||||
8000000,
|
|
||||||
9000000,
|
|
||||||
10000000
|
|
||||||
};
|
|
||||||
|
|
||||||
const char* sampleRatesTxt =
|
|
||||||
"2MHz\0"
|
|
||||||
"3MHz\0"
|
|
||||||
"4MHz\0"
|
|
||||||
"5MHz\0"
|
|
||||||
"6MHz\0"
|
|
||||||
"7MHz\0"
|
|
||||||
"8MHz\0"
|
|
||||||
"9MHz\0"
|
|
||||||
"10MHz\0";
|
|
||||||
|
|
||||||
sdrplay_api_Bw_MHzT bandwidths[] = {
|
|
||||||
sdrplay_api_BW_0_200,
|
|
||||||
sdrplay_api_BW_0_300,
|
|
||||||
sdrplay_api_BW_0_600,
|
|
||||||
sdrplay_api_BW_1_536,
|
|
||||||
sdrplay_api_BW_5_000,
|
|
||||||
sdrplay_api_BW_6_000,
|
|
||||||
sdrplay_api_BW_7_000,
|
|
||||||
sdrplay_api_BW_8_000,
|
|
||||||
};
|
|
||||||
|
|
||||||
const char* bandwidthsTxt =
|
|
||||||
"200KHz\0"
|
|
||||||
"300KHz\0"
|
|
||||||
"600KHz\0"
|
|
||||||
"1.536MHz\0"
|
|
||||||
"5MHz\0"
|
|
||||||
"6MHz\0"
|
|
||||||
"7MHz\0"
|
|
||||||
"8MHz\0"
|
|
||||||
"Auto\0";
|
|
||||||
|
|
||||||
sdrplay_api_Bw_MHzT preferedBandwidth[] = {
|
|
||||||
sdrplay_api_BW_5_000,
|
|
||||||
sdrplay_api_BW_5_000,
|
|
||||||
sdrplay_api_BW_5_000,
|
|
||||||
sdrplay_api_BW_5_000,
|
|
||||||
sdrplay_api_BW_6_000,
|
|
||||||
sdrplay_api_BW_7_000,
|
|
||||||
sdrplay_api_BW_8_000,
|
|
||||||
sdrplay_api_BW_8_000,
|
|
||||||
sdrplay_api_BW_8_000
|
|
||||||
};
|
|
||||||
|
|
||||||
const sdrplay_api_Rsp2_AntennaSelectT rsp2_antennaPorts[] = {
|
const sdrplay_api_Rsp2_AntennaSelectT rsp2_antennaPorts[] = {
|
||||||
sdrplay_api_Rsp2_ANTENNA_A,
|
sdrplay_api_Rsp2_ANTENNA_A,
|
||||||
sdrplay_api_Rsp2_ANTENNA_B,
|
sdrplay_api_Rsp2_ANTENNA_B,
|
||||||
@ -208,6 +152,11 @@ public:
|
|||||||
name += devArr[i].SerNo;
|
name += devArr[i].SerNo;
|
||||||
name += ')';
|
name += ')';
|
||||||
break;
|
break;
|
||||||
|
case SDRPLAY_RSP1B_ID:
|
||||||
|
name = "RSP1B (";
|
||||||
|
name += devArr[i].SerNo;
|
||||||
|
name += ')';
|
||||||
|
break;
|
||||||
case SDRPLAY_RSP2_ID:
|
case SDRPLAY_RSP2_ID:
|
||||||
name = "RSP2 (";
|
name = "RSP2 (";
|
||||||
name += devArr[i].SerNo;
|
name += devArr[i].SerNo;
|
||||||
@ -223,6 +172,11 @@ public:
|
|||||||
name += devArr[i].SerNo;
|
name += devArr[i].SerNo;
|
||||||
name += ')';
|
name += ')';
|
||||||
break;
|
break;
|
||||||
|
case SDRPLAY_RSPdxR2_ID:
|
||||||
|
name = "RSPdx-R2 (";
|
||||||
|
name += devArr[i].SerNo;
|
||||||
|
name += ')';
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
name = "Unknown (";
|
name = "Unknown (";
|
||||||
name += devArr[i].SerNo;
|
name += devArr[i].SerNo;
|
||||||
@ -290,6 +244,29 @@ public:
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Define the valid samplerates
|
||||||
|
samplerates.clear();
|
||||||
|
samplerates.define(2e6, "2MHz", 2e6);
|
||||||
|
samplerates.define(3e6, "3MHz", 3e6);
|
||||||
|
samplerates.define(4e6, "4MHz", 4e6);
|
||||||
|
samplerates.define(5e6, "5MHz", 5e6);
|
||||||
|
samplerates.define(6e6, "6MHz", 6e6);
|
||||||
|
samplerates.define(7e6, "7MHz", 7e6);
|
||||||
|
samplerates.define(8e6, "8MHz", 8e6);
|
||||||
|
samplerates.define(9e6, "9MHz", 9e6);
|
||||||
|
samplerates.define(10e6, "10MHz", 10e6);
|
||||||
|
|
||||||
|
// Define the valid bandwidths
|
||||||
|
bandwidths.define(0, "Auto", sdrplay_api_BW_Undefined);
|
||||||
|
bandwidths.define(200e3, "200KHz", sdrplay_api_BW_0_200);
|
||||||
|
bandwidths.define(300e3, "300KHz", sdrplay_api_BW_0_300);
|
||||||
|
bandwidths.define(600e3, "600KHz", sdrplay_api_BW_0_600);
|
||||||
|
bandwidths.define(1.536e6, "1.536MHz", sdrplay_api_BW_1_536);
|
||||||
|
bandwidths.define(5e6, "5MHz", sdrplay_api_BW_5_000);
|
||||||
|
bandwidths.define(6e6, "6MHz", sdrplay_api_BW_6_000);
|
||||||
|
bandwidths.define(7e6, "7MHz", sdrplay_api_BW_7_000);
|
||||||
|
bandwidths.define(8e6, "8MHz", sdrplay_api_BW_8_000);
|
||||||
|
|
||||||
channelParams = openDevParams->rxChannelA;
|
channelParams = openDevParams->rxChannelA;
|
||||||
|
|
||||||
selectedName = devNameList[id];
|
selectedName = devNameList[id];
|
||||||
@ -297,7 +274,7 @@ public:
|
|||||||
if (openDev.hwVer == SDRPLAY_RSP1_ID) {
|
if (openDev.hwVer == SDRPLAY_RSP1_ID) {
|
||||||
lnaSteps = 4;
|
lnaSteps = 4;
|
||||||
}
|
}
|
||||||
else if (openDev.hwVer == SDRPLAY_RSP1A_ID) {
|
else if (openDev.hwVer == SDRPLAY_RSP1A_ID || openDev.hwVer == SDRPLAY_RSP1B_ID) {
|
||||||
lnaSteps = 10;
|
lnaSteps = 10;
|
||||||
}
|
}
|
||||||
else if (openDev.hwVer == SDRPLAY_RSP2_ID) {
|
else if (openDev.hwVer == SDRPLAY_RSP2_ID) {
|
||||||
@ -306,7 +283,7 @@ public:
|
|||||||
else if (openDev.hwVer == SDRPLAY_RSPduo_ID) {
|
else if (openDev.hwVer == SDRPLAY_RSPduo_ID) {
|
||||||
lnaSteps = 10;
|
lnaSteps = 10;
|
||||||
}
|
}
|
||||||
else if (openDev.hwVer == SDRPLAY_RSPdx_ID) {
|
else if (openDev.hwVer == SDRPLAY_RSPdx_ID || openDev.hwVer == SDRPLAY_RSPdxR2_ID) {
|
||||||
lnaSteps = 28;
|
lnaSteps = 28;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -331,7 +308,7 @@ public:
|
|||||||
if (openDev.hwVer == SDRPLAY_RSP1_ID) {
|
if (openDev.hwVer == SDRPLAY_RSP1_ID) {
|
||||||
// No config to load
|
// No config to load
|
||||||
}
|
}
|
||||||
else if (openDev.hwVer == SDRPLAY_RSP1A_ID) {
|
else if (openDev.hwVer == SDRPLAY_RSP1A_ID || openDev.hwVer == SDRPLAY_RSP1B_ID) {
|
||||||
config.conf["devices"][selectedName]["fmmwNotch"] = false;
|
config.conf["devices"][selectedName]["fmmwNotch"] = false;
|
||||||
config.conf["devices"][selectedName]["dabNotch"] = false;
|
config.conf["devices"][selectedName]["dabNotch"] = false;
|
||||||
config.conf["devices"][selectedName]["biast"] = false;
|
config.conf["devices"][selectedName]["biast"] = false;
|
||||||
@ -347,7 +324,7 @@ public:
|
|||||||
config.conf["devices"][selectedName]["dabNotch"] = false;
|
config.conf["devices"][selectedName]["dabNotch"] = false;
|
||||||
config.conf["devices"][selectedName]["biast"] = false;
|
config.conf["devices"][selectedName]["biast"] = false;
|
||||||
}
|
}
|
||||||
else if (openDev.hwVer == SDRPLAY_RSPdx_ID) {
|
else if (openDev.hwVer == SDRPLAY_RSPdx_ID || openDev.hwVer == SDRPLAY_RSPdxR2_ID) {
|
||||||
config.conf["devices"][selectedName]["antenna"] = 0;
|
config.conf["devices"][selectedName]["antenna"] = 0;
|
||||||
config.conf["devices"][selectedName]["fmmwNotch"] = false;
|
config.conf["devices"][selectedName]["fmmwNotch"] = false;
|
||||||
config.conf["devices"][selectedName]["dabNotch"] = false;
|
config.conf["devices"][selectedName]["dabNotch"] = false;
|
||||||
@ -415,7 +392,7 @@ public:
|
|||||||
if (openDev.hwVer == SDRPLAY_RSP1_ID) {
|
if (openDev.hwVer == SDRPLAY_RSP1_ID) {
|
||||||
// No config to load
|
// No config to load
|
||||||
}
|
}
|
||||||
else if (openDev.hwVer == SDRPLAY_RSP1A_ID) {
|
else if (openDev.hwVer == SDRPLAY_RSP1A_ID || openDev.hwVer == SDRPLAY_RSP1B_ID) {
|
||||||
if (config.conf["devices"][selectedName].contains("fmmwNotch")) {
|
if (config.conf["devices"][selectedName].contains("fmmwNotch")) {
|
||||||
rsp1a_fmmwNotch = config.conf["devices"][selectedName]["fmmwNotch"];
|
rsp1a_fmmwNotch = config.conf["devices"][selectedName]["fmmwNotch"];
|
||||||
}
|
}
|
||||||
@ -451,7 +428,7 @@ public:
|
|||||||
rspduo_biasT = config.conf["devices"][selectedName]["biast"];
|
rspduo_biasT = config.conf["devices"][selectedName]["biast"];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (openDev.hwVer == SDRPLAY_RSPdx_ID) {
|
else if (openDev.hwVer == SDRPLAY_RSPdx_ID || openDev.hwVer == SDRPLAY_RSPdxR2_ID) {
|
||||||
if (config.conf["devices"][selectedName].contains("antenna")) {
|
if (config.conf["devices"][selectedName].contains("antenna")) {
|
||||||
rspdx_antennaPort = config.conf["devices"][selectedName]["antenna"];
|
rspdx_antennaPort = config.conf["devices"][selectedName]["antenna"];
|
||||||
}
|
}
|
||||||
@ -571,7 +548,7 @@ private:
|
|||||||
_this->bufferSize = (float)_this->sampleRate / 200.0f;
|
_this->bufferSize = (float)_this->sampleRate / 200.0f;
|
||||||
|
|
||||||
// RSP1A Options
|
// RSP1A Options
|
||||||
if (_this->openDev.hwVer == SDRPLAY_RSP1A_ID) {
|
if (_this->openDev.hwVer == SDRPLAY_RSP1A_ID || _this->openDev.hwVer == SDRPLAY_RSP1B_ID) {
|
||||||
_this->openDevParams->devParams->rsp1aParams.rfNotchEnable = _this->rsp1a_fmmwNotch;
|
_this->openDevParams->devParams->rsp1aParams.rfNotchEnable = _this->rsp1a_fmmwNotch;
|
||||||
_this->openDevParams->devParams->rsp1aParams.rfDabNotchEnable = _this->rsp1a_dabNotch;
|
_this->openDevParams->devParams->rsp1aParams.rfDabNotchEnable = _this->rsp1a_dabNotch;
|
||||||
_this->channelParams->rsp1aTunerParams.biasTEnable = _this->rsp1a_biasT;
|
_this->channelParams->rsp1aTunerParams.biasTEnable = _this->rsp1a_biasT;
|
||||||
@ -601,7 +578,7 @@ private:
|
|||||||
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_RspDuo_RfDabNotchControl, sdrplay_api_Update_Ext1_None);
|
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_RspDuo_RfDabNotchControl, sdrplay_api_Update_Ext1_None);
|
||||||
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_RspDuo_Tuner1AmNotchControl, sdrplay_api_Update_Ext1_None);
|
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_RspDuo_Tuner1AmNotchControl, sdrplay_api_Update_Ext1_None);
|
||||||
}
|
}
|
||||||
else if (_this->openDev.hwVer == SDRPLAY_RSPdx_ID) {
|
else if (_this->openDev.hwVer == SDRPLAY_RSPdx_ID || _this->openDev.hwVer == SDRPLAY_RSPdxR2_ID) {
|
||||||
_this->openDevParams->devParams->rspDxParams.rfNotchEnable = _this->rspdx_fmmwNotch;
|
_this->openDevParams->devParams->rspDxParams.rfNotchEnable = _this->rspdx_fmmwNotch;
|
||||||
_this->openDevParams->devParams->rspDxParams.rfDabNotchEnable = _this->rspdx_dabNotch;
|
_this->openDevParams->devParams->rspDxParams.rfDabNotchEnable = _this->rspdx_dabNotch;
|
||||||
_this->openDevParams->devParams->rspDxParams.biasTEnable = _this->rspdx_biasT;
|
_this->openDevParams->devParams->rspDxParams.biasTEnable = _this->rspdx_biasT;
|
||||||
@ -693,8 +670,8 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (_this->ifModeId == 0) {
|
if (_this->ifModeId == 0) {
|
||||||
if (SmGui::Combo(CONCAT("##sdrplay_sr", _this->name), &_this->srId, sampleRatesTxt)) {
|
if (SmGui::Combo(CONCAT("##sdrplay_sr", _this->name), &_this->srId, _this->samplerates.txt)) {
|
||||||
_this->sampleRate = sampleRates[_this->srId];
|
_this->sampleRate = _this->samplerates[_this->srId];
|
||||||
if (_this->bandwidthId == 8) {
|
if (_this->bandwidthId == 8) {
|
||||||
_this->bandwidth = preferedBandwidth[_this->srId];
|
_this->bandwidth = preferedBandwidth[_this->srId];
|
||||||
}
|
}
|
||||||
@ -854,6 +831,7 @@ private:
|
|||||||
_this->RSP1Menu();
|
_this->RSP1Menu();
|
||||||
break;
|
break;
|
||||||
case SDRPLAY_RSP1A_ID:
|
case SDRPLAY_RSP1A_ID:
|
||||||
|
case SDRPLAY_RSP1B_ID:
|
||||||
_this->RSP1AMenu();
|
_this->RSP1AMenu();
|
||||||
break;
|
break;
|
||||||
case SDRPLAY_RSP2_ID:
|
case SDRPLAY_RSP2_ID:
|
||||||
@ -863,6 +841,7 @@ private:
|
|||||||
_this->RSPduoMenu();
|
_this->RSPduoMenu();
|
||||||
break;
|
break;
|
||||||
case SDRPLAY_RSPdx_ID:
|
case SDRPLAY_RSPdx_ID:
|
||||||
|
case SDRPLAY_RSPdxR2_ID:
|
||||||
_this->RSPdxMenu();
|
_this->RSPdxMenu();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -1201,6 +1180,9 @@ private:
|
|||||||
std::string devListTxt;
|
std::string devListTxt;
|
||||||
std::vector<std::string> devNameList;
|
std::vector<std::string> devNameList;
|
||||||
std::string selectedName;
|
std::string selectedName;
|
||||||
|
|
||||||
|
OptionList<int, int> samplerates;
|
||||||
|
OptionList<int, sdrplay_api_Bw_MHzT> bandwidths;
|
||||||
};
|
};
|
||||||
|
|
||||||
MOD_EXPORT void _INIT_() {
|
MOD_EXPORT void _INIT_() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user