/** * Copyright 2013-2021 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_PUCCH_NR_H #define SRSLTE_PUCCH_NR_H #include "srslte/phy/ch_estimation/chest_ul.h" #include "srslte/phy/common/phy_common_nr.h" #include "srslte/phy/common/zc_sequence.h" #include "srslte/phy/modem/modem_table.h" #include "srslte/phy/phch/uci_nr.h" /** * @brief Maximum number of symbols (without DMRS) that NR-PUCCH format 1 can transmit */ #define SRSLTE_PUCCH_NR_FORMAT1_N_MAX 7 typedef struct SRSLTE_API { srslte_uci_nr_args_t uci; uint32_t max_nof_prb; } srslte_pucch_nr_args_t; typedef struct SRSLTE_API { float rsrp; float rsrp_dBfs; float epre; float epre_dBfs; float norm_corr; } srslte_pucch_nr_measure_t; /** * @brief NR-PUCCH encoder/decoder object */ typedef struct SRSLTE_API { uint32_t max_prb; srslte_zc_sequence_lut_t r_uv_1prb; cf_t format1_w_i_m[SRSLTE_PUCCH_NR_FORMAT1_N_MAX][SRSLTE_PUCCH_NR_FORMAT1_N_MAX][SRSLTE_PUCCH_NR_FORMAT1_N_MAX]; srslte_modem_table_t bpsk; srslte_modem_table_t qpsk; srslte_uci_nr_t uci; uint8_t* b; cf_t* d; cf_t* ce; } srslte_pucch_nr_t; /** * @brief Initialises an NR-PUCCH encoder/decoder object * @param q Object * @return SRSLTE_SUCCESS if successful, SRSLTE_ERROR code otherwise */ SRSLTE_API int srslte_pucch_nr_init(srslte_pucch_nr_t* q, const srslte_pucch_nr_args_t* args); /** * @brief Deallocates an NR-PUCCH encoder/decoder object * @param q Object */ SRSLTE_API void srslte_pucch_nr_free(srslte_pucch_nr_t* q); /** * @brief Computes the NR-PUCCH group sequence * @remark Implemented according to TS 38.211 clause 6.3.2.2.1 Group and sequence hopping * @param[in] carrier Serving cell and UL BWP configuration * @param[in] cfg PUCCH common configuration * @param[out] u_ Group sequence (u) * @param[out] v_ Base sequence (v) * @return SRSLTE_SUCCESS if provide arguments are right, SRSLTE_ERROR code otherwise */ SRSLTE_API int srslte_pucch_nr_group_sequence(const srslte_carrier_nr_t* carrier, const srslte_pucch_nr_common_cfg_t* cfg, uint32_t* u_, uint32_t* v_); /** * @brief Computes the NR alpha index (1-NRE) * @param[in] carrier Serving cell and UL BWP configuration * @param[in] cfg PUCCH common configuration * @param[in] slot slot configuration * @param[in] l OFDM Symbol, relative to the NR-PUCCH transmission start * @param[in] l_prime Initial OFDM symbol, relative to the transmission slot start * @param[in] m0 Initial cyclic shift * @param[in] m_cs Set to zero expect for format 0 * @param[out] alpha_idx Computed alpha index * @return SRSLTE_SUCCESS if provide arguments are right, SRSLTE_ERROR code otherwise */ SRSLTE_API int srslte_pucch_nr_alpha_idx(const srslte_carrier_nr_t* carrier, const srslte_pucch_nr_common_cfg_t* cfg, const srslte_slot_cfg_t* slot, uint32_t l, uint32_t l_prime, uint32_t m0, uint32_t m_cs, uint32_t* alpha_idx); /** * @brief Encode and writes NR-PUCCH format 0 in the resource grid * @remark Described in TS 38.211 clause 6.3.2.3 PUCCH format 0 * @param[in,out] q NR-PUCCH encoder/decoder object * @param[in] carrier Serving cell and Uplink BWP configuration * @param[in] cfg PUCCH common configuration * @param[in] slot slot configuration * @param[in] resource PUCCH format 0 resource * @param[in] m_cs Cyclic shift according to TS 38.213 clause 5 * @param[out] slot_symbols Resource grid of the given slot * @return SRSLTE_SUCCESS if successful, SRSLTE_ERROR code otherwise */ SRSLTE_API int srslte_pucch_nr_format0_encode(const srslte_pucch_nr_t* q, const srslte_carrier_nr_t* carrier, const srslte_pucch_nr_common_cfg_t* cfg, const srslte_slot_cfg_t* slot, srslte_pucch_nr_resource_t* resource, uint32_t m_cs, cf_t* slot_symbols); /** * @brief Measures PUCCH format 0 in the resource grid * @param[in,out] q NR-PUCCH encoder/decoder object * @param[in] carrier Serving cell and Uplink BWP configuration * @param[in] cfg PUCCH common configuration * @param[in] slot slot configuration * @param[in] resource PUCCH format 0 resource * @param[in] m_cs Cyclic shift according to TS 38.213 clause 5 * @param[in] slot_symbols Resource grid of the given slot * @param[out] measure Measurement structure * @return SRSLTE_SUCCESS if successful, SRSLTE_ERROR code otherwise */ SRSLTE_API int srslte_pucch_nr_format0_measure(const srslte_pucch_nr_t* q, const srslte_carrier_nr_t* carrier, const srslte_pucch_nr_common_cfg_t* cfg, const srslte_slot_cfg_t* slot, srslte_pucch_nr_resource_t* resource, uint32_t m_cs, const cf_t* slot_symbols, srslte_pucch_nr_measure_t* measure); /** * @brief Get NR-PUCCH orthogonal sequence w * @remark Defined by TS 38.211 Table 6.3.2.4.1-2: Orthogonal sequences ... for PUCCH format 1 * @param[in,out] q NR-PUCCH encoder/decoder object * @param[in] n_pucch Number of PUCCH symbols * @param[in] i sequence index * @param m OFDM symbol index * @return Orthogonal sequence complex number if valid, NAN otherwise */ SRSLTE_API cf_t srslte_pucch_nr_format1_w(const srslte_pucch_nr_t* q, uint32_t n_pucch, uint32_t i, uint32_t m); /** * @brief Encodes and puts NR-PUCCH format 1 in the resource grid * @remark Described in TS 38.211 clause 6.3.2.4 PUCCH format 1 * @param[in,out] q NR-PUCCH encoder/decoder object * @param[in] carrier Serving cell and Uplink BWP configuration * @param[in] cfg PUCCH common configuration * @param[in] slot slot configuration * @param[in] resource PUCCH format 1 resource * @param[in] b Bits to encode in the message * @param[in] nof_bits Number of bits to encode in the message * @param[out] slot_symbols Resource grid of the given slot * @return SRSLTE_SUCCESS if successful, SRSLTE_ERROR code otherwise */ SRSLTE_API int srslte_pucch_nr_format1_encode(const srslte_pucch_nr_t* q, const srslte_carrier_nr_t* carrier, const srslte_pucch_nr_common_cfg_t* cfg, const srslte_slot_cfg_t* slot, const srslte_pucch_nr_resource_t* resource, uint8_t* b, uint32_t nof_bits, cf_t* slot_symbols); /** * @brief Decodes NR-PUCCH format 1 * @param[in,out] q NR-PUCCH encoder/decoder object * @param[in] carrier Serving cell and Uplink BWP configuration * @param[in] cfg PUCCH common configuration * @param[in] slot slot configuration * @param[in] resource PUCCH format 2-4 resource * @param[in] chest_res Channel estimator result * @param[in] slot_symbols Resource grid of the given slot * @param[out] b Bits to decode * @param[in] nof_bits Number of bits to decode in the message * @return SRSLTE_SUCCESS if successful, SRSLTE_ERROR code otherwise */ SRSLTE_API int srslte_pucch_nr_format1_decode(srslte_pucch_nr_t* q, const srslte_carrier_nr_t* carrier, const srslte_pucch_nr_common_cfg_t* cfg, const srslte_slot_cfg_t* slot, const srslte_pucch_nr_resource_t* resource, srslte_chest_ul_res_t* chest_res, cf_t* slot_symbols, uint8_t b[SRSLTE_PUCCH_NR_FORMAT1_MAX_NOF_BITS], uint32_t nof_bits); /** * @brief Encoder NR-PUCCH formats 2, 3 and 4. The NR-PUCCH format is selected by resource->format. * @param[in,out] q NR-PUCCH encoder/decoder object * @param[in] carrier Serving cell and Uplink BWP configuration * @param[in] cfg PUCCH common configuration * @param[in] slot slot configuration * @param[in] resource PUCCH format 1 resource * @param[in] uci_cfg Uplink Control Information configuration * @param[in] uci_value Uplink Control Information data * @param[out] slot_symbols Resource grid of the given slot * @return SRSLTE_SUCCESS if successful, SRSLTE_ERROR code otherwise */ SRSLTE_API int srslte_pucch_nr_format_2_3_4_encode(srslte_pucch_nr_t* q, const srslte_carrier_nr_t* carrier, const srslte_pucch_nr_common_cfg_t* cfg, const srslte_slot_cfg_t* slot, const srslte_pucch_nr_resource_t* resource, const srslte_uci_cfg_nr_t* uci_cfg, const srslte_uci_value_nr_t* uci_value, cf_t* slot_symbols); /** * @brief Decode NR-PUCCH format 2, 3, and 4. The NR-PUCCH format is selected by resource->format. * @param q[in,out] q NR-PUCCH encoder/decoder * @param[in] carrier Serving cell and Uplink BWP configuration * @param[in] cfg PUCCH common configuration * @param[in] slot slot configuration * @param[in] resource PUCCH format 2-4 resource * @param[in] uci_cfg Uplink Control Information configuration * @param[in] chest_res Channel estimator result * @param[in] slot_symbols Resource grid of the given slot * @param[out] uci_value Uplink Control Information data * @return SRSLTE_SUCCESS if successful, SRSLTE_ERROR code otherwise */ SRSLTE_API int srslte_pucch_nr_format_2_3_4_decode(srslte_pucch_nr_t* q, const srslte_carrier_nr_t* carrier, const srslte_pucch_nr_common_cfg_t* cfg, const srslte_slot_cfg_t* slot, const srslte_pucch_nr_resource_t* resource, const srslte_uci_cfg_nr_t* uci_cfg, srslte_chest_ul_res_t* chest_res, cf_t* slot_symbols, srslte_uci_value_nr_t* uci_value); SRSLTE_API uint32_t srslte_pucch_nr_tx_info(const srslte_pucch_nr_resource_t* resource, const srslte_uci_data_nr_t* uci_data, char* str, uint32_t str_len); #endif // SRSLTE_PUCCH_NR_H