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
bc2ea375
Commit
bc2ea375
authored
Mar 31, 2022
by
rmagueta
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Replace nr_construct_HhH_elements by nr_a_sum_b function in nr_csi_rs_ri_estimation
parent
da1e542a
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
141 additions
and
60 deletions
+141
-60
openair1/PHY/NR_UE_TRANSPORT/csi_rx.c
openair1/PHY/NR_UE_TRANSPORT/csi_rx.c
+31
-43
openair1/PHY/NR_UE_TRANSPORT/nr_dlsch_demodulation.c
openair1/PHY/NR_UE_TRANSPORT/nr_dlsch_demodulation.c
+83
-0
openair1/PHY/NR_UE_TRANSPORT/nr_transport_proto_ue.h
openair1/PHY/NR_UE_TRANSPORT/nr_transport_proto_ue.h
+27
-17
No files found.
openair1/PHY/NR_UE_TRANSPORT/csi_rx.c
View file @
bc2ea375
...
@@ -372,6 +372,12 @@ int nr_csi_rs_ri_estimation(PHY_VARS_NR_UE *ue,
...
@@ -372,6 +372,12 @@ int nr_csi_rs_ri_estimation(PHY_VARS_NR_UE *ue,
* | conjch01 conjch11 | | ch10 ch11 | | conjch01*ch00+conjch11*ch10 conjch01*ch01+conjch11*ch11 |
* | conjch01 conjch11 | | ch10 ch11 | | conjch01*ch00+conjch11*ch10 conjch01*ch01+conjch11*ch11 |
*/
*/
for
(
uint16_t
port_tx_conjch
=
0
;
port_tx_conjch
<
nr_csi_rs_info
->
N_ports
;
port_tx_conjch
++
)
{
for
(
uint16_t
port_tx_ch
=
0
;
port_tx_ch
<
nr_csi_rs_info
->
N_ports
;
port_tx_ch
++
)
{
memset
(
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
port_tx_conjch
][
port_tx_ch
],
0
,
NR_MAX_OFDM_SYMBOL_SIZE
*
sizeof
(
int32_t
));
}
}
for
(
int
rb
=
csirs_config_pdu
->
start_rb
;
rb
<
(
csirs_config_pdu
->
start_rb
+
csirs_config_pdu
->
nr_of_rbs
);
rb
++
)
{
for
(
int
rb
=
csirs_config_pdu
->
start_rb
;
rb
<
(
csirs_config_pdu
->
start_rb
+
csirs_config_pdu
->
nr_of_rbs
);
rb
++
)
{
if
(
csirs_config_pdu
->
freq_density
<=
1
&&
csirs_config_pdu
->
freq_density
!=
(
rb
%
2
))
{
if
(
csirs_config_pdu
->
freq_density
<=
1
&&
csirs_config_pdu
->
freq_density
!=
(
rb
%
2
))
{
...
@@ -379,61 +385,43 @@ int nr_csi_rs_ri_estimation(PHY_VARS_NR_UE *ue,
...
@@ -379,61 +385,43 @@ int nr_csi_rs_ri_estimation(PHY_VARS_NR_UE *ue,
}
}
uint16_t
k
=
(
frame_parms
->
first_carrier_offset
+
rb
*
NR_NB_SC_PER_RB
)
%
frame_parms
->
ofdm_symbol_size
;
uint16_t
k
=
(
frame_parms
->
first_carrier_offset
+
rb
*
NR_NB_SC_PER_RB
)
%
frame_parms
->
ofdm_symbol_size
;
// conjch x ch computation
for
(
int
ant_rx_conjch
=
0
;
ant_rx_conjch
<
frame_parms
->
nb_antennas_rx
;
ant_rx_conjch
++
)
{
for
(
int
ant_rx_conjch
=
0
;
ant_rx_conjch
<
frame_parms
->
nb_antennas_rx
;
ant_rx_conjch
++
)
{
for
(
uint16_t
port_tx_conjch
=
0
;
port_tx_conjch
<
nr_csi_rs_info
->
N_ports
;
port_tx_conjch
++
)
{
for
(
uint16_t
port_tx_conjch
=
0
;
port_tx_conjch
<
nr_csi_rs_info
->
N_ports
;
port_tx_conjch
++
)
{
for
(
int
ant_rx_ch
=
0
;
ant_rx_ch
<
frame_parms
->
nb_antennas_rx
;
ant_rx_ch
++
)
{
for
(
int
ant_rx_ch
=
0
;
ant_rx_ch
<
frame_parms
->
nb_antennas_rx
;
ant_rx_ch
++
)
{
for
(
uint16_t
port_tx_ch
=
0
;
port_tx_ch
<
nr_csi_rs_info
->
N_ports
;
port_tx_ch
++
)
{
for
(
uint16_t
port_tx_ch
=
0
;
port_tx_ch
<
nr_csi_rs_info
->
N_ports
;
port_tx_ch
++
)
{
// conjch x ch computation
nr_conjch0_mult_ch1
(
&
csi_rs_estimated_channel_freq
[
ant_rx_conjch
][
port_tx_conjch
][
k
],
nr_conjch0_mult_ch1
(
&
csi_rs_estimated_channel_freq
[
ant_rx_conjch
][
port_tx_conjch
][
k
],
&
csi_rs_estimated_channel_freq
[
ant_rx_ch
][
port_tx_ch
][
k
],
&
csi_rs_estimated_channel_freq
[
ant_rx_ch
][
port_tx_ch
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
ant_rx_conjch
][
port_tx_conjch
][
ant_rx_ch
][
port_tx_ch
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
ant_rx_conjch
][
port_tx_conjch
][
ant_rx_ch
][
port_tx_ch
][
k
],
1
,
1
,
0
);
0
);
// construct Hh x H elements
if
(
ant_rx_conjch
==
ant_rx_ch
)
{
nr_a_sum_b
((
__m128i
*
)
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
port_tx_conjch
][
port_tx_ch
][
k
],
(
__m128i
*
)
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
ant_rx_conjch
][
port_tx_conjch
][
ant_rx_ch
][
port_tx_ch
][
k
],
1
);
}
}
}
}
}
}
}
}
}
// construct Hh x H elements
nr_construct_HhH_elements
(
0
<
frame_parms
->
nb_antennas_rx
&&
0
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
0
][
0
][
0
][
0
][
k
]
:
NULL
,
0
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
0
][
1
][
0
][
1
][
k
]
:
NULL
,
1
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
1
][
1
][
1
][
1
][
k
]
:
NULL
,
1
<
frame_parms
->
nb_antennas_rx
&&
0
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
1
][
0
][
1
][
0
][
k
]
:
NULL
,
2
<
frame_parms
->
nb_antennas_rx
&&
0
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
2
][
0
][
2
][
0
][
k
]
:
NULL
,
2
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
2
][
1
][
2
][
1
][
k
]
:
NULL
,
3
<
frame_parms
->
nb_antennas_rx
&&
0
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
3
][
0
][
3
][
0
][
k
]
:
NULL
,
3
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
3
][
1
][
3
][
1
][
k
]
:
NULL
,
0
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
0
][
0
][
0
][
1
][
k
]
:
NULL
,
0
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
0
][
1
][
0
][
0
][
k
]
:
NULL
,
1
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
1
][
0
][
1
][
1
][
k
]
:
NULL
,
1
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
1
][
1
][
1
][
0
][
k
]
:
NULL
,
2
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
2
][
0
][
2
][
1
][
k
]
:
NULL
,
2
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
2
][
1
][
2
][
0
][
k
]
:
NULL
,
3
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
3
][
0
][
3
][
1
][
k
]
:
NULL
,
3
<
frame_parms
->
nb_antennas_rx
&&
1
<
nr_csi_rs_info
->
N_ports
?
&
nr_csi_rs_info
->
csi_rs_estimated_conjch_ch
[
3
][
1
][
3
][
0
][
k
]
:
NULL
,
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
0
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
0
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
1
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
1
][
1
][
k
],
1
,
0
);
// compute the determinant of A_MF (denominator)
// compute the determinant of A_MF (denominator)
nr_det_
HhH
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
0
][
0
][
k
],
nr_det_
A_MF_2x2
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
0
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
0
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
0
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
1
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
1
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
1
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
1
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_determ_fin
[
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_determ_fin
[
k
],
1
,
1
);
0
,
0
);
// compute the square of A_MF (numerator)
// compute the square of A_MF (numerator)
squared_matrix_element
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
0
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
0
][
0
][
k
],
1
);
nr_
squared_matrix_element
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
0
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
0
][
0
][
k
],
1
);
squared_matrix_element
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
0
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
0
][
1
][
k
],
1
);
nr_
squared_matrix_element
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
0
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
0
][
1
][
k
],
1
);
squared_matrix_element
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
1
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
1
][
0
][
k
],
1
);
nr_
squared_matrix_element
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
1
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
1
][
0
][
k
],
1
);
squared_matrix_element
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
1
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
1
][
1
][
k
],
1
);
nr_
squared_matrix_element
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF
[
1
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
1
][
1
][
k
],
1
);
n
umer
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
0
][
0
][
k
],
n
r_numer_2x2
(
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
0
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
0
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
0
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
1
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
1
][
0
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
1
][
1
][
k
],
&
nr_csi_rs_info
->
csi_rs_estimated_A_MF_sq
[
1
][
1
][
k
],
...
...
openair1/PHY/NR_UE_TRANSPORT/nr_dlsch_demodulation.c
View file @
bc2ea375
...
@@ -1869,6 +1869,89 @@ void nr_dlsch_detection_mrc(int **rxdataF_comp,
...
@@ -1869,6 +1869,89 @@ void nr_dlsch_detection_mrc(int **rxdataF_comp,
#endif
#endif
}
}
void
nr_det_A_MF_2x2
(
int32_t
*
a_mf_00
,
int32_t
*
a_mf_01
,
int32_t
*
a_mf_10
,
int32_t
*
a_mf_11
,
int32_t
*
det_fin
,
unsigned
short
nb_rb
)
{
int16_t
nr_conjug2
[
8
]
__attribute__
((
aligned
(
16
)))
=
{
1
,
-
1
,
1
,
-
1
,
1
,
-
1
,
1
,
-
1
}
;
__m128i
ad_re_128
,
bc_re_128
,
det_re_128
;
__m128i
*
a_mf_00_128
=
(
__m128i
*
)
a_mf_00
;
__m128i
*
a_mf_01_128
=
(
__m128i
*
)
a_mf_01
;
__m128i
*
a_mf_10_128
=
(
__m128i
*
)
a_mf_10
;
__m128i
*
a_mf_11_128
=
(
__m128i
*
)
a_mf_11
;
__m128i
*
det_fin_128
=
(
__m128i
*
)
det_fin
;
for
(
int
rb
=
0
;
rb
<
3
*
nb_rb
;
rb
++
)
{
//complex multiplication (I_a+jQ_a)(I_d+jQ_d) = (I_aI_d - Q_aQ_d) + j(Q_aI_d + I_aQ_d)
//The imag part is often zero, we compute only the real part
ad_re_128
=
_mm_sign_epi16
(
a_mf_00_128
[
0
],
*
(
__m128i
*
)
&
nr_conjug2
[
0
]);
ad_re_128
=
_mm_madd_epi16
(
ad_re_128
,
a_mf_11_128
[
0
]);
//Re: I_a0*I_d0 - Q_a1*Q_d1
//complex multiplication (I_b+jQ_b)(I_c+jQ_c) = (I_bI_c - Q_bQ_c) + j(Q_bI_c + I_bQ_c)
//The imag part is often zero, we compute only the real part
bc_re_128
=
_mm_sign_epi16
(
a_mf_01_128
[
0
],
*
(
__m128i
*
)
&
nr_conjug2
[
0
]);
bc_re_128
=
_mm_madd_epi16
(
bc_re_128
,
a_mf_10_128
[
0
]);
//Re: I_b0*I_c0 - Q_b1*Q_c1
det_re_128
=
_mm_sub_epi32
(
ad_re_128
,
bc_re_128
);
//det in Q30 format
det_fin_128
[
0
]
=
_mm_abs_epi32
(
det_re_128
);
det_fin_128
+=
1
;
a_mf_00_128
+=
1
;
a_mf_01_128
+=
1
;
a_mf_10_128
+=
1
;
a_mf_11_128
+=
1
;
}
_mm_empty
();
_m_empty
();
}
void
nr_squared_matrix_element
(
int32_t
*
a
,
int32_t
*
a_sq
,
unsigned
short
nb_rb
)
{
__m128i
*
a_128
=
(
__m128i
*
)
a
;
__m128i
*
a_sq_128
=
(
__m128i
*
)
a_sq
;
for
(
int
rb
=
0
;
rb
<
3
*
nb_rb
;
rb
++
)
{
a_sq_128
[
0
]
=
_mm_madd_epi16
(
a_128
[
0
],
a_128
[
0
]);
a_sq_128
+=
1
;
a_128
+=
1
;
}
_mm_empty
();
_m_empty
();
}
void
nr_numer_2x2
(
int32_t
*
a_00_sq
,
int32_t
*
a_01_sq
,
int32_t
*
a_10_sq
,
int32_t
*
a_11_sq
,
int32_t
*
num_fin
,
unsigned
short
nb_rb
)
{
__m128i
*
a_00_sq_128
=
(
__m128i
*
)
a_00_sq
;
__m128i
*
a_01_sq_128
=
(
__m128i
*
)
a_01_sq
;
__m128i
*
a_10_sq_128
=
(
__m128i
*
)
a_10_sq
;
__m128i
*
a_11_sq_128
=
(
__m128i
*
)
a_11_sq
;
__m128i
*
num_fin_128
=
(
__m128i
*
)
num_fin
;
for
(
int
rb
=
0
;
rb
<
3
*
nb_rb
;
rb
++
)
{
__m128i
sq_a_plus_sq_d_128
=
_mm_add_epi32
(
a_00_sq_128
[
0
],
a_11_sq_128
[
0
]);
__m128i
sq_b_plus_sq_c_128
=
_mm_add_epi32
(
a_01_sq_128
[
0
],
a_10_sq_128
[
0
]);
num_fin_128
[
0
]
=
_mm_add_epi32
(
sq_a_plus_sq_d_128
,
sq_b_plus_sq_c_128
);
num_fin_128
+=
1
;
a_00_sq_128
+=
1
;
a_01_sq_128
+=
1
;
a_10_sq_128
+=
1
;
a_11_sq_128
+=
1
;
}
_mm_empty
();
_m_empty
();
}
/* Zero Forcing Rx function: nr_a_sum_b()
/* Zero Forcing Rx function: nr_a_sum_b()
* Compute the complex addition x=x+y
* Compute the complex addition x=x+y
*
*
...
...
openair1/PHY/NR_UE_TRANSPORT/nr_transport_proto_ue.h
View file @
bc2ea375
...
@@ -851,10 +851,6 @@ void construct_HhH_elements(int *ch0conj_ch0,
...
@@ -851,10 +851,6 @@ void construct_HhH_elements(int *ch0conj_ch0,
int32_t
*
after_mf_11
,
int32_t
*
after_mf_11
,
unsigned
short
nb_rb
);
unsigned
short
nb_rb
);
void
squared_matrix_element
(
int32_t
*
Hh_h_00
,
int32_t
*
Hh_h_00_sq
,
unsigned
short
nb_rb
);
void
dlsch_channel_level_TM34_meas
(
int
*
ch00
,
void
dlsch_channel_level_TM34_meas
(
int
*
ch00
,
int
*
ch01
,
int
*
ch01
,
int
*
ch10
,
int
*
ch10
,
...
@@ -881,17 +877,31 @@ void nr_dlsch_detection_mrc(int **rxdataF_comp,
...
@@ -881,17 +877,31 @@ void nr_dlsch_detection_mrc(int **rxdataF_comp,
unsigned
short
nb_rb
,
unsigned
short
nb_rb
,
int
length
);
int
length
);
void
det_HhH
(
int32_t
*
after_mf_00
,
void
nr_conjch0_mult_ch1
(
int
*
ch0
,
int32_t
*
after_mf_01
,
int
*
ch1
,
int32_t
*
after_mf_10
,
int32_t
*
ch0conj_ch1
,
int32_t
*
after_mf_11
,
unsigned
short
nb_rb
,
int32_t
*
det_fin_128
,
unsigned
char
output_shift0
);
void
nr_a_sum_b
(
__m128i
*
input_x
,
__m128i
*
input_y
,
unsigned
short
nb_rb
);
void
nr_det_A_MF_2x2
(
int32_t
*
a_mf_00
,
int32_t
*
a_mf_01
,
int32_t
*
a_mf_10
,
int32_t
*
a_mf_11
,
int32_t
*
det_fin
,
unsigned
short
nb_rb
);
void
nr_squared_matrix_element
(
int32_t
*
a
,
int32_t
*
a_sq
,
unsigned
short
nb_rb
);
unsigned
short
nb_rb
);
void
n
umer
(
int32_t
*
Hh_h
_00_sq
,
void
n
r_numer_2x2
(
int32_t
*
a
_00_sq
,
int32_t
*
Hh_h
_01_sq
,
int32_t
*
a
_01_sq
,
int32_t
*
Hh_h
_10_sq
,
int32_t
*
a
_10_sq
,
int32_t
*
Hh_h
_11_sq
,
int32_t
*
a
_11_sq
,
int32_t
*
num_fin
,
int32_t
*
num_fin
,
unsigned
short
nb_rb
);
unsigned
short
nb_rb
);
...
...
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