From 2287564752aecfdf4c0e3ccb3ee9b4d0c98b15b4 Mon Sep 17 00:00:00 2001 From: Carles Fernandez Date: Fri, 1 Oct 2021 12:52:29 +0200 Subject: [PATCH] Make the address sanitizer happy --- .../gps_l1_ca_pcps_assisted_acquisition.cc | 2 +- ...o_e5a_noncoherent_iq_acquisition_caf_cc.cc | 24 +++++++++---------- .../pcps_acquisition_fine_doppler_cc.cc | 6 ++--- .../pcps_assisted_acquisition_cc.cc | 2 +- .../pcps_cccwsr_acquisition_cc.cc | 14 +++++------ .../pcps_opencl_acquisition_cc.cc | 4 ++-- .../pcps_quicksync_acquisition_cc.cc | 18 +++++++------- .../pcps_tong_acquisition_cc.cc | 4 ++-- .../input_filter/adapters/fir_filter.cc | 6 +---- .../adapters/freq_xlating_fir_filter.cc | 6 +---- .../gnuradio_blocks/signal_generator_c.cc | 2 +- .../gnuradio_blocks/dll_pll_veml_tracking.cc | 8 +++---- .../dll_pll_veml_tracking_fpga.cc | 8 +++---- .../tracking/libs/fpga_multicorrelator.cc | 8 +++---- 14 files changed, 52 insertions(+), 60 deletions(-) diff --git a/src/algorithms/acquisition/adapters/gps_l1_ca_pcps_assisted_acquisition.cc b/src/algorithms/acquisition/adapters/gps_l1_ca_pcps_assisted_acquisition.cc index 8d731a394..da6b57597 100644 --- a/src/algorithms/acquisition/adapters/gps_l1_ca_pcps_assisted_acquisition.cc +++ b/src/algorithms/acquisition/adapters/gps_l1_ca_pcps_assisted_acquisition.cc @@ -57,7 +57,7 @@ GpsL1CaPcpsAssistedAcquisition::GpsL1CaPcpsAssistedAcquisition( // --- Find number of samples per spreading code ------------------------- vector_length_ = static_cast(round(fs_in_ / (GPS_L1_CA_CODE_RATE_CPS / GPS_L1_CA_CODE_LENGTH_CHIPS))); - code_.reserve(vector_length_); + code_ = std::vector>(vector_length_); if (item_type_ == "gr_complex") { diff --git a/src/algorithms/acquisition/gnuradio_blocks/galileo_e5a_noncoherent_iq_acquisition_caf_cc.cc b/src/algorithms/acquisition/gnuradio_blocks/galileo_e5a_noncoherent_iq_acquisition_caf_cc.cc index 4994c300b..538a2e6d6 100644 --- a/src/algorithms/acquisition/gnuradio_blocks/galileo_e5a_noncoherent_iq_acquisition_caf_cc.cc +++ b/src/algorithms/acquisition/gnuradio_blocks/galileo_e5a_noncoherent_iq_acquisition_caf_cc.cc @@ -96,25 +96,25 @@ galileo_e5a_noncoherentIQ_acquisition_caf_cc::galileo_e5a_noncoherentIQ_acquisit d_CAF_window_hz = CAF_window_hz_; d_enable_monitor_output = enable_monitor_output; - d_inbuffer.reserve(d_fft_size); - d_fft_code_I_A.reserve(d_fft_size); - d_magnitudeIA.reserve(d_fft_size); + d_inbuffer = std::vector(d_fft_size); + d_fft_code_I_A = std::vector(d_fft_size); + d_magnitudeIA = std::vector(d_fft_size); if (d_both_signal_components == true) { - d_fft_code_Q_A.reserve(d_fft_size); - d_magnitudeQA.reserve(d_fft_size); + d_fft_code_Q_A = std::vector(d_fft_size); + d_magnitudeQA = std::vector(d_fft_size); } // IF COHERENT INTEGRATION TIME > 1 if (d_sampled_ms > 1) { - d_fft_code_I_B.reserve(d_fft_size); - d_magnitudeIB.reserve(d_fft_size); + d_fft_code_I_B = std::vector(d_fft_size); + d_magnitudeIB = std::vector(d_fft_size); if (d_both_signal_components == true) { - d_fft_code_Q_B.reserve(d_fft_size); - d_magnitudeQB.reserve(d_fft_size); + d_fft_code_Q_B = std::vector(d_fft_size); + d_magnitudeQB = std::vector(d_fft_size); } } @@ -244,11 +244,11 @@ void galileo_e5a_noncoherentIQ_acquisition_caf_cc::init() * separately before non-coherent integration */ if (d_CAF_window_hz > 0) { - d_CAF_vector.reserve(d_num_doppler_bins); - d_CAF_vector_I.reserve(d_num_doppler_bins); + d_CAF_vector = std::vector(d_num_doppler_bins); + d_CAF_vector_I = std::vector(d_num_doppler_bins); if (d_both_signal_components == true) { - d_CAF_vector_Q.reserve(d_num_doppler_bins); + d_CAF_vector_Q = std::vector(d_num_doppler_bins); } } } diff --git a/src/algorithms/acquisition/gnuradio_blocks/pcps_acquisition_fine_doppler_cc.cc b/src/algorithms/acquisition/gnuradio_blocks/pcps_acquisition_fine_doppler_cc.cc index fa02b1c74..a52e99520 100644 --- a/src/algorithms/acquisition/gnuradio_blocks/pcps_acquisition_fine_doppler_cc.cc +++ b/src/algorithms/acquisition/gnuradio_blocks/pcps_acquisition_fine_doppler_cc.cc @@ -55,9 +55,9 @@ pcps_acquisition_fine_doppler_cc::pcps_acquisition_fine_doppler_cc(const Acq_Con d_max_dwells = conf_.max_dwells; d_gnuradio_forecast_samples = d_fft_size; d_state = 0; - d_fft_codes.reserve(d_fft_size); - d_magnitude.reserve(d_fft_size); - d_10_ms_buffer.reserve(50 * d_samples_per_ms); + d_fft_codes = volk_gnsssdr::vector(d_fft_size); + d_magnitude = volk_gnsssdr::vector(d_fft_size); + d_10_ms_buffer = volk_gnsssdr::vector(50 * d_samples_per_ms); d_fft_if = gnss_fft_fwd_make_unique(d_fft_size); d_ifft = gnss_fft_rev_make_unique(d_fft_size); diff --git a/src/algorithms/acquisition/gnuradio_blocks/pcps_assisted_acquisition_cc.cc b/src/algorithms/acquisition/gnuradio_blocks/pcps_assisted_acquisition_cc.cc index 4f0c8226a..d799a1d59 100644 --- a/src/algorithms/acquisition/gnuradio_blocks/pcps_assisted_acquisition_cc.cc +++ b/src/algorithms/acquisition/gnuradio_blocks/pcps_assisted_acquisition_cc.cc @@ -66,7 +66,7 @@ pcps_assisted_acquisition_cc::pcps_assisted_acquisition_cc( d_input_power = 0.0; d_state = 0; d_disable_assist = false; - d_fft_codes.reserve(d_fft_size); + d_fft_codes = std::vector(d_fft_size); d_fft_if = gnss_fft_fwd_make_unique(d_fft_size); d_ifft = gnss_fft_rev_make_unique(d_fft_size); diff --git a/src/algorithms/acquisition/gnuradio_blocks/pcps_cccwsr_acquisition_cc.cc b/src/algorithms/acquisition/gnuradio_blocks/pcps_cccwsr_acquisition_cc.cc index 86a964c4c..1bf2ea65e 100644 --- a/src/algorithms/acquisition/gnuradio_blocks/pcps_cccwsr_acquisition_cc.cc +++ b/src/algorithms/acquisition/gnuradio_blocks/pcps_cccwsr_acquisition_cc.cc @@ -77,13 +77,13 @@ pcps_cccwsr_acquisition_cc::pcps_cccwsr_acquisition_cc( d_input_power = 0.0; d_num_doppler_bins = 0; - d_fft_code_data.reserve(d_fft_size); - d_fft_code_pilot.reserve(d_fft_size); - d_data_correlation.reserve(d_fft_size); - d_pilot_correlation.reserve(d_fft_size); - d_correlation_plus.reserve(d_fft_size); - d_correlation_minus.reserve(d_fft_size); - d_magnitude.reserve(d_fft_size); + d_fft_code_data = std::vector(d_fft_size); + d_fft_code_pilot = std::vector(d_fft_size); + d_data_correlation = std::vector(d_fft_size); + d_pilot_correlation = std::vector(d_fft_size); + d_correlation_plus = std::vector(d_fft_size); + d_correlation_minus = std::vector(d_fft_size); + d_magnitude = std::vector(d_fft_size); d_fft_if = gnss_fft_fwd_make_unique(d_fft_size); d_ifft = gnss_fft_rev_make_unique(d_fft_size); diff --git a/src/algorithms/acquisition/gnuradio_blocks/pcps_opencl_acquisition_cc.cc b/src/algorithms/acquisition/gnuradio_blocks/pcps_opencl_acquisition_cc.cc index 0465f90db..dcc7db50a 100644 --- a/src/algorithms/acquisition/gnuradio_blocks/pcps_opencl_acquisition_cc.cc +++ b/src/algorithms/acquisition/gnuradio_blocks/pcps_opencl_acquisition_cc.cc @@ -102,8 +102,8 @@ pcps_opencl_acquisition_cc::pcps_opencl_acquisition_cc( d_cl_fft_batch_size = 1; d_in_buffer = std::vector>(d_max_dwells, std::vector(d_fft_size)); - d_magnitude.reserve(d_fft_size); - d_fft_codes.reserve(d_fft_size_pow2); + d_magnitude = std::vector(d_fft_size); + d_fft_codes = std::vector(_fft_size_pow2); d_zero_vector = std::vector(d_fft_size_pow2 - d_fft_size, 0.0); d_opencl = init_opencl_environment("math_kernel.cl"); diff --git a/src/algorithms/acquisition/gnuradio_blocks/pcps_quicksync_acquisition_cc.cc b/src/algorithms/acquisition/gnuradio_blocks/pcps_quicksync_acquisition_cc.cc index dddd8232f..d4047c3fd 100644 --- a/src/algorithms/acquisition/gnuradio_blocks/pcps_quicksync_acquisition_cc.cc +++ b/src/algorithms/acquisition/gnuradio_blocks/pcps_quicksync_acquisition_cc.cc @@ -83,15 +83,14 @@ pcps_quicksync_acquisition_cc::pcps_quicksync_acquisition_cc( // fft size is reduced. d_fft_size = (d_samples_per_code) / d_folding_factor; - d_fft_codes.reserve(d_fft_size); - d_magnitude.reserve(d_samples_per_code * d_folding_factor); - d_magnitude_folded.reserve(d_fft_size); + d_fft_codes = std::vector(d_fft_size); + d_magnitude = std::vector(d_samples_per_code * d_folding_factor); + d_magnitude_folded = std::vector(d_fft_size); + d_possible_delay = std::vector(d_folding_factor); + d_corr_output_f = std::vector(d_folding_factor); - d_possible_delay.reserve(d_folding_factor); - d_corr_output_f.reserve(d_folding_factor); - - /*Create the d_code signal , which would store the values of the code in its - original form to perform later correlation in time domain*/ + // Create the d_code vector, which would store the values of the code in its + // original form to perform later correlation in time domain d_code = std::vector(d_samples_per_code, lv_cmake(0.0F, 0.0F)); d_fft_if = gnss_fft_fwd_make_unique(d_fft_size); @@ -104,7 +103,8 @@ pcps_quicksync_acquisition_cc::pcps_quicksync_acquisition_cc( d_enable_monitor_output = enable_monitor_output; d_code_folded = std::vector(d_fft_size, lv_cmake(0.0F, 0.0F)); - d_signal_folded.reserve(d_fft_size); + + d_signal_folded = std::vector(d_fft_size); d_noise_floor_power = 0; d_doppler_resolution = 0; d_threshold = 0; diff --git a/src/algorithms/acquisition/gnuradio_blocks/pcps_tong_acquisition_cc.cc b/src/algorithms/acquisition/gnuradio_blocks/pcps_tong_acquisition_cc.cc index c2a490a91..c8a56277f 100644 --- a/src/algorithms/acquisition/gnuradio_blocks/pcps_tong_acquisition_cc.cc +++ b/src/algorithms/acquisition/gnuradio_blocks/pcps_tong_acquisition_cc.cc @@ -98,8 +98,8 @@ pcps_tong_acquisition_cc::pcps_tong_acquisition_cc( d_input_power = 0.0; d_num_doppler_bins = 0; - d_fft_codes.reserve(d_fft_size); - d_magnitude.reserve(d_fft_size); + d_fft_codes = std::vector(d_fft_size); + d_magnitude = std::vector(d_fft_size); d_fft_if = gnss_fft_fwd_make_unique(d_fft_size); d_ifft = gnss_fft_rev_make_unique(d_fft_size); diff --git a/src/algorithms/input_filter/adapters/fir_filter.cc b/src/algorithms/input_filter/adapters/fir_filter.cc index 7f42d1ce3..7831bccb9 100644 --- a/src/algorithms/input_filter/adapters/fir_filter.cc +++ b/src/algorithms/input_filter/adapters/fir_filter.cc @@ -187,11 +187,7 @@ void FirFilter::init() // impulse response given a set of band edges, the desired response on // those bands, and the weight given to the error in those bands. const std::vector taps_d = gr::filter::pm_remez(number_of_taps - 1, bands, ampl, error_w, filter_type, grid_density); - taps_.reserve(taps_d.size()); - for (const auto& it : taps_d) - { - taps_.push_back(static_cast(it)); - } + taps_ = std::vector(taps_d.begin(), taps_d.end()); } diff --git a/src/algorithms/input_filter/adapters/freq_xlating_fir_filter.cc b/src/algorithms/input_filter/adapters/freq_xlating_fir_filter.cc index 73b6b9381..6e4c03acc 100644 --- a/src/algorithms/input_filter/adapters/freq_xlating_fir_filter.cc +++ b/src/algorithms/input_filter/adapters/freq_xlating_fir_filter.cc @@ -90,11 +90,7 @@ FreqXlatingFirFilter::FreqXlatingFirFilter(const ConfigurationInterface* configu const int grid_density = configuration->property(role_ + ".grid_density", default_grid_density); const std::vector taps_d = gr::filter::pm_remez(number_of_taps - 1, bands, ampl, error_w, filter_type, grid_density); - taps_.reserve(taps_d.size()); - for (const auto& it : taps_d) - { - taps_.push_back(static_cast(it)); - } + taps_ = std::vector(taps_d.begin(), taps_d.end()); } else { diff --git a/src/algorithms/signal_generator/gnuradio_blocks/signal_generator_c.cc b/src/algorithms/signal_generator/gnuradio_blocks/signal_generator_c.cc index 2f075b98d..7d0f3e511 100644 --- a/src/algorithms/signal_generator/gnuradio_blocks/signal_generator_c.cc +++ b/src/algorithms/signal_generator/gnuradio_blocks/signal_generator_c.cc @@ -87,7 +87,7 @@ void signal_generator_c::init() { work_counter_ = 0; - complex_phase_.reserve(vector_length_); + complex_phase_ = std::vector(vector_length_); start_phase_rad_.reserve(num_sats_); current_data_bit_int_.reserve(num_sats_); ms_counter_.reserve(num_sats_); diff --git a/src/algorithms/tracking/gnuradio_blocks/dll_pll_veml_tracking.cc b/src/algorithms/tracking/gnuradio_blocks/dll_pll_veml_tracking.cc index e8e77e912..c6bd2a059 100644 --- a/src/algorithms/tracking/gnuradio_blocks/dll_pll_veml_tracking.cc +++ b/src/algorithms/tracking/gnuradio_blocks/dll_pll_veml_tracking.cc @@ -434,8 +434,8 @@ dll_pll_veml_tracking::dll_pll_veml_tracking(const Dll_Pll_Conf &conf_) : gr::bl d_n_correlator_taps = 3; } - d_correlator_outs.reserve(d_n_correlator_taps); - d_local_code_shift_chips.reserve(d_n_correlator_taps); + d_correlator_outs = volk_gnsssdr::vector(d_n_correlator_taps); + d_local_code_shift_chips = volk_gnsssdr::vector(d_n_correlator_taps); // map memory pointers of correlator outputs if (d_veml) { @@ -504,13 +504,13 @@ dll_pll_veml_tracking::dll_pll_veml_tracking(const Dll_Pll_Conf &conf_) : gr::bl // CN0 estimation and lock detector buffers d_cn0_estimation_counter = 0; - d_Prompt_buffer.reserve(d_trk_parameters.cn0_samples); + d_Prompt_buffer = volk_gnsssdr::vector(d_trk_parameters.cn0_samples); d_carrier_lock_test = 1.0; d_CN0_SNV_dB_Hz = 0.0; d_carrier_lock_fail_counter = 0; d_code_lock_fail_counter = 0; d_carrier_lock_threshold = d_trk_parameters.carrier_lock_th; - d_Prompt_Data.reserve(1); + d_Prompt_Data = volk_gnsssdr::vector(1); d_cn0_smoother = Exponential_Smoother(); d_cn0_smoother.set_alpha(d_trk_parameters.cn0_smoother_alpha); diff --git a/src/algorithms/tracking/gnuradio_blocks/dll_pll_veml_tracking_fpga.cc b/src/algorithms/tracking/gnuradio_blocks/dll_pll_veml_tracking_fpga.cc index fa5f26047..fce909dff 100644 --- a/src/algorithms/tracking/gnuradio_blocks/dll_pll_veml_tracking_fpga.cc +++ b/src/algorithms/tracking/gnuradio_blocks/dll_pll_veml_tracking_fpga.cc @@ -311,8 +311,8 @@ dll_pll_veml_tracking_fpga::dll_pll_veml_tracking_fpga(const Dll_Pll_Conf_Fpga & d_n_correlator_taps = 3; } - d_correlator_outs.reserve(d_n_correlator_taps); - d_local_code_shift_chips.reserve(d_n_correlator_taps); + d_correlator_outs = volk_gnsssdr::vector(d_n_correlator_taps); + d_local_code_shift_chips = volk_gnsssdr::vector(d_n_correlator_taps); // map memory pointers of correlator outputs if (d_veml) { @@ -371,13 +371,13 @@ dll_pll_veml_tracking_fpga::dll_pll_veml_tracking_fpga(const Dll_Pll_Conf_Fpga & // CN0 estimation and lock detector buffers d_cn0_estimation_counter = 0; - d_Prompt_buffer.reserve(d_trk_parameters.cn0_samples); + d_Prompt_buffer = volk_gnsssdr::vector(d_trk_parameters.cn0_samples); d_carrier_lock_test = 1.0; d_CN0_SNV_dB_Hz = 0.0; d_carrier_lock_fail_counter = 0; d_code_lock_fail_counter = 0; d_carrier_lock_threshold = d_trk_parameters.carrier_lock_th; - d_Prompt_Data.reserve(1); + d_Prompt_Data = volk_gnsssdr::vector(1); d_cn0_smoother = Exponential_Smoother(); d_cn0_smoother.set_alpha(d_trk_parameters.cn0_smoother_alpha); if (d_code_period > 0.0) diff --git a/src/algorithms/tracking/libs/fpga_multicorrelator.cc b/src/algorithms/tracking/libs/fpga_multicorrelator.cc index 3ca164ed8..32dcd7899 100644 --- a/src/algorithms/tracking/libs/fpga_multicorrelator.cc +++ b/src/algorithms/tracking/libs/fpga_multicorrelator.cc @@ -61,13 +61,13 @@ Fpga_Multicorrelator_8sc::Fpga_Multicorrelator_8sc(int32_t n_correlators, // instantiate variable length vectors if (d_track_pilot) { - d_initial_index.reserve(n_correlators + 1); - d_initial_interp_counter.reserve(n_correlators + 1); + d_initial_index = volk_gnsssdr::vector(n_correlators + 1); + d_initial_interp_counter = volk_gnsssdr::vector(n_correlators + 1); } else { - d_initial_index.reserve(n_correlators); - d_initial_interp_counter.reserve(n_correlators); + d_initial_index = volk_gnsssdr::vector(n_correlators); + d_initial_interp_counter = volk_gnsssdr::vector(n_correlators); } d_shifts_chips = nullptr; d_prompt_data_shift = nullptr;