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
1
Merge Requests
1
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
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
OpenXG
OpenXG-RAN
Commits
018ca77a
Commit
018ca77a
authored
May 23, 2024
by
Jaroslava Fiedlerova
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/issue-734' into integration_2024_w21b
parents
e580450a
6379350f
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
26 additions
and
25 deletions
+26
-25
openair1/PHY/NR_TRANSPORT/nr_ulsch_demodulation.c
openair1/PHY/NR_TRANSPORT/nr_ulsch_demodulation.c
+26
-10
openair1/PHY/defs_gNB.h
openair1/PHY/defs_gNB.h
+0
-15
No files found.
openair1/PHY/NR_TRANSPORT/nr_ulsch_demodulation.c
View file @
018ca77a
...
@@ -1389,6 +1389,20 @@ static void inner_rx(PHY_VARS_gNB *gNB,
...
@@ -1389,6 +1389,20 @@ static void inner_rx(PHY_VARS_gNB *gNB,
rel15_ul
->
qam_mod_order
);
rel15_ul
->
qam_mod_order
);
}
}
typedef
struct
puschSymbolProc_s
{
PHY_VARS_gNB
*
gNB
;
NR_DL_FRAME_PARMS
*
frame_parms
;
nfapi_nr_pusch_pdu_t
*
rel15_ul
;
int
ulsch_id
;
int
slot
;
int
startSymbol
;
int
numSymbols
;
int16_t
*
llr
;
int16_t
**
llr_layers
;
int16_t
*
scramblingSequence
;
uint32_t
nvar
;
}
puschSymbolProc_t
;
static
void
nr_pusch_symbol_processing
(
void
*
arg
)
static
void
nr_pusch_symbol_processing
(
void
*
arg
)
{
{
puschSymbolProc_t
*
rdata
=
(
puschSymbolProc_t
*
)
arg
;
puschSymbolProc_t
*
rdata
=
(
puschSymbolProc_t
*
)
arg
;
...
@@ -1438,8 +1452,10 @@ static void nr_pusch_symbol_processing(void *arg)
...
@@ -1438,8 +1452,10 @@ static void nr_pusch_symbol_processing(void *arg)
}
}
// unscrambling
// unscrambling
int16_t
*
llr16
=
(
int16_t
*
)
&
rdata
->
llr
[
pusch_vars
->
llr_offset
[
symbol
]
*
rel15_ul
->
nrOfLayers
];
int16_t
*
llr16
=
(
int16_t
*
)
&
rdata
->
llr
[
pusch_vars
->
llr_offset
[
symbol
]
*
rel15_ul
->
nrOfLayers
];
for
(
int
i
=
0
;
i
<
(
nb_re_pusch
*
rel15_ul
->
qam_mod_order
*
rel15_ul
->
nrOfLayers
);
i
++
)
int16_t
*
s
=
rdata
->
scramblingSequence
+
pusch_vars
->
llr_offset
[
symbol
]
*
rel15_ul
->
nrOfLayers
;
llr16
[
i
]
=
llr_ptr
[
i
]
*
rdata
->
s
[
i
];
const
int
end
=
nb_re_pusch
*
rel15_ul
->
qam_mod_order
*
rel15_ul
->
nrOfLayers
;
for
(
int
i
=
0
;
i
<
end
;
i
++
)
llr16
[
i
]
=
llr_ptr
[
i
]
*
s
[
i
];
}
}
}
}
...
@@ -1455,7 +1471,7 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
...
@@ -1455,7 +1471,7 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
NR_gNB_PUSCH
*
pusch_vars
=
&
gNB
->
pusch_vars
[
ulsch_id
];
NR_gNB_PUSCH
*
pusch_vars
=
&
gNB
->
pusch_vars
[
ulsch_id
];
pusch_vars
->
dmrs_symbol
=
INVALID_VALUE
;
pusch_vars
->
dmrs_symbol
=
INVALID_VALUE
;
gNB
->
nbSymb
=
0
;
int
nbSymb
=
0
;
uint32_t
bwp_start_subcarrier
=
((
rel15_ul
->
rb_start
+
rel15_ul
->
bwp_start
)
*
NR_NB_SC_PER_RB
+
frame_parms
->
first_carrier_offset
)
%
frame_parms
->
ofdm_symbol_size
;
uint32_t
bwp_start_subcarrier
=
((
rel15_ul
->
rb_start
+
rel15_ul
->
bwp_start
)
*
NR_NB_SC_PER_RB
+
frame_parms
->
first_carrier_offset
)
%
frame_parms
->
ofdm_symbol_size
;
LOG_D
(
PHY
,
"pusch %d.%d : bwp_start_subcarrier %d, rb_start %d, first_carrier_offset %d
\n
"
,
frame
,
slot
,
bwp_start_subcarrier
,
rel15_ul
->
rb_start
,
frame_parms
->
first_carrier_offset
);
LOG_D
(
PHY
,
"pusch %d.%d : bwp_start_subcarrier %d, rb_start %d, first_carrier_offset %d
\n
"
,
frame
,
slot
,
bwp_start_subcarrier
,
rel15_ul
->
rb_start
,
frame_parms
->
first_carrier_offset
);
LOG_D
(
PHY
,
"pusch %d.%d : ul_dmrs_symb_pos %x
\n
"
,
frame
,
slot
,
rel15_ul
->
ul_dmrs_symb_pos
);
LOG_D
(
PHY
,
"pusch %d.%d : ul_dmrs_symb_pos %x
\n
"
,
frame
,
slot
,
rel15_ul
->
ul_dmrs_symb_pos
);
...
@@ -1571,9 +1587,9 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
...
@@ -1571,9 +1587,9 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
gNB
->
ulsch
[
ulsch_id
].
unav_res
=
unav_res
;
gNB
->
ulsch
[
ulsch_id
].
unav_res
=
unav_res
;
// initialize scrambling sequence //
// initialize scrambling sequence //
int16_t
s
[
G
+
96
]
__attribute__
((
aligned
(
32
)));
int16_t
s
cramblingSequence
[
G
+
96
]
__attribute__
((
aligned
(
32
)));
nr_codeword_unscrambling_init
(
s
,
G
,
0
,
rel15_ul
->
data_scrambling_id
,
rel15_ul
->
rnti
);
nr_codeword_unscrambling_init
(
s
cramblingSequence
,
G
,
0
,
rel15_ul
->
data_scrambling_id
,
rel15_ul
->
rnti
);
// first the computation of channel levels
// first the computation of channel levels
...
@@ -1674,23 +1690,23 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
...
@@ -1674,23 +1690,23 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
rdata
->
ulsch_id
=
ulsch_id
;
rdata
->
ulsch_id
=
ulsch_id
;
rdata
->
llr
=
pusch_vars
->
llr
;
rdata
->
llr
=
pusch_vars
->
llr
;
rdata
->
llr_layers
=
pusch_vars
->
llr_layers
;
rdata
->
llr_layers
=
pusch_vars
->
llr_layers
;
rdata
->
s
=
&
s
[
pusch_vars
->
llr_offset
[
symbol
]
*
rel15_ul
->
nrOfLayers
]
;
rdata
->
s
cramblingSequence
=
scramblingSequence
;
rdata
->
nvar
=
nvar
;
rdata
->
nvar
=
nvar
;
if
(
rel15_ul
->
pdu_bit_map
&
PUSCH_PDU_BITMAP_PUSCH_PTRS
)
{
if
(
rel15_ul
->
pdu_bit_map
&
PUSCH_PDU_BITMAP_PUSCH_PTRS
)
{
nr_pusch_symbol_processing
(
rdata
);
nr_pusch_symbol_processing
(
rdata
);
}
else
{
}
else
{
pushTpool
(
&
gNB
->
threadPool
,
req
);
pushTpool
(
&
gNB
->
threadPool
,
req
);
gNB
->
nbSymb
++
;
nbSymb
++
;
}
}
LOG_D
(
PHY
,
"%d.%d Added symbol %d (count %d) to process, in pipe
\n
"
,
frame
,
slot
,
symbol
,
gNB
->
nbSymb
);
LOG_D
(
PHY
,
"%d.%d Added symbol %d (count %d) to process, in pipe
\n
"
,
frame
,
slot
,
symbol
,
nbSymb
);
}
}
}
// symbol loop
}
// symbol loop
while
(
gNB
->
nbSymb
>
0
)
{
while
(
nbSymb
)
{
notifiedFIFO_elt_t
*
req
=
pullTpool
(
&
gNB
->
respPuschSymb
,
&
gNB
->
threadPool
);
notifiedFIFO_elt_t
*
req
=
pullTpool
(
&
gNB
->
respPuschSymb
,
&
gNB
->
threadPool
);
gNB
->
nbSymb
--
;
nbSymb
--
;
delNotifiedFIFO_elt
(
req
);
delNotifiedFIFO_elt
(
req
);
}
}
...
...
openair1/PHY/defs_gNB.h
View file @
018ca77a
...
@@ -716,7 +716,6 @@ typedef struct PHY_VARS_gNB_s {
...
@@ -716,7 +716,6 @@ typedef struct PHY_VARS_gNB_s {
notifiedFIFO_t
L1_rx_out
;
notifiedFIFO_t
L1_rx_out
;
notifiedFIFO_t
resp_RU_tx
;
notifiedFIFO_t
resp_RU_tx
;
tpool_t
threadPool
;
tpool_t
threadPool
;
int
nbSymb
;
int
num_pusch_symbols_per_thread
;
int
num_pusch_symbols_per_thread
;
pthread_t
L1_rx_thread
;
pthread_t
L1_rx_thread
;
int
L1_rx_thread_core
;
int
L1_rx_thread_core
;
...
@@ -728,20 +727,6 @@ typedef struct PHY_VARS_gNB_s {
...
@@ -728,20 +727,6 @@ typedef struct PHY_VARS_gNB_s {
rt_L1_profiling_t
rt_L1_profiling
;
rt_L1_profiling_t
rt_L1_profiling
;
}
PHY_VARS_gNB
;
}
PHY_VARS_gNB
;
typedef
struct
puschSymbolProc_s
{
PHY_VARS_gNB
*
gNB
;
NR_DL_FRAME_PARMS
*
frame_parms
;
nfapi_nr_pusch_pdu_t
*
rel15_ul
;
int
ulsch_id
;
int
slot
;
int
startSymbol
;
int
numSymbols
;
int16_t
*
llr
;
int16_t
**
llr_layers
;
int16_t
*
s
;
uint32_t
nvar
;
}
puschSymbolProc_t
;
struct
puschSymbolReqId
{
struct
puschSymbolReqId
{
uint16_t
ulsch_id
;
uint16_t
ulsch_id
;
uint16_t
frame
;
uint16_t
frame
;
...
...
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