mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-25 10:00:21 -04:00 
			
		
		
		
	PVS-Studio Analysis corrections for serious issues
This commit is contained in:
		
							parent
							
								
									bc50bf9afa
								
							
						
					
					
						commit
						059228e39f
					
				| @ -68,7 +68,7 @@ public slots: | |||||||
| private: | private: | ||||||
| 	QMutex m_startWaitMutex; | 	QMutex m_startWaitMutex; | ||||||
| 	QWaitCondition m_startWaiter; | 	QWaitCondition m_startWaiter; | ||||||
| 	bool m_running; | 	volatile bool m_running; | ||||||
| 
 | 
 | ||||||
|     CM256 m_cm256; |     CM256 m_cm256; | ||||||
|     CM256 *m_cm256p; |     CM256 *m_cm256p; | ||||||
|  | |||||||
| @ -65,7 +65,8 @@ public: | |||||||
| 	    ATV_FM3,  //!< Classical frequency modulation with phase derivative discriminator
 | 	    ATV_FM3,  //!< Classical frequency modulation with phase derivative discriminator
 | ||||||
|         ATV_AM,   //!< Classical amplitude modulation
 |         ATV_AM,   //!< Classical amplitude modulation
 | ||||||
|         ATV_USB,  //!< AM with vestigial lower side band (main signal is in the upper side)
 |         ATV_USB,  //!< AM with vestigial lower side band (main signal is in the upper side)
 | ||||||
|         ATV_LSB   //!< AM with vestigial upper side band (main signal is in the lower side)
 |         ATV_LSB,  //!< AM with vestigial upper side band (main signal is in the lower side)
 | ||||||
|  |         ATV_NONE  //!< No modulation just produces zeros
 | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	struct ATVConfig | 	struct ATVConfig | ||||||
|  | |||||||
| @ -83,7 +83,7 @@ public: | |||||||
| private: | private: | ||||||
|     QMutex m_startWaitMutex; |     QMutex m_startWaitMutex; | ||||||
|     QWaitCondition m_startWaiter; |     QWaitCondition m_startWaiter; | ||||||
|     bool m_running; |     volatile bool m_running; | ||||||
| 
 | 
 | ||||||
|     MessageQueue m_inputMessageQueue; |     MessageQueue m_inputMessageQueue; | ||||||
|     SDRDaemonDataQueue *m_dataQueue; |     SDRDaemonDataQueue *m_dataQueue; | ||||||
|  | |||||||
| @ -395,14 +395,10 @@ unsigned int Bladerf1OutputGui::getXb200Index(bool xb_200, bladerf_xb200_path xb | |||||||
| 			{ | 			{ | ||||||
| 				return 6; | 				return 6; | ||||||
| 			} | 			} | ||||||
| 			else if (xb200Filter == BLADERF_XB200_222M) | 			else // xb200Filter == BLADERF_XB200_222M
 | ||||||
| 			{ | 			{ | ||||||
| 				return 7; | 				return 7; | ||||||
| 			} | 			} | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
| 				return 0; |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	else | 	else | ||||||
|  | |||||||
| @ -303,6 +303,10 @@ bool BladeRF2Output::start() | |||||||
|                 m_deviceShared.m_dev->closeTx(i); |                 m_deviceShared.m_dev->closeTx(i); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             // was used as temporary storage:
 | ||||||
|  |             delete[] fifos; | ||||||
|  |             delete[] log2Interps; | ||||||
|  | 
 | ||||||
|             needsStart = true; |             needsStart = true; | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
| @ -450,6 +454,10 @@ void BladeRF2Output::stop() | |||||||
| 
 | 
 | ||||||
|             bladeRF2OutputThread->startWork(); |             bladeRF2OutputThread->startWork(); | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         // was used as temporary storage:
 | ||||||
|  |         delete[] fifos; | ||||||
|  |         delete[] log2Interps; | ||||||
|     } |     } | ||||||
|     else // remove channel from existing thread
 |     else // remove channel from existing thread
 | ||||||
|     { |     { | ||||||
|  | |||||||
| @ -46,9 +46,13 @@ void UDPSinkFECWorker::startWork() | |||||||
|     qDebug("UDPSinkFECWorker::startWork"); |     qDebug("UDPSinkFECWorker::startWork"); | ||||||
|     m_startWaitMutex.lock(); |     m_startWaitMutex.lock(); | ||||||
|     m_udpSocket = new QUdpSocket(this); |     m_udpSocket = new QUdpSocket(this); | ||||||
|  | 
 | ||||||
|     start(); |     start(); | ||||||
|     while(!m_running) | 
 | ||||||
|  |     while(!m_running) { | ||||||
|         m_startWaiter.wait(&m_startWaitMutex, 100); |         m_startWaiter.wait(&m_startWaitMutex, 100); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     m_startWaitMutex.unlock(); |     m_startWaitMutex.unlock(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -135,7 +135,7 @@ private: | |||||||
| 
 | 
 | ||||||
|     QMutex m_startWaitMutex; |     QMutex m_startWaitMutex; | ||||||
|     QWaitCondition m_startWaiter; |     QWaitCondition m_startWaiter; | ||||||
|     bool m_running; |     volatile bool m_running; | ||||||
|     CM256 m_cm256;                       //!< CM256 library object
 |     CM256 m_cm256;                       //!< CM256 library object
 | ||||||
|     bool m_cm256Valid;                   //!< true if CM256 library is initialized correctly
 |     bool m_cm256Valid;                   //!< true if CM256 library is initialized correctly
 | ||||||
|     QUdpSocket   *m_udpSocket; |     QUdpSocket   *m_udpSocket; | ||||||
|  | |||||||
| @ -463,14 +463,10 @@ unsigned int Bladerf1InputGui::getXb200Index(bool xb_200, bladerf_xb200_path xb2 | |||||||
| 			{ | 			{ | ||||||
| 				return 6; | 				return 6; | ||||||
| 			} | 			} | ||||||
| 			else if (xb200Filter == BLADERF_XB200_222M) | 			else // xb200Filter == BLADERF_XB200_222M
 | ||||||
| 			{ | 			{ | ||||||
| 				return 7; | 				return 7; | ||||||
| 			} | 			} | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
| 				return 0; |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	else | 	else | ||||||
|  | |||||||
| @ -329,6 +329,11 @@ bool BladeRF2Input::start() | |||||||
|                 ((DeviceBladeRF2Shared*) (*it)->getBuddySharedPtr())->m_source->setThread(0); |                 ((DeviceBladeRF2Shared*) (*it)->getBuddySharedPtr())->m_source->setThread(0); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             // was used as temporary storage:
 | ||||||
|  |             delete[] fifos; | ||||||
|  |             delete[] log2Decims; | ||||||
|  |             delete[] fcPoss; | ||||||
|  | 
 | ||||||
|             needsStart = true; |             needsStart = true; | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
| @ -470,6 +475,11 @@ void BladeRF2Input::stop() | |||||||
|         if (stillActiveFIFO) { |         if (stillActiveFIFO) { | ||||||
|             bladerf2InputThread->startWork(); |             bladerf2InputThread->startWork(); | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         // was used as temporary storage:
 | ||||||
|  |         delete[] fifos; | ||||||
|  |         delete[] log2Decims; | ||||||
|  |         delete[] fcPoss; | ||||||
|     } |     } | ||||||
|     else // remove channel from existing thread
 |     else // remove channel from existing thread
 | ||||||
|     { |     { | ||||||
|  | |||||||
| @ -262,13 +262,7 @@ void SDRdaemonSourceUDPHandler::tick() | |||||||
|     const SDRDaemonMetaDataFEC& metaData =  m_sdrDaemonBuffer.getCurrentMeta(); |     const SDRDaemonMetaDataFEC& metaData =  m_sdrDaemonBuffer.getCurrentMeta(); | ||||||
|     m_readLength = m_readLengthSamples * (metaData.m_sampleBytes & 0xF) * 2; |     m_readLength = m_readLengthSamples * (metaData.m_sampleBytes & 0xF) * 2; | ||||||
| 
 | 
 | ||||||
|     if (SDR_RX_SAMP_SZ == metaData.m_sampleBits) // same sample size
 |     if ((metaData.m_sampleBits == 16) && (SDR_RX_SAMP_SZ == 24)) // 16 -> 24 bits
 | ||||||
|     { |  | ||||||
|         // read samples directly feeding the SampleFifo (no callback)
 |  | ||||||
|         m_sampleFifo->write(reinterpret_cast<quint8*>(m_sdrDaemonBuffer.readData(m_readLength)), m_readLength); |  | ||||||
|         m_samplesCount += m_readLengthSamples; |  | ||||||
|     } |  | ||||||
|     else if (metaData.m_sampleBits == 16) // 16 -> 24 bits
 |  | ||||||
|     { |     { | ||||||
|         if (m_readLengthSamples > m_converterBufferNbSamples) |         if (m_readLengthSamples > m_converterBufferNbSamples) | ||||||
|         { |         { | ||||||
| @ -288,7 +282,7 @@ void SDRdaemonSourceUDPHandler::tick() | |||||||
| 
 | 
 | ||||||
|         m_sampleFifo->write(reinterpret_cast<quint8*>(m_converterBuffer), m_readLengthSamples*sizeof(Sample)); |         m_sampleFifo->write(reinterpret_cast<quint8*>(m_converterBuffer), m_readLengthSamples*sizeof(Sample)); | ||||||
|     } |     } | ||||||
|     else if (metaData.m_sampleBits == 24) // 24 -> 16 bits
 |     else if ((metaData.m_sampleBits == 24) && (SDR_RX_SAMP_SZ == 16)) // 24 -> 16 bits
 | ||||||
|     { |     { | ||||||
|         if (m_readLengthSamples > m_converterBufferNbSamples) |         if (m_readLengthSamples > m_converterBufferNbSamples) | ||||||
|         { |         { | ||||||
| @ -307,7 +301,13 @@ void SDRdaemonSourceUDPHandler::tick() | |||||||
| 
 | 
 | ||||||
|         m_sampleFifo->write(reinterpret_cast<quint8*>(m_converterBuffer), m_readLengthSamples*sizeof(Sample)); |         m_sampleFifo->write(reinterpret_cast<quint8*>(m_converterBuffer), m_readLengthSamples*sizeof(Sample)); | ||||||
|     } |     } | ||||||
|     else |     else if ((metaData.m_sampleBits == 16) || (metaData.m_sampleBits == 24)) // same sample size and valid size
 | ||||||
|  |     { | ||||||
|  |         // read samples directly feeding the SampleFifo (no callback)
 | ||||||
|  |         m_sampleFifo->write(reinterpret_cast<quint8*>(m_sdrDaemonBuffer.readData(m_readLength)), m_readLength); | ||||||
|  |         m_samplesCount += m_readLengthSamples; | ||||||
|  |     } | ||||||
|  |     else // invalid size
 | ||||||
|     { |     { | ||||||
|         qWarning("SDRdaemonSourceUDPHandler::tick: unexpected sample size in stream: %d bits", (int) metaData.m_sampleBits); |         qWarning("SDRdaemonSourceUDPHandler::tick: unexpected sample size in stream: %d bits", (int) metaData.m_sampleBits); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -42,13 +42,20 @@ struct SDRDaemonMetaDataFEC | |||||||
|     uint8_t  m_sampleBits;        //!< 10 number of effective bits per sample (deprecated)
 |     uint8_t  m_sampleBits;        //!< 10 number of effective bits per sample (deprecated)
 | ||||||
|     uint8_t  m_nbOriginalBlocks;  //!< 11 number of blocks with original (protected) data
 |     uint8_t  m_nbOriginalBlocks;  //!< 11 number of blocks with original (protected) data
 | ||||||
|     uint8_t  m_nbFECBlocks;       //!< 12 number of blocks carrying FEC
 |     uint8_t  m_nbFECBlocks;       //!< 12 number of blocks carrying FEC
 | ||||||
|  | 
 | ||||||
|     uint32_t m_tv_sec;            //!< 16 seconds of timestamp at start time of super-frame processing
 |     uint32_t m_tv_sec;            //!< 16 seconds of timestamp at start time of super-frame processing
 | ||||||
|     uint32_t m_tv_usec;           //!< 20 microseconds of timestamp at start time of super-frame processing
 |     uint32_t m_tv_usec;           //!< 20 microseconds of timestamp at start time of super-frame processing
 | ||||||
|     uint32_t m_crc32;             //!< 24 CRC32 of the above
 |     uint32_t m_crc32;             //!< 24 CRC32 of the above
 | ||||||
| 
 | 
 | ||||||
|     bool operator==(const SDRDaemonMetaDataFEC& rhs) |     bool operator==(const SDRDaemonMetaDataFEC& rhs) | ||||||
|     { |     { | ||||||
|         return (memcmp((const void *) this, (const void *) &rhs, 12) == 0); // Only the 12 first bytes are relevant
 |         // Only the first 6 fields are relevant
 | ||||||
|  |         return (m_centerFrequency == rhs.m_centerFrequency) | ||||||
|  |             && (m_sampleRate == rhs.m_sampleRate) | ||||||
|  |             && (m_sampleBytes == rhs.m_sampleBytes) | ||||||
|  |             && (m_sampleBits == rhs.m_sampleBits) | ||||||
|  |             && (m_nbOriginalBlocks == rhs.m_nbOriginalBlocks) | ||||||
|  |             && (m_nbFECBlocks == rhs.m_nbFECBlocks); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void init() |     void init() | ||||||
|  | |||||||
| @ -295,7 +295,7 @@ void DownChannelizer::freeFilterChain() | |||||||
| 
 | 
 | ||||||
| void DownChannelizer::debugFilterChain() | void DownChannelizer::debugFilterChain() | ||||||
| { | { | ||||||
|     qDebug("DownChannelizer::debugFilterChain: %lu stages", m_filterStages.size()); |     qDebug("DownChannelizer::debugFilterChain: %u stages", m_filterStages.size()); | ||||||
| 
 | 
 | ||||||
|     for(FilterStages::iterator it = m_filterStages.begin(); it != m_filterStages.end(); ++it) |     for(FilterStages::iterator it = m_filterStages.begin(); it != m_filterStages.end(); ++it) | ||||||
|     { |     { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user