gNB_scheduler_phytest.c 5.13 KB
Newer Older
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 30 31
/*
 * 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.0  (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 gNB_scheduler_phytest.c
 * \brief gNB scheduling procedures in phy_test mode
 * \author  Guy De Souza
 * \date 07/2018
 * \email: desouza@eurecom.fr
 * \version 1.0
 * @ingroup _mac
 */

#include "nr_mac_gNB.h"
Guy De Souza's avatar
Guy De Souza committed
32
#include "SCHED_NR/sched_nr.h"
33 34 35 36 37 38 39

extern RAN_CONTEXT_t RC;

/*Scheduling of DLSCH with associated DCI in common search space
 * current version has only a DCI for type 1 PDCCH for RA-RNTI*/
void nr_schedule_css_dlsch_phytest(module_id_t   module_idP,
                                   frame_t       frameP,
40
                                   sub_frame_t   slotP)
41 42 43
{
  uint8_t  CC_id;

Guy De Souza's avatar
Guy De Souza committed
44
  gNB_MAC_INST                        *nr_mac      = RC.nrmac[module_idP];
yilmazt's avatar
yilmazt committed
45
  //NR_COMMON_channels_t                *cc           = nr_mac->common_channels;
46 47
  nfapi_nr_dl_config_request_body_t   *dl_req;
  nfapi_nr_dl_config_request_pdu_t  *dl_config_pdu;
Guy De Souza's avatar
Guy De Souza committed
48
  nfapi_tx_request_pdu_t            *TX_req;
Raymond Knopp's avatar
Raymond Knopp committed
49 50
  nfapi_nr_config_request_t *cfg = &nr_mac->config[0];

51
  uint16_t sfn_sf = frameP << 4 | slotP;
Raymond Knopp's avatar
Raymond Knopp committed
52
  int dl_carrier_bandwidth = cfg->rf_config.dl_carrier_bandwidth.value;
53

Raymond Knopp's avatar
Raymond Knopp committed
54 55 56 57
  // everything here is hard-coded to 30 kHz
  int scs = kHz30;
  int mu = 1;
  int slots_per_frame = 10 * (1<<mu);
58 59 60
  for (CC_id=0; CC_id<MAX_NUM_CCs; CC_id++) {
    LOG_I(MAC, "Scheduling common search space DCI type 1 for CC_id %d\n",CC_id);

Raymond Knopp's avatar
Raymond Knopp committed
61

Guy De Souza's avatar
Guy De Souza committed
62
    dl_req = &nr_mac->DL_req[CC_id].dl_config_request_body;
Guy De Souza's avatar
Guy De Souza committed
63
    dl_config_pdu = &dl_req->dl_config_pdu_list[dl_req->number_pdu];
64 65 66 67 68 69
    memset((void*)dl_config_pdu,0,sizeof(nfapi_nr_dl_config_request_pdu_t));
    dl_config_pdu->pdu_type = NFAPI_NR_DL_CONFIG_DCI_DL_PDU_TYPE;
    dl_config_pdu->pdu_size = (uint8_t)(2+sizeof(nfapi_nr_dl_config_dci_dl_pdu));

    nfapi_nr_dl_config_dci_dl_pdu_rel15_t *pdu_rel15 = &dl_config_pdu->dci_dl_pdu.dci_dl_pdu_rel15;
    nfapi_nr_dl_config_pdcch_parameters_rel15_t *params_rel15 = &dl_config_pdu->dci_dl_pdu.pdcch_params_rel15;
Guy De Souza's avatar
Guy De Souza committed
70

71

72 73 74 75
    nr_configure_css_dci_initial(params_rel15,
				 scs, scs, nr_FR1, 0, 0,
				 slots_per_frame,
				 dl_carrier_bandwidth);
76

77 78
    params_rel15->first_slot = 0;

Guy De Souza's avatar
Guy De Souza committed
79 80
    pdu_rel15->frequency_domain_assignment = 5;
    pdu_rel15->time_domain_assignment = 2;
81
    pdu_rel15->vrb_to_prb_mapping = 0;
Guy De Souza's avatar
Guy De Souza committed
82
    pdu_rel15->mcs = 12;
83
    pdu_rel15->tb_scaling = 1;
Hongzhi's avatar
Hongzhi committed
84
    LOG_D(MAC, "[gNB scheduler phytest] DCI type 1 payload: freq_alloc %d, time_alloc %d, vrb to prb %d, mcs %d tb_scaling %d\n",
Guy De Souza's avatar
Guy De Souza committed
85 86
                pdu_rel15->frequency_domain_assignment,
                pdu_rel15->time_domain_assignment,
87
                pdu_rel15->vrb_to_prb_mapping,
Guy De Souza's avatar
Guy De Souza committed
88
                pdu_rel15->mcs,
89 90 91 92 93
                pdu_rel15->tb_scaling);

    params_rel15->rnti = 0x03;
    params_rel15->rnti_type = NFAPI_NR_RNTI_RA;
    params_rel15->dci_format = NFAPI_NR_DL_DCI_FORMAT_1_0;
Guy De Souza's avatar
Guy De Souza committed
94
    //params_rel15->aggregation_level = 1;
Hongzhi's avatar
Hongzhi committed
95
    LOG_D(MAC, "DCI type 1 params: rmsi_pdcch_config %d, rnti %d, rnti_type %d, dci_format %d\n \
96 97 98 99 100 101 102 103 104 105 106 107 108 109 110
                coreset params: mux_pattern %d, n_rb %d, n_symb %d, rb_offset %d  \n \
                ss params : nb_ss_sets_per_slot %d, first symb %d, nb_slots %d, sfn_mod2 %d, first slot %d\n",
                0,
                params_rel15->rnti,
                params_rel15->rnti_type,
                params_rel15->dci_format,
                params_rel15->mux_pattern,
                params_rel15->n_rb,
                params_rel15->n_symb,
                params_rel15->rb_offset,
                params_rel15->nb_ss_sets_per_slot,
                params_rel15->first_symbol,
                params_rel15->nb_slots,
                params_rel15->sfn_mod2,
                params_rel15->first_slot);
Guy De Souza's avatar
Guy De Souza committed
111 112
  dl_req->number_dci++;
  dl_req->number_pdu++;
Guy De Souza's avatar
Guy De Souza committed
113 114 115 116 117 118 119 120 121 122 123

  TX_req = &nr_mac->TX_req[CC_id].tx_request_body.tx_pdu_list[nr_mac->TX_req[CC_id].tx_request_body.number_of_pdus];
  TX_req->pdu_length = 6;
  TX_req->pdu_index = nr_mac->pdu_index[CC_id]++;
  TX_req->num_segments = 1;
  TX_req->segments[0].segment_length = 8;
  //TX_req->segments[0].segment_data = (uint8_t*)pdu_rel15;
  nr_mac->TX_req[CC_id].tx_request_body.number_of_pdus++;
  nr_mac->TX_req[CC_id].sfn_sf = sfn_sf;
  nr_mac->TX_req[CC_id].tx_request_body.tl.tag = NFAPI_TX_REQUEST_BODY_TAG;
  nr_mac->TX_req[CC_id].header.message_id = NFAPI_TX_REQUEST;
124 125 126
    
  }
}