Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-RAN
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
canghaiwuhen
OpenXG-RAN
Commits
7ce5066f
Commit
7ce5066f
authored
Mar 01, 2020
by
ISIP
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
parallel architecture of 5G NR
parent
10dd25b2
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
406 additions
and
66 deletions
+406
-66
cmake_targets/build_oai
cmake_targets/build_oai
+2
-1
openair1/PHY/NR_TRANSPORT/nr_dlsch.c
openair1/PHY/NR_TRANSPORT/nr_dlsch.c
+36
-15
openair1/PHY/NR_TRANSPORT/nr_dlsch_coding.c
openair1/PHY/NR_TRANSPORT/nr_dlsch_coding.c
+18
-5
openair1/PHY/defs_gNB.h
openair1/PHY/defs_gNB.h
+29
-4
openair1/SIMULATION/NR_PHY/dlsim.c
openair1/SIMULATION/NR_PHY/dlsim.c
+321
-41
No files found.
cmake_targets/build_oai
View file @
7ce5066f
...
@@ -661,7 +661,8 @@ function main() {
...
@@ -661,7 +661,8 @@ function main() {
if
[
"
$SIMUS_PHY
"
=
"1"
]
;
then
if
[
"
$SIMUS_PHY
"
=
"1"
]
;
then
echo_info
"Compiling physical unitary tests simulators"
echo_info
"Compiling physical unitary tests simulators"
# TODO: fix: dlsim_tm4 pucchsim prachsim pdcchsim pbchsim mbmssim
# TODO: fix: dlsim_tm4 pucchsim prachsim pdcchsim pbchsim mbmssim
simlist
=
"dlsim ulsim ldpctest polartest smallblocktest nr_pbchsim nr_dlschsim nr_ulschsim nr_dlsim nr_ulsim nr_pucchsim"
simlist
=
"nr_dlsim "
#simlist="dlsim ulsim ldpctest polartest smallblocktest nr_pbchsim nr_dlschsim nr_ulschsim nr_dlsim nr_ulsim nr_pucchsim"
for
f
in
$simlist
;
do
for
f
in
$simlist
;
do
compilations
\
compilations
\
phy_simulators
$f
\
phy_simulators
$f
\
...
...
openair1/PHY/NR_TRANSPORT/nr_dlsch.c
View file @
7ce5066f
...
@@ -37,7 +37,7 @@
...
@@ -37,7 +37,7 @@
#include "nr_dci.h"
#include "nr_dci.h"
#include "nr_sch_dmrs.h"
#include "nr_sch_dmrs.h"
#include "PHY/MODULATION/nr_modulation.h"
#include "PHY/MODULATION/nr_modulation.h"
#define thread_for_scrambling_modulation
//#define DEBUG_DLSCH
//#define DEBUG_DLSCH
//#define DEBUG_DLSCH_MAPPING
//#define DEBUG_DLSCH_MAPPING
...
@@ -88,20 +88,23 @@ uint8_t nr_generate_pdsch(NR_gNB_DLSCH_t *dlsch,
...
@@ -88,20 +88,23 @@ uint8_t nr_generate_pdsch(NR_gNB_DLSCH_t *dlsch,
PHY_VARS_gNB
*
gNB
=
RC
.
gNB
[
0
][
0
];
PHY_VARS_gNB
*
gNB
=
RC
.
gNB
[
0
][
0
];
NR_DL_gNB_HARQ_t
*
harq
=
dlsch
->
harq_processes
[
dci_alloc
->
harq_pid
];
NR_DL_gNB_HARQ_t
*
harq
=
dlsch
->
harq_processes
[
dci_alloc
->
harq_pid
];
nfapi_nr_dl_config_dlsch_pdu_rel15_t
*
rel15
=
&
harq
->
dlsch_pdu
.
dlsch_pdu_rel15
;
nfapi_nr_dl_config_dlsch_pdu_rel15_t
*
rel15
=
&
harq
->
dlsch_pdu
.
dlsch_pdu_rel15
;
//
nfapi_nr_dl_config_pdcch_parameters_rel15_t pdcch_params = dci_alloc->pdcch_params;
nfapi_nr_dl_config_pdcch_parameters_rel15_t
pdcch_params
=
dci_alloc
->
pdcch_params
;
//
uint32_t scrambled_output[NR_MAX_NB_CODEWORDS][NR_MAX_PDSCH_ENCODED_LENGTH>>5];
uint32_t
scrambled_output
[
NR_MAX_NB_CODEWORDS
][
NR_MAX_PDSCH_ENCODED_LENGTH
>>
5
];
int16_t
**
mod_symbs
=
(
int16_t
**
)
dlsch
->
mod_symbs
;
int16_t
**
mod_symbs
=
(
int16_t
**
)
dlsch
->
mod_symbs
;
int16_t
**
tx_layers
=
(
int16_t
**
)
dlsch
->
txdataF
;
int16_t
**
tx_layers
=
(
int16_t
**
)
dlsch
->
txdataF
;
int8_t
Wf
[
2
],
Wt
[
2
],
l0
,
l_prime
[
2
],
delta
;
int8_t
Wf
[
2
],
Wt
[
2
],
l0
,
l_prime
[
2
],
delta
;
uint16_t
nb_symbols
=
rel15
->
nb_mod_symbols
;
uint16_t
nb_symbols
=
rel15
->
nb_mod_symbols
;
//uint8_t Qm = rel15->modulation_order;
struct
timespec
tt1
,
tt2
,
tt3
,
tt4
,
tt5
;
//uint32_t encoded_length = nb_symbols*Qm;
uint8_t
Qm
=
rel15
->
modulation_order
;
//printf("encoded_length = %d\n",encoded_length);
uint32_t
encoded_length
=
nb_symbols
*
Qm
;
gNB
->
complete_scrambling_and_modulation
=
0
;
gNB
->
complete_scrambling
=
0
;
gNB
->
complete_scrambling
=
0
;
gNB
->
complete_modulation
=
0
;
gNB
->
complete_modulation
=
0
;
for
(
int
q
=
0
;
q
<
13
;
q
++
){
/*
for(int q = 0 ;q<NR_MAX_NB_CODEWORDS;q++){
gNB->q_scrambling[q] = 0;
gNB->q_scrambling[q] = 0;
}
}
*/
/// CRC, coding, interleaving and rate matching
/// CRC, coding, interleaving and rate matching
AssertFatal
(
harq
->
pdu
!=
NULL
,
"harq->pdu is null
\n
"
);
AssertFatal
(
harq
->
pdu
!=
NULL
,
"harq->pdu is null
\n
"
);
start_meas
(
dlsch_encoding_stats
);
start_meas
(
dlsch_encoding_stats
);
...
@@ -123,16 +126,34 @@ for (int i=0; i<encoded_length>>3; i++) {
...
@@ -123,16 +126,34 @@ for (int i=0; i<encoded_length>>3; i++) {
}
}
printf
(
"
\n
"
);
printf
(
"
\n
"
);
#endif
#endif
long
sum
=
0
;
#ifdef thread_for_scrambling_modulation
// for(int j = 0;j<100;j++){
gNB
->
complete_scrambling_and_modulation
=
0
;
gNB
->
complete_modulation
=
0
;
clock_gettime
(
CLOCK_REALTIME
,
&
tt3
);
//clock_gettime(CLOCK_REALTIME, &tt1);
//pthread_cond_signal(&gNB->thread_modulation.cond_tx);
for
(
int
q
=
0
;
q
<
rel15
->
nb_codewords
;
q
++
)
pthread_cond_signal
(
&
gNB
->
thread_scrambling
[
q
].
cond_tx
);
//clock_gettime(CLOCK_REALTIME, &tt2);
//printf("pthread_cond_signal thread_scrambling [%d] consumes %ld nanoseconds!\n",j,tt2.tv_nsec - tt1.tv_nsec);
//while(gNB->complete_modulation != 1);
//clock_gettime(CLOCK_REALTIME, &tt1);
while
(
gNB
->
complete_scrambling_and_modulation
!=
1
);
//clock_gettime(CLOCK_REALTIME, &tt2);
//printf(" busy waiting for [%d] consumes %ld nanoseconds!\n",j,tt2.tv_nsec - tt1.tv_nsec);
clock_gettime
(
CLOCK_REALTIME
,
&
tt4
);
//usleep(100000);
// printf("scrambling_proc[] for all consumes %ld nanoseconds!%%%%%%%%%%%%%%%\n",tt4.tv_nsec - tt3.tv_nsec);
// sum += (tt4.tv_nsec - tt3.tv_nsec);
// }
// printf("averge time = %ld\n",sum/100);
pthread_cond_signal
(
&
gNB
->
thread_modulation
.
cond_tx
);
#else
pthread_cond_signal
(
&
gNB
->
thread_scrambling
.
cond_tx
);
while
(
gNB
->
complete_scrambling
!=
1
);
while
(
gNB
->
complete_modulation
!=
1
);
/*
/// scrambling
/// scrambling
start_meas
(
dlsch_scrambling_stats
);
start_meas
(
dlsch_scrambling_stats
);
printf("nb_codewords = %d encoded_length = %d\n",rel15->nb_codewords,encoded_length);
//
printf("nb_codewords = %d encoded_length = %d\n",rel15->nb_codewords,encoded_length);
for
(
int
q
=
0
;
q
<
rel15
->
nb_codewords
;
q
++
)
for
(
int
q
=
0
;
q
<
rel15
->
nb_codewords
;
q
++
)
memset
((
void
*
)
scrambled_output
[
q
],
0
,
(
encoded_length
>>
5
)
*
sizeof
(
uint32_t
));
memset
((
void
*
)
scrambled_output
[
q
],
0
,
(
encoded_length
>>
5
)
*
sizeof
(
uint32_t
));
uint16_t
n_RNTI
=
(
pdcch_params
.
search_space_type
==
NFAPI_NR_SEARCH_SPACE_TYPE_UE_SPECIFIC
)
?
\
uint16_t
n_RNTI
=
(
pdcch_params
.
search_space_type
==
NFAPI_NR_SEARCH_SPACE_TYPE_UE_SPECIFIC
)
?
\
...
@@ -174,8 +195,8 @@ for (int i=0; i<nb_symbols>>3; i++) {
...
@@ -174,8 +195,8 @@ for (int i=0; i<nb_symbols>>3; i++) {
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
#endif
#endif
*/
#endif
/// Layer mapping
/// Layer mapping
nr_layer_mapping
(
mod_symbs
,
nr_layer_mapping
(
mod_symbs
,
rel15
->
nb_layers
,
rel15
->
nb_layers
,
...
...
openair1/PHY/NR_TRANSPORT/nr_dlsch_coding.c
View file @
7ce5066f
...
@@ -158,6 +158,9 @@ NR_gNB_DLSCH_t *new_gNB_dlsch(unsigned char Kmimo,
...
@@ -158,6 +158,9 @@ NR_gNB_DLSCH_t *new_gNB_dlsch(unsigned char Kmimo,
for
(
int
q
=
0
;
q
<
NR_MAX_NB_CODEWORDS
;
q
++
)
for
(
int
q
=
0
;
q
<
NR_MAX_NB_CODEWORDS
;
q
++
)
dlsch
->
mod_symbs
[
q
]
=
(
int32_t
*
)
malloc16
(
NR_MAX_PDSCH_ENCODED_LENGTH
*
sizeof
(
int32_t
));
dlsch
->
mod_symbs
[
q
]
=
(
int32_t
*
)
malloc16
(
NR_MAX_PDSCH_ENCODED_LENGTH
*
sizeof
(
int32_t
));
for
(
int
q
=
0
;
q
<
NR_MAX_NB_CODEWORDS
;
q
++
)
dlsch
->
mod_symbs_test
[
q
]
=
(
int32_t
*
)
malloc16
(
NR_MAX_PDSCH_ENCODED_LENGTH
*
sizeof
(
int32_t
));
dlsch
->
calib_dl_ch_estimates
=
(
int32_t
**
)
malloc16
(
64
*
sizeof
(
int32_t
*
));
dlsch
->
calib_dl_ch_estimates
=
(
int32_t
**
)
malloc16
(
64
*
sizeof
(
int32_t
*
));
for
(
aa
=
0
;
aa
<
64
;
aa
++
)
{
for
(
aa
=
0
;
aa
<
64
;
aa
++
)
{
dlsch
->
calib_dl_ch_estimates
[
aa
]
=
(
int32_t
*
)
malloc16
(
OFDM_SYMBOL_SIZE_COMPLEX_SAMPLES
*
sizeof
(
int32_t
));
dlsch
->
calib_dl_ch_estimates
[
aa
]
=
(
int32_t
*
)
malloc16
(
OFDM_SYMBOL_SIZE_COMPLEX_SAMPLES
*
sizeof
(
int32_t
));
...
@@ -276,7 +279,16 @@ int nr_dlsch_encoding(unsigned char *a,
...
@@ -276,7 +279,16 @@ int nr_dlsch_encoding(unsigned char *a,
NR_gNB_DLSCH_t
*
dlsch
,
NR_gNB_DLSCH_t
*
dlsch
,
NR_DL_FRAME_PARMS
*
frame_parms
)
NR_DL_FRAME_PARMS
*
frame_parms
)
{
{
PHY_VARS_gNB
*
gNB
=
RC
.
gNB
[
0
][
0
];
gNB
->
complete_encode
[
0
]
=
0
;
gNB
->
complete_encode
[
1
]
=
0
;
gNB
->
complete_encode
[
2
]
=
0
;
gNB
->
complete_encode
[
3
]
=
0
;
for
(
int
t
=
0
;
t
<
4
;
t
++
){
pthread_cond_signal
(
&
gNB
->
thread_encode
[
t
].
cond_encode
);
}
while
((
gNB
->
complete_encode
[
0
]
!=
1
)
||
(
gNB
->
complete_encode
[
1
]
!=
1
)
||
(
gNB
->
complete_encode
[
2
]
!=
1
)
||
(
gNB
->
complete_encode
[
3
]
!=
1
));
/*
unsigned int G;
unsigned int G;
unsigned int crc=1;
unsigned int crc=1;
uint8_t harq_pid = dlsch->harq_ids[frame&2][slot];
uint8_t harq_pid = dlsch->harq_ids[frame&2][slot];
...
@@ -299,14 +311,14 @@ int nr_dlsch_encoding(unsigned char *a,
...
@@ -299,14 +311,14 @@ int nr_dlsch_encoding(unsigned char *a,
uint16_t length_dmrs = 1;
uint16_t length_dmrs = 1;
float Coderate = 0.0;
float Coderate = 0.0;
uint8_t Nl = 4;
uint8_t Nl = 4;
*/
/*
/*
uint8_t *channel_input[MAX_NUM_DLSCH_SEGMENTS]; //unsigned char
uint8_t *channel_input[MAX_NUM_DLSCH_SEGMENTS]; //unsigned char
for(j=0;j<MAX_NUM_DLSCH_SEGMENTS;j++) {
for(j=0;j<MAX_NUM_DLSCH_SEGMENTS;j++) {
channel_input[j] = (unsigned char *)malloc16(sizeof(unsigned char) * 68*384);
channel_input[j] = (unsigned char *)malloc16(sizeof(unsigned char) * 68*384);
}
}
*/
*/
/*
VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_ENB_DLSCH_ENCODING, VCD_FUNCTION_IN);
VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_ENB_DLSCH_ENCODING, VCD_FUNCTION_IN);
A = rel15.transport_block_size;
A = rel15.transport_block_size;
...
@@ -320,6 +332,7 @@ int nr_dlsch_encoding(unsigned char *a,
...
@@ -320,6 +332,7 @@ int nr_dlsch_encoding(unsigned char *a,
#ifdef DEBUG_DLSCH_CODING
#ifdef DEBUG_DLSCH_CODING
printf("encoding thinks this is a new packet \n");
printf("encoding thinks this is a new packet \n");
#endif
#endif
*/
/*
/*
int i;
int i;
printf("dlsch (tx): \n");
printf("dlsch (tx): \n");
...
@@ -327,7 +340,7 @@ int nr_dlsch_encoding(unsigned char *a,
...
@@ -327,7 +340,7 @@ int nr_dlsch_encoding(unsigned char *a,
printf("%02x.",a[i]);
printf("%02x.",a[i]);
printf("\n");
printf("\n");
*/
*/
/*
if (A > 3824) {
if (A > 3824) {
// Add 24-bit crc (polynomial A) to payload
// Add 24-bit crc (polynomial A) to payload
crc = crc24a(a,A)>>8;
crc = crc24a(a,A)>>8;
...
@@ -480,6 +493,6 @@ int nr_dlsch_encoding(unsigned char *a,
...
@@ -480,6 +493,6 @@ int nr_dlsch_encoding(unsigned char *a,
}
}
VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_ENB_DLSCH_ENCODING, VCD_FUNCTION_OUT);
VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_ENB_DLSCH_ENCODING, VCD_FUNCTION_OUT);
*/
return
0
;
return
0
;
}
}
openair1/PHY/defs_gNB.h
View file @
7ce5066f
...
@@ -133,6 +133,8 @@ typedef struct {
...
@@ -133,6 +133,8 @@ typedef struct {
int32_t
*
txdataF
[
NR_MAX_NB_LAYERS
];
int32_t
*
txdataF
[
NR_MAX_NB_LAYERS
];
/// Modulated symbols buffer
/// Modulated symbols buffer
int32_t
*
mod_symbs
[
NR_MAX_NB_CODEWORDS
];
int32_t
*
mod_symbs
[
NR_MAX_NB_CODEWORDS
];
/// Modulated symbols buffer for test
int32_t
*
mod_symbs_test
[
NR_MAX_NB_CODEWORDS
];
/// beamforming weights for UE-spec transmission (antenna ports 5 or 7..14), for each codeword, maximum 4 layers?
/// beamforming weights for UE-spec transmission (antenna ports 5 or 7..14), for each codeword, maximum 4 layers?
int32_t
**
ue_spec_bf_weights
[
NR_MAX_NB_LAYERS
];
int32_t
**
ue_spec_bf_weights
[
NR_MAX_NB_LAYERS
];
/// dl channel estimates (estimated from ul channel estimates)
/// dl channel estimates (estimated from ul channel estimates)
...
@@ -298,8 +300,21 @@ typedef struct{
...
@@ -298,8 +300,21 @@ typedef struct{
//=====//
//=====//
relaying_type_t
r_type
;
relaying_type_t
r_type
;
pthread_attr_t
attr_scrambling
;
pthread_attr_t
attr_scrambling
;
int
q_id
;
}
scrambling_channel
;
}
scrambling_channel
;
typedef
struct
{
pthread_t
pthread_encode
;
pthread_cond_t
cond_encode
;
pthread_mutex_t
mutex_encode
;
pthread_attr_t
attr_encode
;
volatile
int
flag_wait
;
int
id
;
}
dlsch_encoding_ISIP
;
typedef
struct
{
int
seg
;
}
ldpc_encoding_ISIP
;
typedef
struct
{
typedef
struct
{
pthread_t
pthread_modulation
;
pthread_t
pthread_modulation
;
pthread_cond_t
cond_tx
;
pthread_cond_t
cond_tx
;
...
@@ -847,12 +862,22 @@ typedef struct PHY_VARS_gNB_s {
...
@@ -847,12 +862,22 @@ typedef struct PHY_VARS_gNB_s {
int32_t
pusch_stats_bsr
[
NUMBER_OF_UE_MAX
][
10240
];
int32_t
pusch_stats_bsr
[
NUMBER_OF_UE_MAX
][
10240
];
int32_t
pusch_stats_BO
[
NUMBER_OF_UE_MAX
][
10240
];
int32_t
pusch_stats_BO
[
NUMBER_OF_UE_MAX
][
10240
];
scrambling_channel
thread_scrambling
;
scrambling_channel
thread_scrambling
[
NR_MAX_NB_CODEWORDS
]
;
modulation_channel
thread_modulation
;
modulation_channel
thread_modulation
;
volatile
int
complete_modulation
;
volatile
uint8_t
complete_modulation
;
volatile
int
complete_scrambling
;
volatile
uint8_t
complete_scrambling
;
volatile
uint8_t
complete_scrambling_and_modulation
;
uint32_t
scrambled_output
[
NR_MAX_NB_CODEWORDS
][
NR_MAX_PDSCH_ENCODED_LENGTH
>>
5
];
uint32_t
scrambled_output
[
NR_MAX_NB_CODEWORDS
][
NR_MAX_PDSCH_ENCODED_LENGTH
>>
5
];
volatile
int
q_scrambling
[
13
];
uint32_t
scrambled_output_test
[
NR_MAX_NB_CODEWORDS
][
NR_MAX_PDSCH_ENCODED_LENGTH
>>
5
];
volatile
int
q_scrambling
[
NR_MAX_NB_CODEWORDS
];
pthread_mutex_t
complete_scrambling_modulation_mutex
;
//**************************DLSCH ENCODING**************************//
dlsch_encoding_ISIP
thread_encode
[
4
];
ldpc_encoding_ISIP
ldpc_encode
;
volatile
uint8_t
complete_encode
[
4
];
//**************************DLSCH ENCODING**************************//
}
PHY_VARS_gNB
;
}
PHY_VARS_gNB
;
#endif
#endif
openair1/SIMULATION/NR_PHY/dlsim.c
View file @
7ce5066f
...
@@ -18,7 +18,9 @@
...
@@ -18,7 +18,9 @@
* For more information about the OpenAirInterface (OAI) Software Alliance:
* For more information about the OpenAirInterface (OAI) Software Alliance:
* contact@openairinterface.org
* contact@openairinterface.org
*/
*/
#define _GNU_SOURCE
#include <sched.h>
#include <time.h>
#include "PHY/phy_extern.h"
#include "PHY/phy_extern.h"
#include <fcntl.h>
#include <fcntl.h>
#include <math.h>
#include <math.h>
...
@@ -57,7 +59,7 @@
...
@@ -57,7 +59,7 @@
#include "openair1/SIMULATION/TOOLS/sim.h"
#include "openair1/SIMULATION/TOOLS/sim.h"
#include "openair1/SIMULATION/NR_PHY/nr_unitary_defs.h"
#include "openair1/SIMULATION/NR_PHY/nr_unitary_defs.h"
#include "openair1/SIMULATION/NR_PHY/nr_dummy_functions.c"
#include "openair1/SIMULATION/NR_PHY/nr_dummy_functions.c"
#define CPU_AFF
PHY_VARS_gNB
*
gNB
;
PHY_VARS_gNB
*
gNB
;
PHY_VARS_NR_UE
*
UE
;
PHY_VARS_NR_UE
*
UE
;
RAN_CONTEXT_t
RC
;
RAN_CONTEXT_t
RC
;
...
@@ -125,10 +127,166 @@ void mac_rlc_data_ind (
...
@@ -125,10 +127,166 @@ void mac_rlc_data_ind (
// needed for some functions
// needed for some functions
openair0_config_t
openair0_cfg
[
MAX_CARDS
];
openair0_config_t
openair0_cfg
[
MAX_CARDS
];
uint32_t
nr_get_G
(
uint16_t
nb_rb
,
uint16_t
nb_symb_sch
,
uint8_t
nb_re_dmrs
,
uint16_t
length_dmrs
,
uint8_t
Qm
,
uint8_t
Nl
);
uint32_t
nr_get_E
(
uint32_t
G
,
uint8_t
C
,
uint8_t
Qm
,
uint8_t
Nl
,
uint8_t
r
);
uint32_t
nr_compute_tbslbrm
(
uint16_t
table
,
uint16_t
nb_rb
,
uint8_t
Nl
,
uint8_t
C
);
void
nr_interleaving_ldpc
(
uint32_t
E
,
uint8_t
Qm
,
uint8_t
*
e
,
uint8_t
*
f
);
int
nr_rate_matching_ldpc
(
uint8_t
Ilbrm
,
uint32_t
Tbslbrm
,
uint8_t
BG
,
uint16_t
Z
,
uint8_t
*
w
,
uint8_t
*
e
,
uint8_t
C
,
uint8_t
rvidx
,
uint32_t
E
);
int32_t
nr_segmentation
(
unsigned
char
*
input_buffer
,
unsigned
char
**
output_buffers
,
unsigned
int
B
,
unsigned
int
*
C
,
unsigned
int
*
K
,
unsigned
int
*
Zout
,
unsigned
int
*
F
,
uint8_t
BG
);
int
ldpc_encoder_optim_8seg_multi
(
unsigned
char
**
test_input
,
unsigned
char
**
channel_input
,
int
Zc
,
int
Kb
,
short
block_length
,
short
BG
,
int
n_segments
,
unsigned
int
macro_num
,
time_stats_t
*
tinput
,
time_stats_t
*
tprep
,
time_stats_t
*
tparity
,
time_stats_t
*
toutput
);
static
void
*
dlsch_encoding_proc
(
void
*
ptr
){
dlsch_encoding_ISIP
*
test
=
(
dlsch_encoding_ISIP
*
)
ptr
;
int
num
=
test
->
id
;
static
int
encode_status
=
0
;
uint8_t
Nl
=
4
,
Ilbrm
=
1
,
BG
=
1
;
uint16_t
r
,
Kr
=
0
,
R
;
uint32_t
A
,
E
,
Z
,
Kb
;
uint32_t
*
Zc
=
&
Z
,
Tbslbrm
=
950984
,
r_offset
=
0
,
F
=
0
;
int
frame
=
0
,
slot
=
1
;
float
Coderate
=
0
.
0
;
unsigned
int
crc
=
1
;
while
(
!
oai_exit
){
while
(
pthread_cond_wait
(
&
gNB
->
thread_encode
[
num
].
cond_encode
,
&
gNB
->
thread_encode
[
num
].
mutex_encode
)
!=
0
);
// TICK(TIME_DLSCH_ENCODING_THREAD);
test
->
flag_wait
=
0
;
uint8_t
num_pdsch_rnti
=
gNB
->
pdcch_vars
.
num_pdsch_rnti
;
for
(
int
i
=
0
;
i
<
num_pdsch_rnti
;
i
++
)
{
NR_gNB_DLSCH_t
*
nr_gnb_dlsch
=
gNB
->
dlsch
[
i
][
0
];
NR_gNB_DCI_ALLOC_t
*
dci_alloc
=
&
gNB
->
pdcch_vars
.
dci_alloc
[
i
];
NR_DL_gNB_HARQ_t
*
harq
=
nr_gnb_dlsch
->
harq_processes
[
dci_alloc
->
harq_pid
];
uint8_t
harq_pid
=
nr_gnb_dlsch
->
harq_ids
[
frame
&
2
][
slot
];
nfapi_nr_dl_config_dlsch_pdu_rel15_t
rel15
=
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
dlsch_pdu
.
dlsch_pdu_rel15
;
uint16_t
nb_rb
=
rel15
.
n_prb
;
uint8_t
nb_symb_sch
=
rel15
.
nb_symbols
;
uint8_t
mod_order
=
rel15
.
modulation_order
;
uint8_t
nb_re_dmrs
=
rel15
.
nb_re_dmrs
;
uint16_t
length_dmrs
=
1
;
unsigned
int
G
=
nr_get_G
(
nb_rb
,
nb_symb_sch
,
nb_re_dmrs
,
length_dmrs
,
mod_order
,
rel15
.
nb_layers
);
unsigned
char
*
a
=
harq
->
pdu
;
A
=
rel15
.
transport_block_size
;
R
=
rel15
.
coding_rate
;
if
(
A
>
3824
)
{
// Add 24-bit crc (polynomial A) to payload
crc
=
crc24a
(
a
,
A
)
>>
8
;
a
[
A
>>
3
]
=
((
uint8_t
*
)
&
crc
)[
2
];
a
[
1
+
(
A
>>
3
)]
=
((
uint8_t
*
)
&
crc
)[
1
];
a
[
2
+
(
A
>>
3
)]
=
((
uint8_t
*
)
&
crc
)[
0
];
//printf("CRC %x (A %d)\n",crc,A);
//printf("a0 %d a1 %d a2 %d\n", a[A>>3], a[1+(A>>3)], a[2+(A>>3)]);
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
B
=
A
+
24
;
// nr_gnb_dlsch->harq_processes[harq_pid]->b = a;
AssertFatal
((
A
/
8
)
+
4
<=
MAX_DLSCH_PAYLOAD_BYTES
,
"A %d is too big (A/8+4 = %d > %d)
\n
"
,
A
,(
A
/
8
)
+
4
,
MAX_DLSCH_PAYLOAD_BYTES
);
memcpy
(
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
b
,
a
,(
A
/
8
)
+
4
);
// why is this +4 if the CRC is only 3 bytes?
}
else
{
// Add 16-bit crc (polynomial A) to payload
crc
=
crc16
(
a
,
A
)
>>
16
;
a
[
A
>>
3
]
=
((
uint8_t
*
)
&
crc
)[
1
];
a
[
1
+
(
A
>>
3
)]
=
((
uint8_t
*
)
&
crc
)[
0
];
//printf("CRC %x (A %d)\n",crc,A);
//printf("a0 %d a1 %d \n", a[A>>3], a[1+(A>>3)]);
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
B
=
A
+
16
;
// nr_gnb_dlsch->harq_processes[harq_pid]->b = a;
AssertFatal
((
A
/
8
)
+
3
<=
MAX_DLSCH_PAYLOAD_BYTES
,
"A %d is too big (A/8+3 = %d > %d)
\n
"
,
A
,(
A
/
8
)
+
3
,
MAX_DLSCH_PAYLOAD_BYTES
);
memcpy
(
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
b
,
a
,(
A
/
8
)
+
3
);
// using 3 bytes to mimic the case of 24 bit crc
}
if
(
R
<
1000
)
Coderate
=
(
float
)
R
/
(
float
)
1024
;
else
// to scale for mcs 20 and 26 in table 5.1.3.1-2 which are decimal and input 2* in nr_tbs_tools
Coderate
=
(
float
)
R
/
(
float
)
2048
;
if
((
A
<=
292
)
||
((
A
<=
3824
)
&&
(
Coderate
<=
0
.
6667
))
||
Coderate
<=
0
.
25
)
BG
=
2
;
else
BG
=
1
;
Kb
=
nr_segmentation
(
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
b
,
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
c
,
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
B
,
&
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
C
,
&
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
K
,
Zc
,
&
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
F
,
BG
);
F
=
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
F
;
Kr
=
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
K
;
//for(int j = 0; j < (nr_gnb_dlsch->harq_processes[harq_pid]->C/8 + 1); j++) {
//ldpc_encoder_optim_8seg_multi(nr_gnb_dlsch->harq_processes[harq_pid]->c,nr_gnb_dlsch->harq_processes[harq_pid]->d,*Zc,Kb,Kr,BG,nr_gnb_dlsch->harq_processes[harq_pid]->C,(gNB->ldpc_encode).seg,NULL,NULL,NULL,NULL);
ldpc_encoder_optim_8seg_multi
(
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
c
,
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
d
,
*
Zc
,
Kb
,
Kr
,
BG
,
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
C
,
0
,
NULL
,
NULL
,
NULL
,
NULL
);
//}
for
(
r
=
0
;
r
<
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
C
;
r
++
)
{
if
(
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
F
>
0
)
{
for
(
int
k
=
(
Kr
-
F
-
2
*
(
*
Zc
));
k
<
Kr
-
2
*
(
*
Zc
);
k
++
)
{
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
d
[
r
][
k
]
=
NR_NULL
;
}
}
E
=
nr_get_E
(
G
,
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
C
,
mod_order
,
rel15
.
nb_layers
,
r
);
// for tbslbrm calculation according to 5.4.2.1 of 38.212
if
(
rel15
.
nb_layers
<
Nl
)
Nl
=
rel15
.
nb_layers
;
Tbslbrm
=
nr_compute_tbslbrm
(
rel15
.
mcs_table
,
nb_rb
,
Nl
,
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
C
);
//TICK(TIME_NR_RATE_MATCH_LDPC);
nr_rate_matching_ldpc
(
Ilbrm
,
Tbslbrm
,
BG
,
*
Zc
,
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
d
[
r
],
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
e
+
r_offset
,
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
C
,
rel15
.
redundancy_version
,
E
);
//TOCK(TIME_NR_RATE_MATCH_LDPC);
//TICK(TIME_NR_INTERLEAVING_LDPC);
nr_interleaving_ldpc
(
E
,
mod_order
,
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
e
+
r_offset
,
nr_gnb_dlsch
->
harq_processes
[
harq_pid
]
->
f
+
r_offset
);
//TOCK(TIME_NR_INTERLEAVING_LDPC);
r_offset
+=
E
;
}
}
gNB
->
complete_encode
[
num
]
=
1
;
// TOCK(TIME_DLSCH_ENCODING_THREAD);
}
encode_status
=
0
;
return
&
encode_status
;
}
static
void
*
scrambling_proc
(
void
*
ptr
){
static
void
*
scrambling_proc
(
void
*
ptr
){
PHY_VARS_gNB
*
gNB
=
RC
.
gNB
[
0
][
0
];
NR_gNB_DLSCH_t
*
dlsch
=
gNB
->
dlsch
[
0
][
0
];
scrambling_channel
*
test
=
(
scrambling_channel
*
)
ptr
;
int
q_id
=
test
->
q_id
;
struct
timespec
tt1
,
tt2
,
tt3
,
tt4
;
//clock_gettime(CLOCK_REALTIME, &eNB->tt17);
//clock_gettime(CLOCK_REALTIME, &eNB->tt17);
//printf("cch_proc consumes %ld nanoseconds!\n",eNB->tt17.tv_nsec-eNB->tt13.tv_nsec);
//printf("cch_proc consumes %ld nanoseconds!\n",eNB->tt17.tv_nsec-eNB->tt13.tv_nsec);
static
int
scrambling_channel_status
;
static
int
scrambling_channel_status
;
...
@@ -136,42 +294,68 @@ static void *scrambling_proc(void *ptr){
...
@@ -136,42 +294,68 @@ static void *scrambling_proc(void *ptr){
//scrambling_channel *scrambling_proc=(scrambling_channel*)ptr;
//scrambling_channel *scrambling_proc=(scrambling_channel*)ptr;
//PHY_VARS_eNB *eNB = PHY_vars_eNB_g[0][0];
//PHY_VARS_eNB *eNB = PHY_vars_eNB_g[0][0];
/**********************************************************************/
/**********************************************************************/
#ifdef CPU_AFF
cpu_set_t
cpuset
;
int
cpu
=
0
;
int
s
;
CPU_ZERO
(
&
cpuset
);
//clears the cpuset
CPU_SET
(
cpu
,
&
cpuset
);
//set CPU 0~7 on cpuset
s
=
pthread_setaffinity_np
(
pthread_self
(),
sizeof
(
cpu_set_t
),
&
cpuset
);
if
(
s
!=
0
)
{
perror
(
"pthread_setaffinity_np"
);
exit_fun
(
"Error setting processor affinity"
);
}
s
=
pthread_getaffinity_np
(
pthread_self
(),
sizeof
(
cpu_set_t
),
&
cpuset
);
if
(
s
!=
0
)
{
perror
(
"pthread_getaffinity_np"
);
exit_fun
(
"Error getting processor affinity "
);
}
printf
(
"[SCHED][gNB] scrambling_proc scheduler thread started on CPU %d TID %ld
\n
"
,
sched_getcpu
(),
gettid
());
#endif
/**********************************************************************/
while
(
!
oai_exit
)
while
(
!
oai_exit
)
{
{
while
(
pthread_cond_wait
(
&
gNB
->
thread_scrambling
.
cond_tx
,
&
gNB
->
thread_scrambling
.
mutex_tx
)
!=
0
);
while
(
pthread_cond_wait
(
&
gNB
->
thread_scrambling
[
test
->
q_id
].
cond_tx
,
&
gNB
->
thread_scrambling
[
test
->
q_id
]
.
mutex_tx
)
!=
0
);
//VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_ENB_CONTROL_CHANNEL_THREAD_TX,1);
//VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_ENB_CONTROL_CHANNEL_THREAD_TX,1);
//clock_gettime(CLOCK_REALTIME, &tt1);
PHY_VARS_gNB
*
gNB
=
RC
.
gNB
[
0
][
0
];
NR_gNB_DLSCH_t
*
dlsch
=
gNB
->
dlsch
[
0
][
0
];
NR_gNB_DCI_ALLOC_t
*
dci_alloc
=
&
gNB
->
pdcch_vars
.
dci_alloc
[
0
];
NR_gNB_DCI_ALLOC_t
*
dci_alloc
=
&
gNB
->
pdcch_vars
.
dci_alloc
[
0
];
NR_DL_gNB_HARQ_t
*
harq
=
dlsch
->
harq_processes
[
dci_alloc
->
harq_pid
];
NR_DL_gNB_HARQ_t
*
harq
=
dlsch
->
harq_processes
[
dci_alloc
->
harq_pid
];
nfapi_nr_dl_config_dlsch_pdu_rel15_t
*
rel15
=
&
harq
->
dlsch_pdu
.
dlsch_pdu_rel15
;
nfapi_nr_dl_config_dlsch_pdu_rel15_t
*
rel15
=
&
harq
->
dlsch_pdu
.
dlsch_pdu_rel15
;
nfapi_nr_config_request_t
*
config
=
&
gNB
->
gNB_config
;
nfapi_nr_config_request_t
*
config
=
&
gNB
->
gNB_config
;
nfapi_nr_dl_config_pdcch_parameters_rel15_t
pdcch_params
=
dci_alloc
->
pdcch_params
;
nfapi_nr_dl_config_pdcch_parameters_rel15_t
pdcch_params
=
dci_alloc
->
pdcch_params
;
//uint32_t scrambled_output[NR_MAX_NB_CODEWORDS][NR_MAX_PDSCH_ENCODED_LENGTH>>5];
uint32_t
scrambled_output
[
NR_MAX_NB_CODEWORDS
][
NR_MAX_PDSCH_ENCODED_LENGTH
>>
5
];
//int16_t **mod_symbs = (int16_t**)dlsch->mod_symbs;
int16_t
**
mod_symbs
=
(
int16_t
**
)
dlsch
->
mod_symbs
;
//int16_t **tx_layers = (int16_t**)dlsch->txdataF;
//int16_t **tx_layers = (int16_t**)dlsch->txdataF;
//int8_t Wf[2], Wt[2], l0, l_prime[2], delta;
//int8_t Wf[2], Wt[2], l0, l_prime[2], delta;
uint16_t
nb_symbols
=
rel15
->
nb_mod_symbols
;
uint16_t
nb_symbols
=
rel15
->
nb_mod_symbols
;
uint8_t
Qm
=
rel15
->
modulation_order
;
uint8_t
Qm
=
rel15
->
modulation_order
;
uint32_t
encoded_length
=
nb_symbols
*
Qm
;
uint32_t
encoded_length
=
nb_symbols
*
Qm
;
//clock_gettime(CLOCK_REALTIME, &tt2);
//printf("scrambling_proc initial for q = %d consumes %ld nanoseconds!!!!!!!!!!!\n", q_id,tt2.tv_nsec - tt1.tv_nsec);
//VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_ENB_PMCH_PBCH_TX,1);
//VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_ENB_PMCH_PBCH_TX,1);
/// scrambling
/// scrambling
clock_gettime
(
CLOCK_REALTIME
,
&
tt3
);
clock_gettime
(
CLOCK_REALTIME
,
&
tt1
);
for
(
int
q
=
0
;
q
<
rel15
->
nb_codewords
;
q
++
)
for
(
int
q
=
0
;
q
<
rel15
->
nb_codewords
;
q
++
)
memset
((
void
*
)(
gNB
->
scrambled_output
[
q
]),
0
,
(
encoded_length
>>
5
)
*
sizeof
(
uint32_t
));
memset
((
void
*
)(
scrambled_output
[
q
]),
0
,
(
encoded_length
>>
5
)
*
sizeof
(
uint32_t
));
uint16_t
n_RNTI
=
(
pdcch_params
.
search_space_type
==
NFAPI_NR_SEARCH_SPACE_TYPE_UE_SPECIFIC
)
?
\
uint16_t
n_RNTI
=
(
pdcch_params
.
search_space_type
==
NFAPI_NR_SEARCH_SPACE_TYPE_UE_SPECIFIC
)
?
\
((
pdcch_params
.
scrambling_id
==
0
)
?
pdcch_params
.
rnti
:
0
)
:
0
;
((
pdcch_params
.
scrambling_id
==
0
)
?
pdcch_params
.
rnti
:
0
)
:
0
;
uint16_t
Nid
=
(
pdcch_params
.
search_space_type
==
NFAPI_NR_SEARCH_SPACE_TYPE_UE_SPECIFIC
)
?
\
uint16_t
Nid
=
(
pdcch_params
.
search_space_type
==
NFAPI_NR_SEARCH_SPACE_TYPE_UE_SPECIFIC
)
?
\
pdcch_params
.
scrambling_id
:
config
->
sch_config
.
physical_cell_id
.
value
;
pdcch_params
.
scrambling_id
:
config
->
sch_config
.
physical_cell_id
.
value
;
for
(
int
q
=
0
;
q
<
rel15
->
nb_codewords
;
q
++
){
nr_pdsch_codeword_scrambling
(
harq
->
f
,
nr_pdsch_codeword_scrambling
(
harq
->
f
,
encoded_length
,
encoded_length
,
q
,
q
_id
,
Nid
,
Nid
,
n_RNTI
,
n_RNTI
,
gNB
->
scrambled_output
[
q
]);
scrambled_output
[
q_id
]);
gNB
->
q_scrambling
[
q
]
=
1
;
}
clock_gettime
(
CLOCK_REALTIME
,
&
tt2
);
// printf("scrambling for q = %d consumes %ld nanoseconds!\n", q_id,tt2.tv_nsec - tt1.tv_nsec);
#ifdef DEBUG_DLSCH
#ifdef DEBUG_DLSCH
printf
(
"PDSCH scrambling:
\n
"
);
printf
(
"PDSCH scrambling:
\n
"
);
for
(
int
i
=
0
;
i
<
encoded_length
>>
8
;
i
++
)
{
for
(
int
i
=
0
;
i
<
encoded_length
>>
8
;
i
++
)
{
...
@@ -182,9 +366,32 @@ static void *scrambling_proc(void *ptr){
...
@@ -182,9 +366,32 @@ static void *scrambling_proc(void *ptr){
#endif
#endif
clock_gettime
(
CLOCK_REALTIME
,
&
tt1
);
nr_modulation
(
scrambled_output
[
q_id
],
encoded_length
,
Qm
,
mod_symbs
[
q_id
]);
//gNB->q_scrambling[q] = 0;
clock_gettime
(
CLOCK_REALTIME
,
&
tt2
);
// printf("modulation for q = %d consumes %ld nanoseconds!\n", q_id,tt2.tv_nsec - tt1.tv_nsec);
//stop_meas(dlsch_modulation_stats);
#ifdef DEBUG_DLSCH
printf
(
"PDSCH Modulation: Qm %d(%d)
\n
"
,
Qm
,
nb_symbols
);
for
(
int
i
=
0
;
i
<
nb_symbols
>>
3
;
i
++
)
{
for
(
int
j
=
0
;
j
<
8
;
j
++
)
{
printf
(
"%d %d
\t
"
,
mod_symbs
[
0
][((
i
<<
3
)
+
j
)
<<
1
],
mod_symbs
[
0
][(((
i
<<
3
)
+
j
)
<<
1
)
+
1
]);
}
printf
(
"
\n
"
);
}
#endif
//printf("complete_scrambling\n");
//printf("complete_scrambling\n");
gNB
->
complete_scrambling
=
1
;
//pthread_mutex_lock(&gNB->complete_scrambling_modulation_mutex);
//gNB->complete_scrambling_and_modulation++;
//pthread_mutex_unlock(&gNB->complete_scrambling_modulation_mutex);
clock_gettime
(
CLOCK_REALTIME
,
&
tt4
);
// printf("scrambling&modulation for q = %d consumes %ld nanoseconds!\n", q_id,tt4.tv_nsec - tt3.tv_nsec);
gNB
->
complete_scrambling_and_modulation
++
;
}
}
printf
(
"Exiting gNB thread scrambling_channel
\n
"
);
printf
(
"Exiting gNB thread scrambling_channel
\n
"
);
return
&
scrambling_channel_status
;
return
&
scrambling_channel_status
;
...
@@ -198,41 +405,94 @@ static void *modulation_proc(void *ptr){
...
@@ -198,41 +405,94 @@ static void *modulation_proc(void *ptr){
//printf("cch_proc consumes %ld nanoseconds!\n",eNB->tt17.tv_nsec-eNB->tt13.tv_nsec);
//printf("cch_proc consumes %ld nanoseconds!\n",eNB->tt17.tv_nsec-eNB->tt13.tv_nsec);
static
int
modulation_channel_status
;
static
int
modulation_channel_status
;
modulation_channel_status
=
0
;
modulation_channel_status
=
0
;
//modulation_channel *modulation_proc=(modulation_channel*)ptr;
struct
timespec
tt1
,
tt2
;
//PHY_VARS_eNB *eNB = PHY_vars_eNB_g[0][0];
PHY_VARS_gNB
*
gNB
=
RC
.
gNB
[
0
][
0
];
/**********************************************************************/
NR_gNB_DLSCH_t
*
dlsch
=
gNB
->
dlsch
[
0
][
0
];
/**********************************************************************/
#ifdef CPU_AFF
cpu_set_t
cpuset
;
int
cpu
=
1
;
int
s
;
CPU_ZERO
(
&
cpuset
);
//clears the cpuset
CPU_SET
(
cpu
,
&
cpuset
);
//set CPU 0~7 on cpuset
s
=
pthread_setaffinity_np
(
pthread_self
(),
sizeof
(
cpu_set_t
),
&
cpuset
);
if
(
s
!=
0
)
{
perror
(
"pthread_setaffinity_np"
);
exit_fun
(
"Error setting processor affinity"
);
}
s
=
pthread_getaffinity_np
(
pthread_self
(),
sizeof
(
cpu_set_t
),
&
cpuset
);
if
(
s
!=
0
)
{
perror
(
"pthread_getaffinity_np"
);
exit_fun
(
"Error getting processor affinity "
);
}
printf
(
"[SCHED][gNB] scrambling_proc scheduler thread started on CPU %d TID %ld
\n
"
,
sched_getcpu
(),
gettid
());
#endif
/*
NR_gNB_DCI_ALLOC_t *dci_alloc = &gNB->pdcch_vars.dci_alloc[0];
NR_DL_gNB_HARQ_t *harq = dlsch->harq_processes[dci_alloc->harq_pid];
nfapi_nr_dl_config_dlsch_pdu_rel15_t *rel15 = &harq->dlsch_pdu.dlsch_pdu_rel15;
nfapi_nr_config_request_t *config = &gNB->gNB_config;
nfapi_nr_dl_config_pdcch_parameters_rel15_t pdcch_params = dci_alloc->pdcch_params;
uint32_t scrambled_output[NR_MAX_NB_CODEWORDS][NR_MAX_PDSCH_ENCODED_LENGTH>>5];
*/
while
(
!
oai_exit
)
while
(
!
oai_exit
)
{
{
while
(
pthread_cond_wait
(
&
gNB
->
thread_modulation
.
cond_tx
,
&
gNB
->
thread_modulation
.
mutex_tx
)
!=
0
);
while
(
pthread_cond_wait
(
&
gNB
->
thread_modulation
.
cond_tx
,
&
gNB
->
thread_modulation
.
mutex_tx
)
!=
0
);
clock_gettime
(
CLOCK_REALTIME
,
&
tt1
);
//VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_ENB_CONTROL_CHANNEL_THREAD_TX,1);
//VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_ENB_CONTROL_CHANNEL_THREAD_TX,1);
PHY_VARS_gNB
*
gNB
=
RC
.
gNB
[
0
][
0
];
gNB
->
complete_modulation
=
0
;
NR_gNB_DLSCH_t
*
dlsch
=
gNB
->
dlsch
[
0
][
0
];
NR_gNB_DCI_ALLOC_t
*
dci_alloc
=
&
gNB
->
pdcch_vars
.
dci_alloc
[
0
];
NR_gNB_DCI_ALLOC_t
*
dci_alloc
=
&
gNB
->
pdcch_vars
.
dci_alloc
[
0
];
NR_DL_gNB_HARQ_t
*
harq
=
dlsch
->
harq_processes
[
dci_alloc
->
harq_pid
];
NR_DL_gNB_HARQ_t
*
harq
=
dlsch
->
harq_processes
[
dci_alloc
->
harq_pid
];
nfapi_nr_dl_config_dlsch_pdu_rel15_t
*
rel15
=
&
harq
->
dlsch_pdu
.
dlsch_pdu_rel15
;
nfapi_nr_dl_config_dlsch_pdu_rel15_t
*
rel15
=
&
harq
->
dlsch_pdu
.
dlsch_pdu_rel15
;
//nfapi_nr_config_request_t *config = &gNB->gNB_config;
nfapi_nr_config_request_t
*
config
=
&
gNB
->
gNB_config
;
//nfapi_nr_dl_config_pdcch_parameters_rel15_t pdcch_params = dci_alloc->pdcch_params;
nfapi_nr_dl_config_pdcch_parameters_rel15_t
pdcch_params
=
dci_alloc
->
pdcch_params
;
//uint32_t scrambled_output[NR_MAX_NB_CODEWORDS][NR_MAX_PDSCH_ENCODED_LENGTH>>5];
uint32_t
scrambled_output
[
NR_MAX_NB_CODEWORDS
][
NR_MAX_PDSCH_ENCODED_LENGTH
>>
5
];
int16_t
**
mod_symbs
=
(
int16_t
**
)
dlsch
->
mod_symbs
;
int16_t
**
mod_symbs
=
(
int16_t
**
)
dlsch
->
mod_symbs_test
;
//int16_t **tx_layers = (int16_t**)dlsch->txdataF;
//int8_t Wf[2], Wt[2], l0, l_prime[2], delta;
//int16_t **mod_symbs ;/*= (int16_t**)dlsch->mod_symbs;*/
uint16_t
nb_symbols
=
rel15
->
nb_mod_symbols
;
uint16_t
nb_symbols
=
rel15
->
nb_mod_symbols
;
uint8_t
Qm
=
rel15
->
modulation_order
;
uint8_t
Qm
=
rel15
->
modulation_order
;
uint32_t
encoded_length
=
nb_symbols
*
Qm
;
uint32_t
encoded_length
=
nb_symbols
*
Qm
;
//VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_ENB_PMCH_PBCH_TX,1);
//VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME(VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_ENB_PMCH_PBCH_TX,1);
/// scrambling
/// scrambling
for
(
int
q
=
0
;
q
<
rel15
->
nb_codewords
;
q
++
)
memset
((
void
*
)(
scrambled_output
[
q
]),
0
,
(
encoded_length
>>
5
)
*
sizeof
(
uint32_t
));
uint16_t
n_RNTI
=
(
pdcch_params
.
search_space_type
==
NFAPI_NR_SEARCH_SPACE_TYPE_UE_SPECIFIC
)
?
\
((
pdcch_params
.
scrambling_id
==
0
)
?
pdcch_params
.
rnti
:
0
)
:
0
;
uint16_t
Nid
=
(
pdcch_params
.
search_space_type
==
NFAPI_NR_SEARCH_SPACE_TYPE_UE_SPECIFIC
)
?
\
pdcch_params
.
scrambling_id
:
config
->
sch_config
.
physical_cell_id
.
value
;
nr_pdsch_codeword_scrambling
(
harq
->
f
,
encoded_length
,
0
,
Nid
,
n_RNTI
,
scrambled_output
[
0
]);
printf
(
"nr_pdsch_codeword_scrambling in test
\n
"
);
#ifdef DEBUG_DLSCH
printf
(
"PDSCH scrambling:
\n
"
);
for
(
int
i
=
0
;
i
<
encoded_length
>>
8
;
i
++
)
{
for
(
int
j
=
0
;
j
<
8
;
j
++
)
printf
(
"0x%08x
\t
"
,
scrambled_output
[
0
][(
i
<<
3
)
+
j
]);
printf
(
"
\n
"
);
}
#endif
/// Modulation
/// Modulation
//start_meas(dlsch_modulation_stats);
//start_meas(dlsch_modulation_stats);
for
(
int
q
=
0
;
q
<
rel15
->
nb_codewords
;
q
++
){
nr_modulation
(
gNB
->
scrambled_output
[
0
],
while
(
gNB
->
q_scrambling
[
q
]
!=
1
);
nr_modulation
(
gNB
->
scrambled_output
[
q
],
encoded_length
,
encoded_length
,
Qm
,
Qm
,
mod_symbs
[
q
]);
mod_symbs
[
0
]);
gNB
->
q_scrambling
[
q
]
=
0
;
}
//printf("nr_modulation in test\n");
//stop_meas(dlsch_modulation_stats);
//stop_meas(dlsch_modulation_stats);
#ifdef DEBUG_DLSCH
#ifdef DEBUG_DLSCH
printf
(
"PDSCH Modulation: Qm %d(%d)
\n
"
,
Qm
,
nb_symbols
);
printf
(
"PDSCH Modulation: Qm %d(%d)
\n
"
,
Qm
,
nb_symbols
);
...
@@ -244,7 +504,10 @@ static void *modulation_proc(void *ptr){
...
@@ -244,7 +504,10 @@ static void *modulation_proc(void *ptr){
}
}
#endif
#endif
//printf("complete_modulation\n");
//printf("complete_modulation\n");
gNB
->
complete_modulation
=
1
;
gNB
->
complete_modulation
++
;
//printf("complete_modulation = %d\n",gNB->complete_modulation);
clock_gettime
(
CLOCK_REALTIME
,
&
tt2
);
//printf("scrambling_proc for test consumes %ld nanoseconds!\n",tt2.tv_nsec - tt1.tv_nsec);
}
}
printf
(
"Exiting gNB thread modulation_channel
\n
"
);
printf
(
"Exiting gNB thread modulation_channel
\n
"
);
return
&
modulation_channel_status
;
return
&
modulation_channel_status
;
...
@@ -286,6 +549,8 @@ int main(int argc, char **argv)
...
@@ -286,6 +549,8 @@ int main(int argc, char **argv)
SCM_t
channel_model
=
AWGN
;
//Rayleigh1_anticorr;
SCM_t
channel_model
=
AWGN
;
//Rayleigh1_anticorr;
//double pbch_sinr;
//double pbch_sinr;
//int pbch_tx_ant;
//int pbch_tx_ant;
int
N_RB_DL
=
106
,
mu
=
1
;
int
N_RB_DL
=
106
,
mu
=
1
;
...
@@ -669,16 +934,31 @@ int main(int argc, char **argv)
...
@@ -669,16 +934,31 @@ int main(int argc, char **argv)
printf
(
"Error at UE NR initialisation
\n
"
);
printf
(
"Error at UE NR initialisation
\n
"
);
exit
(
-
1
);
exit
(
-
1
);
}
}
pthread_mutex_init
(
&
(
gNB
->
thread_scrambling
.
mutex_tx
),
NULL
);
pthread_cond_init
(
&
(
gNB
->
thread_scrambling
.
cond_tx
),
NULL
);
for
(
int
t
=
0
;
t
<
4
;
t
++
){
pthread_create
(
&
(
gNB
->
thread_scrambling
.
pthread_scrambling
),
&
gNB
->
thread_scrambling
.
attr_scrambling
,
scrambling_proc
,
&
gNB
->
thread_scrambling
);
gNB
->
thread_encode
[
t
].
id
=
t
;
printf
(
"[CREATE] scrambling_channel thread
\n
"
);
gNB
->
thread_encode
[
t
].
flag_wait
=
1
;
pthread_mutex_init
(
&
(
gNB
->
thread_encode
[
t
].
mutex_encode
),
NULL
);
pthread_cond_init
(
&
(
gNB
->
thread_encode
[
t
].
cond_encode
),
NULL
);
pthread_create
(
&
(
gNB
->
thread_encode
[
t
].
pthread_encode
),
&
gNB
->
thread_encode
[
t
].
attr_encode
,
dlsch_encoding_proc
,
&
gNB
->
thread_encode
[
t
]);
printf
(
"[CREATE] DLSCH ENCODER Thread %d
\n
"
,
gNB
->
thread_encode
[
t
].
id
);
}
for
(
int
aa
=
0
;
aa
<
1
;
aa
++
){
pthread_attr_init
(
&
gNB
->
thread_scrambling
[
aa
].
attr_scrambling
);
pthread_mutex_init
(
&
(
gNB
->
thread_scrambling
[
aa
].
mutex_tx
),
NULL
);
pthread_cond_init
(
&
(
gNB
->
thread_scrambling
[
aa
].
cond_tx
),
NULL
);
gNB
->
thread_scrambling
[
aa
].
q_id
=
aa
;
pthread_create
(
&
(
gNB
->
thread_scrambling
[
aa
].
pthread_scrambling
),
&
gNB
->
thread_scrambling
[
aa
].
attr_scrambling
,
scrambling_proc
,
&
gNB
->
thread_scrambling
[
aa
]);
printf
(
"[CREATE] scrambling_channel thread[%d]
\n
"
,
aa
);
}
pthread_mutex_init
(
&
(
gNB
->
thread_modulation
.
mutex_tx
),
NULL
);
pthread_mutex_init
(
&
(
gNB
->
thread_modulation
.
mutex_tx
),
NULL
);
pthread_cond_init
(
&
(
gNB
->
thread_modulation
.
cond_tx
),
NULL
);
pthread_cond_init
(
&
(
gNB
->
thread_modulation
.
cond_tx
),
NULL
);
pthread_create
(
&
(
gNB
->
thread_modulation
.
pthread_modulation
),
&
gNB
->
thread_modulation
.
attr_modulation
,
modulation_proc
,
&
gNB
->
thread_modulation
);
pthread_create
(
&
(
gNB
->
thread_modulation
.
pthread_modulation
),
&
gNB
->
thread_modulation
.
attr_modulation
,
modulation_proc
,
&
gNB
->
thread_modulation
);
printf
(
"[CREATE] modulation_channel thread
\n
"
);
printf
(
"[CREATE] modulation_channel thread
\n
"
);
init_nr_ue_transport
(
UE
,
0
);
init_nr_ue_transport
(
UE
,
0
);
usleep
(
1000000
);
nr_gold_pbch
(
UE
);
nr_gold_pbch
(
UE
);
nr_gold_pdcch
(
UE
,
0
,
2
);
nr_gold_pdcch
(
UE
,
0
,
2
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment