Skip to content

Latest commit

 

History

History
256 lines (198 loc) · 11.2 KB

NR_SA_Tutorial_OAI_nrUE.md

File metadata and controls

256 lines (198 loc) · 11.2 KB
OAI 5G NR SA tutorial with OAI nrUE

Table of Contents

[[TOC]]

1. Scenario

In this tutorial we describe how to configure and run a 5G end-to-end setup with OAI CN5G, OAI gNB and OAI nrUE.

Minimum hardware requirements:

  • Laptop/Desktop/Server for OAI CN5G and OAI gNB
  • Laptop for UE
  • USRP B210, USRP N300 or USRP X300
    • Please identify the network interface(s) on which the USRP is connected and update the gNB configuration file

2. OAI CN5G

2.1 OAI CN5G pre-requisites

Please install and configure OAI CN5G as described here: OAI CN5G

3. OAI gNB and OAI nrUE

3.1 OAI gNB and OAI nrUE pre-requisites

Build UHD from source

# https://files.ettus.com/manual/page_build_guide.html
sudo apt install -y autoconf automake build-essential ccache cmake cpufrequtils doxygen ethtool g++ git inetutils-tools libboost-all-dev libncurses-dev libusb-1.0-0 libusb-1.0-0-dev libusb-dev python3-dev python3-mako python3-numpy python3-requests python3-scipy python3-setuptools python3-ruamel.yaml

git clone https://github.com/EttusResearch/uhd.git ~/uhd
cd ~/uhd
git checkout v4.7.0.0
cd host
mkdir build
cd build
cmake ../
make -j $(nproc)
make test # This step is optional
sudo make install
sudo ldconfig
sudo uhd_images_downloader

3.2 Build OAI gNB and OAI nrUE

# Get openairinterface5g source code
git clone https://gitlab.eurecom.fr/oai/openairinterface5g.git ~/openairinterface5g
cd ~/openairinterface5g
git checkout develop

# Install OAI dependencies
cd ~/openairinterface5g/cmake_targets
./build_oai -I

# nrscope dependencies
sudo apt install -y libforms-dev libforms-bin

# Build OAI gNB
cd ~/openairinterface5g/cmake_targets
./build_oai -w USRP --ninja --nrUE --gNB --build-lib "nrscope" -C

4. Run OAI CN5G and OAI gNB

4.1 Run OAI CN5G

cd ~/oai-cn5g
docker compose up -d

4.2 Run OAI gNB

Note: From tag 2024.w45, OAI gNB runs by default in standalone (SA) mode.
In earlier versions the default mode was non-standalone (NSA).
If you are using an earlier version than 2024.w45, you should add the --sa argument to the sample commands below to obtain a correct behavior.

USRP B210

cd ~/openairinterface5g/cmake_targets/ran_build/build
sudo ./nr-softmodem -O ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.fr1.106PRB.usrpb210.conf --gNBs.[0].min_rxtxtime 6 -E --continuous-tx

USRP N300

cd ~/openairinterface5g/cmake_targets/ran_build/build
sudo ./nr-softmodem -O ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band77.fr1.273PRB.2x2.usrpn300.conf --gNBs.[0].min_rxtxtime 6 --usrp-tx-thread-config 1

USRP X300

cd ~/openairinterface5g/cmake_targets/ran_build/build
sudo ./nr-softmodem -O ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band77.fr1.273PRB.2x2.usrpn300.conf --gNBs.[0].min_rxtxtime 6 --usrp-tx-thread-config 1 -E --continuous-tx

RFsimulator

cd ~/openairinterface5g/cmake_targets/ran_build/build
sudo ./nr-softmodem -O ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.fr1.106PRB.usrpb210.conf --gNBs.[0].min_rxtxtime 6 --rfsim

RFsimulator in FR2

cd ~/openairinterface5g/cmake_targets/ran_build/build
sudo ./nr-softmodem -O ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band257.u3.32prb.usrpx410.conf --rfsim

5. OAI UE

5.1 Run OAI nrUE

Note: From tag 2024.w45, OAI nrUE runs by default in standalone (SA) mode.
In earlier versions the default mode was non-standalone (NSA).
If you are using an earlier version than 2024.w45, you should add the --sa argument to the sample commands below to obtain a correct behavior.

USRP B210

Important notes:

  • This should be run in a second Ubuntu 22.04 host, other than gNB
  • It only applies when running OAI gNB with USRP B210

Run OAI nrUE with USRP B210

cd ~/openairinterface5g/cmake_targets/ran_build/build
sudo ./nr-uesoftmodem -r 106 --numerology 1 --band 78 -C 3619200000 --ue-fo-compensation -E --uicc0.imsi 001010000000001

RFsimulator

Important notes:

  • This should be run on the same host as the OAI gNB
  • It only applies when running OAI gNB with RFsimulator

Run OAI nrUE with RFsimulator

cd ~/openairinterface5g/cmake_targets/ran_build/build
sudo ./nr-uesoftmodem -r 106 --numerology 1 --band 78 -C 3619200000 --uicc0.imsi 001010000000001 --rfsim

RFsimulator in FR2

Important notes:

  • This should be run on the same host as the OAI gNB
  • It only applies when running OAI gNB with RFsimulator in FR2

Run OAI nrUE with RFsimulator in FR2

cd ~/openairinterface5g/cmake_targets/ran_build/build
sudo ./nr-uesoftmodem -r 32 --numerology 3 --band 257 -C 27533280000 --uicc0.imsi 001010000000001 --ssb 72 --rfsim

Connection to an NG-Core

A configuration file can be fed to the nrUE command line in order to connect to the local NGC.

The nrUE configuration file (e.g. ue.conf) is structured in a key-value format and contains the relevant UICC parameters that are necessary to authenticate the UE to the local 5GC. E.g.:

uicc0 = {
  imsi = "001010000000001";
  key = "fec86ba6eb707ed08905757b1bb44b8f";
  opc = "C42449363BBAD02B66D16BC975D77CC1";
  dnn = "oai";
  nssai_sst = 1;
}
Parameter Description Default Value
IMSI Unique identifier for the UE within the mobile network. Used by the network to identify the UE during authentication. It ensures that the UE is correctly identified by the network. 001010000000001
key Cryptographic key shared between the UE and the network, used for encryption during the authentication process. fec86ba6eb707ed08905757b1bb44b8f
OPC Operator key for the Milenage Authentication and Key Agreement algorithm used for encryption during the authentication process. Ensures secure communication between the UE and the network by matching the encryption keys.
DNN Specifies the name of the data network the UE wishes to connect to, similar to an APN in 4G networks. oai
NSSAI Allows the UE to select the appropriate network slice, which provides different QoS. 1

The UE configuration must match the one of the network's AMF. The nrUE can connect by default to OAI CN5G with no need to provide the configuration file.

When running the nr-uesoftmodem, one can specify the nrUE configuration file using the -O option. E.g.:

sudo ./nr-uesoftmodem --rfsim --rfsimulator.serveraddr 127.0.0.1 -r 106 --numerology 1 --band 78 -C 3619200000 -O ~/nrue.uicc.conf

The CL option --uicc0.imsi can override the IMSI value in the configuration file if necessary (e.g. when running multiple UEs): --uicc0.imsi 001010000000001.

More details available at ci-scripts/yaml_files/5g_rfsimulator/README.md.

Note: From tag 2024.w45, OAI nrUE runs by default in standalone (SA) mode.
In earlier versions the default mode was non-standalone (NSA).
If you are using an earlier version than 2024.w45, you should add the --sa argument to the sample commands above to obtain a correct behavior.

5.2 End-to-end connectivity test

  • Ping test from the UE host to the CN5G
ping 192.168.70.135 -I oaitun_ue1

6. Advanced configurations (optional)

6.1 USRP N300 and X300 Ethernet Tuning

Please also refer to the official USRP Host Performance Tuning Tips and Tricks tuning guide.

The following steps are recommended. Please change the network interface(s) as required. Also, you should have 10Gbps interface(s): if you use two cables, you should have the XG firmware. Refer to the N300 Getting Started Guide for more information.

  • Use an MTU of 9000: how to change this depends on the network management tool. In the case of Network Manager, this can be done from the GUI.
  • Increase the kernel socket buffer (also done by the USRP driver in OAI)
  • Increase Ethernet Ring Buffers: sudo ethtool -G <ifname> rx 4096 tx 4096
  • Disable hyper-threading in the BIOS (This step is optional)
  • Optional: Disable KPTI Protections for Spectre/Meltdown for more performance. This is a security risk. Add mitigations=off nosmt in your grub config and update grub. (This step is optional)

Example code to run:

for ((i=0;i<$(nproc);i++)); do sudo cpufreq-set -c $i -r -g performance; done
sudo sysctl -w net.core.wmem_max=62500000
sudo sysctl -w net.core.rmem_max=62500000
sudo sysctl -w net.core.wmem_default=62500000
sudo sysctl -w net.core.rmem_default=62500000
sudo ethtool -G enp1s0f0 tx 4096 rx 4096

6.2 Real-time performance workarounds

  • Enable Performance Mode sudo cpupower idle-set -D 0
  • If you get real-time problems on heavy UL traffic, reduce the maximum UL MCS using an additional command-line switch: --MACRLCs.[0].ul_max_mcs 14.
  • You can also reduce the number of LDPC decoder iterations, which will make the LDPC decoder take less time: --L1s.[0].max_ldpc_iterations 4.

6.3 Uplink issues related with noise on the DC carriers

  • There is noise on the DC carriers on N300 and especially the X300 in UL. To avoid their use or shift them away from the center to use more UL spectrum, use the --tune-offset <Hz> command line switch, where <Hz> is ideally half the bandwidth, or possibly less.

6.4 Timing-related Problems

  • Sometimes, the nrUE would keep repeating RA procedure because of Msg3 failure at the gNB. If it happens, add the -A option at the nrUE and/or gNB side, e.g., -A 45. This modifies the timing advance (in samples). Adjust +/-5 if the issue persists.
  • This can be necessary since certain USRPs have larger signal delays than others; it is therefore specific to the used USRP model.
  • The x310 and B210 are found to work with the default configuration; N310 and x410 can benefit from setting this timing advance.
  • For example if the OAI UE uses the X410 and the gNB based on Nvidia Aerial and Foxconn a timing advance of 90 has been found to work well.

6.5 Lower latency on user plane

  • To lower latency on the user plane, you can force the UE to be scheduled constantly in uplink: --MACRLCs.[0].ulsch_max_frame_inactivity 0 .