/*! * \file fpga_acquisition.h * \brief High optimized FPGA vector correlator class * \authors * * Class that controls and executes a high optimized acquisition HW * accelerator in the FPGA * * ------------------------------------------------------------------------- * * Copyright (C) 2010-2018 (see AUTHORS file for a list of contributors) * * GNSS-SDR is a software defined Global Navigation * Satellite Systems receiver * * This file is part of GNSS-SDR. * * GNSS-SDR 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, either version 3 of the License, or * (at your option) any later version. * * GNSS-SDR 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 for more details. * * You should have received a copy of the GNU General Public License * along with GNSS-SDR. If not, see . * * ------------------------------------------------------------------------- */ #ifndef GNSS_SDR_FPGA_ACQUISITION_H_ #define GNSS_SDR_FPGA_ACQUISITION_H_ #include #include #include /*! * \brief Class that implements carrier wipe-off and correlators. */ class fpga_acquisition { public: fpga_acquisition(std::string device_name, uint32_t nsamples, uint32_t doppler_max, uint32_t nsamples_total, int64_t fs_in, uint32_t sampled_ms, uint32_t select_queue, lv_16sc_t *all_fft_codes, uint32_t excludelimit); ~fpga_acquisition(); bool init(); bool set_local_code(uint32_t PRN); bool free(); void set_doppler_sweep(uint32_t num_sweeps); //void set_doppler_sweep_debug(uint32_t num_sweeps, uint32_t doppler_index); void run_acquisition(void); void set_phase_step(uint32_t doppler_index); //void read_acquisition_results(uint32_t *max_index, float *max_magnitude, // uint64_t *initial_sample, float *power_sum, uint32_t *doppler_index); void read_acquisition_results(uint32_t *max_index, float *firstpeak, float *secondpeak, uint64_t *initial_sample, float *power_sum, uint32_t *doppler_index, uint32_t *total_blk_exp); void block_samples(); void unblock_samples(); /*! * \brief Set maximum Doppler grid search * \param doppler_max - Maximum Doppler shift considered in the grid search [Hz]. */ void set_doppler_max(uint32_t doppler_max) { //printf("acq lib set doppler max called\n"); d_doppler_max = doppler_max; //printf("set acq lib d_doppler_max = %d\n", (int) d_doppler_max); } /*! * \brief Set Doppler steps for the grid search * \param doppler_step - Frequency bin of the search grid [Hz]. */ void set_doppler_step(uint32_t doppler_step) { //printf("acq lib set doppler step called\n"); d_doppler_step = doppler_step; //printf("set acq lib d_doppler_step = %d\n", (int) d_doppler_step); } /*! * \brief this function is only used in the unit test */ void set_single_doppler_flag(unsigned int single_doppler_flag); /*! * \brief this function is only used in the unit test */ void reset_acquisition(void); /*! * \brief this function is only used in the unit test */ void read_fpga_total_scale_factor(uint32_t *total_scale_factor, uint32_t *fw_scale_factor); void set_block_exp(uint32_t total_block_exp); void write_local_code(void); void configure_acquisition(void); private: int64_t d_fs_in; // data related to the hardware module and the driver int32_t d_fd; // driver descriptor volatile uint32_t *d_map_base; // driver memory map lv_16sc_t *d_all_fft_codes; // memory that contains all the code ffts uint32_t d_vector_length; // number of samples incluing padding and number of ms uint32_t d_excludelimit; uint32_t d_nsamples_total; // number of samples including padding uint32_t d_nsamples; // number of samples not including padding uint32_t d_select_queue; // queue selection std::string d_device_name; // HW device name uint32_t d_doppler_max; // max doppler uint32_t d_doppler_step; // doppler step uint32_t d_PRN; // PRN // FPGA private functions uint32_t fpga_acquisition_test_register(uint32_t writeval); void fpga_configure_acquisition_local_code(lv_16sc_t fft_local_code[]); //void configure_acquisition(); void close_device(); void read_result_valid(uint32_t *result_valid); // test parameters unsigned int d_single_doppler_flag; // this flag is only used for testing purposes }; #endif /* GNSS_SDR_FPGA_ACQUISITION_H_ */