mac_proto.h 16.3 KB
Newer Older
WEI-TAI CHEN's avatar
WEI-TAI CHEN committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
/*
 * Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The OpenAirInterface Software Alliance licenses this file to You under
 * the OAI Public License, Version 1.1  (the "License"); you may not use this file
 * except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.openairinterface.org/?page_id=698
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *-------------------------------------------------------------------------------
 * For more information about the OpenAirInterface (OAI) Software Alliance:
 *      contact@openairinterface.org
 */

/*! \file mac_proto.h
 * \brief MAC functions prototypes for gNB
 * \author Navid Nikaein and Raymond Knopp, WEI-TAI CHEN
 * \date 2010 - 2014, 2018
 * \email navid.nikaein@eurecom.fr, kroempa@gmail.com
 * \version 1.0
 * \company Eurecom, NTUST
 */
30 31 32 33

#ifndef __LAYER2_NR_MAC_PROTO_H__
#define __LAYER2_NR_MAC_PROTO_H__

34
#include "PHY/defs_gNB.h"
35 36

#include "LAYER2/NR_MAC_gNB/nr_mac_gNB.h"
37
#include "NR_TAG-Id.h"
38

39 40
void set_cset_offset(uint16_t);

41 42
void mac_top_init_gNB(void);

43
void config_common(int Mod_idP,
44
                   int pdsch_AntennaPorts,
45 46
		   NR_ServingCellConfigCommon_t *scc
		   );
47

48
int rrc_mac_config_req_gNB(module_id_t Mod_idP, 
49
			   int ssb_SubcarrierOffset,
50
                           int pdsch_AntennaPorts,
51 52
                           int pusch_tgt_snrx10,
                           int pucch_tgt_snrx10,
53 54 55 56
                           NR_ServingCellConfigCommon_t *scc,
			   int nsa_flag,
			   uint32_t rnti,
			   NR_CellGroupConfig_t *secondaryCellGroup
57
                           );
WEI-TAI CHEN's avatar
WEI-TAI CHEN committed
58

59 60 61 62
void clear_nr_nfapi_information(gNB_MAC_INST * gNB, 
                                int CC_idP,
                                frame_t frameP, 
                                sub_frame_t subframeP);
WEI-TAI CHEN's avatar
WEI-TAI CHEN committed
63

64 65
void gNB_dlsch_ulsch_scheduler(module_id_t module_idP,
			       frame_t frame_rxP, sub_frame_t slot_rxP);
66

67
int nr_generate_dlsch_pdu(module_id_t Mod_idP,
68
                          NR_UE_sched_ctrl_t *ue_sched_ctl,
69
                          unsigned char *sdus_payload,
70 71 72 73 74 75 76 77
                          unsigned char *mac_pdu,
                          unsigned char num_sdus,
                          unsigned short *sdu_lengths,
                          unsigned char *sdu_lcids,
                          unsigned char drx_cmd,
                          unsigned char *ue_cont_res_id,
                          unsigned short post_padding);

78 79 80 81
void nr_schedule_ue_spec(module_id_t module_id,
                         frame_t frame,
                         sub_frame_t slot,
                         int num_slots_per_tdd);
82

WEI-TAI CHEN's avatar
WEI-TAI CHEN committed
83 84
void schedule_nr_mib(module_id_t module_idP, frame_t frameP, sub_frame_t subframeP);

85 86 87 88 89 90 91 92 93 94 95 96
/////// Random Access MAC-PHY interface functions and primitives ///////

void nr_schedule_RA(module_id_t module_idP, frame_t frameP, sub_frame_t slotP);

/* \brief Function to indicate a received preamble on PRACH.  It initiates the RA procedure.
@param module_idP Instance ID of gNB
@param preamble_index index of the received RA request
@param slotP Slot number on which to act
@param timing_offset Offset in samples of the received PRACH w.r.t. eNB timing. This is used to
@param rnti RA rnti corresponding to this PRACH preamble
@param rach_resource type (0=non BL/CE,1 CE level 0,2 CE level 1, 3 CE level 2,4 CE level 3)
*/
97 98
void nr_initiate_ra_proc(module_id_t module_idP, int CC_id, frame_t frameP, sub_frame_t slotP,
                         uint16_t preamble_index, uint8_t freq_index, uint8_t symbol, int16_t timing_offset);
99 100 101 102 103

void nr_clear_ra_proc(module_id_t module_idP, int CC_id, frame_t frameP);

int nr_allocate_CCEs(int module_idP, int CC_idP, frame_t frameP, sub_frame_t slotP, int test_only);

104
void nr_get_Msg3alloc(NR_ServingCellConfigCommon_t *scc,
105
                      NR_BWP_Uplink_t *ubwp,
106
                      sub_frame_t current_subframe,
107 108
                      frame_t current_frame,
                      NR_RA_t *ra);
109

cig's avatar
cig committed
110 111 112
/* \brief Function in gNB to fill RAR pdu when requested by PHY.
@param ra Instance of RA resources of gNB
@param dlsch_buffer Pointer to RAR input buffer
113 114
@param N_RB_UL Number of UL resource blocks
*/
115 116
void nr_fill_rar(uint8_t Mod_idP,
                 NR_RA_t * ra,
cig's avatar
cig committed
117
                 uint8_t * dlsch_buffer,
118
                 nfapi_nr_pusch_pdu_t  *pusch_pdu);
119 120


121 122
void schedule_nr_prach(module_id_t module_idP, frame_t frameP, sub_frame_t slotP);

123 124 125 126
uint16_t nr_mac_compute_RIV(uint16_t N_RB_DL, uint16_t RBstart, uint16_t Lcrbs);

/////// Phy test scheduler ///////

Raymond Knopp's avatar
Raymond Knopp committed
127 128 129 130
void nr_schedule_css_dlsch_phytest(module_id_t   module_idP,
                                   frame_t       frameP,
                                   sub_frame_t   subframeP);

131 132 133
void nr_fill_nfapi_dl_pdu(int Mod_id,
                          int UE_id,
                          int bwp_id,
134 135
                          NR_SearchSpace_t *ss,
                          NR_ControlResourceSet_t *coreset,
136 137 138 139 140 141 142 143 144 145 146 147 148 149
                          nfapi_nr_dl_tti_request_body_t *dl_req,
                          NR_sched_pucch *pucch_sched,
                          int nrOfLayers,
                          uint8_t mcs,
                          uint16_t rbSize,
                          uint16_t rbStart,
                          uint8_t numDmrsCdmGrpsNoData,
                          nfapi_nr_dmrs_type_e dmrsConfigType,
                          uint8_t table_idx,
                          uint16_t R,
                          uint8_t Qm,
                          uint32_t tbs,
                          int time_domain_assignment,
                          int StartSymbolIndex,
150 151
                          int NrOfSymbols,
                          uint8_t aggregation_level,
152 153 154 155
                          int CCEIndex,
                          int harq_pid,
                          int ndi,
                          int round);
Raymond Knopp's avatar
Raymond Knopp committed
156

157 158 159 160 161 162
int configure_fapi_dl_pdu_phytest(int Mod_id,
                                  nfapi_nr_dl_tti_request_body_t *dl_req,
                                  NR_sched_pucch *pucch_sched,
                                  uint8_t *mcsIndex,
                                  uint16_t *rbSize,
                                  uint16_t *rbStart);
Raymond Knopp's avatar
Raymond Knopp committed
163

164 165 166 167 168
void nr_rx_acknack(nfapi_nr_uci_pusch_pdu_t *uci_pusch,
                   nfapi_nr_uci_pucch_pdu_format_0_1_t *uci_01,
                   nfapi_nr_uci_pucch_pdu_format_2_3_4_t *uci_234,
                   NR_UL_IND_t *UL_info, NR_UE_sched_ctrl_t *sched_ctrl, NR_mac_stats_t *stats);

169 170 171 172 173
void config_uldci(NR_BWP_Uplink_t *ubwp,
                  nfapi_nr_pusch_pdu_t *pusch_pdu,
                  nfapi_nr_dl_tti_pdcch_pdu_rel15_t *pdcch_pdu_rel15,
                  dci_pdu_rel15_t *dci_pdu_rel15,
                  int *dci_formats, int *rnti_types,
174
                  int time_domain_assignment, uint8_t tpc,
175
                  int n_ubwp, int bwp_id);
176

cig's avatar
cig committed
177 178 179 180 181
void configure_fapi_dl_Tx(module_id_t Mod_idP,
                          frame_t       frameP,
                          sub_frame_t   slotP,
                          nfapi_nr_dl_tti_request_body_t *dl_req,
                          nfapi_nr_pdu_t *tx_req,
182 183 184
                          int tbs_bytes,
                          int16_t pdu_index);

185 186
void nr_schedule_uss_dlsch_phytest(module_id_t   module_idP,
                                   frame_t       frameP,
187
                                   sub_frame_t   slotP,
188
                                   NR_sched_pucch *pucch_sched,
Raymond Knopp's avatar
Raymond Knopp committed
189
                                   nfapi_nr_dl_tti_pdsch_pdu_rel15_t *pdsch_config);
190

191
void nr_schedule_pusch(int Mod_idP,
192
                       int UE_id,
193 194
                       int num_slots_per_tdd,
                       int ul_slots,
195 196
                       frame_t       frameP,
                       sub_frame_t   slotP);
197

198 199 200 201 202 203
void nr_schedule_pucch(int Mod_idP,
                       int UE_id,
                       int nr_ulmix_slots,
                       frame_t frameP,
                       sub_frame_t slotP);

204 205 206 207
void nr_csi_meas_reporting(int Mod_idP,
                           int UE_id,
                           frame_t frameP,
                           sub_frame_t slotP,
208 209
                           int slots_per_tdd,
                           int ul_slots,
210 211 212 213 214 215 216
                           int n_slots_frame);

void nr_acknack_scheduling(int Mod_idP,
                           int UE_id,
                           frame_t frameP,
                           sub_frame_t slotP,
                           int slots_per_tdd,
217 218 219
                           int *pucch_id,
                           int *pucch_occ);

220
int get_pucch_resource(NR_UE_info_t *UE_info,int UE_id,int k,int l);
Francesco Mani's avatar
Francesco Mani committed
221 222 223 224 225

void get_pdsch_to_harq_feedback(int Mod_idP,
                                int UE_id,
                                NR_SearchSpace__searchSpaceType_PR ss_type,
                                uint8_t *pdsch_to_harq_feedback);
226
  
Raymond Knopp's avatar
Raymond Knopp committed
227
void nr_configure_css_dci_initial(nfapi_nr_dl_tti_pdcch_pdu_rel15_t* pdcch_pdu,
228 229 230 231 232 233 234 235 236 237
                                  nr_scs_e scs_common,
                                  nr_scs_e pdcch_scs,
                                  nr_frequency_range_e freq_range,
                                  uint8_t rmsi_pdcch_config,
                                  uint8_t ssb_idx,
                                  uint8_t k_ssb,
                                  uint16_t sfn_ssb,
                                  uint8_t n_ssb,
                                  uint16_t nb_slots_per_frame,
                                  uint16_t N_RB);
238
/*
239
int nr_is_dci_opportunity(nfapi_nr_search_space_t search_space,
240 241 242
                          nfapi_nr_coreset_t coreset,
                          uint16_t frame,
                          uint16_t slot,
243
                          nfapi_nr_config_request_scf_t cfg);
244
*/
Raymond Knopp's avatar
Raymond Knopp committed
245

246 247
void nr_configure_pucch(nfapi_nr_pucch_pdu_t* pucch_pdu,
			NR_ServingCellConfigCommon_t *scc,
248
			NR_BWP_Uplink_t *bwp,
249
                        uint16_t rnti,
250
                        uint8_t pucch_resource,
251
                        uint16_t O_csi,
252
                        uint16_t O_ack,
253
                        uint8_t O_sr);
Francesco Mani's avatar
Francesco Mani committed
254

255 256 257 258
void find_search_space(int ss_type,
                       NR_BWP_Downlink_t *bwp,
                       NR_SearchSpace_t *ss);

259 260 261 262 263 264 265 266 267
void nr_configure_pdcch(gNB_MAC_INST *nr_mac,
                        nfapi_nr_dl_tti_pdcch_pdu_rel15_t *pdcch_pdu,
                        uint16_t rnti,
                        NR_SearchSpace_t *ss,
                        NR_ControlResourceSet_t *coreset,
                        NR_ServingCellConfigCommon_t *scc,
                        NR_BWP_Downlink_t *bwp,
                        uint8_t aggregation_level,
                        int CCEIndex);
Raymond Knopp's avatar
Raymond Knopp committed
268

269 270
void fill_dci_pdu_rel15(NR_ServingCellConfigCommon_t *scc,
                        NR_CellGroupConfig_t *secondaryCellGroup,
271
                        nfapi_nr_dl_tti_pdcch_pdu_rel15_t *pdcch_pdu_rel15,
cig's avatar
cig committed
272 273
                        dci_pdu_rel15_t *dci_pdu_rel15,
                        int *dci_formats,
Francesco Mani's avatar
Francesco Mani committed
274
                        int *rnti_types,
275
                        int N_RB,
Francesco Mani's avatar
Francesco Mani committed
276 277 278 279 280 281
                        int bwp_id);

void prepare_dci(NR_CellGroupConfig_t *secondaryCellGroup,
                 dci_pdu_rel15_t *dci_pdu_rel15,
                 nr_dci_format_t format,
                 int bwp_id);
282

283 284 285 286 287 288 289 290 291 292
/* find coreset within the search space */
NR_ControlResourceSet_t *get_coreset(NR_BWP_Downlink_t *bwp,
                                     NR_SearchSpace_t *ss,
                                     int ss_type);

/* find a search space within a BWP */
NR_SearchSpace_t *get_searchspace(
    NR_BWP_Downlink_t *bwp,
    NR_SearchSpace__searchSpaceType_PR target_ss);

293 294 295 296
void find_aggregation_candidates(uint8_t *aggregation_level,
                                 uint8_t *nr_of_candidates,
                                 NR_SearchSpace_t *ss);

297 298
uint8_t nr_get_tpc(int target, uint8_t cqi, int incr);

299
int get_spf(nfapi_nr_config_request_scf_t *cfg);
300

301
int to_absslot(nfapi_nr_config_request_scf_t *cfg,int frame,int slot);
302

Raymond Knopp's avatar
Raymond Knopp committed
303
void nr_get_tbs_dl(nfapi_nr_dl_tti_pdsch_pdu *pdsch_pdu,
304
		   int x_overhead,
305
                   uint8_t numdmrscdmgroupnodata,
306
                   uint8_t tb_scaling);
Raymond Knopp's avatar
Raymond Knopp committed
307 308 309 310 311 312 313
/** \brief Computes Q based on I_MCS PDSCH and table_idx for downlink. Implements MCS Tables from 38.214. */
uint8_t nr_get_Qm_dl(uint8_t Imcs, uint8_t table_idx);
uint32_t nr_get_code_rate_dl(uint8_t Imcs, uint8_t table_idx);

/** \brief Computes Q based on I_MCS PDSCH and table_idx for uplink. Implements MCS Tables from 38.214. */
uint8_t nr_get_Qm_ul(uint8_t Imcs, uint8_t table_idx);
uint32_t nr_get_code_rate_ul(uint8_t Imcs, uint8_t table_idx);
314 315 316 317 318

int NRRIV2BW(int locationAndBandwidth,int N_RB);

int NRRIV2PRBOFFSET(int locationAndBandwidth,int N_RB);

Robert Schmidt's avatar
Robert Schmidt committed
319
void dump_nr_ue_list(NR_UE_list_t *listP);
Robert Schmidt's avatar
Robert Schmidt committed
320
void add_nr_ue_list(NR_UE_list_t *listP, int UE_id);
321

cig's avatar
cig committed
322
int find_nr_UE_id(module_id_t mod_idP, rnti_t rntiP);
323

cig's avatar
cig committed
324
int add_new_nr_ue(module_id_t mod_idP, rnti_t rntiP);
325

Cedric Roux's avatar
Cedric Roux committed
326 327
void mac_remove_nr_ue(module_id_t mod_id, rnti_t rnti);

328
int allocate_nr_CCEs(gNB_MAC_INST *nr_mac,
329 330
                     NR_BWP_Downlink_t *bwp,
                     NR_ControlResourceSet_t *coreset,
cig's avatar
cig committed
331
                     int aggregation,
332
                     uint16_t n_RNTI,
333
                     int m);
334

335 336 337 338 339 340 341 342 343
uint16_t compute_pucch_prb_size(uint8_t format,
                                uint8_t nr_prbs,
                                uint16_t O_tot,
                                uint16_t O_csi,
                                NR_PUCCH_MaxCodeRate_t *maxCodeRate,
                                uint8_t Qm,
                                uint8_t n_symb,
                                uint8_t n_re_ctrl);

344
void compute_csi_bitlen (NR_CellGroupConfig_t *secondaryCellGroup, NR_UE_info_t *UE_info, int UE_id);
345

cig's avatar
cig committed
346 347 348 349 350 351 352
int get_dlscs(nfapi_nr_config_request_t *cfg);

int get_ulscs(nfapi_nr_config_request_t *cfg);

int get_symbolsperslot(nfapi_nr_config_request_t *cfg);

int32_t get_nr_uldl_offset(int nr_bandP);
353

354
void config_nr_mib(int Mod_idP, 
355 356 357 358 359 360 361 362
                   int CC_idP,
                   int p_gNBP,
                   int subCarrierSpacingCommon,
                   uint32_t ssb_SubcarrierOffset,
                   int dmrs_TypeA_Position,
                   uint32_t pdcch_ConfigSIB1,
                   int cellBarred,
                   int intraFreqReselection);
363

364

365 366 367 368 369
void nr_generate_Msg2(module_id_t module_idP,
                      int CC_id,
                      frame_t frameP,
                      sub_frame_t slotP);

370 371
void nr_schedule_reception_msg3(module_id_t module_idP, int CC_id, frame_t frameP, sub_frame_t slotP);

372 373 374 375
void schedule_fapi_ul_pdu(int Mod_idP,
                          frame_t frameP,
                          sub_frame_t slotP,
                          int num_slots_per_tdd,
376
                          int ul_slots,
377 378
                          int time_domain_assignment,
                          uint64_t ulsch_in_slot_bitmap);
379

380 381
void nr_process_mac_pdu(
    module_id_t module_idP,
382
    rnti_t rnti,
383 384 385 386
    uint8_t CC_id,
    frame_t frameP,
    uint8_t *pduP,
    uint16_t mac_pdu_len);
387

388 389
int binomial(int n, int k);

390 391
bool is_xlsch_in_slot(uint64_t bitmap, sub_frame_t slot);

392

393 394 395 396 397 398 399 400 401 402
/* \brief Function to indicate a received SDU on ULSCH.
@param Mod_id Instance ID of gNB
@param CC_id Component carrier index
@param rnti RNTI of UE transmitting the SDU
@param sdu Pointer to received SDU
@param sdu_len Length of SDU
@param timing_advance timing advance adjustment after this pdu
@param ul_cqi Uplink CQI estimate after this pdu (SNR quantized to 8 bits, -64 ... 63.5 dB in .5dB steps)
*/
void nr_rx_sdu(const module_id_t gnb_mod_idP,
cig's avatar
cig committed
403 404 405 406 407 408
               const int CC_idP,
               const frame_t frameP,
               const sub_frame_t subframeP,
               const rnti_t rntiP,
               uint8_t * sduP,
               const uint16_t sdu_lenP,
409 410 411
               const uint16_t timing_advance,
               const uint8_t ul_cqi,
               const uint16_t rssi);
412

413
void handle_nr_ul_harq(uint16_t slot, NR_UE_sched_ctrl_t *sched_ctrl, NR_mac_stats_t *stats, nfapi_nr_crc_t crc_pdu);
414

415
void handle_nr_uci(NR_UL_IND_t *UL_info, NR_UE_sched_ctrl_t *sched_ctrl, NR_mac_stats_t *stats, int target_snrx10);
416
#endif /*__LAYER2_NR_MAC_PROTO_H__*/