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
lizhongxiao
OpenXG-RAN
Commits
59cb6021
Commit
59cb6021
authored
Aug 29, 2022
by
Thomas Schlichter
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
review changes
parent
63106069
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
80 additions
and
134 deletions
+80
-134
openair1/PHY/MODULATION/ofdm_mod.c
openair1/PHY/MODULATION/ofdm_mod.c
+20
-26
openair1/PHY/MODULATION/slot_fep_nr.c
openair1/PHY/MODULATION/slot_fep_nr.c
+48
-89
openair1/PHY/NR_UE_TRANSPORT/nr_ulsch_ue.c
openair1/PHY/NR_UE_TRANSPORT/nr_ulsch_ue.c
+12
-19
No files found.
openair1/PHY/MODULATION/ofdm_mod.c
View file @
59cb6021
...
...
@@ -348,39 +348,33 @@ void apply_nr_rotation(NR_DL_FRAME_PARMS *fp,
{
int
symb_offset
=
(
slot
%
fp
->
slots_per_subframe
)
*
fp
->
symbols_per_slot
;
c16_t
*
symbol_rotation
=
fp
->
symbol_rotation
[
0
];
c16_t
*
symbol_rotation
=
fp
->
symbol_rotation
[
0
]
+
symb_offset
;
for
(
int
sidx
=
0
;
sidx
<
nsymb
;
sidx
++
)
{
for
(
int
sidx
=
first_symbol
;
sidx
<
first_symbol
+
nsymb
;
sidx
++
)
{
c16_t
*
this_rotation
=
symbol_rotation
+
sidx
;
c16_t
*
this_symbol
=
((
c16_t
*
)
txdataF
)
+
sidx
*
fp
->
ofdm_symbol_size
;
LOG_D
(
PHY
,
"Rotating symbol %d, slot %d, symbol_subframe_index %d (%d,%d)
\n
"
,
first_symbol
+
sidx
,
sidx
,
slot
,
sidx
+
first_symbol
+
symb_offset
,
symbol_rotation
[
sidx
+
first_symbol
+
symb_offset
].
r
,
symbol_rotation
[
sidx
+
first_symbol
+
symb_offset
].
i
);
sidx
+
symb_offset
,
this_rotation
->
r
,
this_rotation
->
i
);
if
(
fp
->
N_RB_DL
&
1
)
{
rotate_cpx_vector
(((
c16_t
*
)
txdataF
)
+
sidx
*
fp
->
ofdm_symbol_size
,
symbol_rotation
+
sidx
+
first_symbol
+
symb_offset
,
((
c16_t
*
)
txdataF
)
+
sidx
*
fp
->
ofdm_symbol_size
,
(
fp
->
N_RB_DL
+
1
)
*
6
,
15
);
rotate_cpx_vector
(((
c16_t
*
)
txdataF
)
+
sidx
*
fp
->
ofdm_symbol_size
+
fp
->
first_carrier_offset
-
6
,
symbol_rotation
+
sidx
+
first_symbol
+
symb_offset
,
((
c16_t
*
)
txdataF
)
+
sidx
*
fp
->
ofdm_symbol_size
+
fp
->
first_carrier_offset
-
6
,
(
fp
->
N_RB_DL
+
1
)
*
6
,
15
);
rotate_cpx_vector
(
this_symbol
,
this_rotation
,
this_symbol
,
(
fp
->
N_RB_DL
+
1
)
*
6
,
15
);
rotate_cpx_vector
(
this_symbol
+
fp
->
first_carrier_offset
-
6
,
this_rotation
,
this_symbol
+
fp
->
first_carrier_offset
-
6
,
(
fp
->
N_RB_DL
+
1
)
*
6
,
15
);
}
else
{
rotate_cpx_vector
(((
c16_t
*
)
txdataF
)
+
sidx
*
fp
->
ofdm_symbol_size
,
symbol_rotation
+
sidx
+
first_symbol
+
symb_offset
,
((
c16_t
*
)
txdataF
)
+
sidx
*
fp
->
ofdm_symbol_size
,
fp
->
N_RB_DL
*
6
,
15
);
rotate_cpx_vector
(((
c16_t
*
)
txdataF
)
+
sidx
*
fp
->
ofdm_symbol_size
+
fp
->
first_carrier_offset
,
symbol_rotation
+
sidx
+
first_symbol
+
symb_offset
,
((
c16_t
*
)
txdataF
)
+
sidx
*
fp
->
ofdm_symbol_size
+
fp
->
first_carrier_offset
,
fp
->
N_RB_DL
*
6
,
15
);
rotate_cpx_vector
(
this_symbol
,
this_rotation
,
this_symbol
,
fp
->
N_RB_DL
*
6
,
15
);
rotate_cpx_vector
(
this_symbol
+
fp
->
first_carrier_offset
,
this_rotation
,
this_symbol
+
fp
->
first_carrier_offset
,
fp
->
N_RB_DL
*
6
,
15
);
}
}
}
...
...
openair1/PHY/MODULATION/slot_fep_nr.c
View file @
59cb6021
...
...
@@ -108,53 +108,34 @@ int nr_slot_fep(PHY_VARS_NR_UE *ue,
#endif
c16_t
*
shift_rot
=
frame_parms
->
timeshift_symbol_rotation
;
c16_t
*
this_symbol
=
(
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
];
if
(
frame_parms
->
N_RB_DL
&
1
)
{
rotate_cpx_vector
((
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
],
rotate_cpx_vector
(
this_symbol
,
&
rot2
,
this_symbol
,
(
frame_parms
->
N_RB_DL
+
1
)
*
6
,
15
);
rotate_cpx_vector
(
this_symbol
+
frame_parms
->
first_carrier_offset
-
6
,
&
rot2
,
(
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
],
(
frame_parms
->
N_RB_DL
+
1
)
*
6
,
15
);
rotate_cpx_vector
((
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
+
frame_parms
->
first_carrier_offset
-
6
],
&
rot2
,
(
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
+
frame_parms
->
first_carrier_offset
-
6
],
(
frame_parms
->
N_RB_DL
+
1
)
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
],
(
int16_t
*
)
shift_rot
,
(
int16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
],
1
,
(
frame_parms
->
N_RB_DL
+
1
)
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
+
frame_parms
->
first_carrier_offset
-
6
],
this_symbol
+
frame_parms
->
first_carrier_offset
-
6
,
(
frame_parms
->
N_RB_DL
+
1
)
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
this_symbol
,
(
int16_t
*
)
shift_rot
,
(
int16_t
*
)
this_symbol
,
1
,
(
frame_parms
->
N_RB_DL
+
1
)
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)(
this_symbol
+
frame_parms
->
first_carrier_offset
-
6
),
(
int16_t
*
)(
shift_rot
+
frame_parms
->
first_carrier_offset
-
6
),
(
int16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
+
frame_parms
->
first_carrier_offset
-
6
],
1
,
(
frame_parms
->
N_RB_DL
+
1
)
*
6
,
15
);
(
int16_t
*
)(
this_symbol
+
frame_parms
->
first_carrier_offset
-
6
),
1
,
(
frame_parms
->
N_RB_DL
+
1
)
*
6
,
15
);
}
else
{
rotate_cpx_vector
((
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
],
rotate_cpx_vector
(
this_symbol
,
&
rot2
,
this_symbol
,
frame_parms
->
N_RB_DL
*
6
,
15
);
rotate_cpx_vector
(
this_symbol
+
frame_parms
->
first_carrier_offset
,
&
rot2
,
(
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
],
frame_parms
->
N_RB_DL
*
6
,
15
);
rotate_cpx_vector
((
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
+
frame_parms
->
first_carrier_offset
],
&
rot2
,
(
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
+
frame_parms
->
first_carrier_offset
],
frame_parms
->
N_RB_DL
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
],
(
int16_t
*
)
shift_rot
,
(
int16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
],
1
,
frame_parms
->
N_RB_DL
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
+
frame_parms
->
first_carrier_offset
],
this_symbol
+
frame_parms
->
first_carrier_offset
,
frame_parms
->
N_RB_DL
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
this_symbol
,
(
int16_t
*
)
shift_rot
,
(
int16_t
*
)
this_symbol
,
1
,
frame_parms
->
N_RB_DL
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)(
this_symbol
+
frame_parms
->
first_carrier_offset
),
(
int16_t
*
)(
shift_rot
+
frame_parms
->
first_carrier_offset
),
(
int16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
+
frame_parms
->
first_carrier_offset
],
1
,
frame_parms
->
N_RB_DL
*
6
,
15
);
(
int16_t
*
)(
this_symbol
+
frame_parms
->
first_carrier_offset
),
1
,
frame_parms
->
N_RB_DL
*
6
,
15
);
}
}
...
...
@@ -258,11 +239,8 @@ int nr_slot_fep_init_sync(PHY_VARS_NR_UE *ue,
symbol
+
symb_offset
,
rot2
.
r
,
rot2
.
i
);
#endif
rotate_cpx_vector
((
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
],
&
rot2
,
(
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
],
frame_parms
->
ofdm_symbol_size
,
15
);
c16_t
*
this_symbol
=
(
c16_t
*
)
&
common_vars
->
common_vars_rx_data_per_thread
[
proc
->
thread_id
].
rxdataF
[
aa
][
frame_parms
->
ofdm_symbol_size
*
symbol
];
rotate_cpx_vector
(
this_symbol
,
&
rot2
,
this_symbol
,
frame_parms
->
ofdm_symbol_size
,
15
);
}
#ifdef DEBUG_FEP
...
...
@@ -348,53 +326,34 @@ void apply_nr_rotation_ul(NR_DL_FRAME_PARMS *frame_parms,
LOG_D
(
PHY
,
"slot %d, symb_offset %d rotating by %d.%d
\n
"
,
slot
,
symb_offset
,
rot2
.
r
,
rot2
.
i
);
c16_t
*
shift_rot
=
frame_parms
->
timeshift_symbol_rotation
;
c16_t
*
this_symbol
=
(
c16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)];
if
(
frame_parms
->
N_RB_UL
&
1
)
{
rotate_cpx_vector
((
c16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)],
&
rot2
,
(
c16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)],
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
rotate_cpx_vector
((
c16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)
+
frame_parms
->
first_carrier_offset
-
6
],
rotate_cpx_vector
(
this_symbol
,
&
rot2
,
this_symbol
,
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
rotate_cpx_vector
(
this_symbol
+
frame_parms
->
first_carrier_offset
-
6
,
&
rot2
,
(
c16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)
+
frame_parms
->
first_carrier_offset
-
6
],
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)],
(
int16_t
*
)
shift_rot
,
(
int16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)],
1
,
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)
+
frame_parms
->
first_carrier_offset
-
6
],
this_symbol
+
frame_parms
->
first_carrier_offset
-
6
,
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
this_symbol
,
(
int16_t
*
)
shift_rot
,
(
int16_t
*
)
this_symbol
,
1
,
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)(
this_symbol
+
frame_parms
->
first_carrier_offset
-
6
),
(
int16_t
*
)(
shift_rot
+
frame_parms
->
first_carrier_offset
-
6
),
(
int16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)
+
frame_parms
->
first_carrier_offset
-
6
],
1
,
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
(
int16_t
*
)(
this_symbol
+
frame_parms
->
first_carrier_offset
-
6
),
1
,
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
}
else
{
rotate_cpx_vector
((
c16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)],
&
rot2
,
(
c16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)],
frame_parms
->
N_RB_UL
*
6
,
15
);
rotate_cpx_vector
((
c16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)
+
frame_parms
->
first_carrier_offset
],
rotate_cpx_vector
(
this_symbol
,
&
rot2
,
this_symbol
,
frame_parms
->
N_RB_UL
*
6
,
15
);
rotate_cpx_vector
(
this_symbol
+
frame_parms
->
first_carrier_offset
,
&
rot2
,
(
c16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)
+
frame_parms
->
first_carrier_offset
],
frame_parms
->
N_RB_UL
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)],
(
int16_t
*
)
shift_rot
,
(
int16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)],
1
,
frame_parms
->
N_RB_UL
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)
+
frame_parms
->
first_carrier_offset
],
this_symbol
+
frame_parms
->
first_carrier_offset
,
frame_parms
->
N_RB_UL
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)
this_symbol
,
(
int16_t
*
)
shift_rot
,
(
int16_t
*
)
this_symbol
,
1
,
frame_parms
->
N_RB_UL
*
6
,
15
);
multadd_cpx_vector
((
int16_t
*
)(
this_symbol
+
frame_parms
->
first_carrier_offset
),
(
int16_t
*
)(
shift_rot
+
frame_parms
->
first_carrier_offset
),
(
int16_t
*
)
&
rxdataF
[
soffset
+
(
frame_parms
->
ofdm_symbol_size
*
symbol
)
+
frame_parms
->
first_carrier_offset
],
1
,
frame_parms
->
N_RB_UL
*
6
,
15
);
(
int16_t
*
)(
this_symbol
+
frame_parms
->
first_carrier_offset
),
1
,
frame_parms
->
N_RB_UL
*
6
,
15
);
}
}
}
openair1/PHY/NR_UE_TRANSPORT/nr_ulsch_ue.c
View file @
59cb6021
...
...
@@ -597,34 +597,27 @@ uint8_t nr_ue_pusch_common_procedures(PHY_VARS_NR_UE *UE,
int
symb_offset
=
(
slot
%
frame_parms
->
slots_per_subframe
)
*
frame_parms
->
symbols_per_slot
;
for
(
ap
=
0
;
ap
<
n_antenna_ports
;
ap
++
)
{
for
(
int
s
=
0
;
s
<
NR_NUMBER_OF_SYMBOLS_PER_SLOT
;
s
++
){
c16_t
rot
=
((
c16_t
*
)
frame_parms
->
symbol_rotation
[
1
])[
s
+
symb_offset
];
c16_t
*
this_symbol
=
(
c16_t
*
)
&
txdataF
[
ap
][
frame_parms
->
ofdm_symbol_size
*
s
];
c16_t
rot
=
frame_parms
->
symbol_rotation
[
1
][
s
+
symb_offset
];
LOG_D
(
PHY
,
"rotating txdataF symbol %d (%d) => (%d.%d)
\n
"
,
s
,
s
+
symb_offset
,
rot
.
r
,
rot
.
i
);
if
(
frame_parms
->
N_RB_UL
&
1
)
{
rotate_cpx_vector
((
c16_t
*
)
&
txdataF
[
ap
][
frame_parms
->
ofdm_symbol_size
*
s
],
rotate_cpx_vector
(
this_symbol
,
&
rot
,
this_symbol
,
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
rotate_cpx_vector
(
this_symbol
+
frame_parms
->
first_carrier_offset
-
6
,
&
rot
,
(
c16_t
*
)
&
txdataF
[
ap
][
frame_parms
->
ofdm_symbol_size
*
s
],
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
rotate_cpx_vector
((
c16_t
*
)
&
txdataF
[
ap
][
frame_parms
->
ofdm_symbol_size
*
s
+
frame_parms
->
first_carrier_offset
-
6
],
&
rot
,
(
c16_t
*
)
&
txdataF
[
ap
][
frame_parms
->
ofdm_symbol_size
*
s
+
frame_parms
->
first_carrier_offset
-
6
],
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
this_symbol
+
frame_parms
->
first_carrier_offset
-
6
,
(
frame_parms
->
N_RB_UL
+
1
)
*
6
,
15
);
}
else
{
rotate_cpx_vector
((
c16_t
*
)
&
txdataF
[
ap
][
frame_parms
->
ofdm_symbol_size
*
s
],
&
rot
,
(
c16_t
*
)
&
txdataF
[
ap
][
frame_parms
->
ofdm_symbol_size
*
s
],
frame_parms
->
N_RB_UL
*
6
,
15
);
rotate_cpx_vector
((
c16_t
*
)
&
txdataF
[
ap
][
frame_parms
->
ofdm_symbol_size
*
s
+
frame_parms
->
first_carrier_offset
],
rotate_cpx_vector
(
this_symbol
,
&
rot
,
this_symbol
,
frame_parms
->
N_RB_UL
*
6
,
15
);
rotate_cpx_vector
(
this_symbol
+
frame_parms
->
first_carrier_offset
,
&
rot
,
(
c16_t
*
)
&
txdataF
[
ap
][
frame_parms
->
ofdm_symbol_size
*
s
+
frame_parms
->
first_carrier_offset
],
frame_parms
->
N_RB_UL
*
6
,
15
);
this_symbol
+
frame_parms
->
first_carrier_offset
,
frame_parms
->
N_RB_UL
*
6
,
15
);
}
}
}
...
...
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