mirror of
https://github.com/AlexandreRouma/SDRPlusPlus.git
synced 2025-03-25 17:25:30 +01:00
added more options to sdrplay module
This commit is contained in:
parent
d3a6ee6a94
commit
9e0fee27ab
@ -69,7 +69,7 @@ private:
|
|||||||
if (_this->running) { return; }
|
if (_this->running) { return; }
|
||||||
if (_this->reader == NULL) { return; }
|
if (_this->reader == NULL) { return; }
|
||||||
_this->running = true;
|
_this->running = true;
|
||||||
_this->workerThread = std::thread(worker, _this);
|
_this->workerThread = _this->float32Mode ? std::thread(floatWorker, _this) : std::thread(worker, _this);
|
||||||
spdlog::info("FileSourceModule '{0}': Start!", _this->name);
|
spdlog::info("FileSourceModule '{0}': Start!", _this->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -101,18 +101,14 @@ private:
|
|||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
_this->reader = new WavReader(_this->fileSelect.path);
|
_this->reader = new WavReader(_this->fileSelect.path);
|
||||||
if (_this->reader->isValid() && _this->reader->getBitDepth() == 16 && _this->reader->getChannelCount() == 2) {
|
|
||||||
_this->sampleRate = _this->reader->getSampleRate();
|
_this->sampleRate = _this->reader->getSampleRate();
|
||||||
core::setInputSampleRate(_this->sampleRate);
|
core::setInputSampleRate(_this->sampleRate);
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
_this->reader->close();
|
|
||||||
delete _this->reader;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (std::exception e) {}
|
catch (std::exception e) {}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ImGui::Checkbox("Float32 Mode##_file_source", &_this->float32Mode);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void worker(void* ctx) {
|
static void worker(void* ctx) {
|
||||||
@ -133,6 +129,20 @@ private:
|
|||||||
delete[] inBuf;
|
delete[] inBuf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void floatWorker(void* ctx) {
|
||||||
|
FileSourceModule* _this = (FileSourceModule*)ctx;
|
||||||
|
double sampleRate = _this->reader->getSampleRate();
|
||||||
|
int blockSize = sampleRate / 200.0f;
|
||||||
|
dsp::complex_t* inBuf = new dsp::complex_t[blockSize];
|
||||||
|
|
||||||
|
while (true) {
|
||||||
|
_this->reader->readSamples(_this->stream.writeBuf, blockSize * sizeof(dsp::complex_t));
|
||||||
|
if (!_this->stream.swap(blockSize)) { break; };
|
||||||
|
}
|
||||||
|
|
||||||
|
delete[] inBuf;
|
||||||
|
}
|
||||||
|
|
||||||
FileSelect fileSelect;
|
FileSelect fileSelect;
|
||||||
std::string name;
|
std::string name;
|
||||||
dsp::stream<dsp::complex_t> stream;
|
dsp::stream<dsp::complex_t> stream;
|
||||||
@ -142,6 +152,8 @@ private:
|
|||||||
bool enabled = true;
|
bool enabled = true;
|
||||||
float sampleRate = 48000;
|
float sampleRate = 48000;
|
||||||
std::thread workerThread;
|
std::thread workerThread;
|
||||||
|
|
||||||
|
bool float32Mode = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
MOD_EXPORT void _INIT_() {
|
MOD_EXPORT void _INIT_() {
|
||||||
|
@ -22,6 +22,65 @@ SDRPP_MOD_INFO {
|
|||||||
|
|
||||||
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
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class SDRPlaySourceModule : public ModuleManager::Instance {
|
class SDRPlaySourceModule : public ModuleManager::Instance {
|
||||||
public:
|
public:
|
||||||
SDRPlaySourceModule(std::string name) {
|
SDRPlaySourceModule(std::string name) {
|
||||||
@ -34,7 +93,11 @@ public:
|
|||||||
|
|
||||||
sdrplay_api_Open();
|
sdrplay_api_Open();
|
||||||
|
|
||||||
sampleRate = 8000000.0;
|
sampleRate = 2000000.0;
|
||||||
|
srId = 0;
|
||||||
|
|
||||||
|
bandwidth = sdrplay_api_BW_5_000;
|
||||||
|
bandwidthId = 8;
|
||||||
|
|
||||||
handler.ctx = this;
|
handler.ctx = this;
|
||||||
handler.selectHandler = menuSelected;
|
handler.selectHandler = menuSelected;
|
||||||
@ -52,8 +115,6 @@ public:
|
|||||||
// sampleRate = sampleRateList[0];
|
// sampleRate = sampleRateList[0];
|
||||||
// }
|
// }
|
||||||
|
|
||||||
sampleRate = 8000000;
|
|
||||||
|
|
||||||
// Select device from config
|
// Select device from config
|
||||||
// config.aquire();
|
// config.aquire();
|
||||||
// std::string devSerial = config.conf["device"];
|
// std::string devSerial = config.conf["device"];
|
||||||
@ -119,10 +180,19 @@ public:
|
|||||||
selectDev(devList[0]);
|
selectDev(devList[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void selectById(int id) {
|
||||||
|
selectDev(devList[id]);
|
||||||
|
}
|
||||||
|
|
||||||
void selectDev(sdrplay_api_DeviceT dev) {
|
void selectDev(sdrplay_api_DeviceT dev) {
|
||||||
openDev = dev;
|
openDev = dev;
|
||||||
sdrplay_api_ErrT err;
|
sdrplay_api_ErrT err;
|
||||||
|
|
||||||
|
if (deviceOpen) {
|
||||||
|
sdrplay_api_Uninit(openDev.dev);
|
||||||
|
sdrplay_api_ReleaseDevice(&openDev);
|
||||||
|
}
|
||||||
|
|
||||||
err = sdrplay_api_SelectDevice(&openDev);
|
err = sdrplay_api_SelectDevice(&openDev);
|
||||||
if (err != sdrplay_api_Success) {
|
if (err != sdrplay_api_Success) {
|
||||||
const char* errStr = sdrplay_api_GetErrorString(err);
|
const char* errStr = sdrplay_api_GetErrorString(err);
|
||||||
@ -188,13 +258,16 @@ private:
|
|||||||
_this->bufferIndex = 0;
|
_this->bufferIndex = 0;
|
||||||
_this->bufferSize = 8000000 / 200;
|
_this->bufferSize = 8000000 / 200;
|
||||||
|
|
||||||
_this->openDevParams->devParams->fsFreq.fsHz = 8000000;
|
_this->openDevParams->devParams->fsFreq.fsHz = _this->sampleRate;
|
||||||
_this->openDevParams->rxChannelA->tunerParams.bwType = sdrplay_api_BW_8_000;
|
_this->openDevParams->rxChannelA->tunerParams.bwType = _this->bandwidth;
|
||||||
_this->openDevParams->rxChannelA->tunerParams.rfFreq.rfHz = _this->freq;
|
_this->openDevParams->rxChannelA->tunerParams.rfFreq.rfHz = _this->freq;
|
||||||
_this->openDevParams->rxChannelA->tunerParams.gain.gRdB = 59;
|
_this->openDevParams->rxChannelA->tunerParams.gain.gRdB = _this->gain;
|
||||||
_this->openDevParams->rxChannelA->tunerParams.gain.LNAstate = 9;
|
_this->openDevParams->rxChannelA->tunerParams.gain.LNAstate = _this->lnaGain;
|
||||||
_this->openDevParams->rxChannelA->ctrlParams.agc.enable = sdrplay_api_AGC_DISABLE;
|
_this->openDevParams->rxChannelA->ctrlParams.agc.enable = sdrplay_api_AGC_DISABLE;
|
||||||
//_this->openDevParams->devParams->
|
|
||||||
|
// RSP1A Options
|
||||||
|
_this->openDevParams->devParams->rsp1aParams.rfNotchEnable = _this->fmNotch;
|
||||||
|
_this->openDevParams->devParams->rsp1aParams.rfNotchEnable = _this->dabNotch;
|
||||||
|
|
||||||
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Dev_Fs, sdrplay_api_Update_Ext1_None);
|
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Dev_Fs, sdrplay_api_Update_Ext1_None);
|
||||||
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Tuner_BwType, sdrplay_api_Update_Ext1_None);
|
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Tuner_BwType, sdrplay_api_Update_Ext1_None);
|
||||||
@ -202,6 +275,10 @@ private:
|
|||||||
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Tuner_Gr, sdrplay_api_Update_Ext1_None);
|
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Tuner_Gr, sdrplay_api_Update_Ext1_None);
|
||||||
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Ctrl_Agc, sdrplay_api_Update_Ext1_None);
|
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Ctrl_Agc, sdrplay_api_Update_Ext1_None);
|
||||||
|
|
||||||
|
// RSP1A Options
|
||||||
|
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Rsp1a_RfNotchControl, sdrplay_api_Update_Ext1_None);
|
||||||
|
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Rsp1a_RfDabNotchControl, sdrplay_api_Update_Ext1_None);
|
||||||
|
|
||||||
_this->running = true;
|
_this->running = true;
|
||||||
spdlog::info("SDRPlaySourceModule '{0}': Start!", _this->name);
|
spdlog::info("SDRPlaySourceModule '{0}': Start!", _this->name);
|
||||||
}
|
}
|
||||||
@ -240,11 +317,30 @@ private:
|
|||||||
|
|
||||||
|
|
||||||
if (ImGui::Combo(CONCAT("##sdrplay_dev", _this->name), &_this->devId, _this->devListTxt.c_str())) {
|
if (ImGui::Combo(CONCAT("##sdrplay_dev", _this->name), &_this->devId, _this->devListTxt.c_str())) {
|
||||||
|
_this->selectById(_this->devId);
|
||||||
|
// Save config
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
ImGui::SetNextItemWidth(menuWidth);
|
||||||
|
if (ImGui::Combo(CONCAT("##sdrplay_sr", _this->name), &_this->srId, sampleRatesTxt)) {
|
||||||
|
_this->sampleRate = sampleRates[_this->srId];
|
||||||
|
core::setInputSampleRate(_this->sampleRate);
|
||||||
|
// Save config
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_this->running) { style::endDisabled(); }
|
if (_this->running) { style::endDisabled(); }
|
||||||
|
|
||||||
|
ImGui::SetNextItemWidth(menuWidth);
|
||||||
|
if (ImGui::Combo(CONCAT("##sdrplay_bw", _this->name), &_this->bandwidthId, bandwidthsTxt)) {
|
||||||
|
_this->bandwidth = (_this->bandwidthId == 8) ? preferedBandwidth[_this->srId] : bandwidths[_this->bandwidthId];
|
||||||
|
if (_this->running) {
|
||||||
|
_this->openDevParams->rxChannelA->tunerParams.bwType = _this->bandwidth;
|
||||||
|
sdrplay_api_Update(_this->openDev.dev, _this->openDev.tuner, sdrplay_api_Update_Tuner_BwType, sdrplay_api_Update_Ext1_None);
|
||||||
|
}
|
||||||
|
// Save config
|
||||||
|
}
|
||||||
|
|
||||||
if (_this->deviceOpen) {
|
if (_this->deviceOpen) {
|
||||||
switch (_this->openDev.hwVer) {
|
switch (_this->openDev.hwVer) {
|
||||||
case SDRPLAY_RSP1_ID:
|
case SDRPLAY_RSP1_ID:
|
||||||
@ -281,23 +377,28 @@ private:
|
|||||||
ImGui::Text("LNA Gain");
|
ImGui::Text("LNA Gain");
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
float pos = ImGui::GetCursorPosX();
|
float pos = ImGui::GetCursorPosX();
|
||||||
if (ImGui::SliderInt(CONCAT("##sdrplay_lna_gain", name), &gainTest, 9, 0, "")) {
|
if (ImGui::SliderInt(CONCAT("##sdrplay_lna_gain", name), &lnaGain, 9, 0, "")) {
|
||||||
openDevParams->rxChannelA->tunerParams.gain.LNAstate = gainTest;
|
openDevParams->rxChannelA->tunerParams.gain.LNAstate = lnaGain;
|
||||||
sdrplay_api_Update(openDev.dev, openDev.tuner, sdrplay_api_Update_Tuner_Gr, sdrplay_api_Update_Ext1_None);
|
sdrplay_api_Update(openDev.dev, openDev.tuner, sdrplay_api_Update_Tuner_Gr, sdrplay_api_Update_Ext1_None);
|
||||||
}
|
}
|
||||||
|
|
||||||
ImGui::Text("IF Gain");
|
ImGui::Text("IF Gain");
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
ImGui::SetCursorPosX(pos);
|
ImGui::SetCursorPosX(pos);
|
||||||
if (ImGui::SliderInt(CONCAT("##sdrplay_gain", name), &gainTest2, 59, 20, "")) {
|
if (ImGui::SliderInt(CONCAT("##sdrplay_gain", name), &gain, 59, 20, "")) {
|
||||||
openDevParams->rxChannelA->tunerParams.gain.gRdB = gainTest2;
|
openDevParams->rxChannelA->tunerParams.gain.gRdB = gain;
|
||||||
sdrplay_api_Update(openDev.dev, openDev.tuner, sdrplay_api_Update_Tuner_Gr, sdrplay_api_Update_Ext1_None);
|
sdrplay_api_Update(openDev.dev, openDev.tuner, sdrplay_api_Update_Tuner_Gr, sdrplay_api_Update_Ext1_None);
|
||||||
}
|
}
|
||||||
ImGui::PopItemWidth();
|
ImGui::PopItemWidth();
|
||||||
|
|
||||||
bool test = false;
|
if (ImGui::Checkbox("FM Notch", &fmNotch)) {
|
||||||
ImGui::Checkbox("FM Notch", &test);
|
openDevParams->devParams->rsp1aParams.rfNotchEnable = fmNotch;
|
||||||
ImGui::Checkbox("DAB Notch", &test);
|
sdrplay_api_Update(openDev.dev, openDev.tuner, sdrplay_api_Update_Rsp1a_RfNotchControl, sdrplay_api_Update_Ext1_None);
|
||||||
|
}
|
||||||
|
if (ImGui::Checkbox("DAB Notch", &dabNotch)) {
|
||||||
|
openDevParams->devParams->rsp1aParams.rfNotchEnable = dabNotch;
|
||||||
|
sdrplay_api_Update(openDev.dev, openDev.tuner, sdrplay_api_Update_Rsp1a_RfDabNotchControl, sdrplay_api_Update_Ext1_None);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSP2Menu(float menuWidth) {
|
void RSP2Menu(float menuWidth) {
|
||||||
@ -351,19 +452,24 @@ private:
|
|||||||
sdrplay_api_DeviceT openDev;
|
sdrplay_api_DeviceT openDev;
|
||||||
sdrplay_api_DeviceParamsT * openDevParams;
|
sdrplay_api_DeviceParamsT * openDevParams;
|
||||||
|
|
||||||
|
sdrplay_api_Bw_MHzT bandwidth;
|
||||||
|
int bandwidthId = 0;
|
||||||
|
|
||||||
int devId = 0;
|
int devId = 0;
|
||||||
int srId = 0;
|
int srId = 0;
|
||||||
|
|
||||||
int gainTest = 9;
|
int lnaGain = 9;
|
||||||
int gainTest2 = 59;
|
int gain = 59;
|
||||||
|
|
||||||
int bufferSize = 0;
|
int bufferSize = 0;
|
||||||
int bufferIndex = 0;
|
int bufferIndex = 0;
|
||||||
|
|
||||||
|
// RSP1A Options
|
||||||
|
bool fmNotch = false;
|
||||||
|
bool dabNotch = false;
|
||||||
|
|
||||||
std::vector<sdrplay_api_DeviceT> devList;
|
std::vector<sdrplay_api_DeviceT> devList;
|
||||||
std::string devListTxt;
|
std::string devListTxt;
|
||||||
std::vector<uint32_t> sampleRateList;
|
|
||||||
std::string sampleRateListTxt;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
MOD_EXPORT void _INIT_() {
|
MOD_EXPORT void _INIT_() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user