From 0719f0fa5a169537fa1b73da4d6d3b6f3fc97e40 Mon Sep 17 00:00:00 2001 From: Litao Gao Date: Tue, 11 Jan 2022 10:00:54 -0500 Subject: [PATCH] Add documentation of Deploy FlexRAN 21.11 on StarlingX - Add doc of FlexRAN 21.11 build, deploy and run on StarlingX - Some minor change in doc of FlexRAN 21.07 Story: 2009750 Task: 44264 Change-Id: I6734eb59a23c5819dc4d9ed7327e2cb789cb24aa Signed-off-by: Litao Gao --- ...lexran-2107-on-starlingx-c4efa00b1b98.rst} | 38 +- ...flexran-2111-on-starlingx-ca139fa4e285.rst | 915 ++++++++++++++++++ doc/source/sample_apps/flexran/index.rst | 16 + doc/source/sample_apps/index.rst | 4 +- 4 files changed, 952 insertions(+), 21 deletions(-) rename doc/source/sample_apps/{deploy-flexran-on-starlingx-c4efa00b1b98.rst => flexran/deploy-flexran-2107-on-starlingx-c4efa00b1b98.rst} (96%) create mode 100644 doc/source/sample_apps/flexran/deploy-flexran-2111-on-starlingx-ca139fa4e285.rst create mode 100644 doc/source/sample_apps/flexran/index.rst diff --git a/doc/source/sample_apps/deploy-flexran-on-starlingx-c4efa00b1b98.rst b/doc/source/sample_apps/flexran/deploy-flexran-2107-on-starlingx-c4efa00b1b98.rst similarity index 96% rename from doc/source/sample_apps/deploy-flexran-on-starlingx-c4efa00b1b98.rst rename to doc/source/sample_apps/flexran/deploy-flexran-2107-on-starlingx-c4efa00b1b98.rst index 654df1ff0..b26c5f5e7 100644 --- a/doc/source/sample_apps/deploy-flexran-on-starlingx-c4efa00b1b98.rst +++ b/doc/source/sample_apps/flexran/deploy-flexran-2107-on-starlingx-c4efa00b1b98.rst @@ -1,8 +1,8 @@ -.. _deploy-flexran-on-starlingx-c4efa00b1b98: +.. _deploy-flexran-2107-on-starlingx-c4efa00b1b98: -=========================== -Deploy FlexRAN on StarlingX -=========================== +================================= +Deploy FlexRAN 21.07 on StarlingX +================================= .. contents:: :local: @@ -74,15 +74,15 @@ following hardware for FlexRAN applications. +---------------------------+--------------------------------------------------------------------------------+ | Minimum network ports | OAM: 1x1GE, If only test timer mode, no other NIC required. | +---------------------------+--------------------------------------------------------------------------------+ -| BIOS settings | - Hyper-Threading technology: enabled; | -| | - Virtualization technology: enabled; | -| | - VT for directed I/O: enabled; | -| | - CPU power and performance policy set to performance; | -| | - CPU C state control: enabled; | -| | - Plug & play BMC detection: disabled; | -| | - Uncore Frequency Scaling : Disabled; | -| | - Performance P-limit : Disabled; | -| | - Enhanced Intel SpeedStep (R) Tech : Enabled; | +| BIOS settings | - Hyper-Threading technology : Enabled | +| | - Virtualization technology : Enabled | +| | - VT for directed I/O : Enabled | +| | - CPU Power and Performance Policy : Performance | +| | - CPU C state control : Enabled | +| | - Plug & play BMC detection : Disabled | +| | - Uncore Frequency Scaling : Disabled | +| | - Performance P-limit : Disabled | +| | - Enhanced Intel SpeedStep (R) Tech : Enabled | | | - Intel(R) Turbo Boost Technology : Enabled | +---------------------------+--------------------------------------------------------------------------------+ | Accelerator Card | Mt. Bryce ACC100 (Intel eASIC chip which can be mounted on third party card) | @@ -344,7 +344,7 @@ The following steps provide a quick-start procedure for developers. flxr_install_dir=/opt/flexran/ # populate flexran related env var - cd ${lxr_install_dir} + cd ${flxr_install_dir} source set_env_var.sh -d # prepare the FlexRAN binaries @@ -563,14 +563,14 @@ Build FlexRAN in Pod .. code:: bash mkdir -p /opt/scrach && cd /opt/scrach - scp flexran-21.07.tar.gz.part00 . - scp flexran-21.07.tar.gz.part01 . + scp FlexRAN-21.07.tar.gz.part00 . + scp FlexRAN-21.07.tar.gz.part01 . scp dpdk_21.07.patch . scp system_studio_2019_update_5_ultimate_edition.tar.gz . - cat flexran-21.07.tar.gz.part00 flexran-21.07.tar.gz.part01 > flexran-21.07.tar.gz - rm flexran-21.07.tar.gz.part00 - rm flexran-21.07.tar.gz.part01 + cat FlexRAN-21.07.tar.gz.part00 FlexRAN-21.07.tar.gz.part01 > FlexRAN-21.07.tar.gz + rm FlexRAN-21.07.tar.gz.part00 + rm FlexRAN-21.07.tar.gz.part01 #. Copy |DPDK| source code into the pod's |PVC|: diff --git a/doc/source/sample_apps/flexran/deploy-flexran-2111-on-starlingx-ca139fa4e285.rst b/doc/source/sample_apps/flexran/deploy-flexran-2111-on-starlingx-ca139fa4e285.rst new file mode 100644 index 000000000..dc821821d --- /dev/null +++ b/doc/source/sample_apps/flexran/deploy-flexran-2111-on-starlingx-ca139fa4e285.rst @@ -0,0 +1,915 @@ +.. _deploy-flexran-2111-on-starlingx-ca139fa4e285: + +================================= +Deploy FlexRAN 21.11 on StarlingX +================================= + +.. contents:: + :local: + :depth: 1 + +----- +Scope +----- + +`FlexRAN `__ +is a vRAN reference implementation for virtualized cloud-enabled radio access +networks. FlexRAN is not an open-source project. It is provided here as an +example of a 5G application running on |prod|. + +This document provides details on how to build FlexRAN software for |prod|, +generate a containerized version of the prebuilt FlexRAN binaries, and deploy +on |prod| solution. + +.. note:: + + The steps in this guide are based on FlexRAN 21.11. The instructions are + subject to change in future releases of FlexRAN. + +----------------- +Intended Audience +----------------- + +The intended audience for this document are software engineers and +system architects who want to design and develop 5G systems using the +O-RAN Specifications based on FlexRAN and |prod| OpenSource Edge +computing platform. + +------------------------ +AIO Simplex Installation +------------------------ + +************************************************* +Prepare USB stick with StarlingX Installation ISO +************************************************* + +#. Get StarlingX Installation ISO from following location: + + http://mirror.starlingx.cengn.ca/mirror/starlingx/master/centos/latest_build/outputs/iso/bootimage.iso + +#. Burn the image to a USB stick: + + .. note:: + + Be sure to use the correct USB device name when copying the image. + + .. code:: + + dd if=bootimage.iso of=/dev/sdc bs=1M + +***************************** +Follow the installation guide +***************************** + + +In addition to the :ref:`aio_simplex_hardware_r6` for |prod|, you will need the +following hardware for FlexRAN applications. + ++---------------------------+--------------------------------------------------------------------------------+ +| Minimum Requirement | All-in-one Controller Node | ++===========================+================================================================================+ +| Minimum processor class | Single-CPU Intel Xeon Cascade Lake (14 nm) or IceLake (10 nm) | ++---------------------------+--------------------------------------------------------------------------------+ +| Minimum memory | 64 GB single socket | ++---------------------------+--------------------------------------------------------------------------------+ +| Minimum network ports | OAM: 1x1GE, If only test timer mode, no other NIC required. | ++---------------------------+--------------------------------------------------------------------------------+ +| BIOS settings | - Hyper-Threading technology: Enabled | +| | - Virtualization technology: Enabled | +| | - VT for directed I/O: Enabled | +| | - CPU Power and Performance Policy: Performance | +| | - CPU C state control: Enabled | +| | - Plug & play BMC detection: Disabled | +| | - Uncore Frequency Scaling: Disabled | +| | - Performance P-limit: Disabled | +| | - Enhanced Intel SpeedStep (R) Tech: Enabled | +| | - Intel(R) Turbo Boost Technology: Enabled | +| | - Processor C6: Enabled | +| | - Package C-State: C0/C1 | +| | - Hardware P-states: Disabled | +| | - Memory Configuration: 8-way interleave | +| | - AVX License Pre-Grant: Enabled | +| | - AVX ICCP Pre-Grant Level: AVX-512 Heavy | ++---------------------------+--------------------------------------------------------------------------------+ +| Accelerator Card | Mt. Bryce ACC100 (Intel eASIC chip which can be mounted on third party card) | ++---------------------------+--------------------------------------------------------------------------------+ + +The FlexRAN application on |prod| has been tested on Intel Reference Hardware +platform: **Coyote Pass** (housing ICX-SP). + +.. note:: + + Some third-party platforms like SuperMicro / HPE / Dell / Quanta / + and others can also be used depending on customer platform requirements, + certain optimizations for low-latency and power savings mode by the + platform vendors. + +:ref:`aio_simplex_install_kubernetes_r6`: + +#. In addition to required |prod| configuration, you must set up the Ceph + backend for Kubernetes |PVC|, isolcpus and hugepages: + + .. code:: bash + + source /etc/platform/openrc + + NODE=controller-0 + OAM_IF= + + # if you use flat oam network + system host-if-modify ${NODE} $OAM_IF -c platform + system interface-network-assign ${NODE} $OAM_IF oam + + # if you use vlan oam network + VLANID= + system host-if-modify -n pltif -c platform $NODE $OAM_IF + system host-if-add ${NODE} -V $VLANID -c platform oam0 vlan pltif + system interface-network-assign ${NODE} oam0 oam + + system host-label-assign $NODE sriovdp=enabled + system host-label-assign $NODE kube-topology-mgr-policy=restricted + + # Ceph backend for k8s pvc + system storage-backend-add ceph --confirmed + system host-disk-list ${NODE} | awk '/\/dev\/sdb/{print $2}' | xargs -i system host-stor-add ${NODE} {} + + # isolate cpus depends on number of the physical core + system host-cpu-modify -f application-isolated -p0 28 controller-0 + + # allocate/enable hugepages for DPDK usage + system host-memory-modify $NODE -1G 10 0 + + system host-unlock $NODE + +#. After the system has been unlocked and available for the first time, + configure ACC100 / Mount Bryce: + + .. code:: bash + + source /etc/platform/openrc + + system host-lock $NODE + + # get the device name of the Mount Bryce, we assume it is + # pci_0000_85_00_0 here. + system host-device-list controller-0 + + # Modify the Mount Bryce device to enable it, specify the base driver + # and vf driver, and configure it for 1 VFs + + # NOTE: If this is the initial install and have not unlocked, you will + # get following error message. + # Cannot configure device 73b13ddf-99be-44c8-8fbe-db85eb8d99ba until host + # controller-0 is unlocked for the first time. + system host-device-modify controller-0 pci_0000_85_00_0 -e true --driver igb_uio --vf-driver vfio -N 1 + + system host-unlock $NODE + +------------------------------ +FlexRAN Software Prerequisites +------------------------------ + +* FlexRAN 21.11 Release Package + + FlexRAN Software Wireless Access Solutions is available from the following page: + https://www.intel.com/content/www/us/en/developer/topic-technology/edge-5g/tools/flexran.html + +* FlexRAN |DPDK| BBDEV v21.11 Patch + + This patch file is also available in FlexRAN Software Wireless Access + Solutions mentioned above. + +* |DPDK| version 20.11.3 + + |DPDK| version 20.11.3 is available in http://static.dpdk.org/rel/dpdk-20.11.3.tar.xz + +* Intel oneAPI Compiler + + The Intel oneAPI Compiler is used to compile Intel |DPDK| and L1 software. The + Intel oneAPI Compiler can be obtained using the following link: + https://www.intel.com/content/www/us/en/developer/tools/oneapi/base-toolkit-download.html + +----------------------------- +Build, Deploy and Run FlexRAN +----------------------------- + +Generally speaking, the build and execution environments should not be the same. +To facilitate building, deploying, and running the process on |prod|, a +custom containerized build environment has been prepared and verified. Developers +can use the instructions to build the customized Docker image themselves or use +the prebuilt Docker image directly. + +Using this method, developers can: + +#. Start the build soon after |prod| is ready. +#. Use the scripts provided to generate a Docker image with pre-built + FlexRAN binaries. +#. Launch the FlexRAN Pod using the image just generated. +#. Execute L1 test cases. + +The following procedures provide detailed instructions for completing the stages +described above. + +************************* +FlexRAN build preparation +************************* + +For details, see: + +https://www.intel.com/content/www/us/en/developer/topic-technology/edge-5g/tools/flexran.html + +You can find build instructions in the Compilation Chapter of :title:`FlexRAN 5GNR Reference Solution 21.11`. + +The following steps provide a quick-start procedure for developers. + +#. Create a |PVC| for FlexRAN build storage: + + .. note:: + + The |PVC| size should be larger than 70G. + + .. code:: bash + + cat > volume-ceph.yaml << 'EOF' + kind: PersistentVolumeClaim + apiVersion: v1 + metadata: + name: flexran-storage + spec: + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 80Gi + storageClassName: general + EOF + + kubectl create -f volume-ceph.yaml + + kubectl create -f volume-ceph.yaml + persistentvolumeclaim/flexran-storage created + controller-0:~$ kubectl get pvc + NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE + flexran-storage Bound pvc-43e50806-785f-440b-8ed2-85bb3c9e8f79 80Gi RWO general 9s + +#. Launch the `quick start building Pod `__ + attaching to the |PVC|: + + .. note:: + + This pod is assumed to be assigned enough resources to launch quickly + after FlexRAN is built. If you don't have isolated CPU, hugepage and + accelerator resources configured as part of the system used for + building, feel free to remove related content from the yaml spec + file. Hugepages-1Gi and intel.com/intel_acc100_fec are not required to + perform the build. + + .. code:: bash + + cat > flexran-buildpod.yml << 'EOF' + apiVersion: v1 + kind: Pod + metadata: + name: buildpod + annotations: + spec: + restartPolicy: Never + containers: + - name: buildpod + image: wrsnfv/flexran-builder:21.11 + imagePullPolicy: IfNotPresent + volumeMounts: + - name: usrsrc + mountPath: /usr/src + - mountPath: /hugepages + name: hugepage + - name: lib-modules + mountPath: /lib/modules + - name: pvc1 + mountPath: /opt/fb + - name: docker-sock-volume + mountPath: /var/run/docker.sock + command: ["/bin/bash", "-ec", "sleep infinity"] + securityContext: + privileged: true + capabilities: + add: + ["IPC_LOCK", "SYS_ADMIN"] + resources: + requests: + memory: 32Gi + hugepages-1Gi: 10Gi + intel.com/intel_acc100_fec: '1' + limits: + memory: 32Gi + intel.com/intel_acc100_fec: '1' + hugepages-1Gi: 10Gi + volumes: + - name: usrsrc + hostPath: + path: /usr/src + - name: lib-modules + hostPath: + path: /lib/modules + - name: hugepage + emptyDir: + medium: HugePages + - name: docker-sock-volume + hostPath: + path: /var/run/docker.sock + type: Socket + - name: pvc1 + persistentVolumeClaim: + claimName: flexran-storage + EOF + + kubectl create -f flexran-buildpod.yml + +#. (Optional) Instructions for FlexRAN building image creation: + + .. note:: + + You can use the following instructions to build the default image or a + customized version to meet your needs. + + .. code:: bash + + mkdir dockerbuilder && cd dockerbuilder + + # prepare the artifacts used for FlexRAN prebuilt binary Docker image + mkdir docker-image-building + cat > docker-image-building/readme << 'EOF' + # Instructions of Docker image generation + + # Following steps are supposed to be executed inside building Pod, + # after building FlexRAN from source code + + flxr_install_dir=/opt/fb/flexran/ + + # populate flexran related env var + cd ${flxr_install_dir} + source set_env_var.sh -d + + # prepare the FlexRAN binaries + ./transport.sh + + # build the Docker image + docker build -t flr-run -f Dockerfile . + + # tag and push + orgname=somename + docker tag flr-run ${orgname}/flr-run + + EOF + + cat > docker-image-building/transport.sh << 'EOF' + #!/bin/bash + + # ICXPATH=/opt/fb/intel/oneapi/ + + echo "Make sure source setvars.sh first.(located in ICX oneapi installation directory)" + echo "Make sure source set_env_var.sh -d first.(located in FlexRAN installation directory)" + + [[ -z "$MKLROOT" ]] && { echo "MKLROOT not set, exit..."; exit 1; } + [[ -z "$IPPROOT" ]] && { echo "MKLROOT not set, exit..."; exit 1; } + [[ -z "$CMPLR_ROOT" ]] && { echo "MKLROOT not set, exit..."; exit 1; } + [[ -z "$DIR_WIRELESS_SDK_ROOT" ]] && { echo "DIR_WIRELESS_SDK_ROOT not set, exit..."; exit 1; } + + FLXPATH=`echo $DIR_WIRELESS_SDK_ROOT| awk -F '/sdk' '{print $1}'` + + [[ -d stuff ]] && { echo "Directory stuff exists, move it to old."; mv -f stuff stuff.old; } + + mkdir stuff; cd stuff + + mkdir libs + cp -a $MKLROOT/lib/intel64/libmkl_intel_lp64.so* libs + cp -a $MKLROOT/lib/intel64/libmkl_core.so* libs + cp -a $MKLROOT/lib/intel64/libmkl_intel_thread.so* libs + cp -a $MKLROOT/lib/intel64/libmkl_avx512.so.* libs + cp -a $MKLROOT/lib/intel64/libmkl_avx2.so* libs + cp -a $MKLROOT/lib/intel64/libmkl_avx.so* libs + + cp -a $IPPROOT/lib/intel64/libipps.so* libs + cp -a $IPPROOT/lib/intel64/libippe.so* libs + cp -a $IPPROOT/lib/intel64/libippcore.so* libs + cp -a $IPPROOT/lib/intel64/libippee9.so* libs + cp -a $IPPROOT/lib/intel64/libippse9.so* libs + + cp -a $CMPLR_ROOT/linux/compiler/lib/intel64_lin/libiomp5.so* libs + cp -a $CMPLR_ROOT/linux/compiler/lib/intel64_lin/libirc.so* libs + cp -a $CMPLR_ROOT/linux/compiler/lib/intel64_lin/libimf.so* libs + cp -a $CMPLR_ROOT/linux/compiler/lib/intel64_lin/libsvml.so* libs + cp -a $CMPLR_ROOT/linux/compiler/lib/intel64_lin/libintlc.so* libs + cp -a $CMPLR_ROOT/linux/compiler/lib/intel64_lin/libirng.so* libs + + cp -a $FLXPATH/libs/cpa/bin/libmmwcpadrv.so* libs + cp -a $FLXPATH/wls_mod/libwls.so* libs + + mkdir -p flexran/sdk/build-avx512-icx/ + cp -rf $FLXPATH/sdk/build-avx512-icx/source flexran/sdk/build-avx512-icx/ + cp -rf $FLXPATH/sdk/build-avx512-icx/install flexran/sdk/build-avx512-icx/ + cp -rf $FLXPATH/bin flexran/ + cp -rf $FLXPATH/set_env_var.sh flexran/ + + # testcase files + mkdir -p tests/nr5g/ + cd tests/nr5g/ + for cfg in $FLXPATH/bin/nr5g/gnb/testmac/icelake-sp/*.cfg + do + cat $cfg | grep TEST_FD > /tmp/$$.testfile + while IFS= read line + do + array=($(echo "$line" | sed 's/5GNR,/ /g')) + for i in "${array[@]}"; do + if [[ "$i" =~ \.cfg ]]; then + casedir=`echo "$i"| cut -d / -f 1-3 | xargs` + caseabsdir=$FLXPATH/tests/nr5g/$casedir + [[ ! -d $casedir ]] && { mkdir -p $casedir; cp -rf $caseabsdir/* $casedir; } + fi + done + done < /tmp/$$.testfile + done + + echo "Transportation Completed." + EOF + + chmod a+x docker-image-building/transport.sh + + cat > docker-image-building/set-l1-env.sh << 'EOF' + # source this script to l1 binary location + + export WORKSPACE=/root/flexran + export isa=avx512 + + cd $WORKSPACE + source ./set_env_var.sh -i ${isa} + + MODE=$1 + [[ -z "$MODE" ]] && read -p "Enter the MODE(LTE or 5G): " MODE + + if [ $MODE = LTE ]; then + cd $WORKSPACE/bin/lte/l1/ + fi + if [ $MODE = 5G ]; then + cd $WORKSPACE/bin/nr5g/gnb/l1 + fi + EOF + + cat > docker-image-building/set-l2-env.sh << 'EOF' + # source this script to l2 binary location + + export WORKSPACE=/root/flexran + export isa=avx512 + + cd $WORKSPACE + source ./set_env_var.sh -i ${isa} + + MODE=$1 + [[ -z "$MODE" ]] && read -p "Enter the MODE(LTE or 5G): " MODE + + if [ $MODE = LTE ]; then + cd $WORKSPACE/bin/lte/testmac/ + fi + if [ $MODE = 5G ]; then + cd $WORKSPACE/bin/nr5g/gnb/testmac + fi + EOF + + cat > docker-image-building/res-setup.sh << 'EOF' + #!/bin/bash + + [[ -z "$PCIDEVICE_INTEL_COM_INTEL_ACC100_FEC" ]] && { echo "ACC100 not used, sleep..."; sleep infinity; } + + sed -i 's#.*dpdkBasebandFecMode.*# 1#' /root/flexran/bin/nr5g/gnb/l1/phycfg_timer.xml + sed -i 's#.*dpdkBasebandDevice.*# '"$PCIDEVICE_INTEL_COM_INTEL_ACC100_FEC"'#' /root/flexran/bin/nr5g/gnb/l1/phycfg_timer.xml + + echo "Resource setup Completed, sleep..." + sleep infinity + EOF + + chmod a+x docker-image-building/res-setup.sh + + mkdir docker-image-building/rootdir + mv docker-image-building/res-setup.sh docker-image-building/rootdir + mv docker-image-building/set-l1-env.sh docker-image-building/rootdir + mv docker-image-building/set-l2-env.sh docker-image-building/rootdir + + cat > docker-image-building/Dockerfile << 'EOF' + FROM centos:7.9.2009 + + RUN [ -e /etc/yum.conf ] && sed -i '/tsflags=nodocs/d' /etc/yum.conf || true + + RUN yum install -y libhugetlbfs* libstdc++* numa* gcc g++ iproute \ + module-init-tools kmod pciutils python libaio libaio-devel \ + numactl-devel nettools ethtool + RUN yum clean all + + COPY stuff/libs/* /usr/lib64/ + + WORKDIR /root/ + COPY stuff/flexran ./flexran + COPY stuff/tests ./flexran/tests + COPY rootdir/* ./ + + CMD ["/root/res-setup.sh"] + EOF + + cat > Dockerfile << 'EOF' + FROM centos:7.9.2009 + + RUN [ -e /etc/yum.conf ] && sed -i '/tsflags=nodocs/d' /etc/yum.conf || true + + RUN yum groupinstall -y 'Development Tools' + + RUN yum install -y vim gcc-c++ libhugetlbfs* libstdc++* kernel-devel numa* gcc git mlocate \ + cmake wget ncurses-devel hmaccalc zlib-devel binutils-devel elfutils-libelf-devel \ + numactl-devel libhugetlbfs-devel bc patch git patch tar zip unzip python3 sudo docker + + RUN yum install -y gtk3 mesa-libgbm at-spi2-core libdrm xdg-utils libxcb libnotify + + RUN yum install -y centos-release-scl + RUN yum install -y devtoolset-8 + + RUN yum clean all + + RUN pip3 install meson && \ + pip3 install ninja pyelftools + + # ENV HTTP_PROXY="" + # ENV HTTPS_PROXY="" + + WORKDIR /usr/src/ + RUN git clone https://github.com/pkgconf/pkgconf.git + WORKDIR /usr/src/pkgconf + RUN ./autogen.sh && ./configure && make && make install + + WORKDIR /usr/src/ + RUN git clone git://git.kernel.org/pub/scm/utils/rt-tests/rt-tests.git + WORKDIR /usr/src/rt-tests + RUN git checkout stable/v1.0 + RUN make all && make install + + COPY docker-image-building /root/docker-image-building + + WORKDIR /opt + + # Set default command + CMD ["/usr/bin/bash"] + EOF + + # build the Docker image for FlexRAN building environment + orgname=somename + docker build -t flexran-builder . + docker tag flexran-builder ${orgname}/flexran-builder:21.11 + docker login + docker push ${orgname}/flexran-builder:21.11 + +******************** +Build FlexRAN in Pod +******************** + +#. Use a shell inside Pod to build FlexRAN: + + .. code:: bash + + kubectl exec -it buildpod -- bash + +#. Use ``scp`` to copy the FlexRAN related files into the pod's |PVC|: + + .. code:: bash + + mkdir -p /opt/fb/scratch && cd /opt/fb/scratch + scp FlexRAN-21.11.tar.gz.part00 . + scp FlexRAN-21.11.tar.gz.part01 . + scp dpdk_patch_21.11.patch . + + cat FlexRAN-21.11.tar.gz.part00 FlexRAN-21.11.tar.gz.part01 > FlexRAN-21.11.tar.gz + rm FlexRAN-21.11.tar.gz.part00 + rm FlexRAN-21.11.tar.gz.part01 + +#. Copy |DPDK| source code into the pod's |PVC|: + + .. code:: bash + + cd /opt && wget http://static.dpdk.org/rel/dpdk-20.11.3.tar.xz + tar xf dpdk-20.11.3.tar.xz + mv dpdk-stable-20.11.3/ /opt/fb/dpdk-flxr-21.11 + cd /opt/fb/dpdk-flxr-21.11 + patch -p1 < /opt/fb/scratch/dpdk_patch_21.11.patch + +#. Install oneAPI (ICX) Compiler: + + .. code:: bash + + cd /opt/fb/scratch/ + + wget https://registrationcenterdownload.intel.com/akdlm/irc_nas/18236/l_BaseKit_p_2021.4.0.3422_offline.sh + chmod a+x l_BaseKit_p_2021.4.0.3422_offline.sh + + ./l_BaseKit_p_2021.4.0.3422_offline.sh -a -s --eula accept --install-dir /opt/fb/intel/oneapi + +#. Extract FlexRAN and populate the environment variables: + + .. code:: bash + + cd /opt/fb/scrach/ && tar zxvf FlexRAN-21.11.tar.gz && ./extract.sh + # input '/opt/fb/flexran' for Extract destination directory + + cd /opt/fb/flexran/ + + # apply following patch to set_env_var.sh + cat > set_env_icx.diff << 'EOF' + + diff --git a/set_env_var.sh b/set_env_var.sh + index 38ac4e4..6f475d3 100755 + --- a/set_env_var.sh + +++ b/set_env_var.sh + @@ -132,30 +132,6 @@ echo "" + # Set ICC and DPDK environment + if [ $set_dependencies -eq 1 ]; then + if [ $continue_run -eq 1 ]; then + - # ICC + - if [ ! -f "$icc_file" ] + - then + - read -p 'Enter Intel SystemStudio / ParallelStudio Install Directory for icc, or just enter to set default ' val + - if [ -z "$val" ]; then + - val=$icc_default_path + - fi + - else + - val=`cat $icc_file` + - fi + - + - if [ -f "$val/bin/iccvars.sh" ]; then + - icc_path=$val + - echo "sourcing $icc_path/bin/iccvars.sh intel64 -platform linux" + - source $icc_path/bin/iccvars.sh intel64 -platform linux + - echo $icc_path > $icc_file + - else + - echo "ICC Directory $val is invalid" + - rm -rf $icc_file + - continue_run=0 + - fi + - fi + - + - if [ $continue_run -eq 1 ]; then + #DPDK + if [ ! -f "$dpdk_file" ] + then + @@ -188,7 +164,7 @@ fi + + # Validate ISA + if [ $continue_run -eq 1 ]; then + - export WIRELESS_SDK_TOOLCHAIN=icc + + export WIRELESS_SDK_TOOLCHAIN=icx + case $target_isa in + avx2) + export WIRELESS_SDK_TARGET_ISA=avx2 + + EOF + patch -p1 < set_env_icx.diff + + source ./set_env_var.sh -d + # When following promote message shows: + # Enter DPDK Install Directory, or just enter to set default + # input: /opt/fb/dpdk-flxr-21.11 + + # populate oneapi environment variables also + source /opt/fb/intel/oneapi/setvars.sh + +#. Switch to devtoolset-8 environment: + + .. code:: bash + + scl enable devtoolset-8 bash + +#. Build FlexRAN SDK: + + .. code:: bash + + cd /opt/fb/flexran && ./flexran_build.sh -e -r 5gnr -m sdk + +#. Build |DPDK| with the FlexRAN patch: + + .. code:: bash + + cd /opt/fb/dpdk-flxr-21.11 && meson build + cd /opt/fb/dpdk-flxr-21.11/build && meson configure -Dflexran_sdk=/opt/fb/flexran/sdk/build-avx512-icx/install && ninja + +#. Build the FlexRAN applications: + + .. code:: bash + + cd /opt/fb/flexran + + # Linux 5.6 deprecated ioremap_nocache, need to change to use ioremap_cache instead + sed -i 's#ioremap_nocache#ioremap_cache#g' ./libs/cpa/mmw/rec/drv/src/nr_dev.c + + # compile all available modules for 5gnr + ./flexran_build.sh -e -r 5gnr + + +******************************************* +Generate Docker image with FlexRAN binaries +******************************************* + +.. note:: + + Since host path ``/var/run/docker.sock`` has been mounted into the building + pod, you can build the Docker image using the FlexRAN binaries from the + previous step inside the building pod. The artifacts used + by :command:`docker build` have been integrated into the build image and + are ready to use. + +#. Prepare the env var for the script in ``/root/docker-image-building/transport.sh``: + + .. code:: bash + + source /opt/fb/intel/oneapi/setvars.sh + cd /opt/fb/flexran && source ./set_env_var.sh -d + +#. Prepare binaries and scripts for Docker build: + + .. code:: bash + + cd /root/docker-image-building + ./transport.sh + +#. Build Docker image which will be saved in local host: + + .. code:: bash + + docker build -t flr-run -f Dockerfile . + + +********************************* +Run the FlexRAN Test cases in Pod +********************************* + +After the build and Docker image generation steps above, you can launch the +FlexRAN execution pod from the host. + +#. Push the Docker image to a registry, for example, `dockerhub.io `__: + + .. code:: bash + + docker login + orgname=somename + docker tag flr-run ${orgname}/flr-run:v1 + docker push ${orgname}/flr-run:v1 + +#. Launch the FlexRAN Pod. + + Adjust the CPU and memory for your configuration. + Memory should be more than 32Gi for the test case pass rate. + + .. note:: + + ``command`` should not be used in the spec, otherwise it will overwrite + the default container command which does accelerator |PCI| address + filling for L1. + + .. code:: bash + + cat > runpod-flxr.yml << 'EOF' + apiVersion: v1 + kind: Pod + metadata: + name: runpod + annotations: + spec: + restartPolicy: Never + containers: + - name: runpod + image: somename/flr-run:v1 + imagePullPolicy: IfNotPresent + volumeMounts: + - mountPath: /hugepages + name: hugepage + securityContext: + privileged: false + capabilities: + add: + ["IPC_LOCK", "SYS_ADMIN", "SYS_NICE"] + resources: + requests: + memory: 32Gi + hugepages-1Gi: 6Gi + intel.com/intel_acc100_fec: '1' + limits: + memory: 32Gi + hugepages-1Gi: 6Gi + intel.com/intel_acc100_fec: '1' + volumes: + - name: hugepage + emptyDir: + medium: HugePages + EOF + + kubectl create -f runpod-flxr.yml + +#. Execute L1. + + #. Enter the L1 directory inside Pod: + + .. code:: bash + + kubectl exec -it runpod -- bash + source set-l1-env.sh 5G + + + #. Edit L1 configuration file: + + .. note:: + + ``phycfg_timer.xml`` has been modified by entry script to use the FEC + accelerator: ``1`` + ``0000:8b:00.0`` + + This configuration is scripted and runs automatically, no manual + configuration is needed. You can use :command:`printenv + PCIDEVICE_INTEL_COM_INTEL_ACC100_FEC` to check dpdkBasebandDevice. + + .. code:: console + + # change default CPU binding in section of in phycfg_timer.xml + # use the first 3 assigned CPUs for the Applications threads + + + + + 2, 0, 0 + + + 3, 96, 0 + + + 4, 96, 0 + + + + 4, 96, 0 + + + 2, 99, 0 + + + + #. Run L1 application: + + .. code:: bash + + # launch L1app + ./l1.sh -e + +#. Execute testmac after L1 is up and running in another terminal. + + #. Enter the testmac directory inside Pod: + + .. code:: bash + + kubectl exec -it runpod -- bash + source set-l2-env.sh 5G + + #. Edit testmac configuration file: + + .. code:: console + + # Modify default CPU binding in section of in testmac_cfg.xml + # Make sure to use the CPU from the CPU whose ID is bigger than 13, + # this way, the Application Threads will not overlap with the BBUPool CPUs. + + + + 16, 90, 0 + + + 14, 0, 0 + + + 14, 89, 0 + + + 15, 90, 0 + + + # workaround the known issue of parsing zero value in the config file + sed -i '/>0