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
zzha zzha
OpenXG-RAN
Commits
80cc29ac
Commit
80cc29ac
authored
Aug 16, 2020
by
Raymond Knopp
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
optimization of RE extraction for NR ULSCH. Addition of faster memcpy to utils
parent
b16b2f7d
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
87 additions
and
59 deletions
+87
-59
cmake_targets/CMakeLists.txt
cmake_targets/CMakeLists.txt
+1
-0
common/utils/utils.c
common/utils/utils.c
+6
-0
common/utils/utils.h
common/utils/utils.h
+3
-0
openair1/PHY/MODULATION/ofdm_mod.c
openair1/PHY/MODULATION/ofdm_mod.c
+3
-1
openair1/PHY/NR_TRANSPORT/nr_transport_proto.h
openair1/PHY/NR_TRANSPORT/nr_transport_proto.h
+1
-0
openair1/PHY/NR_TRANSPORT/nr_ulsch_demodulation.c
openair1/PHY/NR_TRANSPORT/nr_ulsch_demodulation.c
+73
-57
openair1/PHY/defs_common.h
openair1/PHY/defs_common.h
+0
-1
No files found.
cmake_targets/CMakeLists.txt
View file @
80cc29ac
...
...
@@ -2979,6 +2979,7 @@ target_link_libraries(nr_ulschsim
add_executable
(
nr_ulsim
${
OPENAIR1_DIR
}
/SIMULATION/NR_PHY/ulsim.c
${
OPENAIR_DIR
}
/common/utils/utils.c
${
OPENAIR_DIR
}
/common/utils/system.c
${
OPENAIR_DIR
}
/common/utils/nr/nr_common.c
${
OPENAIR_DIR
}
/executables/softmodem-common.c
...
...
common/utils/utils.c
View file @
80cc29ac
...
...
@@ -105,3 +105,9 @@ char *itoa(int i) {
return
strdup
(
buffer
);
}
void
*
memcpy1
(
void
*
dst
,
const
void
*
src
,
size_t
n
)
{
void
*
ret
=
dst
;
asm
volatile
(
"rep movsb"
:
"+D"
(
dst
)
:
"c"
(
n
),
"S"
(
src
)
:
"cc"
,
"memory"
);
return
(
ret
);
}
common/utils/utils.h
View file @
80cc29ac
...
...
@@ -15,6 +15,9 @@ int hex_char_to_hex_value (char c);
// Converts an hexadecimal ASCII coded string into its value.**
int
hex_string_to_hex_value
(
uint8_t
*
hex_value
,
const
char
*
hex_string
,
int
size
);
void
*
memcpy1
(
void
*
dst
,
const
void
*
src
,
size_t
n
);
char
*
itoa
(
int
i
);
#define findInList(keY, result, list, element_type) {\
...
...
openair1/PHY/MODULATION/ofdm_mod.c
View file @
80cc29ac
...
...
@@ -27,6 +27,7 @@
This section deals with basic functions for OFDM Modulation.
*/
#include "PHY/defs_eNB.h"
...
...
@@ -47,6 +48,7 @@ void normal_prefix_mod(int32_t *txdataF,int32_t *txdata,uint8_t nsymb,LTE_DL_FRA
PHY_ofdm_mod
(
txdataF
,
// input
txdata
,
// output
frame_parms
->
ofdm_symbol_size
,
1
,
// number of symbols
frame_parms
->
nb_prefix_samples0
,
// number of prefix samples
CYCLIC_PREFIX
);
...
...
@@ -177,7 +179,7 @@ void PHY_ofdm_mod(int *input, /// pointer to complex input
/*for (j=0; j<fftsize ; j++) {
output_ptr[j] = temp_ptr[j];
}*/
memcpy
((
void
*
)
output_ptr
,(
void
*
)
temp_ptr
,
fftsize
<<
2
);
memcpy
1
((
void
*
)
output_ptr
,(
void
*
)
temp_ptr
,
fftsize
<<
2
);
}
j
=
fftsize
;
...
...
openair1/PHY/NR_TRANSPORT/nr_transport_proto.h
View file @
80cc29ac
...
...
@@ -157,6 +157,7 @@ void nr_ulsch_extract_rbs_single(int32_t **rxdataF,
NR_gNB_PUSCH
*
pusch_vars
,
unsigned
char
symbol
,
uint8_t
is_dmrs_symbol
,
uint8_t
is_ptrs_symbol
,
nfapi_nr_pusch_pdu_t
*
pusch_pdu
,
NR_DL_FRAME_PARMS
*
frame_parms
);
...
...
openair1/PHY/NR_TRANSPORT/nr_ulsch_demodulation.c
View file @
80cc29ac
...
...
@@ -226,6 +226,7 @@ void nr_ulsch_extract_rbs_single(int32_t **rxdataF,
NR_gNB_PUSCH
*
pusch_vars
,
unsigned
char
symbol
,
uint8_t
is_dmrs_symbol
,
uint8_t
is_ptrs_symbol
,
nfapi_nr_pusch_pdu_t
*
pusch_pdu
,
NR_DL_FRAME_PARMS
*
frame_parms
)
{
...
...
@@ -238,7 +239,7 @@ void nr_ulsch_extract_rbs_single(int32_t **rxdataF,
uint32_t
ul_ch0_index
=
0
;
uint32_t
ul_ch0_ptrs_ext_index
=
0
;
uint32_t
ul_ch0_ptrs_index
=
0
;
uint8_t
is_ptrs_symbol_flag
,
k_prime
;
uint8_t
k_prime
;
uint16_t
n
=
0
,
num_ptrs_symbols
;
int16_t
*
rxF
,
*
rxF_ext
;
int
*
ul_ch0
,
*
ul_ch0_ext
;
...
...
@@ -253,10 +254,9 @@ void nr_ulsch_extract_rbs_single(int32_t **rxdataF,
#endif
uint8_t
is_dmrs_re
;
uint8_t
is_dmrs_re
=
0
,
is_ptrs_re
=
0
;
start_re
=
(
frame_parms
->
first_carrier_offset
+
(
pusch_pdu
->
rb_start
*
NR_NB_SC_PER_RB
))
%
frame_parms
->
ofdm_symbol_size
;
nb_re_pusch
=
NR_NB_SC_PER_RB
*
pusch_pdu
->
rb_size
;
is_ptrs_symbol_flag
=
0
;
num_ptrs_symbols
=
0
;
for
(
aarx
=
0
;
aarx
<
frame_parms
->
nb_antennas_rx
;
aarx
++
)
{
...
...
@@ -275,63 +275,73 @@ void nr_ulsch_extract_rbs_single(int32_t **rxdataF,
n
=
0
;
k_prime
=
0
;
for
(
re
=
0
;
re
<
nb_re_pusch
;
re
++
)
{
if
(
is_dmrs_symbol
)
is_dmrs_re
=
(
re
==
get_dmrs_freq_idx_ul
(
n
,
k_prime
,
delta
,
pusch_pdu
->
dmrs_config_type
));
else
is_dmrs_re
=
0
;
if
(
pusch_pdu
->
pdu_bit_map
&
PUSCH_PDU_BITMAP_PUSCH_PTRS
)
{
K_ptrs
=
(
pusch_pdu
->
pusch_ptrs
.
ptrs_freq_density
)
?
4
:
2
;
if
(
is_ptrs_symbol
(
symbol
,
pusch_vars
->
ptrs_symbols
))
is_ptrs_symbol_flag
=
is_ptrs_subcarrier
((
start_re
+
re
)
%
frame_parms
->
ofdm_symbol_size
,
n_rnti
,
aarx
,
pusch_pdu
->
dmrs_config_type
,
K_ptrs
,
pusch_pdu
->
rb_size
,
pusch_pdu
->
pusch_ptrs
.
ptrs_ports_list
[
0
].
ptrs_re_offset
,
start_re
,
frame_parms
->
ofdm_symbol_size
);
if
(
is_ptrs_symbol_flag
==
1
)
num_ptrs_symbols
++
;
}
#ifdef DEBUG_RB_EXT
printf
(
"re = %d, is_ptrs_symbol_flag = %d, symbol = %d
\n
"
,
re
,
is_ptrs_symbol_flag
,
symbol
);
#endif
if
(
is_dmrs_re
==
0
&&
is_ptrs_symbol_flag
==
0
)
{
rxF_ext
[
rxF_ext_index
]
=
(
rxF
[
((
start_re
+
re
)
*
2
)
%
(
frame_parms
->
ofdm_symbol_size
*
2
)]);
rxF_ext
[
rxF_ext_index
+
1
]
=
(
rxF
[(((
start_re
+
re
)
*
2
)
+
1
)
%
(
frame_parms
->
ofdm_symbol_size
*
2
)]);
ul_ch0_ext
[
ul_ch0_ext_index
]
=
ul_ch0
[
ul_ch0_index
];
ul_ch0_ptrs_ext
[
ul_ch0_ptrs_ext_index
]
=
ul_ch0_ptrs
[
ul_ch0_ptrs_index
];
#ifdef DEBUG_RB_EXT
printf
(
"rxF_ext[%d] = (%d,%d)
\n
"
,
rxF_ext_index
>>
1
,
rxF_ext
[
rxF_ext_index
],
rxF_ext
[
rxF_ext_index
+
1
]);
#endif
ul_ch0_ext_index
++
;
ul_ch0_ptrs_ext_index
++
;
rxF_ext_index
+=
2
;
}
else
{
k_prime
++
;
k_prime
&=
1
;
n
+=
(
k_prime
)
?
0
:
1
;
if
(
is_dmrs_symbol
==
0
&&
is_ptrs_symbol
==
0
)
{
//
//rxF[ ((start_re + re)*2) % (frame_parms->ofdm_symbol_size*2)]);
if
(
start_re
+
nb_re_pusch
<
frame_parms
->
ofdm_symbol_size
)
memcpy1
((
void
*
)
rxF_ext
,
(
void
*
)
&
rxF
[
start_re
*
2
],
nb_re_pusch
*
sizeof
(
int32_t
));
else
{
int
neg_length
=
frame_parms
->
ofdm_symbol_size
-
start_re
;
int
pos_length
=
nb_re_pusch
-
neg_length
;
memcpy1
((
void
*
)
rxF_ext
,(
void
*
)
&
rxF
[
start_re
*
2
],
neg_length
*
sizeof
(
int32_t
));
memcpy1
((
void
*
)
&
rxF_ext
[
2
*
neg_length
],(
void
*
)
rxF
,
pos_length
*
sizeof
(
int32_t
));
}
ul_ch0_index
++
;
ul_ch0_ptrs_index
++
;
memcpy1
((
void
*
)
ul_ch0_ext
,(
void
*
)
ul_ch0
,
nb_re_pusch
*
sizeof
(
int32_t
));
}
}
else
{
for
(
re
=
0
;
re
<
nb_re_pusch
;
re
++
)
{
if
(
is_dmrs_symbol
)
is_dmrs_re
=
(
re
==
get_dmrs_freq_idx_ul
(
n
,
k_prime
,
delta
,
pusch_pdu
->
dmrs_config_type
));
if
(
is_ptrs_symbol
)
{
K_ptrs
=
(
pusch_pdu
->
pusch_ptrs
.
ptrs_freq_density
)
?
4
:
2
;
is_ptrs_re
=
is_ptrs_subcarrier
((
start_re
+
re
)
%
frame_parms
->
ofdm_symbol_size
,
n_rnti
,
aarx
,
pusch_pdu
->
dmrs_config_type
,
K_ptrs
,
pusch_pdu
->
rb_size
,
pusch_pdu
->
pusch_ptrs
.
ptrs_ports_list
[
0
].
ptrs_re_offset
,
start_re
,
frame_parms
->
ofdm_symbol_size
);
num_ptrs_symbols
+=
is_ptrs_re
;
}
#ifdef DEBUG_RB_EXT
printf
(
"re = %d, ptrs_symbol_flag = %d, symbol = %d
\n
"
,
re
,
ptrs_symbol_flag
,
symbol
);
#endif
if
(
is_dmrs_re
==
0
&&
is_ptrs_re
==
0
)
{
rxF_ext
[
rxF_ext_index
]
=
(
rxF
[
((
start_re
+
re
)
*
2
)
%
(
frame_parms
->
ofdm_symbol_size
*
2
)]);
rxF_ext
[
rxF_ext_index
+
1
]
=
(
rxF
[(((
start_re
+
re
)
*
2
)
+
1
)
%
(
frame_parms
->
ofdm_symbol_size
*
2
)]);
ul_ch0_ext
[
ul_ch0_ext_index
]
=
ul_ch0
[
ul_ch0_index
];
ul_ch0_ptrs_ext
[
ul_ch0_ptrs_ext_index
]
=
ul_ch0_ptrs
[
ul_ch0_ptrs_index
];
#ifdef DEBUG_RB_EXT
printf
(
"rxF_ext[%d] = (%d,%d)
\n
"
,
rxF_ext_index
>>
1
,
rxF_ext
[
rxF_ext_index
],
rxF_ext
[
rxF_ext_index
+
1
]);
#endif
ul_ch0_ext_index
++
;
ul_ch0_ptrs_ext_index
++
;
rxF_ext_index
+=
2
;
}
else
{
k_prime
++
;
k_prime
&=
1
;
n
+=
(
k_prime
)
?
0
:
1
;
}
ul_ch0_index
++
;
ul_ch0_ptrs_index
++
;
}
}
// is_dmrs_symbol ==0 && is_ptrs_symbol == 0
}
pusch_vars
->
ptrs_sc_per_ofdm_symbol
=
num_ptrs_symbols
;
}
void
nr_ulsch_scale_channel
(
int
**
ul_ch_estimates_ext
,
NR_DL_FRAME_PARMS
*
frame_parms
,
NR_gNB_ULSCH_t
**
ulsch_gNB
,
...
...
@@ -1019,6 +1029,7 @@ int nr_rx_pusch(PHY_VARS_gNB *gNB,
{
uint8_t
aarx
,
aatx
,
dmrs_symbol_flag
;
// dmrs_symbol_flag, a flag to indicate DMRS REs in current symbol
uint8_t
ptrs_symbol_flag
;
// a flag to indicate PTRS REs in current symbol
uint32_t
nb_re_pusch
,
bwp_start_subcarrier
;
uint8_t
L_ptrs
=
0
;
// PTRS parameter
int
avgs
;
...
...
@@ -1027,6 +1038,8 @@ int nr_rx_pusch(PHY_VARS_gNB *gNB,
nfapi_nr_pusch_pdu_t
*
rel15_ul
=
&
gNB
->
ulsch
[
ulsch_id
][
0
]
->
harq_processes
[
harq_pid
]
->
ulsch_pdu
;
dmrs_symbol_flag
=
0
;
ptrs_symbol_flag
=
0
;
gNB
->
pusch_vars
[
ulsch_id
]
->
ptrs_sc_per_ofdm_symbol
=
0
;
if
(
symbol
==
rel15_ul
->
start_symbol_index
){
...
...
@@ -1046,6 +1059,7 @@ int nr_rx_pusch(PHY_VARS_gNB *gNB,
}
}
bwp_start_subcarrier
=
(
rel15_ul
->
rb_start
*
NR_NB_SC_PER_RB
+
frame_parms
->
first_carrier_offset
)
%
frame_parms
->
ofdm_symbol_size
;
dmrs_symbol_flag
=
((
rel15_ul
->
ul_dmrs_symb_pos
)
>>
symbol
)
&
0x01
;
...
...
@@ -1068,11 +1082,12 @@ int nr_rx_pusch(PHY_VARS_gNB *gNB,
}
if
(
rel15_ul
->
pdu_bit_map
&
PUSCH_PDU_BITMAP_PUSCH_PTRS
)
{
// if there is ptrs pdu
if
(
is_ptrs_symbol
(
symbol
,
gNB
->
pusch_vars
[
ulsch_id
]
->
ptrs_symbols
))
if
(
is_ptrs_symbol
(
symbol
,
gNB
->
pusch_vars
[
ulsch_id
]
->
ptrs_symbols
))
{
gNB
->
pusch_vars
[
ulsch_id
]
->
ptrs_symbol_index
=
symbol
;
ptrs_symbol_flag
=
1
;
}
}
//----------------------------------------------------------
//--------------------- Channel estimation ---------------------
//----------------------------------------------------------
...
...
@@ -1105,6 +1120,7 @@ int nr_rx_pusch(PHY_VARS_gNB *gNB,
gNB
->
pusch_vars
[
ulsch_id
],
symbol
,
dmrs_symbol_flag
,
ptrs_symbol_flag
,
rel15_ul
,
frame_parms
);
stop_meas
(
&
gNB
->
ulsch_rbs_extraction_stats
);
...
...
openair1/PHY/defs_common.h
View file @
80cc29ac
...
...
@@ -1094,5 +1094,4 @@ static inline int release_thread(pthread_mutex_t *mutex,
return
(
0
);
}
#endif // __PHY_DEFS_COMMON_H__
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