|
|
@ -151,6 +151,7 @@ int srslte_chest_sl_gen_dmrs(srslte_chest_sl_t* q,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
for (int i = 0; i < q->nof_dmrs_symbols; i++) {
|
|
|
|
for (int i = 0; i < q->nof_dmrs_symbols; i++) {
|
|
|
|
|
|
|
|
// All DMRS symbols have the same cyclic shift
|
|
|
|
q->n_CS[i] = cyclic_shift;
|
|
|
|
q->n_CS[i] = cyclic_shift;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -158,7 +159,7 @@ int srslte_chest_sl_gen_dmrs(srslte_chest_sl_t* q,
|
|
|
|
case SRSLTE_SIDELINK_PSSCH:
|
|
|
|
case SRSLTE_SIDELINK_PSSCH:
|
|
|
|
if (tm <= SRSLTE_SIDELINK_TM2) {
|
|
|
|
if (tm <= SRSLTE_SIDELINK_TM2) {
|
|
|
|
for (int i = 0; i < q->nof_dmrs_symbols; i++) {
|
|
|
|
for (int i = 0; i < q->nof_dmrs_symbols; i++) {
|
|
|
|
q->n_CS[i] = (int)(N_x_id / 2) % 8;
|
|
|
|
q->n_CS[i] = ((int)floor(N_x_id / 2)) % 8;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
// TODO: both equation are the same here but spec says N_id_X for Mode3+4
|
|
|
|
// TODO: both equation are the same here but spec says N_id_X for Mode3+4
|
|
|
@ -180,22 +181,20 @@ int srslte_chest_sl_gen_dmrs(srslte_chest_sl_t* q,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Group Hopping
|
|
|
|
// Group Hopping
|
|
|
|
uint32_t f_gh; // Group Hopping Flag
|
|
|
|
uint32_t f_gh = 0; // Group Hopping Flag
|
|
|
|
uint32_t f_ss;
|
|
|
|
uint32_t f_ss = 0;
|
|
|
|
uint32_t u[SRSLTE_SL_MAX_DMRS_SYMB]; // Sequence Group Number
|
|
|
|
uint32_t u[SRSLTE_SL_MAX_DMRS_SYMB]; // Sequence Group Number
|
|
|
|
|
|
|
|
|
|
|
|
// 36.211, Section 10.1.4.1.3
|
|
|
|
// 36.211, Section 10.1.4.1.3
|
|
|
|
// Base Sequence Number - always 0 for sidelink
|
|
|
|
// Base Sequence Number - always 0 for sidelink
|
|
|
|
switch (ch) {
|
|
|
|
switch (ch) {
|
|
|
|
case SRSLTE_SIDELINK_PSBCH:
|
|
|
|
case SRSLTE_SIDELINK_PSBCH:
|
|
|
|
f_gh = 0;
|
|
|
|
|
|
|
|
f_ss = (N_sl_id / 16) % SRSLTE_SL_N_RU_SEQ;
|
|
|
|
f_ss = (N_sl_id / 16) % SRSLTE_SL_N_RU_SEQ;
|
|
|
|
for (int ns = 0; ns < q->nof_dmrs_symbols; ns++) {
|
|
|
|
for (int ns = 0; ns < q->nof_dmrs_symbols; ns++) {
|
|
|
|
u[ns] = (f_gh + f_ss) % SRSLTE_SL_N_RU_SEQ;
|
|
|
|
u[ns] = (f_gh + f_ss) % SRSLTE_SL_N_RU_SEQ;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case SRSLTE_SIDELINK_PSCCH:
|
|
|
|
case SRSLTE_SIDELINK_PSCCH:
|
|
|
|
f_gh = 0;
|
|
|
|
|
|
|
|
if (tm <= SRSLTE_SIDELINK_TM2) {
|
|
|
|
if (tm <= SRSLTE_SIDELINK_TM2) {
|
|
|
|
f_ss = 0;
|
|
|
|
f_ss = 0;
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
@ -228,8 +227,6 @@ int srslte_chest_sl_gen_dmrs(srslte_chest_sl_t* q,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case SRSLTE_SIDELINK_PSDCH:
|
|
|
|
case SRSLTE_SIDELINK_PSDCH:
|
|
|
|
f_gh = 0;
|
|
|
|
|
|
|
|
f_ss = 0;
|
|
|
|
|
|
|
|
for (int ns = 0; ns < q->nof_dmrs_symbols; ns++) {
|
|
|
|
for (int ns = 0; ns < q->nof_dmrs_symbols; ns++) {
|
|
|
|
u[ns] = (f_gh + f_ss) % SRSLTE_SL_N_RU_SEQ;
|
|
|
|
u[ns] = (f_gh + f_ss) % SRSLTE_SL_N_RU_SEQ;
|
|
|
|
}
|
|
|
|
}
|
|
|
|