|
|
|
/*
|
|
|
|
* Copyright 2013-2020 Software Radio Systems Limited
|
|
|
|
*
|
|
|
|
* This file is part of srsLTE.
|
|
|
|
*
|
|
|
|
* srsLTE is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of
|
|
|
|
* the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* srsLTE 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 Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* A copy of the GNU Affero General Public License can be found in
|
|
|
|
* the LICENSE file in the top-level directory of this distribution
|
|
|
|
* and at http://www.gnu.org/licenses/.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SRSLTE_DMRS_PDSCH_H
|
|
|
|
#define SRSLTE_DMRS_PDSCH_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "srslte/phy/common/phy_common_nr.h"
|
|
|
|
#include "srslte/phy/phch/pdsch_cfg_nr.h"
|
|
|
|
#include "srslte/srslte.h"
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#define SRSLTE_DMRS_PDSCH_MAX_SYMBOLS 4
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PDSCH DMRS estimator object
|
|
|
|
*
|
|
|
|
* @note The DMRS PDSCH object has to be initialised and the carrier parameters needs to be set.
|
|
|
|
*
|
|
|
|
* @see srslte_dmrs_pdsch_init
|
|
|
|
* @see srslte_dmrs_pdsch_set_carrier
|
|
|
|
* @see srslte_dmrs_pdsch_free
|
|
|
|
* @see srslte_dmrs_pdsch_put_sf
|
|
|
|
* @see srslte_dmrs_pdsch_estimate
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
bool is_ue;
|
|
|
|
|
|
|
|
srslte_carrier_nr_t carrier;
|
|
|
|
|
|
|
|
srslte_interp_lin_t interpolator_type1; /// Type 1 DMRS: 1 pilot every 2 RE
|
|
|
|
srslte_interp_lin_t interpolator_type2; /// Type 2 DMRS: 2 consecutive pilots every 6 RE
|
|
|
|
|
|
|
|
uint32_t max_nof_prb;
|
|
|
|
cf_t* pilot_estimates; /// Pilots least squares estimates
|
|
|
|
cf_t* temp; /// Temporal data vector of size SRSLTE_NRE * carrier.nof_prb
|
|
|
|
|
|
|
|
} srslte_dmrs_pdsch_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Computes the symbol indexes carrying DMRS and stores them in symbols_idx
|
|
|
|
* @param cfg PDSCH configuration that includes DMRS, PDSCH and grant parameters
|
|
|
|
* @param symbols_idx is the destination pointer where the symbols indexes are stored
|
|
|
|
* @return It returns the number of symbols if inputs are valid, otherwise, it returns SRSLTE_ERROR code.
|
|
|
|
*/
|
|
|
|
SRSLTE_API int srslte_dmrs_pdsch_get_symbols_idx(const srslte_pdsch_cfg_nr_t* pdsch_cfg,
|
|
|
|
uint32_t symbols_idx[SRSLTE_DMRS_PDSCH_MAX_SYMBOLS]);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Computes the sub-carrier indexes carrying DMRS
|
|
|
|
*
|
|
|
|
* @param cfg PDSCH DMRS configuration provided by upper layers
|
|
|
|
* @param max_count is the number of sub-carriers to generate
|
|
|
|
* @param sc_idx is the destination pointer where the sub-carrier indexes are stored
|
|
|
|
*
|
|
|
|
* @return It returns the number of sub-carriers if inputs are valid, otherwise, it returns SRSLTE_ERROR code.
|
|
|
|
*/
|
|
|
|
SRSLTE_API int srslte_dmrs_pdsch_get_sc_idx(const srslte_pdsch_dmrs_cfg_t* cfg, uint32_t max_count, uint32_t* sc_idx);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Stringifies the PDSCH DMRS configuration
|
|
|
|
*
|
|
|
|
* @param cfg PDSCH DMRS configuration
|
|
|
|
* @param msg Pointer to the destination array
|
|
|
|
* @param max_len Maximum number of characters to write
|
|
|
|
*
|
|
|
|
* @return It returns the number of characters written in the vector if no error occurs, otherwise it returns
|
|
|
|
* SRSLTE_ERROR code
|
|
|
|
*/
|
|
|
|
SRSLTE_API int srslte_dmrs_pdsch_cfg_to_str(const srslte_pdsch_dmrs_cfg_t* cfg, char* msg, uint32_t max_len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialises DMRS PDSCH object
|
|
|
|
*
|
|
|
|
* @param q DMRS PDSCH object
|
|
|
|
* @param is_ue indicates whethe the object is for a UE (in this case, it shall initialise as an estimator)
|
|
|
|
* @return it returns SRSLTE_ERROR code if an error occurs, otherwise it returns SRSLTE_SUCCESS
|
|
|
|
*/
|
|
|
|
SRSLTE_API int srslte_dmrs_pdsch_init(srslte_dmrs_pdsch_t* q, bool is_ue);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Frees DMRS PDSCH object
|
|
|
|
*
|
|
|
|
* @param q DMRS PDSCH object
|
|
|
|
*/
|
|
|
|
SRSLTE_API void srslte_dmrs_pdsch_free(srslte_dmrs_pdsch_t* q);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Sets the carrier configuration. if the PDSCH DMRS object is configured as UE, it will resize internal buffers
|
|
|
|
* and objects.
|
|
|
|
*
|
|
|
|
* @param q DMRS PDSCH object
|
|
|
|
* @param carrier Carrier configuration
|
|
|
|
*
|
|
|
|
* @return it returns SRSLTE_ERROR code if an error occurs, otherwise it returns SRSLTE_SUCCESS
|
|
|
|
*/
|
|
|
|
SRSLTE_API int srslte_dmrs_pdsch_set_carrier(srslte_dmrs_pdsch_t* q, const srslte_carrier_nr_t* carrier);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Puts PDSCH DMRS into a given resource grid
|
|
|
|
*
|
|
|
|
* @param q DMRS PDSCH object
|
|
|
|
* @param slot_cfg Slot configuration
|
|
|
|
* @param pdsch_cfg PDSCH transmission configuration
|
|
|
|
* @param sf_symbols Resource grid
|
|
|
|
*
|
|
|
|
* @return it returns SRSLTE_ERROR code if an error occurs, otherwise it returns SRSLTE_SUCCESS
|
|
|
|
*/
|
|
|
|
SRSLTE_API int srslte_dmrs_pdsch_put_sf(srslte_dmrs_pdsch_t* q,
|
|
|
|
const srslte_dl_slot_cfg_t* slot_cfg,
|
|
|
|
const srslte_pdsch_cfg_nr_t* pdsch_cfg,
|
|
|
|
cf_t* sf_symbols);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Estimates the channel for PDSCH from the DMRS
|
|
|
|
*
|
|
|
|
* @attention Current implementation is thought for type1 PDSCH DMRS (1 pilot every 2 RE)
|
|
|
|
*
|
|
|
|
* @param q DMRS-PDSCH object
|
|
|
|
* @param slot_cfg Slot configuration
|
|
|
|
* @param sf_symbols Received resource grid
|
|
|
|
* @param[out] ce Channel estimates
|
|
|
|
*
|
|
|
|
* @return it returns SRSLTE_ERROR code if an error occurs, otherwise it returns SRSLTE_SUCCESS
|
|
|
|
*/
|
|
|
|
SRSLTE_API int srslte_dmrs_pdsch_estimate(srslte_dmrs_pdsch_t* q,
|
|
|
|
const srslte_dl_slot_cfg_t* slot_cfg,
|
|
|
|
const srslte_pdsch_cfg_nr_t* pdsch_cfg,
|
|
|
|
const cf_t* sf_symbols,
|
|
|
|
srslte_chest_dl_res_t* chest_res);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // SRSLTE_DMRS_PDSCH_H
|