kopia lustrzana https://github.com/f4exb/sdrangel
				
				
				
			Deep redesign: revised source serialization mechanism and use dedicated classes for this purpose
							rodzic
							
								
									f4f9a74269
								
							
						
					
					
						commit
						5f0056f442
					
				|  | @ -113,6 +113,7 @@ set(sdrbase_SOURCES | ||||||
| 	sdrbase/util/messagequeue.cpp | 	sdrbase/util/messagequeue.cpp | ||||||
| 	sdrbase/util/syncmessenger.cpp | 	sdrbase/util/syncmessenger.cpp | ||||||
| 	#sdrbase/util/miniz.cpp | 	#sdrbase/util/miniz.cpp | ||||||
|  | 	sdrbase/util/samplesourceserializer.cpp | ||||||
| 	sdrbase/util/simpleserializer.cpp | 	sdrbase/util/simpleserializer.cpp | ||||||
| 	sdrbase/util/spinlock.cpp | 	sdrbase/util/spinlock.cpp | ||||||
| ) | ) | ||||||
|  | @ -189,6 +190,7 @@ set(sdrbase_HEADERS | ||||||
| 	include/util/messagequeue.h | 	include/util/messagequeue.h | ||||||
| 	include/util/syncmessenger.h | 	include/util/syncmessenger.h | ||||||
| 	#include/util/miniz.h | 	#include/util/miniz.h | ||||||
|  | 	include/util/samplesourceserializer.h | ||||||
| 	include/util/simpleserializer.h | 	include/util/simpleserializer.h | ||||||
| 	include/util/spinlock.h | 	include/util/spinlock.h | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | @ -0,0 +1,49 @@ | ||||||
|  | ///////////////////////////////////////////////////////////////////////////////////
 | ||||||
|  | // Copyright (C) 2015 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                  //
 | ||||||
|  | //                                                                               //
 | ||||||
|  | // 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_UTIL_SAMPLESOURCESERIALIZER_H_ | ||||||
|  | #define INCLUDE_UTIL_SAMPLESOURCESERIALIZER_H_ | ||||||
|  | 
 | ||||||
|  | #include "util/simpleserializer.h" | ||||||
|  | 
 | ||||||
|  | class SampleSourceSerializer | ||||||
|  | { | ||||||
|  | public: | ||||||
|  | 	struct Data | ||||||
|  | 	{ | ||||||
|  | 		quint64 m_frequency; //!< RF center frequency
 | ||||||
|  | 		qint32 m_correction; //!< LO correction factor
 | ||||||
|  | 		qint32 m_rate;       //!< RF sampler sample rate
 | ||||||
|  | 		quint32 m_log2Decim; //!< Decimation ratio log2
 | ||||||
|  | 		qint32 m_bandwidth;  //!< RF bandwidth
 | ||||||
|  | 		qint32 m_fcPosition; //!< Decimated band placement (infradyne, supradyne, centered)
 | ||||||
|  | 		qint32 m_lnaGain;    //!< RF LNA gain
 | ||||||
|  | 		qint32 m_RxGain1;    //!< Rx first stage amplifier gain
 | ||||||
|  | 		qint32 m_RxGain2;    //!< Rx second stage amplifier gain
 | ||||||
|  | 		qint32 m_RxGain3;    //!< Rx third stage amplifier gain
 | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  | 	static void writeSerializedData(const Data& data, QByteArray& serializedData); | ||||||
|  | 	static bool readSerializedData(const QByteArray& serializedData, Data& data); | ||||||
|  | 	static void setDefaults(Data& data); | ||||||
|  | 
 | ||||||
|  | protected: | ||||||
|  | 	static const uint m_version; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #endif /* INCLUDE_UTIL_SAMPLESOURCESERIALIZER_H_ */ | ||||||
|  | @ -4,6 +4,7 @@ set(bladerf_SOURCES | ||||||
| 	bladerfgui.cpp | 	bladerfgui.cpp | ||||||
| 	bladerfinput.cpp | 	bladerfinput.cpp | ||||||
| 	bladerfplugin.cpp | 	bladerfplugin.cpp | ||||||
|  | 	bladerfserializer.cpp | ||||||
| 	bladerfthread.cpp | 	bladerfthread.cpp | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | @ -11,6 +12,7 @@ set(bladerf_HEADERS | ||||||
| 	bladerfgui.h | 	bladerfgui.h | ||||||
| 	bladerfinput.h | 	bladerfinput.h | ||||||
| 	bladerfplugin.h | 	bladerfplugin.h | ||||||
|  | 	bladerfserializer.h | ||||||
| 	bladerfthread.h | 	bladerfthread.h | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -23,6 +23,7 @@ | ||||||
| #include "bladerfgui.h" | #include "bladerfgui.h" | ||||||
| #include "bladerfinput.h" | #include "bladerfinput.h" | ||||||
| #include "bladerfthread.h" | #include "bladerfthread.h" | ||||||
|  | #include "bladerfserializer.h" | ||||||
| 
 | 
 | ||||||
| MESSAGE_CLASS_DEFINITION(BladerfInput::MsgConfigureBladerf, Message) | MESSAGE_CLASS_DEFINITION(BladerfInput::MsgConfigureBladerf, Message) | ||||||
| MESSAGE_CLASS_DEFINITION(BladerfInput::MsgReportBladerf, Message) | MESSAGE_CLASS_DEFINITION(BladerfInput::MsgReportBladerf, Message) | ||||||
|  | @ -52,62 +53,53 @@ void BladerfInput::Settings::resetToDefaults() | ||||||
| 	m_bandwidth = 1500000; | 	m_bandwidth = 1500000; | ||||||
| 	m_log2Decim = 0; | 	m_log2Decim = 0; | ||||||
| 	m_fcPos = FC_POS_INFRA; | 	m_fcPos = FC_POS_INFRA; | ||||||
| 	m_xb200 = false; | 		m_xb200 = false; | ||||||
| 	m_xb200Path = BLADERF_XB200_MIX; | 		m_xb200Path = BLADERF_XB200_MIX; | ||||||
| 	m_xb200Filter = BLADERF_XB200_AUTO_1DB; | 		m_xb200Filter = BLADERF_XB200_AUTO_1DB; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QByteArray BladerfInput::Settings::serialize() const | QByteArray BladerfInput::Settings::serialize() const | ||||||
| { | { | ||||||
| 	SimpleSerializer s(1); | 	BladeRFSerializer::BladeRFData data; | ||||||
| 	s.writeS32(1, m_lnaGain); | 
 | ||||||
| 	s.writeS32(2, m_vga1); | 	data.m_data.m_lnaGain = m_lnaGain; | ||||||
| 	s.writeS32(3, m_vga2); | 	data.m_data.m_RxGain1 = m_vga1; | ||||||
| 	s.writeU32(4, m_log2Decim); | 	data.m_data.m_RxGain2 = m_vga2; | ||||||
| 	s.writeBool(5, m_xb200); | 	data.m_data.m_log2Decim = m_log2Decim; | ||||||
| 	s.writeS32(6, (int) m_xb200Path); | 	data.m_xb200 = m_xb200; | ||||||
| 	s.writeS32(7, (int) m_xb200Filter); | 	data.m_xb200Path = (int) m_xb200Path; | ||||||
| 	s.writeS32(8, m_bandwidth); | 	data.m_xb200Filter = (int) m_xb200Filter; | ||||||
| 	s.writeS32(9, (int) m_fcPos); | 	data.m_data.m_bandwidth = m_bandwidth; | ||||||
| 	s.writeU64(10, m_centerFrequency); | 	data.m_data.m_fcPosition = (int) m_fcPos; | ||||||
| 	s.writeS32(11, m_devSampleRate); | 	data.m_data.m_frequency = m_centerFrequency; | ||||||
| 	return s.final(); | 	data.m_data.m_rate = m_devSampleRate; | ||||||
|  | 
 | ||||||
|  | 	QByteArray byteArray; | ||||||
|  | 
 | ||||||
|  | 	BladeRFSerializer::writeSerializedData(data, byteArray); | ||||||
|  | 
 | ||||||
|  | 	return byteArray; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool BladerfInput::Settings::deserialize(const QByteArray& data) | bool BladerfInput::Settings::deserialize(const QByteArray& serializedData) | ||||||
| { | { | ||||||
| 	SimpleDeserializer d(data); | 	BladeRFSerializer::BladeRFData data; | ||||||
| 
 | 
 | ||||||
| 	if (!d.isValid()) | 	bool valid = BladeRFSerializer::readSerializedData(serializedData, data); | ||||||
| 	{ |  | ||||||
| 		resetToDefaults(); |  | ||||||
| 		return false; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	if (d.getVersion() == 1) | 	m_lnaGain = data.m_data.m_lnaGain; | ||||||
| 	{ | 	m_vga1 = data.m_data.m_RxGain1; | ||||||
| 		int intval; | 	m_vga2 = data.m_data.m_RxGain2; | ||||||
| 		d.readS32(1, &m_lnaGain, 0); | 	m_log2Decim = data.m_data.m_log2Decim; | ||||||
| 		d.readS32(2, &m_vga1, 20); | 	m_xb200 = data.m_xb200; | ||||||
| 		d.readS32(3, &m_vga2, 9); | 	m_xb200Path = (bladerf_xb200_path) data.m_xb200Path; | ||||||
| 		d.readU32(4, &m_log2Decim, 0); | 	m_xb200Filter = (bladerf_xb200_filter) data.m_xb200Filter; | ||||||
| 		d.readBool(5, &m_xb200); | 	m_bandwidth = data.m_data.m_bandwidth; | ||||||
| 		d.readS32(6, &intval); | 	m_fcPos = (fcPos_t) data.m_data.m_fcPosition; | ||||||
| 		m_xb200Path = (bladerf_xb200_path) intval; | 	m_centerFrequency = data.m_data.m_frequency; | ||||||
| 		d.readS32(7, &intval); | 	m_devSampleRate = data.m_data.m_rate; | ||||||
| 		m_xb200Filter = (bladerf_xb200_filter) intval; | 
 | ||||||
| 		d.readS32(8, &m_bandwidth, 0); | 	return valid; | ||||||
| 		d.readS32(9, &intval, 0); |  | ||||||
| 		m_fcPos = (fcPos_t) intval; |  | ||||||
| 		d.readU64(10, &m_centerFrequency, 435000*1000); |  | ||||||
| 		d.readS32(11, &m_devSampleRate, 3072000); |  | ||||||
| 		return true; |  | ||||||
| 	} |  | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
| 		resetToDefaults(); |  | ||||||
| 		return false; |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| BladerfInput::BladerfInput() : | BladerfInput::BladerfInput() : | ||||||
|  |  | ||||||
|  | @ -0,0 +1,74 @@ | ||||||
|  | ///////////////////////////////////////////////////////////////////////////////////
 | ||||||
|  | // Copyright (C) 2015 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                  //
 | ||||||
|  | //                                                                               //
 | ||||||
|  | // 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 "bladerfinput.h" | ||||||
|  | #include "bladerfserializer.h" | ||||||
|  | 
 | ||||||
|  | void BladeRFSerializer::writeSerializedData(const BladeRFData& data, QByteArray& serializedData) | ||||||
|  | { | ||||||
|  | 	QByteArray sampleSourceSerialized; | ||||||
|  | 	SampleSourceSerializer::writeSerializedData(data.m_data, sampleSourceSerialized); | ||||||
|  | 
 | ||||||
|  | 	SimpleSerializer s(1); | ||||||
|  | 
 | ||||||
|  | 	s.writeBlob(1, sampleSourceSerialized); | ||||||
|  | 	s.writeBool(2, data.m_xb200); | ||||||
|  | 	s.writeS32(3, (int) data.m_xb200Path); | ||||||
|  | 	s.writeS32(4, (int) data.m_xb200Filter); | ||||||
|  | 
 | ||||||
|  | 	serializedData = s.final(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool BladeRFSerializer::readSerializedData(const QByteArray& serializedData, BladeRFData& data) | ||||||
|  | { | ||||||
|  | 	bool valid = SampleSourceSerializer::readSerializedData(serializedData, data.m_data); | ||||||
|  | 
 | ||||||
|  | 	QByteArray sampleSourceSerialized; | ||||||
|  | 
 | ||||||
|  | 	SimpleDeserializer d(serializedData); | ||||||
|  | 
 | ||||||
|  | 	if (!d.isValid()) | ||||||
|  | 	{ | ||||||
|  | 		setDefaults(data); | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if (d.getVersion() == m_version) | ||||||
|  | 	{ | ||||||
|  | 		int intval; | ||||||
|  | 
 | ||||||
|  | 		d.readBlob(1, &sampleSourceSerialized); | ||||||
|  | 		d.readBool(2, &data.m_xb200); | ||||||
|  | 		d.readS32(3, &intval); | ||||||
|  | 		data.m_xb200Path = (bladerf_xb200_path) intval; | ||||||
|  | 		d.readS32(4, &intval); | ||||||
|  | 		data.m_xb200Filter = (bladerf_xb200_filter) intval; | ||||||
|  | 
 | ||||||
|  | 		return SampleSourceSerializer::readSerializedData(sampleSourceSerialized, data.m_data); | ||||||
|  | 	} | ||||||
|  | 	else | ||||||
|  | 	{ | ||||||
|  | 		setDefaults(data); | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void BladeRFSerializer::setDefaults(BladeRFData& data) | ||||||
|  | { | ||||||
|  | 	data.m_xb200 = false; | ||||||
|  | 	data.m_xb200Path = BLADERF_XB200_MIX; | ||||||
|  | 	data.m_xb200Filter = BLADERF_XB200_AUTO_1DB; | ||||||
|  | } | ||||||
|  | @ -0,0 +1,39 @@ | ||||||
|  | ///////////////////////////////////////////////////////////////////////////////////
 | ||||||
|  | // Copyright (C) 2015 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                  //
 | ||||||
|  | //                                                                               //
 | ||||||
|  | // 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 PLUGINS_SAMPLESOURCE_BLADERF_BLADERFSERIALIZER_H_ | ||||||
|  | #define PLUGINS_SAMPLESOURCE_BLADERF_BLADERFSERIALIZER_H_ | ||||||
|  | 
 | ||||||
|  | #include "util/samplesourceserializer.h" | ||||||
|  | 
 | ||||||
|  | class BladeRFSerializer : public SampleSourceSerializer | ||||||
|  | { | ||||||
|  | public: | ||||||
|  | 	struct BladeRFData | ||||||
|  | 	{ | ||||||
|  | 		Data m_data; | ||||||
|  | 		bool m_xb200; | ||||||
|  | 		quint32 m_xb200Path; | ||||||
|  | 		quint32 m_xb200Filter; | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  | 	static void writeSerializedData(const BladeRFData& data, QByteArray& serializedData); | ||||||
|  | 	static bool readSerializedData(const QByteArray& serializedData, BladeRFData& data); | ||||||
|  | 	static void setDefaults(BladeRFData& data); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #endif /* PLUGINS_SAMPLESOURCE_BLADERF_BLADERFSERIALIZER_H_ */ | ||||||
|  | @ -0,0 +1,83 @@ | ||||||
|  | ///////////////////////////////////////////////////////////////////////////////////
 | ||||||
|  | // Copyright (C) 2015 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                  //
 | ||||||
|  | //                                                                               //
 | ||||||
|  | // 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 "util/samplesourceserializer.h" | ||||||
|  | 
 | ||||||
|  | const uint SampleSourceSerializer::m_version = 1; | ||||||
|  | 
 | ||||||
|  | void SampleSourceSerializer::writeSerializedData(const Data& data, QByteArray& serializedData) | ||||||
|  | { | ||||||
|  | 	SimpleSerializer s(1); | ||||||
|  | 
 | ||||||
|  | 	s.writeU64(1, data.m_frequency); | ||||||
|  | 	s.writeS32(2, data.m_correction); | ||||||
|  | 	s.writeS32(3, data.m_rate); | ||||||
|  | 	s.writeU32(4, data.m_log2Decim); | ||||||
|  | 	s.writeS32(5, data.m_bandwidth); | ||||||
|  | 	s.writeS32(6, data.m_fcPosition); | ||||||
|  | 	s.writeS32(7, data.m_lnaGain); | ||||||
|  | 	s.writeS32(8, data.m_RxGain1); | ||||||
|  | 	s.writeS32(9, data.m_RxGain2); | ||||||
|  | 	s.writeS32(10, data.m_RxGain3); | ||||||
|  | 
 | ||||||
|  | 	serializedData = s.final(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool SampleSourceSerializer::readSerializedData(const QByteArray& serializedData, Data& data) | ||||||
|  | { | ||||||
|  | 	SimpleDeserializer d(serializedData); | ||||||
|  | 
 | ||||||
|  | 	if (!d.isValid()) | ||||||
|  | 	{ | ||||||
|  | 		setDefaults(data); | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if (d.getVersion() == m_version) | ||||||
|  | 	{ | ||||||
|  | 		d.readU64(1, &data.m_frequency, 0); | ||||||
|  | 		d.readS32(2, &data.m_correction, 0); | ||||||
|  | 		d.readS32(3, &data.m_rate, 0); | ||||||
|  | 		d.readU32(4, &data.m_log2Decim, 0); | ||||||
|  | 		d.readS32(5, &data.m_bandwidth, 0); | ||||||
|  | 		d.readS32(6, &data.m_fcPosition, 0); | ||||||
|  | 		d.readS32(7, &data.m_lnaGain, 0); | ||||||
|  | 		d.readS32(8, &data.m_RxGain1, 0); | ||||||
|  | 		d.readS32(9, &data.m_RxGain2, 0); | ||||||
|  | 		d.readS32(10, &data.m_RxGain3, 0); | ||||||
|  | 
 | ||||||
|  | 		return true; | ||||||
|  | 	} | ||||||
|  | 	else | ||||||
|  | 	{ | ||||||
|  | 		setDefaults(data); | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void SampleSourceSerializer::setDefaults(Data& data) | ||||||
|  | { | ||||||
|  | 	data.m_frequency = 0; | ||||||
|  | 	data.m_correction = 0; | ||||||
|  | 	data.m_rate = 0; | ||||||
|  | 	data.m_log2Decim = 0; | ||||||
|  | 	data.m_bandwidth = 0; | ||||||
|  | 	data.m_fcPosition = 0; | ||||||
|  | 	data.m_lnaGain = 0; | ||||||
|  | 	data.m_RxGain1 = 0; | ||||||
|  | 	data.m_RxGain2 = 0; | ||||||
|  | 	data.m_RxGain3 = 0; | ||||||
|  | } | ||||||
		Ładowanie…
	
		Reference in New Issue
	
	 f4exb
						f4exb