mac_proto.h 16.1 KB
Newer Older
ChenWeiTai's avatar
ChenWeiTai 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
                           );
ChenWeiTai's avatar
ChenWeiTai 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);
ChenWeiTai's avatar
ChenWeiTai 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
68
void nr_schedule_ue_spec(module_id_t module_id,
                         frame_t frame,
69
                         sub_frame_t slot);
70

71
72
73
74
75
76
77
78
void schedule_control_sib1(module_id_t module_id,
                           int CC_id,
                           int time_domain_allocation,
                           uint8_t mcsTableIdx,
                           uint8_t mcs,
                           int num_total_bytes);

void schedule_nr_sib1(module_id_t module_idP, frame_t frameP, sub_frame_t subframeP);
Roberto Louro Magueta's avatar
Roberto Louro Magueta committed
79

80
81
82
/* \brief default preprocessor */
void nr_simple_dlsch_preprocessor(module_id_t module_id,
                                  frame_t frame,
83
                                  sub_frame_t slot);
84

85
void schedule_nr_mib(module_id_t module_idP, frame_t frameP, sub_frame_t subframeP, uint8_t slots_per_frame);
ChenWeiTai's avatar
ChenWeiTai committed
86

87
88
89
90
91
92
93
94
/// uplink scheduler
void nr_schedule_ulsch(module_id_t module_id,
                       frame_t frame,
                       sub_frame_t slot,
                       int num_slots_per_tdd,
                       int ul_slots,
                       uint64_t ulsch_in_slot_bitmap);

95
bool nr_simple_ulsch_preprocessor(module_id_t module_id,
96
97
98
99
100
                                  frame_t frame,
                                  sub_frame_t slot,
                                  int num_slots_per_tdd,
                                  uint64_t ulsch_in_slot_bitmap);

101
102
103
104
105
106
107
108
109
110
111
112
/////// 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)
*/
113
114
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);
115
116
117
118
119

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);

120
121
122
void nr_get_Msg3alloc(module_id_t module_id,
                      int CC_id,
                      NR_ServingCellConfigCommon_t *scc,
Francesco Mani's avatar
Francesco Mani committed
123
                      NR_BWP_Uplink_t *ubwp,
124
                      sub_frame_t current_subframe,
125
126
                      frame_t current_frame,
                      NR_RA_t *ra);
127

cig's avatar
cig committed
128
129
130
/* \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
131
132
@param N_RB_UL Number of UL resource blocks
*/
133
134
void nr_fill_rar(uint8_t Mod_idP,
                 NR_RA_t * ra,
cig's avatar
cig committed
135
                 uint8_t * dlsch_buffer,
Francesco Mani's avatar
Francesco Mani committed
136
                 nfapi_nr_pusch_pdu_t  *pusch_pdu);
137
138


139
140
void schedule_nr_prach(module_id_t module_idP, frame_t frameP, sub_frame_t slotP);

141
142
143
144
uint16_t nr_mac_compute_RIV(uint16_t N_RB_DL, uint16_t RBstart, uint16_t Lcrbs);

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

Robert Schmidt's avatar
Robert Schmidt committed
145
146
147
148
/* \brief preprocessor for phytest: schedules UE_id 0 with fixed MCS on all
 * freq resources */
void nr_preprocessor_phytest(module_id_t module_id,
                             frame_t frame,
149
                             sub_frame_t slot);
150
151
/* \brief UL preprocessor for phytest: schedules UE_id 0 with fixed MCS on a
 * fixed set of resources */
152
bool nr_ul_preprocessor_phytest(module_id_t module_id,
153
154
155
156
                                frame_t frame,
                                sub_frame_t slot,
                                int num_slots_per_tdd,
                                uint64_t ulsch_in_slot_bitmap);
Robert Schmidt's avatar
Robert Schmidt committed
157

knopp's avatar
knopp committed
158
159
160
161
void nr_schedule_css_dlsch_phytest(module_id_t   module_idP,
                                   frame_t       frameP,
                                   sub_frame_t   subframeP);

162
163
164
void handle_nr_uci_pucch_0_1(module_id_t mod_id,
                             frame_t frame,
                             sub_frame_t slot,
k.ramya's avatar
k.ramya committed
165
166
                             const nfapi_nr_uci_pucch_pdu_format_0_1_t *uci_01,
                             NR_UL_IND_t *UL_info);
167
168
169
void handle_nr_uci_pucch_2_3_4(module_id_t mod_id,
                               frame_t frame,
                               sub_frame_t slot,
k.ramya's avatar
k.ramya committed
170
171
                               const nfapi_nr_uci_pucch_pdu_format_2_3_4_t *uci_234,
                               NR_UL_IND_t *UL_info);
172

173

174
175
void config_uldci(const NR_BWP_Uplink_t *ubwp,
                  const nfapi_nr_pusch_pdu_t *pusch_pdu,
176
                  dci_pdu_rel15_t *dci_pdu_rel15,
177
178
179
180
181
                  int dci_format,
                  int time_domain_assignment,
                  uint8_t tpc,
                  int n_ubwp,
                  int bwp_id);
182

183
184
185
186
void nr_schedule_pucch(int Mod_idP,
                       frame_t frameP,
                       sub_frame_t slotP);

187
void csi_period_offset(const NR_CSI_ReportConfig_t *csirep,
188
189
                       int *period, int *offset);

190
191
void nr_csi_meas_reporting(int Mod_idP,
                           frame_t frameP,
192
                           sub_frame_t slotP);
193

194
bool nr_acknack_scheduling(int Mod_idP,
195
196
                           int UE_id,
                           frame_t frameP,
197
                           sub_frame_t slotP);
Francesco Mani's avatar
Francesco Mani committed
198

199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
int checkTargetSSBInTCIStates_pdcchConfig(int ssb_index_t, int Mod_idP, int UE_id);

int checkTargetSSBInFirst64TCIStates_pdschConfig(int ssb_index_t, int Mod_idP, int UE_id);

int get_measured_rsrp(uint8_t index);

int get_diff_rsrp(uint8_t index, int strongest_rsrp);

void extract_pucch_csi_report (NR_CSI_MeasConfig_t *csi_MeasConfig,
                               nfapi_nr_uci_pucch_pdu_format_2_3_4_t *uci_pdu,
                               NR_UE_sched_ctrl_t *sched_ctrl,
                               frame_t frame,
                               slot_t slot,
                               NR_SubcarrierSpacing_t scs, int UE_id,
                               module_id_t Mod_idP);

Francesco Mani's avatar
Francesco Mani committed
215
216
217
218
void get_pdsch_to_harq_feedback(int Mod_idP,
                                int UE_id,
                                NR_SearchSpace__searchSpaceType_PR ss_type,
                                uint8_t *pdsch_to_harq_feedback);
219
  
knopp's avatar
knopp committed
220
void nr_configure_css_dci_initial(nfapi_nr_dl_tti_pdcch_pdu_rel15_t* pdcch_pdu,
221
222
223
224
225
226
227
228
229
230
                                  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);
231
/*
232
int nr_is_dci_opportunity(nfapi_nr_search_space_t search_space,
233
234
235
                          nfapi_nr_coreset_t coreset,
                          uint16_t frame,
                          uint16_t slot,
236
                          nfapi_nr_config_request_scf_t cfg);
237
*/
knopp's avatar
knopp committed
238

239
240
void nr_configure_pucch(nfapi_nr_pucch_pdu_t* pucch_pdu,
			NR_ServingCellConfigCommon_t *scc,
241
			NR_BWP_Uplink_t *bwp,
242
                        uint16_t rnti,
243
                        uint8_t pucch_resource,
244
                        uint16_t O_csi,
245
                        uint16_t O_ack,
246
                        uint8_t O_sr);
Francesco Mani's avatar
Francesco Mani committed
247

248
249
250
251
void find_search_space(int ss_type,
                       NR_BWP_Downlink_t *bwp,
                       NR_SearchSpace_t *ss);

252
void nr_configure_pdcch(nfapi_nr_dl_tti_pdcch_pdu_rel15_t *pdcch_pdu,
253
254
255
                        NR_SearchSpace_t *ss,
                        NR_ControlResourceSet_t *coreset,
                        NR_ServingCellConfigCommon_t *scc,
256
                        NR_BWP_Downlink_t *bwp);
knopp's avatar
knopp committed
257

258
259
260
void fill_dci_pdu_rel15(const NR_ServingCellConfigCommon_t *scc,
                        const NR_CellGroupConfig_t *secondaryCellGroup,
                        nfapi_nr_dl_dci_pdu_t *pdcch_dci_pdu,
cig's avatar
cig committed
261
                        dci_pdu_rel15_t *dci_pdu_rel15,
262
263
                        int dci_formats,
                        int rnti_types,
264
                        int N_RB,
Francesco Mani's avatar
Francesco Mani committed
265
266
                        int bwp_id);

267
void prepare_dci(const NR_CellGroupConfig_t *secondaryCellGroup,
Francesco Mani's avatar
Francesco Mani committed
268
269
270
                 dci_pdu_rel15_t *dci_pdu_rel15,
                 nr_dci_format_t format,
                 int bwp_id);
271

272
273
274
275
276
277
278
279
280
281
/* 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);

282

283
284
long get_K2(NR_BWP_Uplink_t *ubwp, int time_domain_assignment, int mu);

285
286
287
288
289
290
291
void nr_save_pusch_fields(const NR_ServingCellConfigCommon_t *scc,
                          const NR_BWP_Uplink_t *ubwp,
                          long dci_format,
                          int tda,
                          uint8_t num_dmrs_cdm_grps_no_data,
                          NR_sched_pusch_save_t *ps);

292
293
uint8_t nr_get_tpc(int target, uint8_t cqi, int incr);

294
int get_spf(nfapi_nr_config_request_scf_t *cfg);
295

296
int to_absslot(nfapi_nr_config_request_scf_t *cfg,int frame,int slot);
297

knopp's avatar
knopp committed
298
void nr_get_tbs_dl(nfapi_nr_dl_tti_pdsch_pdu *pdsch_pdu,
299
		   int x_overhead,
300
                   uint8_t numdmrscdmgroupnodata,
301
                   uint8_t tb_scaling);
knopp's avatar
knopp committed
302
303
304
305
306
307
308
/** \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);
309
310
311
312
313

int NRRIV2BW(int locationAndBandwidth,int N_RB);

int NRRIV2PRBOFFSET(int locationAndBandwidth,int N_RB);

314
315
316
317
318
319
320
321
322
/* Functions to manage an NR_list_t */
void dump_nr_list(NR_list_t *listP);
void create_nr_list(NR_list_t *listP, int len);
void destroy_nr_list(NR_list_t *list);
void add_nr_list(NR_list_t *listP, int id);
void remove_nr_list(NR_list_t *listP, int id);
void add_tail_nr_list(NR_list_t *listP, int id);
void add_front_nr_list(NR_list_t *listP, int id);
void remove_front_nr_list(NR_list_t *listP);
323

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

RAJU K N's avatar
RAJU K N committed
326
327
int find_nr_RA_id(module_id_t mod_idP, int CC_idP, rnti_t rntiP);

328
int add_new_nr_ue(module_id_t mod_idP, rnti_t rntiP, NR_CellGroupConfig_t *secondaryCellGroup);
329

Cédric Roux's avatar
Cédric Roux committed
330
331
void mac_remove_nr_ue(module_id_t mod_id, rnti_t rnti);

332
int allocate_nr_CCEs(gNB_MAC_INST *nr_mac,
333
334
                     NR_BWP_Downlink_t *bwp,
                     NR_ControlResourceSet_t *coreset,
cig's avatar
cig committed
335
                     int aggregation,
336
337
338
                     uint16_t Y,
                     int m,
                     int nr_of_candidates);
339

340
341
342
343
344
345
346
347
348
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);

349
void compute_csi_bitlen (NR_CellGroupConfig_t *secondaryCellGroup, NR_UE_info_t *UE_info, int UE_id);
350

cig's avatar
cig committed
351
352
353
354
355
356
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);

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

367
void nr_generate_Msg2(module_id_t module_idP, int CC_id, frame_t frameP, sub_frame_t slotP, NR_RA_t *ra);
368

369
370
void nr_process_mac_pdu(
    module_id_t module_idP,
371
    rnti_t rnti,
372
373
374
375
    uint8_t CC_id,
    frame_t frameP,
    uint8_t *pduP,
    uint16_t mac_pdu_len);
376

377
378
int binomial(int n, int k);

379
380
bool is_xlsch_in_slot(uint64_t bitmap, sub_frame_t slot);

381
382
void fill_ssb_vrb_map (NR_COMMON_channels_t *cc, int rbStart, int CC_id);

383

384
385
386
387
388
389
390
391
392
393
/* \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
394
395
396
397
398
399
               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,
400
401
402
               const uint16_t timing_advance,
               const uint8_t ul_cqi,
               const uint16_t rssi);
403

404
405
406
407
void handle_nr_ul_harq(module_id_t mod_id,
                       frame_t frame,
                       sub_frame_t slot,
                       const nfapi_nr_crc_t *crc_pdu);
408

RAJU K N's avatar
RAJU K N committed
409
410
int16_t ssb_index_from_prach(module_id_t module_idP,
                             frame_t frameP,
411
			     sub_frame_t slotP,
RAJU K N's avatar
RAJU K N committed
412
413
414
415
416
417
                             uint16_t preamble_index,
                             uint8_t freq_index,
                             uint8_t symbol);

void find_SSB_and_RO_available(module_id_t module_idP);

ChiehChun's avatar
ChiehChun committed
418
bool find_free_CCE(module_id_t module_id, sub_frame_t slot, int UE_id);
419
#endif /*__LAYER2_NR_MAC_PROTO_H__*/