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
spbro
OpenXG-RAN
Commits
9890410a
Commit
9890410a
authored
Feb 13, 2024
by
Robert Schmidt
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/l1_tx_thread' into integration_2024_w06
parents
d01c1470
c33a308d
Changes
37
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
37 changed files
with
760 additions
and
518 deletions
+760
-518
ci-scripts/cls_oai_html.py
ci-scripts/cls_oai_html.py
+10
-4
ci-scripts/conf_files/gnb.band78.273prb.usrpn300.phytest-dora.conf
...s/conf_files/gnb.band78.273prb.usrpn300.phytest-dora.conf
+242
-0
ci-scripts/datalog_rt_stats.100.2x2.yaml
ci-scripts/datalog_rt_stats.100.2x2.yaml
+34
-0
ci-scripts/datalog_rt_stats.1x1.60.yaml
ci-scripts/datalog_rt_stats.1x1.60.yaml
+19
-19
ci-scripts/datalog_rt_stats.2x2.yaml
ci-scripts/datalog_rt_stats.2x2.yaml
+19
-17
ci-scripts/datalog_rt_stats.60.2x2.yaml
ci-scripts/datalog_rt_stats.60.2x2.yaml
+19
-19
ci-scripts/datalog_rt_stats.default.yaml
ci-scripts/datalog_rt_stats.default.yaml
+19
-19
ci-scripts/ran.py
ci-scripts/ran.py
+4
-2
ci-scripts/stats_monitor_conf.yaml
ci-scripts/stats_monitor_conf.yaml
+2
-2
ci-scripts/xml_files/gnb_phytest_usrp_run_100_2x2.xml
ci-scripts/xml_files/gnb_phytest_usrp_run_100_2x2.xml
+68
-0
executables/nr-gnb.c
executables/nr-gnb.c
+95
-242
executables/nr-ru.c
executables/nr-ru.c
+90
-45
executables/nr-softmodem.h
executables/nr-softmodem.h
+0
-1
executables/softmodem-common.h
executables/softmodem-common.h
+1
-7
nfapi/oai_integration/nfapi_vnf.c
nfapi/oai_integration/nfapi_vnf.c
+0
-3
nfapi/open-nFAPI/vnf/src/vnf_p7_interface.c
nfapi/open-nFAPI/vnf/src/vnf_p7_interface.c
+0
-2
openair1/PHY/NR_TRANSPORT/nr_prach.c
openair1/PHY/NR_TRANSPORT/nr_prach.c
+2
-2
openair1/PHY/NR_TRANSPORT/nr_ulsch.c
openair1/PHY/NR_TRANSPORT/nr_ulsch.c
+12
-3
openair1/PHY/NR_TRANSPORT/nr_ulsch_demodulation.c
openair1/PHY/NR_TRANSPORT/nr_ulsch_demodulation.c
+2
-2
openair1/PHY/NR_TRANSPORT/pucch_rx.c
openair1/PHY/NR_TRANSPORT/pucch_rx.c
+2
-6
openair1/PHY/NR_TRANSPORT/srs_rx.c
openair1/PHY/NR_TRANSPORT/srs_rx.c
+2
-1
openair1/PHY/defs_RU.h
openair1/PHY/defs_RU.h
+1
-1
openair1/PHY/defs_gNB.h
openair1/PHY/defs_gNB.h
+9
-6
openair1/SCHED_NR/fapi_nr_l1.c
openair1/SCHED_NR/fapi_nr_l1.c
+15
-27
openair1/SCHED_NR/nr_prach_procedures.c
openair1/SCHED_NR/nr_prach_procedures.c
+3
-2
openair1/SCHED_NR/nr_ru_procedures.c
openair1/SCHED_NR/nr_ru_procedures.c
+2
-2
openair1/SCHED_NR/phy_procedures_nr_gNB.c
openair1/SCHED_NR/phy_procedures_nr_gNB.c
+20
-14
openair1/SIMULATION/NR_PHY/dlsim.c
openair1/SIMULATION/NR_PHY/dlsim.c
+1
-0
openair1/SIMULATION/NR_PHY/ulsim.c
openair1/SIMULATION/NR_PHY/ulsim.c
+1
-2
openair2/NR_PHY_INTERFACE/NR_IF_Module.c
openair2/NR_PHY_INTERFACE/NR_IF_Module.c
+42
-55
openair2/NR_PHY_INTERFACE/NR_IF_Module.h
openair2/NR_PHY_INTERFACE/NR_IF_Module.h
+1
-0
openair2/NR_PHY_INTERFACE/nr_sched_response.c
openair2/NR_PHY_INTERFACE/nr_sched_response.c
+4
-0
radio/ETHERNET/eth_udp.c
radio/ETHERNET/eth_udp.c
+3
-2
targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band41.fr1.106PRB.usrpb210.conf
...ENERIC-NR-5GC/CONF/gnb.sa.band41.fr1.106PRB.usrpb210.conf
+13
-8
targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band77.273prb.fhi72.4x4-vvdn.conf
...ERIC-NR-5GC/CONF/gnb.sa.band77.273prb.fhi72.4x4-vvdn.conf
+1
-1
targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.273prb.fhi72.4x2-benetel650.conf
...R-5GC/CONF/gnb.sa.band78.273prb.fhi72.4x2-benetel650.conf
+1
-1
targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.273prb.fhi72.4x4-liteon.conf
...IC-NR-5GC/CONF/gnb.sa.band78.273prb.fhi72.4x4-liteon.conf
+1
-1
No files found.
ci-scripts/cls_oai_html.py
View file @
9890410a
...
...
@@ -437,13 +437,19 @@ class HTMLManagement():
for
k
in
DataLog
[
'Data'
]:
# TestRow
avg
=
DataLog
[
'Data'
][
k
][
0
]
maxval
=
DataLog
[
'Data'
][
k
][
1
]
count
=
DataLog
[
'Data'
][
k
][
2
]
valnorm
=
float
(
DataLog
[
'Data'
][
k
][
3
])
dev
=
DataLog
[
'DeviationThreshold'
][
k
]
ref
=
DataLog
[
'Ref'
][
k
]
self
.
htmlFile
.
write
(
' <tr>
\n
'
)
self
.
htmlFile
.
write
(
' <td colspan="3" bgcolor = "lightcyan" >'
+
k
+
' </td>
\n
'
)
self
.
htmlFile
.
write
(
' <td colspan="2" bgcolor = "lightcyan" >'
+
DataLog
[
'Data'
][
k
][
0
]
+
'; '
+
DataLog
[
'Data'
][
k
][
1
]
+
'; '
+
DataLog
[
'Data'
][
k
][
2
]
+
'
</td>
\n
'
)
if
float
(
DataLog
[
'Data'
][
k
][
3
])
>
DataLog
[
'Threshold'
][
k
]
:
self
.
htmlFile
.
write
(
' <th bgcolor = "red" >'
+
DataLog
[
'Data'
][
k
][
3
]
+
' (Ref = '
+
str
(
DataLog
[
'Ref'
][
k
])
+
' ; Thres = '
+
str
(
DataLog
[
'Threshold'
][
k
])
+
') '
+
'
</th>
\n
'
)
self
.
htmlFile
.
write
(
f' <td colspan="2" bgcolor = "lightcyan" >
{
avg
}
;
{
maxval
}
;
{
count
}
</td>
\n
'
)
if
valnorm
>
1.0
+
dev
or
valnorm
<
1.0
-
dev
:
self
.
htmlFile
.
write
(
f' <th bgcolor = "red" >
{
valnorm
}
(Avg over Ref =
{
avg
}
over
{
ref
}
; max allowed deviation =
{
dev
}
)
</th>
\n
'
)
else
:
self
.
htmlFile
.
write
(
' <th bgcolor = "green" ><font color="white">'
+
DataLog
[
'Data'
][
k
][
3
]
+
' (Ref = '
+
str
(
DataLog
[
'Ref'
][
k
])
+
' ; Thres = '
+
str
(
DataLog
[
'Threshold'
][
k
])
+
') '
+
'
</th>
\n
'
)
self
.
htmlFile
.
write
(
f' <th bgcolor = "green" ><font color="white">
{
valnorm
}
(Avg over Ref =
{
avg
}
over
{
ref
}
; max allowed deviation =
{
dev
}
)</font>
</th>
\n
'
)
self
.
htmlFile
.
write
(
' </tr>
\n
'
)
self
.
htmlFile
.
close
()
...
...
ci-scripts/conf_files/gnb.band78.273prb.usrpn300.phytest-dora.conf
0 → 100644
View file @
9890410a
Active_gNBs
= (
"gNB-Eurecom-5GNRBox"
);
# Asn1_verbosity, choice in: none, info, annoying
Asn1_verbosity
=
"none"
;
gNBs
=
(
{
//////////
Identification
parameters
:
gNB_ID
=
0
xe00
;
cell_type
=
"CELL_MACRO_GNB"
;
gNB_name
=
"gNB-Eurecom-5GNRBox"
;
//
Tracking
area
code
,
0
x0000
and
0
xfffe
are
reserved
values
tracking_area_code
=
1
;
plmn_list
= ({
mcc
=
208
;
mnc
=
93
;
mnc_length
=
2
;});
tr_s_preference
=
"local_mac"
//////////
Physical
parameters
:
pdsch_AntennaPorts_XP
=
2
;
pusch_AntennaPorts
=
2
;
min_rxtxtime
=
6
;
servingCellConfigCommon
= (
{
#spCellConfigCommon
physCellId
=
0
;
# downlinkConfigCommon
#frequencyInfoDL
# this is 3600 MHz + 43 PRBs@30kHz SCS (same as initial BWP)
absoluteFrequencySSB
=
621312
;
dl_frequencyBand
=
78
;
# this is 3600 MHz
dl_absoluteFrequencyPointA
=
620040
;
#scs-SpecificCarrierList
dl_offstToCarrier
=
0
;
# subcarrierSpacing
# 0=kHz15, 1=kHz30, 2=kHz60, 3=kHz120
dl_subcarrierSpacing
=
1
;
dl_carrierBandwidth
=
273
;
#initialDownlinkBWP
#genericParameters
# this is RBstart=41,L=24 (275*(L-1))+RBstart
initialDLBWPlocationAndBandwidth
=
31624
;
# subcarrierSpacing
# 0=kHz15, 1=kHz30, 2=kHz60, 3=kHz120
initialDLBWPsubcarrierSpacing
=
1
;
#pdcch-ConfigCommon
initialDLBWPcontrolResourceSetZero
=
12
;
initialDLBWPsearchSpaceZero
=
0
;
#uplinkConfigCommon
#frequencyInfoUL
ul_frequencyBand
=
78
;
#scs-SpecificCarrierList
ul_offstToCarrier
=
0
;
# subcarrierSpacing
# 0=kHz15, 1=kHz30, 2=kHz60, 3=kHz120
ul_subcarrierSpacing
=
1
;
ul_carrierBandwidth
=
273
;
pMax
=
20
;
#initialUplinkBWP
#genericParameters
initialULBWPlocationAndBandwidth
=
31624
;
# subcarrierSpacing
# 0=kHz15, 1=kHz30, 2=kHz60, 3=kHz120
initialULBWPsubcarrierSpacing
=
1
;
#rach-ConfigCommon
#rach-ConfigGeneric
prach_ConfigurationIndex
=
98
;
#prach_msg1_FDM
#0 = one, 1=two, 2=four, 3=eight
prach_msg1_FDM
=
0
;
prach_msg1_FrequencyStart
=
0
;
zeroCorrelationZoneConfig
=
13
;
preambleReceivedTargetPower
= -
118
;
#preamblTransMax (0...10) = (3,4,5,6,7,8,10,20,50,100,200)
preambleTransMax
=
6
;
#powerRampingStep
# 0=dB0,1=dB2,2=dB4,3=dB6
powerRampingStep
=
1
;
#ra_ReponseWindow
#1,2,4,8,10,20,40,80
ra_ResponseWindow
=
4
;
#ssb_perRACH_OccasionAndCB_PreamblesPerSSB_PR
#1=oneeighth,2=onefourth,3=half,4=one,5=two,6=four,7=eight,8=sixteen
ssb_perRACH_OccasionAndCB_PreamblesPerSSB_PR
=
4
;
#oneHalf (0..15) 4,8,12,16,...60,64
ssb_perRACH_OccasionAndCB_PreamblesPerSSB
=
15
;
#ra_ContentionResolutionTimer
#(0..7) 8,16,24,32,40,48,56,64
ra_ContentionResolutionTimer
=
7
;
rsrp_ThresholdSSB
=
19
;
#prach-RootSequenceIndex_PR
#1 = 839, 2 = 139
prach_RootSequenceIndex_PR
=
2
;
prach_RootSequenceIndex
=
1
;
# SCS for msg1, can only be 15 for 30 kHz < 6 GHz, takes precendence over the one derived from prach-ConfigIndex
#
msg1_SubcarrierSpacing
=
1
,
# restrictedSetConfig
# 0=unrestricted, 1=restricted type A, 2=restricted type B
restrictedSetConfig
=
0
,
msg3_DeltaPreamble
=
1
;
p0_NominalWithGrant
=-
90
;
# pucch-ConfigCommon setup :
# pucchGroupHopping
# 0 = neither, 1= group hopping, 2=sequence hopping
pucchGroupHopping
=
0
;
hoppingId
=
40
;
p0_nominal
= -
90
;
# ssb_PositionsInBurs_BitmapPR
# 1=short, 2=medium, 3=long
ssb_PositionsInBurst_PR
=
2
;
ssb_PositionsInBurst_Bitmap
=
1
;
# ssb_periodicityServingCell
# 0 = ms5, 1=ms10, 2=ms20, 3=ms40, 4=ms80, 5=ms160, 6=spare2, 7=spare1
ssb_periodicityServingCell
=
2
;
# dmrs_TypeA_position
# 0 = pos2, 1 = pos3
dmrs_TypeA_Position
=
0
;
# subcarrierSpacing
# 0=kHz15, 1=kHz30, 2=kHz60, 3=kHz120
subcarrierSpacing
=
1
;
#tdd-UL-DL-ConfigurationCommon
# subcarrierSpacing
# 0=kHz15, 1=kHz30, 2=kHz60, 3=kHz120
referenceSubcarrierSpacing
=
1
;
# pattern1
# dl_UL_TransmissionPeriodicity
# 0=ms0p5, 1=ms0p625, 2=ms1, 3=ms1p25, 4=ms2, 5=ms2p5, 6=ms5, 7=ms10
dl_UL_TransmissionPeriodicity
=
6
;
nrofDownlinkSlots
=
7
;
nrofDownlinkSymbols
=
6
;
nrofUplinkSlots
=
2
;
nrofUplinkSymbols
=
4
;
ssPBCH_BlockPower
= -
25
;
}
);
# ------- SCTP definitions
SCTP
:
{
# Number of streams to use in input/output
SCTP_INSTREAMS
=
2
;
SCTP_OUTSTREAMS
=
2
;
};
//////////
MME
parameters
:
mme_ip_address
= ( {
ipv4
=
"192.168.12.26"
;
ipv6
=
"192:168:30::17"
;
port
=
36412
;
active
=
"yes"
;
preference
=
"ipv4"
;
}
);
NETWORK_INTERFACES
: {
GNB_INTERFACE_NAME_FOR_S1_MME
=
"eth0"
;
GNB_IPV4_ADDRESS_FOR_S1_MME
=
"192.168.12.111/24"
;
GNB_INTERFACE_NAME_FOR_S1U
=
"eth0"
;
GNB_IPV4_ADDRESS_FOR_S1U
=
"192.168.12.111/24"
;
GNB_PORT_FOR_S1U
=
2152
;
# Spec 2152
};
}
);
MACRLCs
= ({
num_cc
=
1
;
tr_s_preference
=
"local_L1"
;
tr_n_preference
=
"local_RRC"
;
});
L1s
= ({
num_cc
=
1
;
tr_n_preference
=
"local_mac"
;
});
RUs
= ({
local_rf
=
"yes"
nb_tx
=
2
nb_rx
=
2
att_tx
=
0
att_rx
=
0
;
bands
= [
7
];
max_pdschReferenceSignalPower
= -
27
;
max_rxgain
=
50
;
eNB_instances
= [
0
];
bf_weights
= [
0
x00007fff
,
0
x0000
];
sdr_addrs
=
"addr=192.168.10.2,second_addr=192.168.20.2"
;
});
THREAD_STRUCT
= ({
#three config for level of parallelism "PARALLEL_SINGLE_THREAD", "PARALLEL_RU_L1_SPLIT", or "PARALLEL_RU_L1_TRX_SPLIT"
parallel_config
=
"PARALLEL_RU_L1_TRX_SPLIT"
;
#two option for worker "WORKER_DISABLE" or "WORKER_ENABLE"
worker_config
=
"WORKER_ENABLE"
;
});
security
= {
# preferred ciphering algorithms
# the first one of the list that an UE supports in chosen
# valid values: nea0, nea1, nea2, nea3
ciphering_algorithms
= (
"nea0"
);
# preferred integrity algorithms
# the first one of the list that an UE supports in chosen
# valid values: nia0, nia1, nia2, nia3
integrity_algorithms
= (
"nia2"
,
"nia0"
);
# setting 'drb_ciphering' to "no" disables ciphering for DRBs, no matter
# what 'ciphering_algorithms' configures; same thing for 'drb_integrity'
drb_ciphering
=
"yes"
;
drb_integrity
=
"no"
;
};
log_config
: {
global_log_level
=
"info"
;
hw_log_level
=
"info"
;
phy_log_level
=
"info"
;
mac_log_level
=
"info"
;
rlc_log_level
=
"info"
;
pdcp_log_level
=
"info"
;
rrc_log_level
=
"info"
;
};
ci-scripts/datalog_rt_stats.100.2x2.yaml
0 → 100644
View file @
9890410a
#this is a configuration file
#used to build real time processing statistics
#for 5G NR phy test (gNB terminate)
Title
:
Processing Time (us) from datalog_rt_stats.100.2x2.yaml
ColNames
:
-
Metric
-
Average; Max; Count
-
Average vs Reference Deviation (Reference Value; Acceptability Deviation Threshold)
Ref
:
feprx
:
150.0
feptx_prec
:
0.0
feptx_ofdm
:
65.0
feptx_total
:
177.0
L1 Tx processing
:
700.0
DLSCH encoding
:
179.0
L1 Rx processing
:
526.0
PUSCH inner-receiver
:
400.0
Schedule Response
:
3.0
DL & UL scheduling timing
:
15.0
UL Indication
:
3.0
Slot Indication
:
17.0
DeviationThreshold
:
feprx
:
0.25
feptx_prec
:
0.25
feptx_ofdm
:
0.25
feptx_total
:
0.25
L1 Tx processing
:
0.25
DLSCH encoding
:
0.25
L1 Rx processing
:
0.25
PUSCH inner-receiver
:
0.25
Schedule Response
:
1.00
DL & UL scheduling timing
:
0.25
UL Indication
:
1.00
Slot Indication
:
0.50
ci-scripts/datalog_rt_stats.1x1.60.yaml
View file @
9890410a
#this is a configuration file
#used to build real time processing statistics
#for 5G NR phy test (gNB terminate)
Title
:
Processing Time (us)
Title
:
Processing Time (us)
from datalog_rt_stats.1x1.60.yaml
ColNames
:
-
Metric
-
Average; Max; Count
-
Average vs Reference Deviation (Reference Value; Acceptability Threshold)
-
Average vs Reference Deviation (Reference Value; Acceptability
Deviation
Threshold)
Ref
:
feprx
:
46.0
feptx_prec
:
15.0
...
...
@@ -15,20 +15,20 @@ Ref :
DLSCH encoding
:
137.0
L1 Rx processing
:
345.0
PUSCH inner-receiver
:
210.0
PUSCH decoding
:
2200
.0
Schedule Response
:
4
8.0
DL & UL scheduling timing
:
1
3.0
UL Indication
:
60
.0
Threshold
:
feprx
:
1
.25
feptx_prec
:
1
.25
feptx_ofdm
:
1
.25
feptx_total
:
1
.25
L1 Tx processing
:
1
.25
DLSCH encoding
:
1
.25
L1 Rx processing
:
1
.25
PUSCH inner-receiver
:
1
.25
PUSCH decoding
:
1.25
Schedule Response
:
1.25
DL & UL scheduling timing
:
1.25
UL Indication
:
1.25
Schedule Response
:
3
.0
DL & UL scheduling timing
:
8.0
UL Indication
:
3.0
Slot Indication
:
8
.0
Deviation
Threshold
:
feprx
:
0
.25
feptx_prec
:
0
.25
feptx_ofdm
:
0
.25
feptx_total
:
0
.25
L1 Tx processing
:
0
.25
DLSCH encoding
:
0
.25
L1 Rx processing
:
0
.25
PUSCH inner-receiver
:
0
.25
Schedule Response
:
1.00
DL & UL scheduling timing
:
0.50
UL Indication
:
1.00
Slot Indication
:
0.50
ci-scripts/datalog_rt_stats.2x2.yaml
View file @
9890410a
#this is a configuration file
#used to build real time processing statistics
#for 5G NR phy test (gNB terminate)
Title
:
Processing Time (us)
Title
:
Processing Time (us)
from datalog_rt_stats.2x2.yaml
ColNames
:
-
Metric
-
Average; Max; Count
-
Average vs Reference Deviation (Reference Value; Acceptability Threshold)
-
Average vs Reference Deviation (Reference Value; Acceptability
Deviation
Threshold)
Ref
:
feprx
:
120.0
feptx_prec
:
30.0
...
...
@@ -15,18 +15,20 @@ Ref :
DLSCH encoding
:
230.0
L1 Rx processing
:
175.0
PUSCH inner-receiver
:
100.0
PUSCH decoding
:
180.0
DL & UL scheduling timing
:
37.0
UL Indication
:
38.0
Threshold
:
feprx
:
1.25
feptx_prec
:
1.25
feptx_ofdm
:
1.25
feptx_total
:
1.25
L1 Tx processing
:
1.25
DLSCH encoding
:
1.25
L1 Rx processing
:
1.25
PUSCH inner-receiver
:
1.25
PUSCH decoding
:
1.25
DL & UL scheduling timing
:
1.25
UL Indication
:
1.25
Schedule Response
:
3.0
DL & UL scheduling timing
:
11.0
UL Indication
:
3.0
Slot Indication
:
14.0
DeviationThreshold
:
feprx
:
0.25
feptx_prec
:
0.25
feptx_ofdm
:
0.25
feptx_total
:
0.25
L1 Tx processing
:
0.25
DLSCH encoding
:
0.25
L1 Rx processing
:
0.25
PUSCH inner-receiver
:
0.25
Schedule Response
:
1.00
DL & UL scheduling timing
:
0.50
UL Indication
:
1.00
Slot Indication
:
0.25
ci-scripts/datalog_rt_stats.60.2x2.yaml
View file @
9890410a
#this is a configuration file
#used to build real time processing statistics
#for 5G NR phy test (gNB terminate)
Title
:
Processing Time (us)
Title
:
Processing Time (us)
from datalog_rt_stats.60.2x2.yaml
ColNames
:
-
Metric
-
Average; Max; Count
-
Average vs Reference Deviation (Reference Value; Acceptability Threshold)
-
Average vs Reference Deviation (Reference Value; Acceptability
Deviation
Threshold)
Ref
:
feprx
:
84.0
feptx_prec
:
14.0
...
...
@@ -15,20 +15,20 @@ Ref :
DLSCH encoding
:
177.0
L1 Rx processing
:
345.0
PUSCH inner-receiver
:
210.0
PUSCH decoding
:
2200
.0
Schedule Response
:
111
.0
DL & UL scheduling timing
:
20
.0
UL Indication
:
127
.0
Threshold
:
feprx
:
1
.25
feptx_prec
:
1
.25
feptx_ofdm
:
1
.25
feptx_total
:
1
.25
L1 Tx processing
:
1
.25
DLSCH encoding
:
1
.25
L1 Rx processing
:
1
.25
PUSCH inner-receiver
:
1
.25
PUSCH decoding
:
1.25
Schedule Response
:
48.0
DL & UL scheduling timing
:
1.25
UL Indication
:
1.2
5
Schedule Response
:
3
.0
DL & UL scheduling timing
:
13
.0
UL Indication
:
3
.0
Slot Indication
:
15
.0
Deviation
Threshold
:
feprx
:
0
.25
feptx_prec
:
0
.25
feptx_ofdm
:
0
.25
feptx_total
:
0
.25
L1 Tx processing
:
0
.25
DLSCH encoding
:
0
.25
L1 Rx processing
:
0
.25
PUSCH inner-receiver
:
0
.25
Schedule Response
:
1.00
DL & UL scheduling timing
:
0.35
UL Indication
:
1.00
Slot Indication
:
0.3
5
ci-scripts/datalog_rt_stats.default.yaml
View file @
9890410a
#this is a configuration file
#used to build real time processing statistics
#for 5G NR phy test (gNB terminate)
Title
:
Processing Time (us)
Title
:
Processing Time (us)
from datalog_rt_stats.default.yaml
ColNames
:
-
Metric
-
Average; Max; Count
-
Average vs Reference Deviation (Reference Value; Acceptability Threshold)
-
Average vs Reference Deviation (Reference Value; Acceptability
Deviation
Threshold)
Ref
:
feprx
:
43.0
feptx_prec
:
13.0
...
...
@@ -15,20 +15,20 @@ Ref :
DLSCH encoding
:
118.0
L1 Rx processing
:
305.0
PUSCH inner-receiver
:
150.0
PUSCH decoding
:
2200
.0
Schedule Response
:
30
.0
DL & UL scheduling timing
:
10
.0
UL Indication
:
40
.0
Threshold
:
feprx
:
1
.25
feptx_prec
:
1
.25
feptx_ofdm
:
1
.25
feptx_total
:
1
.25
L1 Tx processing
:
1
.25
DLSCH encoding
:
1
.25
L1 Rx processing
:
1
.25
PUSCH inner-receiver
:
1
.25
PUSCH decoding
:
1.25
Schedule Response
:
1.25
DL & UL scheduling timing
:
1.25
UL Indication
:
1.25
Schedule Response
:
3
.0
DL & UL scheduling timing
:
6
.0
UL Indication
:
3
.0
Slot Indication
:
7
.0
Deviation
Threshold
:
feprx
:
0
.25
feptx_prec
:
0
.25
feptx_ofdm
:
0
.25
feptx_total
:
0
.25
L1 Tx processing
:
0
.25
DLSCH encoding
:
0
.25
L1 Rx processing
:
0
.25
PUSCH inner-receiver
:
0
.25
Schedule Response
:
1.00
DL & UL scheduling timing
:
0.50
UL Indication
:
1.00
Slot Indication
:
0.50
ci-scripts/ran.py
View file @
9890410a
...
...
@@ -1179,8 +1179,10 @@ class RANManagement():
self
.
datalog_rt_stats
=
datalog_rt_stats
#check if there is a fail => will render the test as failed
for
k
in
datalog_rt_stats
[
'Data'
]:
if
float
(
datalog_rt_stats
[
'Data'
][
k
][
3
])
>
datalog_rt_stats
[
'Threshold'
][
k
]:
#condition for fail : avg/ref is greater than the fixed threshold
logging
.
debug
(
'
\u001B
[1;30;43m datalog_rt_stats metric '
+
k
+
'='
+
datalog_rt_stats
[
'Data'
][
k
][
3
]
+
' > threshold '
+
str
(
datalog_rt_stats
[
'Threshold'
][
k
])
+
'
\u001B
[0m'
)
valnorm
=
float
(
datalog_rt_stats
[
'Data'
][
k
][
3
])
dev
=
datalog_rt_stats
[
'DeviationThreshold'
][
k
]
if
valnorm
>
1.0
+
dev
or
valnorm
<
1.0
-
dev
:
# condition for fail : avg/ref deviates by more than "deviation threshold"
logging
.
debug
(
f'
\u001B
[1;30;43m normalized datalog_rt_stats metric
{
k
}
=
{
valnorm
}
deviates by more than
{
dev
}
\u001B
[0m'
)
RealTimeProcessingIssue
=
True
else
:
statMsg
=
'No real time stats found in the log file
\n
'
...
...
ci-scripts/stats_monitor_conf.yaml
View file @
9890410a
...
...
@@ -24,9 +24,9 @@ gnb :
DLSCH encoding
:
L1 Rx processing
:
PUSCH inner-receiver
:
PUSCH decoding
:
DL & UL scheduling timing
:
UL Indication
:
Slot Indication
:
graph
:
page1
:
dlsch_err
:
...
...
@@ -44,6 +44,6 @@ gnb :
rt.L1 Rx processing
:
page4
:
rt.PUSCH inner-receiver
:
rt.PUSCH decoding
:
rt.DL & UL scheduling timing
:
rt.UL Indication
:
rt.Slot Indication
:
ci-scripts/xml_files/gnb_phytest_usrp_run_100_2x2.xml
0 → 100644
View file @
9890410a
<!--
Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The OpenAirInterface Software Alliance licenses this file to You under
the OAI Public License, Version 1.1 (the "License"); you may not use this file
except in compliance with the License.
You may obtain a copy of the License at
http://www.openairinterface.org/?page_id=698
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
For more information about the OpenAirInterface (OAI) Software Alliance:
contact@openairinterface.org
-->
<testCaseList>
<htmlTabRef>
gNB-PHY-Test-100-2x2
</htmlTabRef>
<htmlTabName>
Timing phytest 100 MHz 2x2
</htmlTabName>
<htmlTabIcon>
tasks
</htmlTabIcon>
<repeatCount>
1
</repeatCount>
<TestCaseRequestedList>
100000 390101 000001 390109 200000
</TestCaseRequestedList>
<TestCaseExclusionList></TestCaseExclusionList>
<testCase
id=
"100000"
>
<class>
Custom_Command
</class>
<desc>
Disable Sleep States
</desc>
<node>
caracal
</node>
<command>
sudo cpupower idle-set -D 0
</command>
</testCase>
<testCase
id=
"200000"
>
<class>
Custom_Command
</class>
<desc>
Enable Sleep States
</desc>
<node>
caracal
</node>
<command>
sudo cpupower idle-set -E
</command>
</testCase>
<testCase
id=
"390101"
>
<class>
Initialize_eNB
</class>
<desc>
Initialize gNB USRP
</desc>
<Initialize_eNB_args>
-O ci-scripts/conf_files/gnb.band78.273prb.usrpn300.phytest-dora.conf --phy-test -q -U 787200 -T 273 -t 23 -D 130175 -m 23 -M 273 -l 2 --usrp-tx-thread-config 1 --log_config.global_log_options level,nocolor,time
</Initialize_eNB_args>
<rt_stats_cfg>
datalog_rt_stats.100.2x2.yaml
</rt_stats_cfg>
<air_interface>
NR
</air_interface>
<USRP_IPAddress>
192.168.20.2
</USRP_IPAddress>
<cmd_prefix>
numactl --cpunodebind=netdev:enp94s0f0np0 --membind=netdev:enp94s0f0np0
</cmd_prefix>
</testCase>
<testCase
id=
"000001"
>
<class>
IdleSleep
</class>
<desc>
Sleep
</desc>
<idle_sleep_time_in_sec>
60
</idle_sleep_time_in_sec>
</testCase>
<testCase
id=
"390109"
>
<class>
Terminate_eNB
</class>
<desc>
Terminate gNB
</desc>
<air_interface>
NR
</air_interface>
</testCase>
</testCaseList>
executables/nr-gnb.c
View file @
9890410a
This diff is collapsed.
Click to expand it.
executables/nr-ru.c
View file @
9890410a
This diff is collapsed.
Click to expand it.
executables/nr-softmodem.h
View file @
9890410a
...
...
@@ -47,7 +47,6 @@ extern char *uecap_file;
// In nr-gnb.c
extern
void
init_gNB
(
int
single_thread_flag
,
int
wait_for_sync
);
extern
void
stop_gNB
(
int
);
extern
void
kill_gNB_proc
(
int
inst
);
// In nr-ru.c
extern
void
init_NR_RU
(
configmodule_interface_t
*
cfg
,
char
*
);
...
...
executables/softmodem-common.h
View file @
9890410a
...
...
@@ -44,7 +44,6 @@ extern "C"
example: -1,3 launches two working threads one floating, the second set on core 3\n\
default 8 floating threads\n\
use N for no pool (runs in calling thread) recommended with rfsim.\n"
#define CONFIG_HLP_REORDER "Disable reorder thread\n"
#define CONFIG_HLP_ULMAXE "set the eNodeB max ULSCH erros\n"
#define CONFIG_HLP_CALUER "set UE RX calibration\n"
#define CONFIG_HLP_CALUERM ""
...
...
@@ -143,7 +142,6 @@ extern "C"
#define SYNC_REF softmodem_params.sync_ref
#define LDPC_OFFLOAD_FLAG softmodem_params.ldpc_offload_flag
#define REORDER_THREAD_DISABLE softmodem_params.reorder_thread_disable
#define DEFAULT_RFCONFIG_FILE "/usr/local/etc/syriq/ue.band7.tm1.PRB100.NR40.dat";
extern
int
usrp_tx_thread
;
...
...
@@ -151,7 +149,6 @@ extern int usrp_tx_thread;
#define CMDLINE_PARAMS_DESC { \
{"rf-config-file", CONFIG_HLP_RFCFGF, 0, .strptr=&RF_CONFIG_FILE, .defstrval=NULL, TYPE_STRING, 0}, \
{"thread-pool", CONFIG_HLP_TPOOL, 0, .strptr=&TP_CONFIG, .defstrval="-1,-1,-1,-1,-1,-1,-1,-1", TYPE_STRING, 0}, \
{"reorder-thread-disable",CONFIG_HLP_REORDER, PARAMFLAG_BOOL, .iptr=&REORDER_THREAD_DISABLE, .defintval=0, TYPE_INT, 0}, \
{"phy-test", CONFIG_HLP_PHYTST, PARAMFLAG_BOOL, .iptr=&PHY_TEST, .defintval=0, TYPE_INT, 0}, \
{"do-ra", CONFIG_HLP_DORA, PARAMFLAG_BOOL, .iptr=&DO_RA, .defintval=0, TYPE_INT, 0}, \
{"sa", CONFIG_HLP_SA, PARAMFLAG_BOOL, .iptr=&SA, .defintval=0, TYPE_INT, 0}, \
...
...
@@ -227,7 +224,6 @@ extern int usrp_tx_thread;
{ .s5 = { NULL } }, \
{ .s5 = { NULL } }, \
{ .s5 = { NULL } }, \
{ .s5 = { NULL } }, \
{ .s3a = { config_checkstr_assign_integer, \
{"MONOLITHIC", "PNF", "VNF","UE_STUB_PNF","UE_STUB_OFFNET","STANDALONE_PNF"}, \
{NFAPI_MONOLITHIC, NFAPI_MODE_PNF, NFAPI_MODE_VNF,NFAPI_UE_STUB_PNF,NFAPI_UE_STUB_OFFNET,NFAPI_MODE_STANDALONE_PNF}, \
...
...
@@ -321,8 +317,7 @@ typedef struct {
uint64_t
optmask
;
//THREAD_STRUCT thread_struct;
char
*
rf_config_file
;
char
*
threadPoolConfig
;
int
reorder_thread_disable
;
char
*
threadPoolConfig
;
int
phy_test
;
int
do_ra
;
int
sa
;
...
...
@@ -368,7 +363,6 @@ extern uint16_t sl_ahead;
extern
uint16_t
sf_ahead
;
extern
int
oai_exit
;
void
tx_func
(
void
*
param
);
void
rx_func
(
void
*
param
);
void
ru_tx_func
(
void
*
param
);
extern
uint8_t
nfapi_mode
;
...
...
nfapi/oai_integration/nfapi_vnf.c
View file @
9890410a
...
...
@@ -1244,7 +1244,6 @@ int phy_nr_slot_indication(nfapi_nr_slot_indication_scf_t *ind) {
int
phy_nr_srs_indication
(
nfapi_nr_srs_indication_t
*
ind
)
{
struct
PHY_VARS_gNB_s
*
gNB
=
RC
.
gNB
[
0
];
pthread_mutex_lock
(
&
gNB
->
UL_INFO_mutex
);
gNB
->
UL_INFO
.
srs_ind
=
*
ind
;
...
...
@@ -1260,8 +1259,6 @@ int phy_nr_srs_indication(nfapi_nr_srs_indication_t *ind) {
);
}
pthread_mutex_unlock
(
&
gNB
->
UL_INFO_mutex
);
return
1
;
}
//end NR phy indication
...
...
nfapi/open-nFAPI/vnf/src/vnf_p7_interface.c
View file @
9890410a
...
...
@@ -182,7 +182,6 @@ int nfapi_nr_vnf_p7_start(nfapi_vnf_p7_config_t* config)
NFAPI_TRACE
(
NFAPI_TRACE_DEBUG
,
"This is the slot_ind queue size %ld in %s():%d
\n
"
,
gnb_slot_ind_queue
.
num_items
,
__FUNCTION__
,
__LINE__
);
if
(
slot_ind
)
{
pthread_mutex_lock
(
&
gNB
->
UL_INFO_mutex
);
gNB
->
UL_INFO
.
frame
=
slot_ind
->
sfn
;
gNB
->
UL_INFO
.
slot
=
slot_ind
->
slot
;
...
...
@@ -198,7 +197,6 @@ int nfapi_nr_vnf_p7_start(nfapi_vnf_p7_config_t* config)
gNB
->
if_inst
->
NR_UL_indication
(
&
gNB
->
UL_INFO
);
prev_slot
=
gNB
->
UL_INFO
.
slot
;
}
pthread_mutex_unlock
(
&
gNB
->
UL_INFO_mutex
);
free
(
slot_ind
);
slot_ind
=
NULL
;
}
...
...
openair1/PHY/NR_TRANSPORT/nr_prach.c
View file @
9890410a
...
...
@@ -76,11 +76,11 @@ void nr_fill_prach(PHY_VARS_gNB *gNB,
nfapi_nr_prach_pdu_t
*
prach_pdu
)
{
int
prach_id
=
find_nr_prach
(
gNB
,
SFN
,
Slot
,
SEARCH_EXIST_OR_FREE
);
AssertFatal
(
((
prach_id
>=
0
)
&&
(
prach_id
<
NUMBER_OF_NR_PRACH_MAX
))
||
(
prach_id
<
0
),
"illegal or no prach_id found!!! prach_id %d
\n
"
,
prach_id
);
AssertFatal
(((
prach_id
>=
0
)
&&
(
prach_id
<
NUMBER_OF_NR_PRACH_MAX
)),
"illegal or no prach_id found!!! prach_id %d
\n
"
,
prach_id
);
gNB
->
prach_vars
.
list
[
prach_id
].
frame
=
SFN
;
gNB
->
prach_vars
.
list
[
prach_id
].
slot
=
Slot
;
LOG_D
(
NR_PHY
,
"Copying prach pdu %d bytes to index %d
\n
"
,(
int
)
sizeof
(
*
prach_pdu
),
prach_id
);
memcpy
((
void
*
)
&
gNB
->
prach_vars
.
list
[
prach_id
].
pdu
,(
void
*
)
prach_pdu
,
sizeof
(
*
prach_pdu
));
}
...
...
openair1/PHY/NR_TRANSPORT/nr_ulsch.c
View file @
9890410a
...
...
@@ -74,8 +74,8 @@ void nr_fill_ulsch(PHY_VARS_gNB *gNB, int frame, int slot, nfapi_nr_pusch_pdu_t
NR_UL_gNB_HARQ_t
*
harq
=
ulsch
->
harq_process
;
if
(
ulsch_pdu
->
pusch_data
.
new_data_indicator
)
harq
->
harq_to_be_cleared
=
true
;
LOG_D
(
PHY
,
"%d.%d RNTI %x HARQ PID %d new data indicator %d
\n
"
,
LOG_D
(
NR_
PHY
,
"
NEW ULSCH
%d.%d RNTI %x HARQ PID %d new data indicator %d
\n
"
,
frame
,
slot
,
ulsch_pdu
->
rnti
,
...
...
@@ -98,8 +98,17 @@ void reset_active_ulsch(PHY_VARS_gNB *gNB, int frame)
// assuming UE disconnected or some other error occurred
for
(
int
i
=
0
;
i
<
gNB
->
max_nb_pusch
;
i
++
)
{
NR_gNB_ULSCH_t
*
ulsch
=
&
gNB
->
ulsch
[
i
];
if
(
ulsch
->
active
&&
(((
frame
-
ulsch
->
frame
+
1024
)
%
1024
)
>
NUMBER_FRAMES_PHY_UE_INACTIVE
))
int
diff
=
(
frame
-
ulsch
->
frame
+
1024
)
&
1023
;
if
(
ulsch
->
active
&&
diff
>
NUMBER_FRAMES_PHY_UE_INACTIVE
&&
diff
<
100
)
{
ulsch
->
active
=
false
;
LOG_D
(
NR_PHY
,
"Frame %d: resetting ulsch %d harq %d (programmed in %d.%d)
\n
"
,
frame
,
i
,
ulsch
->
harq_pid
,
ulsch
->
frame
,
ulsch
->
slot
);
}
}
}
...
...
openair1/PHY/NR_TRANSPORT/nr_ulsch_demodulation.c
View file @
9890410a
...
...
@@ -1409,7 +1409,7 @@ static void nr_pusch_symbol_processing(void *arg)
if
(
gNB
->
pusch_vars
[
ulsch_id
].
ul_valid_re_per_slot
[
symbol
]
==
0
)
continue
;
int
soffset
=
(
slot
&
3
)
*
frame_parms
->
symbols_per_slot
*
frame_parms
->
ofdm_symbol_size
;
int
soffset
=
(
slot
%
RU_RX_SLOT_DEPTH
)
*
frame_parms
->
symbols_per_slot
*
frame_parms
->
ofdm_symbol_size
;
inner_rx
(
gNB
,
ulsch_id
,
slot
,
...
...
@@ -1591,7 +1591,7 @@ int nr_rx_pusch_tp(PHY_VARS_gNB *gNB,
// extract the first dmrs for the channel level computation
// extract the data in the OFDM frame, to the start of the array
int
soffset
=
(
slot
&
3
)
*
frame_parms
->
symbols_per_slot
*
frame_parms
->
ofdm_symbol_size
;
int
soffset
=
(
slot
%
RU_RX_SLOT_DEPTH
)
*
frame_parms
->
symbols_per_slot
*
frame_parms
->
ofdm_symbol_size
;
nb_re_pusch
=
(
nb_re_pusch
+
15
)
&
~
15
;
...
...
openair1/PHY/NR_TRANSPORT/pucch_rx.c
View file @
9890410a
...
...
@@ -501,7 +501,7 @@ void nr_decode_pucch1(c16_t **rxdataF,
* Implement TS 38.211 Subclause 6.3.2.4.1 Sequence modulation
*
*/
const
int
soffset
=
(
nr_tti_tx
&
3
)
*
frame_parms
->
symbols_per_slot
*
frame_parms
->
ofdm_symbol_size
;
const
int
soffset
=
(
nr_tti_tx
%
RU_RX_SLOT_DEPTH
)
*
frame_parms
->
symbols_per_slot
*
frame_parms
->
ofdm_symbol_size
;
// lprime is the index of the OFDM symbol in the slot that corresponds to the first OFDM symbol of the PUCCH transmission in the slot given by [5, TS 38.213]
const
int
lprime
=
startingSymbolIndex
;
// mcs = 0 except for PUCCH format 0
...
...
@@ -1021,14 +1021,10 @@ void nr_decode_pucch2(PHY_VARS_gNB *gNB,
//extract pucch and dmrs first
int
l2
=
pucch_pdu
->
start_symbol_index
;
int
soffset
=
(
slot
&
3
)
*
frame_parms
->
symbols_per_slot
*
frame_parms
->
ofdm_symbol_size
;
int
soffset
=
(
slot
%
RU_RX_SLOT_DEPTH
)
*
frame_parms
->
symbols_per_slot
*
frame_parms
->
ofdm_symbol_size
;
int
re_offset
[
2
];
re_offset
[
0
]
=
(
12
*
(
pucch_pdu
->
prb_start
+
pucch_pdu
->
bwp_start
)
+
frame_parms
->
first_carrier_offset
)
%
frame_parms
->
ofdm_symbol_size
;
if
(
re_offset
[
0
]
>=
frame_parms
->
ofdm_symbol_size
)
re_offset
[
0
]
-=
frame_parms
->
ofdm_symbol_size
;
if
(
pucch_pdu
->
freq_hop_flag
==
0
)
re_offset
[
1
]
=
re_offset
[
0
];
else
{
...
...
openair1/PHY/NR_TRANSPORT/srs_rx.c
View file @
9890410a
...
...
@@ -34,6 +34,7 @@
#include "PHY/impl_defs_nr.h"
#include "PHY/defs_nr_common.h"
#include "PHY/defs_gNB.h"
#include "PHY/defs_RU.h"
#include "PHY/CODING/nrSmallBlock/nr_small_block_defs.h"
#include "PHY/NR_UE_TRANSPORT/srs_modulation_nr.h"
#include "common/utils/LOG/log.h"
...
...
@@ -75,7 +76,7 @@ int nr_get_srs_signal(PHY_VARS_gNB *gNB,
c16_t
**
rxdataF
=
gNB
->
common_vars
.
rxdataF
;
const
NR_DL_FRAME_PARMS
*
frame_parms
=
&
gNB
->
frame_parms
;
const
uint16_t
n_symbols
=
(
slot
&
3
)
*
frame_parms
->
symbols_per_slot
;
// number of symbols until this slot
const
uint16_t
n_symbols
=
(
slot
%
RU_RX_SLOT_DEPTH
)
*
frame_parms
->
symbols_per_slot
;
// number of symbols until this slot
const
uint8_t
l0
=
frame_parms
->
symbols_per_slot
-
1
-
srs_pdu
->
time_start_position
;
// starting symbol in this slot
const
uint64_t
symbol_offset
=
(
n_symbols
+
l0
)
*
frame_parms
->
ofdm_symbol_size
;
const
uint64_t
subcarrier_offset
=
frame_parms
->
first_carrier_offset
+
srs_pdu
->
bwp_start
*
NR_NB_SC_PER_RB
;
...
...
openair1/PHY/defs_RU.h
View file @
9890410a
...
...
@@ -197,7 +197,7 @@ typedef struct {
#define NUMBER_OF_NR_RU_PRACH_MAX 8
#define NUMBER_OF_NR_RU_PRACH_OCCASIONS_MAX 12
#define RU_RX_SLOT_DEPTH 4
typedef
struct
RU_proc_t_s
{
/// Pointer to associated RU descriptor
struct
RU_t_s
*
ru
;
...
...
openair1/PHY/defs_gNB.h
View file @
9890410a
...
...
@@ -562,7 +562,6 @@ typedef struct PHY_VARS_gNB_s {
PHY_MEASUREMENTS_gNB
measurements
;
NR_IF_Module_t
*
if_inst
;
NR_UL_IND_t
UL_INFO
;
pthread_mutex_t
UL_INFO_mutex
;
/// NFAPI RX ULSCH information
nfapi_nr_rx_data_pdu_t
rx_pdu_list
[
MAX_UL_PDUS_PER_SLOT
];
...
...
@@ -640,8 +639,6 @@ typedef struct PHY_VARS_gNB_s {
int
ldpc_offload_flag
;
int
reorder_thread_disable
;
int
max_ldpc_iterations
;
/// indicate the channel estimation technique in time domain
int
chest_time
;
...
...
@@ -694,8 +691,8 @@ typedef struct PHY_VARS_gNB_s {
time_stats_t
rx_pusch_init_stats
;
time_stats_t
rx_pusch_symbol_processing_stats
;
time_stats_t
ul_indication_stats
;
time_stats_t
slot_indication_stats
;
time_stats_t
schedule_response_stats
;
time_stats_t
ulsch_decoding_stats
;
time_stats_t
ulsch_ldpc_decoding_stats
;
time_stats_t
ulsch_deinterleaving_stats
;
time_stats_t
ulsch_channel_estimation_stats
;
...
...
@@ -719,6 +716,7 @@ typedef struct PHY_VARS_gNB_s {
notifiedFIFO_t
L1_tx_free
;
notifiedFIFO_t
L1_tx_filled
;
notifiedFIFO_t
L1_tx_out
;
notifiedFIFO_t
L1_rx_out
;
notifiedFIFO_t
resp_RU_tx
;
tpool_t
threadPool
;
int
nbSymb
;
...
...
@@ -796,9 +794,7 @@ union ldpcReqUnion {
typedef
struct
processingData_L1
{
int
frame_rx
;
int
frame_tx
;
int
slot_rx
;
int
slot_tx
;
openair0_timestamp
timestamp_tx
;
PHY_VARS_gNB
*
gNB
;
}
processingData_L1_t
;
...
...
@@ -812,6 +808,8 @@ typedef enum {
typedef
struct
processingData_L1tx
{
int
frame
;
int
slot
;
int
frame_rx
;
int
slot_rx
;
openair0_timestamp
timestamp_tx
;
PHY_VARS_gNB
*
gNB
;
nfapi_nr_dl_tti_pdcch_pdu
pdcch_pdu
[
NFAPI_NR_MAX_NB_CORESETS
];
...
...
@@ -826,4 +824,9 @@ typedef struct processingData_L1tx {
int
sched_response_id
;
}
processingData_L1tx_t
;
typedef
struct
processingData_L1rx
{
int
frame_rx
;
int
slot_rx
;
PHY_VARS_gNB
*
gNB
;
}
processingData_L1rx_t
;
#endif
openair1/SCHED_NR/fapi_nr_l1.c
View file @
9890410a
...
...
@@ -55,7 +55,7 @@ void handle_nr_nfapi_ssb_pdu(processingData_L1tx_t *msgTx,int frame,int slot,
uint8_t
i_ssb
=
dl_tti_pdu
->
ssb_pdu
.
ssb_pdu_rel15
.
SsbBlockIndex
;
LOG_D
(
PHY
,
"%d.%d : ssb index %d pbch_pdu: %x
\n
"
,
frame
,
slot
,
i_ssb
,
dl_tti_pdu
->
ssb_pdu
.
ssb_pdu_rel15
.
bchPayload
);
LOG_D
(
NR_
PHY
,
"%d.%d : ssb index %d pbch_pdu: %x
\n
"
,
frame
,
slot
,
i_ssb
,
dl_tti_pdu
->
ssb_pdu
.
ssb_pdu_rel15
.
bchPayload
);
if
(
msgTx
->
ssb
[
i_ssb
].
active
)
AssertFatal
(
1
==
0
,
"SSB PDU with index %d already active
\n
"
,
i_ssb
);
else
{
...
...
@@ -109,7 +109,7 @@ void handle_nfapi_nr_csirs_pdu(processingData_L1tx_t *msgTx, int frame, int slot
for
(
int
id
=
0
;
id
<
NR_SYMBOLS_PER_SLOT
;
id
++
)
{
NR_gNB_CSIRS_t
*
csirs
=
&
msgTx
->
csirs_pdu
[
id
];
if
(
csirs
->
active
==
0
)
{
LOG_D
(
PHY
,
"Frame %d Slot %d CSI_RS with ID %d is now active
\n
"
,
frame
,
slot
,
id
);
LOG_D
(
NR_
PHY
,
"Frame %d Slot %d CSI_RS with ID %d is now active
\n
"
,
frame
,
slot
,
id
);
csirs
->
active
=
1
;
memcpy
((
void
*
)
&
csirs
->
csirs_pdu
,
(
void
*
)
csirs_pdu
,
sizeof
(
nfapi_nr_dl_tti_csi_rs_pdu
));
found
=
1
;
...
...
@@ -156,21 +156,9 @@ void nr_schedule_response(NR_Sched_Rsp_t *Sched_INFO)
uint8_t
number_tx_data_pdu
=
(
TX_req
==
NULL
)
?
0
:
TX_req
->
Number_of_PDUs
;
if
(
NFAPI_MODE
==
NFAPI_MONOLITHIC
){
if
(
slot_type
==
NR_DOWNLINK_SLOT
||
slot_type
==
NR_MIXED_SLOT
)
{
notifiedFIFO_elt_t
*
res
=
NULL
;
processingData_L1tx_t
*
msgTx
=
NULL
;
if
(
!
gNB
->
reorder_thread_disable
)
{
res
=
pullNotifiedFIFO
(
&
gNB
->
L1_tx_free
);
if
(
res
==
NULL
)
return
;
// Tpool has been stopped, nothing to process
msgTx
=
(
processingData_L1tx_t
*
)
NotifiedFifoData
(
res
);
}
else
{
msgTx
=
gNB
->
msgDataTx
;
//newNotifiedFIFO_elt(sizeof(processingData_L1tx_t),0, &gNB->L1_tx_out,NULL);
}
/*const time_stats_t ts = exec_time_stats_NotifiedFIFO(res);
merge_meas(&gNB->phy_proc_tx, &ts);
*/
msgTx
=
gNB
->
msgDataTx
;
msgTx
->
num_pdsch_slot
=
0
;
msgTx
->
num_dl_pdcch
=
0
;
msgTx
->
num_ul_pdcch
=
number_ul_dci_pdu
;
...
...
@@ -181,7 +169,7 @@ void nr_schedule_response(NR_Sched_Rsp_t *Sched_INFO)
for
(
int
i
=
0
;
i
<
number_dl_pdu
;
i
++
)
{
nfapi_nr_dl_tti_request_pdu_t
*
dl_tti_pdu
=
&
DL_req
->
dl_tti_request_body
.
dl_tti_pdu_list
[
i
];
LOG_D
(
PHY
,
"NFAPI: dl_pdu %d : type %d
\n
"
,
i
,
dl_tti_pdu
->
PDUType
);
LOG_D
(
NR_
PHY
,
"NFAPI: dl_pdu %d : type %d
\n
"
,
i
,
dl_tti_pdu
->
PDUType
);
switch
(
dl_tti_pdu
->
PDUType
)
{
case
NFAPI_NR_DL_TTI_SSB_PDU_TYPE
:
handle_nr_nfapi_ssb_pdu
(
msgTx
,
frame
,
slot
,
...
...
@@ -189,18 +177,18 @@ void nr_schedule_response(NR_Sched_Rsp_t *Sched_INFO)
break
;
case
NFAPI_NR_DL_TTI_PDCCH_PDU_TYPE
:
LOG_D
(
PHY
,
"frame %d, slot %d, Got NFAPI_NR_DL_TTI_PDCCH_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
DL_req
->
SFN
,
DL_req
->
Slot
);
LOG_D
(
NR_
PHY
,
"frame %d, slot %d, Got NFAPI_NR_DL_TTI_PDCCH_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
DL_req
->
SFN
,
DL_req
->
Slot
);
msgTx
->
pdcch_pdu
[
msgTx
->
num_dl_pdcch
]
=
dl_tti_pdu
->
pdcch_pdu
;
msgTx
->
num_dl_pdcch
++
;
break
;
case
NFAPI_NR_DL_TTI_CSI_RS_PDU_TYPE
:
LOG_D
(
PHY
,
"frame %d, slot %d, Got NFAPI_NR_DL_TTI_CSI_RS_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
DL_req
->
SFN
,
DL_req
->
Slot
);
LOG_D
(
NR_
PHY
,
"frame %d, slot %d, Got NFAPI_NR_DL_TTI_CSI_RS_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
DL_req
->
SFN
,
DL_req
->
Slot
);
handle_nfapi_nr_csirs_pdu
(
msgTx
,
frame
,
slot
,
&
dl_tti_pdu
->
csi_rs_pdu
);
break
;
case
NFAPI_NR_DL_TTI_PDSCH_PDU_TYPE
:
LOG_D
(
PHY
,
"frame %d, slot %d, Got NFAPI_NR_DL_TTI_PDSCH_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
DL_req
->
SFN
,
DL_req
->
Slot
);
LOG_D
(
NR_
PHY
,
"frame %d, slot %d, Got NFAPI_NR_DL_TTI_PDSCH_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
DL_req
->
SFN
,
DL_req
->
Slot
);
nfapi_nr_dl_tti_pdsch_pdu_rel15_t
*
pdsch_pdu_rel15
=
&
dl_tti_pdu
->
pdsch_pdu
.
pdsch_pdu_rel15
;
uint16_t
pduIndex
=
pdsch_pdu_rel15
->
pduIndex
;
AssertFatal
(
TX_req
->
pdu_list
[
pduIndex
].
num_TLV
==
1
,
"TX_req->pdu_list[%d].num_TLV %d != 1
\n
"
,
...
...
@@ -222,29 +210,27 @@ void nr_schedule_response(NR_Sched_Rsp_t *Sched_INFO)
* released only when both threads are done with it.
*/
inc_ref_sched_response
(
Sched_INFO
->
sched_response_id
);
if
(
!
gNB
->
reorder_thread_disable
)
pushNotifiedFIFO
(
&
gNB
->
L1_tx_filled
,
res
);
}
for
(
int
i
=
0
;
i
<
number_ul_tti_pdu
;
i
++
)
{
switch
(
UL_tti_req
->
pdus_list
[
i
].
pdu_type
)
{
case
NFAPI_NR_UL_CONFIG_PUSCH_PDU_TYPE
:
LOG_D
(
PHY
,
"frame %d, slot %d, Got NFAPI_NR_UL_TTI_PUSCH_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
);
LOG_D
(
NR_
PHY
,
"frame %d, slot %d, Got NFAPI_NR_UL_TTI_PUSCH_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
);
nr_fill_ulsch
(
gNB
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
,
&
UL_tti_req
->
pdus_list
[
i
].
pusch_pdu
);
break
;
case
NFAPI_NR_UL_CONFIG_PUCCH_PDU_TYPE
:
LOG_D
(
PHY
,
"frame %d, slot %d, Got NFAPI_NR_UL_TTI_PUCCH_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
);
LOG_D
(
NR_
PHY
,
"frame %d, slot %d, Got NFAPI_NR_UL_TTI_PUCCH_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
);
nr_fill_pucch
(
gNB
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
,
&
UL_tti_req
->
pdus_list
[
i
].
pucch_pdu
);
break
;
case
NFAPI_NR_UL_CONFIG_PRACH_PDU_TYPE
:
LOG_D
(
PHY
,
"frame %d, slot %d, Got NFAPI_NR_UL_TTI_PRACH_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
);
LOG_D
(
NR_
PHY
,
"frame %d, slot %d, Got NFAPI_NR_UL_TTI_PRACH_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
);
nfapi_nr_prach_pdu_t
*
prach_pdu
=
&
UL_tti_req
->
pdus_list
[
i
].
prach_pdu
;
nr_fill_prach
(
gNB
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
,
prach_pdu
);
if
(
gNB
->
RU_list
[
0
]
->
if_south
==
LOCAL_RF
||
gNB
->
RU_list
[
0
]
->
if_south
==
REMOTE_IF5
)
nr_fill_prach_ru
(
gNB
->
RU_list
[
0
],
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
,
prach_pdu
);
break
;
case
NFAPI_NR_UL_CONFIG_SRS_PDU_TYPE
:
LOG_D
(
PHY
,
"frame %d, slot %d, Got NFAPI_NR_UL_CONFIG_SRS_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
);
LOG_D
(
NR_
PHY
,
"frame %d, slot %d, Got NFAPI_NR_UL_CONFIG_SRS_PDU_TYPE for %d.%d
\n
"
,
frame
,
slot
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
);
nr_fill_srs
(
gNB
,
UL_tti_req
->
SFN
,
UL_tti_req
->
Slot
,
&
UL_tti_req
->
pdus_list
[
i
].
srs_pdu
);
break
;
}
...
...
@@ -267,7 +253,9 @@ void nr_schedule_response(NR_Sched_Rsp_t *Sched_INFO)
}
/* this thread is done with the sched_info, decrease the reference counter */
deref_sched_response
(
Sched_INFO
->
sched_response_id
);
if
(
slot_type
==
NR_DOWNLINK_SLOT
||
slot_type
==
NR_MIXED_SLOT
)
{
LOG_D
(
NR_PHY
,
"Calling dref_sched_response for id %d in %d.%d (sched_response)
\n
"
,
Sched_INFO
->
sched_response_id
,
frame
,
slot
);
deref_sched_response
(
Sched_INFO
->
sched_response_id
);
}
stop_meas
(
&
gNB
->
schedule_response_stats
);
}
openair1/SCHED_NR/nr_prach_procedures.c
View file @
9890410a
...
...
@@ -120,6 +120,7 @@ void L1_nr_prach_procedures(PHY_VARS_gNB *gNB,int frame,int slot) {
int
prach_id
=
find_nr_prach
(
gNB
,
frame
,
slot
,
SEARCH_EXIST
);
if
(
prach_id
>=
0
)
{
LOG_D
(
NR_PHY
,
"%d.%d Got prach entry id %d
\n
"
,
frame
,
slot
,
prach_id
);
nfapi_nr_prach_pdu_t
*
prach_pdu
=
&
gNB
->
prach_vars
.
list
[
prach_id
].
pdu
;
uint8_t
prachStartSymbol
;
uint8_t
N_dur
=
get_nr_prach_duration
(
prach_pdu
->
prach_format
);
...
...
@@ -140,9 +141,9 @@ void L1_nr_prach_procedures(PHY_VARS_gNB *gNB,int frame,int slot) {
&
max_preamble
[
0
],
&
max_preamble_energy
[
0
],
&
max_preamble_delay
[
0
]);
LOG_D
(
NR_PHY
,
"Freeing PRACH entry %d
\n
"
,
prach_id
);
free_nr_prach_entry
(
gNB
,
prach_id
);
LOG_D
(
PHY
,
"[RAPROC] Frame %d, slot %d, occasion %d (prachStartSymbol %d) : Most likely preamble %d, energy %d.%d dB delay %d (prach_energy counter %d)
\n
"
,
LOG_D
(
NR_
PHY
,
"[RAPROC] Frame %d, slot %d, occasion %d (prachStartSymbol %d) : Most likely preamble %d, energy %d.%d dB delay %d (prach_energy counter %d)
\n
"
,
frame
,
slot
,
prach_oc
,
prachStartSymbol
,
max_preamble
[
0
],
max_preamble_energy
[
0
]
/
10
,
...
...
openair1/SCHED_NR/nr_ru_procedures.c
View file @
9890410a
...
...
@@ -242,7 +242,7 @@ void nr_fep_full(RU_t *ru, int slot) {
// remove_7_5_kHz(ru,proc->tti_rx<<1);
// remove_7_5_kHz(ru,1+(proc->tti_rx<<1));
int
offset
=
(
proc
->
tti_rx
&
3
)
*
(
fp
->
symbols_per_slot
*
fp
->
ofdm_symbol_size
);
int
offset
=
(
proc
->
tti_rx
%
RU_RX_SLOT_DEPTH
)
*
(
fp
->
symbols_per_slot
*
fp
->
ofdm_symbol_size
);
for
(
l
=
0
;
l
<
fp
->
symbols_per_slot
;
l
++
)
{
for
(
aa
=
0
;
aa
<
fp
->
nb_antennas_rx
;
aa
++
)
{
nr_slot_fep_ul
(
fp
,
...
...
@@ -378,7 +378,7 @@ void nr_fep(void* arg) {
VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME
(
VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_PROCEDURES_RU_FEPRX
+
aid
,
1
);
int
offset
=
(
tti_rx
&
3
)
*
fp
->
symbols_per_slot
*
fp
->
ofdm_symbol_size
;
int
offset
=
(
tti_rx
%
RU_RX_SLOT_DEPTH
)
*
fp
->
symbols_per_slot
*
fp
->
ofdm_symbol_size
;
for
(
int
l
=
startSymbol
;
l
<=
endSymbol
;
l
++
)
nr_slot_fep_ul
(
fp
,
ru
->
common
.
rxdata
[
aid
],
...
...
openair1/SCHED_NR/phy_procedures_nr_gNB.c
View file @
9890410a
...
...
@@ -272,10 +272,11 @@ static void nr_postDecode(PHY_VARS_gNB *gNB, notifiedFIFO_elt_t *req)
}
if
(
crc_valid
&&
!
check_abort
(
&
ulsch_harq
->
abort_decode
)
&&
!
gNB
->
pusch_vars
[
rdata
->
ulsch_id
].
DTX
)
{
LOG_D
(
PHY
,
"[gNB %d] ULSCH: Setting ACK for SFN/SF %d.%d (rnti %x, pid %d, ndi %d, status %d, round %d, TBS %d, Max interation "
LOG_D
(
NR_
PHY
,
"[gNB %d] ULSCH
%d
: Setting ACK for SFN/SF %d.%d (rnti %x, pid %d, ndi %d, status %d, round %d, TBS %d, Max interation "
"(all seg) %d)
\n
"
,
gNB
->
Mod_id
,
rdata
->
ulsch_id
,
ulsch
->
frame
,
ulsch
->
slot
,
ulsch
->
rnti
,
...
...
@@ -316,7 +317,7 @@ static void nr_postDecode(PHY_VARS_gNB *gNB, notifiedFIFO_elt_t *req)
if (ulsch_harq->ulsch_pdu.mcs_index == 0 && dumpsig==1) {
int off = ((ulsch_harq->ulsch_pdu.rb_size&1) == 1)? 4:0;
LOG_M("rxsigF0.m","rxsF0",&gNB->common_vars.rxdataF[0][(ulsch_harq->slot
&3
)*gNB->frame_parms.ofdm_symbol_size*gNB->frame_parms.symbols_per_slot],gNB->frame_parms.ofdm_symbol_size*gNB->frame_parms.symbols_per_slot,1,1);
LOG_M("rxsigF0.m","rxsF0",&gNB->common_vars.rxdataF[0][(ulsch_harq->slot
%RU_RX_SLOT_DEPTH
)*gNB->frame_parms.ofdm_symbol_size*gNB->frame_parms.symbols_per_slot],gNB->frame_parms.ofdm_symbol_size*gNB->frame_parms.symbols_per_slot,1,1);
LOG_M("rxsigF0_ext.m","rxsF0_ext",
&gNB->pusch_vars[0].rxdataF_ext[0][ulsch_harq->ulsch_pdu.start_symbol_index*NR_NB_SC_PER_RB *
ulsch_harq->ulsch_pdu.rb_size],ulsch_harq->ulsch_pdu.nr_of_symbols*(off+(NR_NB_SC_PER_RB *
...
...
@@ -400,7 +401,6 @@ static int nr_ulsch_procedures(PHY_VARS_gNB *gNB, int frame_rx, int slot_rx, int
//--------------------- ULSCH decoding ---------------------
//----------------------------------------------------------
start_meas
(
&
gNB
->
ulsch_decoding_stats
);
int
nbDecode
=
nr_ulsch_decoding
(
gNB
,
ULSCH_id
,
gNB
->
pusch_vars
[
ULSCH_id
].
llr
,
frame_parms
,
pusch_pdu
,
frame_rx
,
slot_rx
,
harq_pid
,
G
);
...
...
@@ -410,9 +410,6 @@ static int nr_ulsch_procedures(PHY_VARS_gNB *gNB, int frame_rx, int slot_rx, int
void
nr_fill_indication
(
PHY_VARS_gNB
*
gNB
,
int
frame
,
int
slot_rx
,
int
ULSCH_id
,
uint8_t
harq_pid
,
uint8_t
crc_flag
,
int
dtx_flag
)
{
if
(
!
get_softmodem_params
()
->
reorder_thread_disable
)
pthread_mutex_lock
(
&
gNB
->
UL_INFO_mutex
);
NR_gNB_ULSCH_t
*
ulsch
=
&
gNB
->
ulsch
[
ULSCH_id
];
NR_UL_gNB_HARQ_t
*
harq_process
=
ulsch
->
harq_process
;
NR_gNB_PHY_STATS_t
*
stats
=
get_phy_stats
(
gNB
,
ulsch
->
rnti
);
...
...
@@ -467,7 +464,13 @@ void nr_fill_indication(PHY_VARS_gNB *gNB, int frame, int slot_rx, int ULSCH_id,
__attribute__
((
unused
))
int
off
=
((
pusch_pdu
->
rb_size
&
1
)
==
1
)
?
4
:
0
;
LOG_M
(
"rxsigF0.m"
,
"rxsF0"
,
&
gNB
->
common_vars
.
rxdataF
[
0
][(
slot_rx
&
3
)
*
gNB
->
frame_parms
.
ofdm_symbol_size
*
gNB
->
frame_parms
.
symbols_per_slot
],
gNB
->
frame_parms
.
ofdm_symbol_size
*
gNB
->
frame_parms
.
symbols_per_slot
,
1
,
1
);
LOG_M
(
"rxsigF0.m"
,
"rxsF0"
,
&
gNB
->
common_vars
.
rxdataF
[
0
][(
slot_rx
%
RU_RX_SLOT_DEPTH
)
*
gNB
->
frame_parms
.
ofdm_symbol_size
*
gNB
->
frame_parms
.
symbols_per_slot
],
gNB
->
frame_parms
.
ofdm_symbol_size
*
gNB
->
frame_parms
.
symbols_per_slot
,
1
,
1
);
LOG_M
(
"chestF0.m"
,
"chF0"
,
&
gNB
->
pusch_vars
[
0
].
ul_ch_estimates
[
0
][
pusch_pdu
->
start_symbol_index
*
gNB
->
frame_parms
.
ofdm_symbol_size
],
...
...
@@ -494,7 +497,14 @@ void nr_fill_indication(PHY_VARS_gNB *gNB, int frame, int slot_rx, int ULSCH_id,
1
,
0
);
if
(
gNB
->
frame_parms
.
nb_antennas_rx
>
1
)
{
LOG_M
(
"rxsigF1.m"
,
"rxsF1"
,
&
gNB
->
common_vars
.
rxdataF
[
1
][(
slot_rx
&
3
)
*
gNB
->
frame_parms
.
ofdm_symbol_size
*
gNB
->
frame_parms
.
symbols_per_slot
],
gNB
->
frame_parms
.
ofdm_symbol_size
*
gNB
->
frame_parms
.
symbols_per_slot
,
1
,
1
);
LOG_M
(
"rxsigF1.m"
,
"rxsF1"
,
&
gNB
->
common_vars
.
rxdataF
[
1
][(
slot_rx
%
RU_RX_SLOT_DEPTH
)
*
gNB
->
frame_parms
.
ofdm_symbol_size
*
gNB
->
frame_parms
.
symbols_per_slot
],
gNB
->
frame_parms
.
ofdm_symbol_size
*
gNB
->
frame_parms
.
symbols_per_slot
,
1
,
1
);
LOG_M
(
"chestF1.m"
,
"chF1"
,
&
gNB
->
pusch_vars
[
0
].
ul_ch_estimates
[
1
][
pusch_pdu
->
start_symbol_index
*
gNB
->
frame_parms
.
ofdm_symbol_size
],
...
...
@@ -557,9 +567,6 @@ void nr_fill_indication(PHY_VARS_gNB *gNB, int frame, int slot_rx, int ULSCH_id,
}
gNB
->
UL_INFO
.
rx_ind
.
number_of_pdus
++
;
if
(
!
get_softmodem_params
()
->
reorder_thread_disable
)
pthread_mutex_unlock
(
&
gNB
->
UL_INFO_mutex
);
}
// Function to fill UL RB mask to be used for N0 measurements
...
...
@@ -834,9 +841,9 @@ int phy_procedures_gNB_uespec_RX(PHY_VARS_gNB *gNB, int frame_rx, int slot_rx)
NR_gNB_ULSCH_t
*
ulsch
=
&
gNB
->
ulsch
[
ULSCH_id
];
NR_UL_gNB_HARQ_t
*
ulsch_harq
=
ulsch
->
harq_process
;
AssertFatal
(
ulsch_harq
!=
NULL
,
"harq_pid %d is not allocated
\n
"
,
ulsch
->
harq_pid
);
if
((
ulsch
->
active
==
true
)
&&
(
ulsch
->
frame
==
frame_rx
)
&&
(
ulsch
->
slot
==
slot_rx
)
&&
(
ulsch
->
handled
==
0
))
{
LOG_D
(
PHY
,
"PUSCH ID %d with RNTI %x detection started in frame %d slot %d
\n
"
,
ULSCH_id
,
ulsch
->
rnti
,
frame_rx
,
slot_rx
);
int
num_dmrs
=
0
;
for
(
int
s
=
0
;
s
<
NR_NUMBER_OF_SYMBOLS_PER_SLOT
;
s
++
)
num_dmrs
+=
(
ulsch_harq
->
ulsch_pdu
.
ul_dmrs_symb_pos
>>
s
)
&
1
;
...
...
@@ -941,7 +948,6 @@ int phy_procedures_gNB_uespec_RX(PHY_VARS_gNB *gNB, int frame_rx, int slot_rx)
delNotifiedFIFO_elt
(
req
);
totalDecode
--
;
}
stop_meas
(
&
gNB
->
ulsch_decoding_stats
);
for
(
int
i
=
0
;
i
<
gNB
->
max_nb_srs
;
i
++
)
{
NR_gNB_SRS_t
*
srs
=
&
gNB
->
srs
[
i
];
if
(
srs
)
{
...
...
openair1/SIMULATION/NR_PHY/dlsim.c
View file @
9890410a
...
...
@@ -895,6 +895,7 @@ int main(int argc, char **argv)
msgDataTx
->
slot
=
slot
;
msgDataTx
->
frame
=
frame
;
memset
(
msgDataTx
->
ssb
,
0
,
64
*
sizeof
(
NR_gNB_SSB_t
));
gNB
->
msgDataTx
=
msgDataTx
;
// Buffers to store internal memory of slot process
int
rx_size
=
(((
14
*
frame_parms
->
N_RB_DL
*
12
*
sizeof
(
int32_t
))
+
15
)
>>
4
)
<<
4
;
...
...
openair1/SIMULATION/NR_PHY/ulsim.c
View file @
9890410a
...
...
@@ -563,6 +563,7 @@ int main(int argc, char *argv[])
notifiedFIFO_elt_t
*
msgL1Tx
=
newNotifiedFIFO_elt
(
sizeof
(
processingData_L1tx_t
),
0
,
&
gNB
->
L1_tx_free
,
NULL
);
processingData_L1tx_t
*
msgDataTx
=
(
processingData_L1tx_t
*
)
NotifiedFifoData
(
msgL1Tx
);
msgDataTx
->
slot
=
-
1
;
gNB
->
msgDataTx
=
msgDataTx
;
//gNB_config = &gNB->gNB_config;
//memset((void *)&gNB->UL_INFO,0,sizeof(gNB->UL_INFO));
...
...
@@ -921,7 +922,6 @@ int main(int argc, char *argv[])
reset_meas
(
&
gNB
->
rx_pusch_stats
);
reset_meas
(
&
gNB
->
rx_pusch_init_stats
);
reset_meas
(
&
gNB
->
rx_pusch_symbol_processing_stats
);
reset_meas
(
&
gNB
->
ulsch_decoding_stats
);
reset_meas
(
&
gNB
->
ulsch_channel_estimation_stats
);
reset_meas
(
&
UE
->
ulsch_ldpc_encoding_stats
);
reset_meas
(
&
UE
->
ulsch_rate_matching_stats
);
...
...
@@ -1546,7 +1546,6 @@ int main(int argc, char *argv[])
printStatIndent2
(
&
gNB
->
ulsch_channel_estimation_stats
,
"ULSCH channel estimation time"
);
printStatIndent2
(
&
gNB
->
rx_pusch_init_stats
,
"RX PUSCH Initialization time"
);
printStatIndent2
(
&
gNB
->
rx_pusch_symbol_processing_stats
,
"RX PUSCH Symbol Processing time"
);
printStatIndent
(
&
gNB
->
ulsch_decoding_stats
,
"ULSCH total decoding time"
);
printf
(
"
\n
UE TX
\n
"
);
printStatIndent
(
&
UE
->
ulsch_encoding_stats
,
"ULSCH total encoding time"
);
...
...
openair2/NR_PHY_INTERFACE/NR_IF_Module.c
View file @
9890410a
...
...
@@ -385,12 +385,49 @@ static void match_crc_rx_pdu(nfapi_nr_rx_data_indication_t *rx_ind, nfapi_nr_crc
}
}
static
void
run_scheduler
(
module_id_t
module_id
,
int
CC_id
,
int
frame
,
int
slot
)
{
NR_IF_Module_t
*
ifi
=
nr_if_inst
[
module_id
];
// gNB_MAC_INST *mac = RC.nrmac[module_id];
NR_Sched_Rsp_t
*
sched_info
;
LOG_D
(
NR_MAC
,
"Calling scheduler for %d.%d
\n
"
,
frame
,
slot
);
sched_info
=
allocate_sched_response
();
// clear UL DCI prior to handling ULSCH
sched_info
->
UL_dci_req
.
numPdus
=
0
;
gNB_dlsch_ulsch_scheduler
(
module_id
,
frame
,
slot
,
sched_info
);
ifi
->
CC_mask
=
0
;
sched_info
->
module_id
=
module_id
;
sched_info
->
CC_id
=
CC_id
;
sched_info
->
frame
=
frame
;
sched_info
->
slot
=
slot
;
/*
sched_info->DL_req = &mac->DL_req[CC_id];
sched_info->UL_dci_req = &mac->UL_dci_req[CC_id];
sched_info->UL_tti_req = mac->UL_tti_req[CC_id];
sched_info->TX_req = &mac->TX_req[CC_id];
*/
#ifdef DUMP_FAPI
dump_dl
(
sched_info
);
#endif
AssertFatal
(
ifi
->
NR_Schedule_response
!=
NULL
,
"nr_schedule_response is null (mod %d, cc %d)
\n
"
,
module_id
,
CC_id
);
ifi
->
NR_Schedule_response
(
sched_info
);
LOG_D
(
NR_PHY
,
"NR_Schedule_response: SFN SLOT:%d %d dl_pdus:%d
\n
"
,
sched_info
->
frame
,
sched_info
->
slot
,
sched_info
->
DL_req
.
dl_tti_request_body
.
nPDUs
);
}
void
NR_UL_indication
(
NR_UL_IND_t
*
UL_info
)
{
AssertFatal
(
UL_info
!=
NULL
,
"UL_info is null
\n
"
);
module_id_t
module_id
=
UL_info
->
module_id
;
int
CC_id
=
UL_info
->
CC_id
;
NR_Sched_Rsp_t
*
sched_info
;
NR_IF_Module_t
*
ifi
=
nr_if_inst
[
module_id
];
module_id_t
module_id
=
UL_info
->
module_id
;
int
CC_id
=
UL_info
->
CC_id
;
LOG_D
(
NR_PHY
,
"SFN/SLOT:%d.%d module_id:%d CC_id:%d UL_info[rach_pdus:%zu rx_ind:%zu crcs:%zu]
\n
"
,
UL_info
->
frame
,
UL_info
->
slot
,
...
...
@@ -449,57 +486,6 @@ void NR_UL_indication(NR_UL_IND_t *UL_info) {
if
(
get_softmodem_params
()
->
emulate_l1
)
{
free_unqueued_nfapi_indications
(
rach_ind
,
uci_ind
,
rx_ind
,
crc_ind
);
}
if
(
NFAPI_MODE
!=
NFAPI_MODE_PNF
)
{
gNB_MAC_INST
*
mac
=
RC
.
nrmac
[
module_id
];
if
(
ifi
->
CC_mask
==
0
)
{
ifi
->
current_frame
=
UL_info
->
frame
;
ifi
->
current_slot
=
UL_info
->
slot
;
}
else
{
AssertFatal
(
UL_info
->
frame
!=
ifi
->
current_frame
,
"CC_mask %x is not full and frame has changed
\n
"
,
ifi
->
CC_mask
);
AssertFatal
(
UL_info
->
slot
!=
ifi
->
current_slot
,
"CC_mask %x is not full and slot has changed
\n
"
,
ifi
->
CC_mask
);
}
ifi
->
CC_mask
|=
(
1
<<
CC_id
);
if
(
ifi
->
CC_mask
==
((
1
<<
MAX_NUM_CCs
)
-
1
))
{
/*
eNB_dlsch_ulsch_scheduler(module_id,
(UL_info->frame+((UL_info->slot>(9-sl_ahead))?1:0)) % 1024,
(UL_info->slot+sl_ahead)%10);
*/
nfapi_nr_config_request_scf_t
*
cfg
=
&
mac
->
config
[
CC_id
];
int
spf
=
get_spf
(
cfg
);
sched_info
=
allocate_sched_response
();
// clear UL DCI prior to handling ULSCH
sched_info
->
UL_dci_req
.
numPdus
=
0
;
gNB_dlsch_ulsch_scheduler
(
module_id
,
(
UL_info
->
frame
+
((
UL_info
->
slot
>
(
spf
-
1
-
ifi
->
sl_ahead
))
?
1
:
0
))
%
1024
,
(
UL_info
->
slot
+
ifi
->
sl_ahead
)
%
spf
,
sched_info
);
ifi
->
CC_mask
=
0
;
sched_info
->
module_id
=
module_id
;
sched_info
->
CC_id
=
CC_id
;
sched_info
->
frame
=
(
UL_info
->
frame
+
((
UL_info
->
slot
>
(
spf
-
1
-
ifi
->
sl_ahead
))
?
1
:
0
))
%
1024
;
sched_info
->
slot
=
(
UL_info
->
slot
+
ifi
->
sl_ahead
)
%
spf
;
#ifdef DUMP_FAPI
dump_dl
(
sched_info
);
#endif
AssertFatal
(
ifi
->
NR_Schedule_response
!=
NULL
,
"nr_schedule_response is null (mod %d, cc %d)
\n
"
,
module_id
,
CC_id
);
ifi
->
NR_Schedule_response
(
sched_info
);
LOG_D
(
NR_PHY
,
"NR_Schedule_response: SFN SLOT:%d %d dl_pdus:%d
\n
"
,
sched_info
->
frame
,
sched_info
->
slot
,
sched_info
->
DL_req
.
dl_tti_request_body
.
nPDUs
);
}
}
}
NR_IF_Module_t
*
NR_IF_Module_init
(
int
Mod_id
)
{
...
...
@@ -514,6 +500,7 @@ NR_IF_Module_t *NR_IF_Module_init(int Mod_id) {
nr_if_inst
[
Mod_id
]
->
CC_mask
=
0
;
nr_if_inst
[
Mod_id
]
->
NR_UL_indication
=
NR_UL_indication
;
nr_if_inst
[
Mod_id
]
->
NR_slot_indication
=
run_scheduler
;
AssertFatal
(
pthread_mutex_init
(
&
nr_if_inst
[
Mod_id
]
->
if_mutex
,
NULL
)
==
0
,
"allocation of nr_if_inst[%d]->if_mutex fails
\n
"
,
Mod_id
);
}
...
...
openair2/NR_PHY_INTERFACE/NR_IF_Module.h
View file @
9890410a
...
...
@@ -113,6 +113,7 @@ typedef struct NR_IF_Module_s {
//define the function pointer
void
(
*
NR_UL_indication
)(
NR_UL_IND_t
*
UL_INFO
);
void
(
*
NR_Schedule_response
)(
NR_Sched_Rsp_t
*
Sched_INFO
);
void
(
*
NR_slot_indication
)(
module_id_t
module_idP
,
int
CC_id
,
int
frame
,
int
slot
);
void
(
*
NR_PHY_config_req
)(
NR_PHY_Config_t
*
config_INFO
);
uint32_t
CC_mask
;
uint16_t
current_frame
;
...
...
openair2/NR_PHY_INTERFACE/nr_sched_response.c
View file @
9890410a
...
...
@@ -105,6 +105,7 @@ NR_Sched_Rsp_t *allocate_sched_response(void)
static
void
release_sched_response
(
int
sched_response_id
)
{
LOG_D
(
NR_MAC
,
"Releasing sched_response %d
\n
"
,
sched_response_id
);
resp_freelist_next
[
sched_response_id
]
=
resp_freelist_head
;
resp_freelist_head
=
sched_response_id
;
}
...
...
@@ -124,6 +125,7 @@ void deref_sched_response(int sched_response_id)
AssertFatal
(
resp_freelist_inited
,
"sched_response used before init
\n
"
);
AssertFatal
(
resp_refcount
[
sched_response_id
]
>
0
,
"sched_reponse decreased too much
\n
"
);
LOG_D
(
NR_MAC
,
"resp_refcount[%d] %d
\n
"
,
sched_response_id
,
resp_refcount
[
sched_response_id
]);
resp_refcount
[
sched_response_id
]
--
;
if
(
resp_refcount
[
sched_response_id
]
==
0
)
release_sched_response
(
sched_response_id
);
...
...
@@ -141,6 +143,8 @@ void inc_ref_sched_response(int sched_response_id)
if
(
sched_response_id
==
-
1
)
return
;
LOG_D
(
NR_MAC
,
"Incrementing sched_resp resp_refounct[%d] = %d
\n
"
,
sched_response_id
,
resp_refcount
[
sched_response_id
]);
if
(
pthread_mutex_lock
(
&
resp_mutex
))
AssertFatal
(
0
,
"pthread_mutex_lock failed
\n
"
);
...
...
radio/ETHERNET/eth_udp.c
View file @
9890410a
...
...
@@ -337,7 +337,7 @@ void *trx_eth_write_udp_cmd(udpTXelem_t *udpTXelem) {
TS
-=
device
->
txrx_offset
;
int
TSinc
=
(
6
*
256
*
device
->
sampling_rate_ratio_d
)
/
device
->
sampling_rate_ratio_n
;
int
len
=
256
;
LOG_D
(
PHY
,
"
TS %llu (%llu),txrx_offset %d,d %d, n %d, buff[0] %p buff[1] %p
\n
"
,
LOG_D
(
NR_PHY
,
"in eth send:
TS %llu (%llu),txrx_offset %d,d %d, n %d, buff[0] %p buff[1] %p
\n
"
,
(
unsigned
long
long
)
TS
,(
unsigned
long
long
)
timestamp
,
device
->
txrx_offset
,
device
->
sampling_rate_ratio_d
,
device
->
sampling_rate_ratio_n
,
buff
[
0
],
buff
[
1
]);
for
(
int
offset
=
0
;
offset
<
nsamps
;
offset
+=
256
,
TS
+=
TSinc
)
{
...
...
@@ -349,7 +349,7 @@ void *trx_eth_write_udp_cmd(udpTXelem_t *udpTXelem) {
*
(
uint8_t
*
)(
buff2
+
2
)
=
len
>>
8
;
*
(
uint8_t
*
)(
buff2
+
3
)
=
len
&
0xff
;
for
(
int
aid
=
0
;
aid
<
nant
;
aid
++
)
{
LOG_D
(
PHY
,
"TS %llu (TS0 %llu) aa %d : offset %d, len %d
\n
"
,(
unsigned
long
long
)
TS
,(
unsigned
long
long
)
fhstate
->
TS0
,
aid
,
offset
,
len
);
LOG_D
(
NR_
PHY
,
"TS %llu (TS0 %llu) aa %d : offset %d, len %d
\n
"
,(
unsigned
long
long
)
TS
,(
unsigned
long
long
)
fhstate
->
TS0
,
aid
,
offset
,
len
);
// ECPRI PC_ID (2 bytes)
*
(
uint16_t
*
)(
buff2
+
4
)
=
aid
;
// bring TX data into 12 MSBs
...
...
@@ -383,6 +383,7 @@ void *trx_eth_write_udp_cmd(udpTXelem_t *udpTXelem) {
}
// aid
}
// offset
free
(
buff
);
LOG_D
(
NR_PHY
,
"Returning from eth send
\n
"
);
return
(
NULL
);
}
...
...
targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band41.fr1.106PRB.usrpb210.conf
View file @
9890410a
...
...
@@ -11,7 +11,7 @@ gNBs =
//
Tracking
area
code
,
0
x0000
and
0
xfffe
are
reserved
values
tracking_area_code
=
1
;
plmn_list
= ({
mcc
=
208
;
mnc
=
9
9
;
mnc_length
=
2
;
snssaiList
= ({
sst
=
1
}) });
plmn_list
= ({
mcc
=
208
;
mnc
=
9
8
;
mnc_length
=
2
;
snssaiList
= ({
sst
=
1
}) });
nr_cellid
=
12345678
L
;
...
...
@@ -136,10 +136,10 @@ gNBs =
# pattern1
# dl_UL_TransmissionPeriodicity
# 0=ms0p5, 1=ms0p625, 2=ms1, 3=ms1p25, 4=ms2, 5=ms2p5, 6=ms5, 7=ms10
dl_UL_TransmissionPeriodicity
=
6
;
nrofDownlinkSlots
=
7
;
dl_UL_TransmissionPeriodicity
=
5
;
nrofDownlinkSlots
=
3
;
nrofDownlinkSymbols
=
6
;
nrofUplinkSlots
=
2
;
nrofUplinkSlots
=
1
;
nrofUplinkSymbols
=
4
;
ssPBCH_BlockPower
= -
25
;
...
...
@@ -168,9 +168,9 @@ gNBs =
NETWORK_INTERFACES
:
{
GNB_INTERFACE_NAME_FOR_NG_AMF
=
"
demo-oai
"
;
GNB_INTERFACE_NAME_FOR_NG_AMF
=
"
internet
"
;
GNB_IPV4_ADDRESS_FOR_NG_AMF
=
"192.168.70.129/24"
;
GNB_INTERFACE_NAME_FOR_NGU
=
"
demo-oai
"
;
GNB_INTERFACE_NAME_FOR_NGU
=
"
internet
"
;
GNB_IPV4_ADDRESS_FOR_NGU
=
"192.168.70.129/24"
;
GNB_PORT_FOR_S1U
=
2152
;
# Spec 2152
};
...
...
@@ -186,6 +186,10 @@ MACRLCs = (
pusch_TargetSNRx10
=
150
;
pucch_TargetSNRx10
=
200
;
ulsch_max_frame_inactivity
=
0
;
ul_max_mcs
=
10
;
min_grant_prb
=
20
;
min_grant_mcs
=
16
;
dl_max_mcs
=
10
;
}
);
...
...
@@ -204,8 +208,8 @@ RUs = (
local_rf
=
"yes"
nb_tx
=
1
nb_rx
=
1
att_tx
=
6
;
att_rx
=
6
;
att_tx
=
0
;
att_rx
=
0
;
bands
= [
41
];
max_pdschReferenceSignalPower
= -
27
;
max_rxgain
=
114
;
...
...
@@ -213,6 +217,7 @@ RUs = (
#beamforming 1x4 matrix:
bf_weights
= [
0
x00007fff
,
0
x0000
,
0
x0000
,
0
x0000
];
clock_src
=
"internal"
;
sl_ahead
=
2
;
}
);
...
...
targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band77.273prb.fhi72.4x4-vvdn.conf
View file @
9890410a
...
...
@@ -217,7 +217,7 @@ L1s = (
#thread_pool_size = 8;
tx_amp_backoff_dB
=
3
;
L1_rx_thread_core
=
8
;
L1_tx_thread_core
=
10
;
# relevant after merge of l1_tx_thread
L1_tx_thread_core
=
10
;
phase_compensation
=
0
;
# needs to match O-RU configuration
}
);
...
...
targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.273prb.fhi72.4x2-benetel650.conf
View file @
9890410a
...
...
@@ -214,7 +214,7 @@ L1s = (
max_ldpc_iterations
=
10
;
tx_amp_backoff_dB
=
20
;
# needs to match O-RU configuration
L1_rx_thread_core
=
8
;
L1_tx_thread_core
=
10
;
# relevant after merge of l1_tx_thread
L1_tx_thread_core
=
10
;
phase_compensation
=
0
;
# needs to match O-RU configuration
}
);
...
...
targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.273prb.fhi72.4x4-liteon.conf
View file @
9890410a
...
...
@@ -215,7 +215,7 @@ L1s = (
max_ldpc_iterations
=
10
;
tx_amp_backoff_dB
=
20
;
# needs to match O-RU configuration
L1_rx_thread_core
=
8
;
L1_tx_thread_core
=
10
;
# relevant after merge of l1_tx_thread
L1_tx_thread_core
=
10
;
phase_compensation
=
1
;
# needs to match O-RU configuration
}
);
...
...
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