Add packing of dci format 1A for pdcch orders.

master
Fabian Eckermann 3 years ago committed by Andre Puschmann
parent adec23cbc5
commit d0c07fc86e

@ -70,7 +70,6 @@ typedef struct SRSRAN_API {
} srsran_dci_tb_t; } srsran_dci_tb_t;
typedef struct SRSRAN_API { typedef struct SRSRAN_API {
uint16_t rnti; uint16_t rnti;
srsran_dci_format_t format; srsran_dci_format_t format;
srsran_dci_location_t location; srsran_dci_location_t location;
@ -94,10 +93,10 @@ typedef struct SRSRAN_API {
bool power_offset; bool power_offset;
uint8_t tpc_pucch; uint8_t tpc_pucch;
// RA order // PDCCH order
bool is_ra_order; bool is_pdcch_order;
uint32_t ra_preamble; uint32_t preamble_idx;
uint32_t ra_mask_idx; uint32_t prach_mask_idx;
// Release 10 // Release 10
uint32_t cif; uint32_t cif;
@ -121,7 +120,6 @@ typedef struct SRSRAN_API {
/** Unpacked DCI Format0 message */ /** Unpacked DCI Format0 message */
typedef struct SRSRAN_API { typedef struct SRSRAN_API {
uint16_t rnti; uint16_t rnti;
srsran_dci_format_t format; srsran_dci_format_t format;
srsran_dci_location_t location; srsran_dci_location_t location;

@ -696,7 +696,7 @@ static int dci_format1_unpack(srsran_cell_t* cell,
/* Packs DCI format 1A for compact scheduling of PDSCH words according to 36.212 5.3.3.1.3 /* Packs DCI format 1A for compact scheduling of PDSCH words according to 36.212 5.3.3.1.3
* *
* TODO: RA procedure initiated by PDCCH, TPC commands * TODO: TPC commands
*/ */
static int dci_format1As_pack(srsran_cell_t* cell, static int dci_format1As_pack(srsran_cell_t* cell,
srsran_dl_sf_cfg_t* sf, srsran_dl_sf_cfg_t* sf,
@ -714,49 +714,64 @@ static int dci_format1As_pack(srsran_cell_t* cell,
*y++ = 1; // format differentiation *y++ = 1; // format differentiation
if (dci->alloc_type != SRSRAN_RA_ALLOC_TYPE2) { // random access procedure initiated by a PDCCH order
ERROR("Format 1A accepts type2 resource allocation only"); if (dci->is_pdcch_order) {
return SRSRAN_ERROR; *y++ = 0; // localized or distributed VRB assignment is always 0 for PDCCH order
}
*y++ = dci->type2_alloc.mode; // localized or distributed VRB assignment // RIV values all set to 1 for PDCCH order
int nof_bits = riv_nbits(cell->nof_prb);
int i = 0;
while (i < nof_bits) {
*y++ = 1;
i++;
}
/* pack RIV according to 7.1.6.3 of 36.213 */ srsran_bit_unpack(dci->preamble_idx, &y, 6); // preamble index
uint32_t riv = dci->type2_alloc.riv; srsran_bit_unpack(dci->prach_mask_idx, &y, 4); // PRACH mask index
uint32_t nb_gap = 0; } else {
if (SRSRAN_RNTI_ISUSER(dci->rnti) && dci->type2_alloc.mode == SRSRAN_RA_TYPE2_DIST && nof_prb >= 50) { if (dci->alloc_type != SRSRAN_RA_ALLOC_TYPE2) {
nb_gap = 1; ERROR("Format 1A accepts type2 resource allocation only");
*y++ = dci->type2_alloc.n_gap; return SRSRAN_ERROR;
} }
srsran_bit_unpack(riv, &y, riv_nbits(nof_prb) - nb_gap);
// in format1A, MCS = TBS according to 7.1.7.2 of 36.213 *y++ = dci->type2_alloc.mode; // localized or distributed VRB assignment
srsran_bit_unpack(dci->tb[0].mcs_idx, &y, 5);
srsran_bit_unpack(dci->pid, &y, HARQ_PID_LEN); /* pack RIV according to 7.1.6.3 of 36.213 */
uint32_t riv = dci->type2_alloc.riv;
uint32_t nb_gap = 0;
if (SRSRAN_RNTI_ISUSER(dci->rnti) && dci->type2_alloc.mode == SRSRAN_RA_TYPE2_DIST && nof_prb >= 50) {
nb_gap = 1;
*y++ = dci->type2_alloc.n_gap;
}
srsran_bit_unpack(riv, &y, riv_nbits(nof_prb) - nb_gap);
// in format1A, MCS = TBS according to 7.1.7.2 of 36.213
srsran_bit_unpack(dci->tb[0].mcs_idx, &y, 5);
srsran_bit_unpack(dci->pid, &y, HARQ_PID_LEN);
if (!SRSRAN_RNTI_ISUSER(dci->rnti)) { if (!SRSRAN_RNTI_ISUSER(dci->rnti)) {
if (nof_prb >= 50 && dci->type2_alloc.mode == SRSRAN_RA_TYPE2_DIST) { if (nof_prb >= 50 && dci->type2_alloc.mode == SRSRAN_RA_TYPE2_DIST) {
*y++ = dci->type2_alloc.n_gap; *y++ = dci->type2_alloc.n_gap;
} else {
y++; // bit reserved
}
} else { } else {
y++; // bit reserved *y++ = dci->tb[0].ndi;
} }
} else {
*y++ = dci->tb[0].ndi;
}
// rv version // rv version
srsran_bit_unpack(dci->tb[0].rv, &y, 2); srsran_bit_unpack(dci->tb[0].rv, &y, 2);
if (SRSRAN_RNTI_ISUSER(dci->rnti)) { if (SRSRAN_RNTI_ISUSER(dci->rnti)) {
// TPC not implemented // TPC not implemented
*y++ = 0; *y++ = 0;
*y++ = 0; *y++ = 0;
} else { } else {
y++; // MSB of TPC is reserved y++; // MSB of TPC is reserved
*y++ = dci->type2_alloc.n_prb1a; // LSB indicates N_prb_1a for TBS *y++ = dci->type2_alloc.n_prb1a; // LSB indicates N_prb_1a for TBS
}
} }
// Padding with zeros // Padding with zeros
uint32_t n = srsran_dci_format_sizeof(cell, sf, cfg, SRSRAN_DCI_FORMAT1A); uint32_t n = srsran_dci_format_sizeof(cell, sf, cfg, SRSRAN_DCI_FORMAT1A);
while (y - msg->payload < n) { while (y - msg->payload < n) {
@ -810,16 +825,16 @@ static int dci_format1As_unpack(srsran_cell_t* cell,
// This is a Random access order // This is a Random access order
y += 1 + nof_bits; y += 1 + nof_bits;
dci->is_ra_order = true; dci->is_pdcch_order = true;
dci->ra_preamble = srsran_bit_pack(&y, 6); dci->preamble_idx = srsran_bit_pack(&y, 6);
dci->ra_mask_idx = srsran_bit_pack(&y, 4); dci->prach_mask_idx = srsran_bit_pack(&y, 4);
return SRSRAN_SUCCESS; return SRSRAN_SUCCESS;
} }
} }
} }
dci->is_ra_order = false; dci->is_pdcch_order = false;
dci->alloc_type = SRSRAN_RA_ALLOC_TYPE2; dci->alloc_type = SRSRAN_RA_ALLOC_TYPE2;
dci->type2_alloc.mode = *y++; dci->type2_alloc.mode = *y++;
@ -1544,36 +1559,46 @@ static char* freq_hop_fl_string(int freq_hop)
void srsran_dci_dl_fprint(FILE* f, srsran_dci_dl_t* dci, uint32_t nof_prb) void srsran_dci_dl_fprint(FILE* f, srsran_dci_dl_t* dci, uint32_t nof_prb)
{ {
fprintf(f, " - Resource Allocation Type:\t\t%s\n", ra_type_string(dci->alloc_type)); if (dci->is_pdcch_order) {
switch (dci->alloc_type) { fprintf(f, "PDCCH order:\n");
case SRSRAN_RA_ALLOC_TYPE0: if (dci->cif_present) {
fprintf(f, " + Resource Block Group Size:\t\t%d\n", srsran_ra_type0_P(nof_prb)); fprintf(f, " - Carrier idx:\t\t\t\t%d\n", dci->cif);
fprintf(f, " + RBG Bitmap:\t\t\t0x%x\n", dci->type0_alloc.rbg_bitmask); }
break; fprintf(f, " - Preamble index:\t\t%d\n", dci->preamble_idx);
case SRSRAN_RA_ALLOC_TYPE1: fprintf(f, " - PRACH mask index:\t\t%d\n", dci->prach_mask_idx);
fprintf(f, " + Resource Block Group Size:\t\t%d\n", srsran_ra_type0_P(nof_prb)); } else {
fprintf(f, " + RBG Bitmap:\t\t\t0x%x\n", dci->type1_alloc.vrb_bitmask); fprintf(f, " - Resource Allocation Type:\t\t%s\n", ra_type_string(dci->alloc_type));
fprintf(f, " + RBG Subset:\t\t\t%d\n", dci->type1_alloc.rbg_subset); switch (dci->alloc_type) {
fprintf(f, " + RBG Shift:\t\t\t\t%s\n", dci->type1_alloc.shift ? "Yes" : "No"); case SRSRAN_RA_ALLOC_TYPE0:
break; fprintf(f, " + Resource Block Group Size:\t\t%d\n", srsran_ra_type0_P(nof_prb));
case SRSRAN_RA_ALLOC_TYPE2: fprintf(f, " + RBG Bitmap:\t\t\t0x%x\n", dci->type0_alloc.rbg_bitmask);
fprintf(f, " + Type:\t\t\t\t%s\n", dci->type2_alloc.mode == SRSRAN_RA_TYPE2_LOC ? "Localized" : "Distributed"); break;
fprintf(f, " + Resource Indicator Value:\t\t%d\n", dci->type2_alloc.riv); case SRSRAN_RA_ALLOC_TYPE1:
break; fprintf(f, " + Resource Block Group Size:\t\t%d\n", srsran_ra_type0_P(nof_prb));
} fprintf(f, " + RBG Bitmap:\t\t\t0x%x\n", dci->type1_alloc.vrb_bitmask);
if (dci->cif_present) { fprintf(f, " + RBG Subset:\t\t\t%d\n", dci->type1_alloc.rbg_subset);
fprintf(f, " - Carrier idx:\t\t\t\t%d\n", dci->cif); fprintf(f, " + RBG Shift:\t\t\t\t%s\n", dci->type1_alloc.shift ? "Yes" : "No");
} break;
fprintf(f, " - HARQ process:\t\t\t%d\n", dci->pid); case SRSRAN_RA_ALLOC_TYPE2:
fprintf(f, " - TPC command for PUCCH:\t\t--\n"); fprintf(
fprintf(f, " - Transport blocks swapped:\t\t%s\n", (dci->tb_cw_swap) ? "true" : "false"); f, " + Type:\t\t\t\t%s\n", dci->type2_alloc.mode == SRSRAN_RA_TYPE2_LOC ? "Localized" : "Distributed");
fprintf(f, " + Resource Indicator Value:\t\t%d\n", dci->type2_alloc.riv);
break;
}
if (dci->cif_present) {
fprintf(f, " - Carrier idx:\t\t\t\t%d\n", dci->cif);
}
fprintf(f, " - HARQ process:\t\t\t%d\n", dci->pid);
fprintf(f, " - TPC command for PUCCH:\t\t--\n");
fprintf(f, " - Transport blocks swapped:\t\t%s\n", (dci->tb_cw_swap) ? "true" : "false");
for (uint32_t i = 0; i < SRSRAN_MAX_CODEWORDS; i++) { for (uint32_t i = 0; i < SRSRAN_MAX_CODEWORDS; i++) {
fprintf(f, " - Transport block %d enabled:\t\t%s\n", i, SRSRAN_DCI_IS_TB_EN(dci->tb[i]) ? "true" : "false"); fprintf(f, " - Transport block %d enabled:\t\t%s\n", i, SRSRAN_DCI_IS_TB_EN(dci->tb[i]) ? "true" : "false");
if (SRSRAN_DCI_IS_TB_EN(dci->tb[i])) { if (SRSRAN_DCI_IS_TB_EN(dci->tb[i])) {
fprintf(f, " + Modulation and coding scheme index:\t%d\n", dci->tb[i].mcs_idx); fprintf(f, " + Modulation and coding scheme index:\t%d\n", dci->tb[i].mcs_idx);
fprintf(f, " + New data indicator:\t\t\t%s\n", dci->tb[i].ndi ? "Yes" : "No"); fprintf(f, " + New data indicator:\t\t\t%s\n", dci->tb[i].ndi ? "Yes" : "No");
fprintf(f, " + Redundancy version:\t\t\t%d\n", dci->tb[i].rv); fprintf(f, " + Redundancy version:\t\t\t%d\n", dci->tb[i].rv);
}
} }
} }
} }
@ -1618,46 +1643,51 @@ uint32_t srsran_dci_dl_info(const srsran_dci_dl_t* dci_dl, char* info_str, uint3
n = srsran_print_check(info_str, len, n, ", cif=%d", dci_dl->cif); n = srsran_print_check(info_str, len, n, ", cif=%d", dci_dl->cif);
} }
switch (dci_dl->alloc_type) { if (dci_dl->is_pdcch_order) {
case SRSRAN_RA_ALLOC_TYPE0: n = srsran_print_check(info_str, len, n, ", preamb_idx=%d", dci_dl->preamble_idx);
n = srsran_print_check(info_str, len, n, ", rbg=0x%x", dci_dl->type0_alloc.rbg_bitmask); n = srsran_print_check(info_str, len, n, ", prach_mask_idx=%d", dci_dl->prach_mask_idx);
break; } else {
case SRSRAN_RA_ALLOC_TYPE1: switch (dci_dl->alloc_type) {
n = srsran_print_check(info_str, case SRSRAN_RA_ALLOC_TYPE0:
len, n = srsran_print_check(info_str, len, n, ", rbg=0x%x", dci_dl->type0_alloc.rbg_bitmask);
n, break;
", vrb=0x%x, rbg_s=%d, sh=%d", case SRSRAN_RA_ALLOC_TYPE1:
dci_dl->type1_alloc.vrb_bitmask, n = srsran_print_check(info_str,
dci_dl->type1_alloc.rbg_subset, len,
dci_dl->type1_alloc.shift); n,
break; ", vrb=0x%x, rbg_s=%d, sh=%d",
case SRSRAN_RA_ALLOC_TYPE2: dci_dl->type1_alloc.vrb_bitmask,
n = srsran_print_check(info_str, len, n, ", riv=%d", dci_dl->type2_alloc.riv); dci_dl->type1_alloc.rbg_subset,
break; dci_dl->type1_alloc.shift);
} break;
case SRSRAN_RA_ALLOC_TYPE2:
n = srsran_print_check(info_str, len, n, ", riv=%d", dci_dl->type2_alloc.riv);
break;
}
n = srsran_print_check(info_str, len, n, ", pid=%d", dci_dl->pid); n = srsran_print_check(info_str, len, n, ", pid=%d", dci_dl->pid);
n = srsran_print_check(info_str, len, n, ", mcs={"); n = srsran_print_check(info_str, len, n, ", mcs={");
n = print_multi(info_str, n, len, dci_dl, 0); n = print_multi(info_str, n, len, dci_dl, 0);
n = srsran_print_check(info_str, len, n, "}"); n = srsran_print_check(info_str, len, n, "}");
n = srsran_print_check(info_str, len, n, ", ndi={"); n = srsran_print_check(info_str, len, n, ", ndi={");
n = print_multi(info_str, n, len, dci_dl, 2); n = print_multi(info_str, n, len, dci_dl, 2);
n = srsran_print_check(info_str, len, n, "}"); n = srsran_print_check(info_str, len, n, "}");
if (dci_dl->format == SRSRAN_DCI_FORMAT1 || dci_dl->format == SRSRAN_DCI_FORMAT1A || if (dci_dl->format == SRSRAN_DCI_FORMAT1 || dci_dl->format == SRSRAN_DCI_FORMAT1A ||
dci_dl->format == SRSRAN_DCI_FORMAT1B || dci_dl->format == SRSRAN_DCI_FORMAT2 || dci_dl->format == SRSRAN_DCI_FORMAT1B || dci_dl->format == SRSRAN_DCI_FORMAT2 ||
dci_dl->format == SRSRAN_DCI_FORMAT2A || dci_dl->format == SRSRAN_DCI_FORMAT2B) { dci_dl->format == SRSRAN_DCI_FORMAT2A || dci_dl->format == SRSRAN_DCI_FORMAT2B) {
n = srsran_print_check(info_str, len, n, ", tpc_pucch=%d", dci_dl->tpc_pucch); n = srsran_print_check(info_str, len, n, ", tpc_pucch=%d", dci_dl->tpc_pucch);
} }
if (dci_dl->is_tdd) { if (dci_dl->is_tdd) {
n = srsran_print_check(info_str, len, n, ", dai=%d", dci_dl->dai); n = srsran_print_check(info_str, len, n, ", dai=%d", dci_dl->dai);
} }
if (dci_dl->format == SRSRAN_DCI_FORMAT2 || dci_dl->format == SRSRAN_DCI_FORMAT2A || if (dci_dl->format == SRSRAN_DCI_FORMAT2 || dci_dl->format == SRSRAN_DCI_FORMAT2A ||
dci_dl->format == SRSRAN_DCI_FORMAT2B) { dci_dl->format == SRSRAN_DCI_FORMAT2B) {
n = srsran_print_check(info_str, len, n, ", tb_sw=%d, pinfo=%d", dci_dl->tb_cw_swap, dci_dl->pinfo); n = srsran_print_check(info_str, len, n, ", tb_sw=%d, pinfo=%d", dci_dl->tb_cw_swap, dci_dl->pinfo);
}
} }
#if SRSRAN_DCI_HEXDEBUG #if SRSRAN_DCI_HEXDEBUG

@ -457,13 +457,13 @@ int main(int argc, char** argv)
dci.rnti = rnti; dci.rnti = rnti;
dci.is_tdd = false; dci.is_tdd = false;
dci.is_dwpts = false; dci.is_dwpts = false;
dci.is_ra_order = false; dci.is_pdcch_order = false;
dci.tb_cw_swap = false; dci.tb_cw_swap = false;
dci.pconf = false; dci.pconf = false;
dci.power_offset = false; dci.power_offset = false;
dci.tpc_pucch = false; dci.tpc_pucch = false;
dci.ra_preamble = false; dci.preamble_idx = 0;
dci.ra_mask_idx = false; dci.prach_mask_idx = 0;
dci.srs_request = false; dci.srs_request = false;
dci.srs_request_present = false; dci.srs_request_present = false;

@ -627,13 +627,13 @@ int main(int argc, char** argv)
dci.rnti = serving_cell_pdsch_rnti; dci.rnti = serving_cell_pdsch_rnti;
dci.is_tdd = false; dci.is_tdd = false;
dci.is_dwpts = false; dci.is_dwpts = false;
dci.is_ra_order = false; dci.is_pdcch_order = false;
dci.tb_cw_swap = false; dci.tb_cw_swap = false;
dci.pconf = false; dci.pconf = false;
dci.power_offset = false; dci.power_offset = false;
dci.tpc_pucch = 0; dci.tpc_pucch = 0;
dci.ra_preamble = 0; dci.preamble_idx = 0;
dci.ra_mask_idx = 0; dci.prach_mask_idx = 0;
dci.srs_request = false; dci.srs_request = false;
dci.srs_request_present = false; dci.srs_request_present = false;
dci.cif_present = false; dci.cif_present = false;

Loading…
Cancel
Save