LabVIEW Communications 1.1 to 2.0 Migration Guide for LTE Application Framework

Overview

This guide provides information and guidance for migrating existing LabVIEW Communications 1.1 applications to LabVIEW Communications 2.0 for the LTE Application Framework. If you prefer to migrate over an existing application, this guide addresses known issues that may arise in the process. It is recommended to start with a new project in 2.0 and duplicate the original project in the newer version.

Contents

How to Use This Guide

This document covers LabVIEW Communications 1.1 to 2.0 Migration Guide for the LTE Application Framework. 

The guide is made up five documents covering the following topics: 

 

Each section discusses the required steps to migrate that specific type of project. For example, if you would like to migrate a USRP streaming project, you should navigate to the USRP Projects section for guidance. If your project does not fall into the first three categories listed above, you should navigate to the General Projects section. Each section is meant to be self-contained and used independently of the others, so redundant information may be included in multiple sections.

Note: Always back up a copy of the original project before attempting any migration efforts.

 

LTE APPLICATION FRAMEWORK

This section describes the necessary steps if you want to reuse a project that was created based on the LTE Application Framework v1.1 (created in LabVIEW Communications 1.1) in LabVIEW Communications 2.0.

The section includes the following steps, each with their own subsection:

  1. Reconfigure the Xilinx IP cores
  2. Migrate to the new USRP interface
  3. Update host-side DMA FIFO’s


Reconfigure the Xilinx IP


Scope


Because the FPGA compile tools uses a new Xilinx Vivado Toolchain version, all Xilinx IP cores must be updated to the new version. By configuring the IP cores again, the dependencies are regenerated ensuring that they will be compatible with the latest Vivado version to ensure successful compilations.

 

Which Files are Affected?

  •  All FPGA GCDL files which include a Xilinx IP core


The affected files can be found by completing the following steps:

  1. Create a backup of your project.
  2. Open your project in LabVIEW Communications 2.0.
  3. Click Yes to convert as shown in Figure 22.


    Figure 22: Convert Dialog
  4. Open the FPGA top-level VI you wish to migrate, for example, “LTE FPGA USRP RIO 40 MHz BW DL.gvi.“
  5. Wait until type propagation has occurred.
  6. If the document finished loading, you will see in the list of errors the affected files as shown in Figure 23.


Figure 23: Error list showing affected files for Xilinx IP Core reconfiguration

 

Step-By-Step Instructions

  1. If not done already, make sure to back up the original project and convert a copy for use with LabVIEW Communications 2.0. For details, refer to steps 1-3 from the previous section “Which Files Are Affected?”.
  2. Once open in LabVIEW Communications 2.0, open the FPGA top-level you wish to migrate, for example, “LTE FPGA USRP RIO 40 MHz BW DL.gvi“.
  3. Double-click on the errors as shown in Figure 23. This will open the affected document.
  4. Select the affected Xilinx IP block and click Configure Xilinx IP Core in the right-hand rail as shown in Figure 24.
  5. Wait for the “Re-customize IP“ dialog to appear.
  6. Inside the “Re-customize IP“ dialog, leave the settings untouched and click OK  as shown in Figure 25.
  7. Wait until the warning “Not Ready“, as shown in Figure 26, has disappeared.
  8. Repeat steps 3 through 6 until all errors in the FPGA top-level have disappeared.


Figure 24: How to reconfigure a Xilinx IP Core (1)




Figure 25: How to reconfigure a Xilinx IP Core (2)

 


Figure 26: "Not Ready" warning because Xilinx tool is processing the IP in the background



Migrate to the New USRP Interface


Scope


Because the USRP interface (40 MHz BW) used in the LTE Application Framework v1.1 is deprecated with LabVIEW Communications 2.0, the new interface must now be used on the FPGA top-level. The new interface now handles both the 40 MHz BW and 120 MHz BW USRP models with the same interface. Hence, an FPGA bitfile rebuild is required.


Without the rebuild, Error -61206 will occur when running the Host top-level, for example, “LTE Host DL.gvi” as shown in Figure 27.


Figure 27: Error -61206 occurs when running the Host Top-Level without migrating the USRP interface

 

Which Files are Affected?

  • The FPGA top-level, for example, “LTE FPGA USRP RIO 40 MHz BW DL.gvi“

    Note: Two new USRP interface files must be included in the project: “Create Resources.gvi“, “Registers.gcdl“

 

Step-By-Step Instructions

  1. Select your USRP Target on the System Designer and change the "Model" in the right-hand rail to the non-deprecated version (ex: NI 2953R USRP (40 MHz BW) Deprecated » NI 2953R USRP (40 MHz BW)).


    Figure 28: Change Deprecated Version


  1. Generate a new 40 MHz Single-Device Streaming project in LabVIEW Communications 2.0 by navigating to New » Project Templates » USRP RIO 40 MHz BW Single-Device Streaming.

    Note:
    This project will only be used to copy the necessary project files, and code sections, into the previous project that is being migrated.
  2. Copy two VIs from the new project must be copied into the original project as shown in Figure 29.

    a. Find the following subVIs from the <project directory>\FPGA subVIs folder:

        i. Create Resources.gvi
        ii. Registers.gcdl



    Figure 29: Files to Copy

b. Copy these on disk and paste to the <project directory>\USRP RIO 40 MHz BW\FPGA directory in the original project.

c. In the “Project Files” view on the Navigation Pane of the original project, the new files will appear slightly grayed out. Right-click on each and select Include, as shown in Figure 30.

d. Since the “Create Resources.gvi” is not a specific FPGA document (for example, CDL, MRD, and so on), there may be a prompt to select the target that the file should reside under. Select the same USRP target that your other files in this directory reside under.


Figure 30: Include Copied Files

  1. In the original project to be migrated, open the FPGA top-level “LTE FPGA USRP RIO 40 MHz BW DL.gvi“.

    Note: If you finished all of the instructions of the first section, Reconfigure the Xilinx IP, no error should be displayed for the FPGA top-level.
  2. Find the three Clock-Driven Loops which are used for interfacing with the USRP as shown in the following Figure 31.


Figure 31: CDLs noted in Step 7

  1. Move the controls “Register Bus & Required“, “TX“ and “RX“ outside the first USRP Clock-Driven Loop as shown in Figure 32.


Figure 32: Clock-Driven Loops for interfacing with the USRP on the FPGA Top-Level

  1.  Delete the three Clock-Driven Loops used for interfacing with the USRP as shown in Figure 33.


Figure 33: Deleting the Clock-Driven Loops for interfacing with the USRP

  1. Open the “Streaming Xcvr (FPGA).gvi” of the new project.

    As shown in Figure 34, select and copy the following from the Diagram: “Create Resources.gvi”, “Process.gvi”, the Clock Constant, and the Clock-Driven Loop.


Figure 34: USRP Interface Elements to be copied to the FPGA Top-Level

  1. In the project you wish to migrate, paste the elements you copied from the new streaming project and wire as shown in Figure 35.


    Figure 35: Pasted USRP interface elements wired up
  2. Allow all document changes to finish loading and save all files.
  3. Close the new streaming project as it is no longer needed.
  4. Compile the FPGA VI.

    a. Open the System Designer (in the “Project Files” view of the Navigation Pane on the left) and double-click on the top most project file.
    b. Select the FPGA top-level under the target you want to build the bitfile for.
    c. Click Build on the right-hand rail as shown in Figure 36.


    Figure 36: Build a bitfile for the selected FPGA Top-Level VI

  5. (Recommended) Once the bitfile is finished building, exclude it from the project as shown in Figure 37 and include it again. This will ensure that the latest changes are actually applied.

Figure 37: Exclude and include the FPGA Top-Level again to make sure it is loaded correctly


Update Host-Side DMA FIFO’S


Scope


The FIFO resource names in the Host subVIs which interface with DMA FIFOs must be updated.
In LabVIEW Communications 1.0/1.1, the FIFO name contained only the name itself, for example, “PDSCH Decoding Status“. In LabVIEW Communications 2.0, the FIFO resource contains of the prefixes the FPGA resource file name and the FIFO name itself, for example, “USRP Resources.grsc\PDSCH Decoding Status“.
Therefore, all occurrences of “Configure DMA FIFO“, “Read DMA FIFO“ and “Write DMA FIFO“ must be updated to reference the new name.

 

Which Files are Affected?

  • All Host subVIs which contain a FIFO node (for example, Start/Stop, Configure, or Read/Write operations)

The list of VIs which require modification for “LTE Host DL.gvi” is included in Table 2. If you miss one occurrence of a DMA FIFO operation, you will receive error -61206 during run-time as shown in Figure 38 in which the error indicates that the FIFO resource name of the node “Configure DMA FIFO“ is incorrect in the file “LTE DL RX FIFO Initialization.gvi.“


Table 2: FIFO “Operations in LTE Host DL.gvi”



Figure 38: Error -61206 occurred because of incorrect FIFO resource name

 

Step-By-Step Instructions

  1. Open the affected VI. In this example, we are demonstrating changes needed for the “LTE DL RX FIFO Initialization.gvi” as shown in Figure 39.


    Figure 39: “LTE DL RX FIFO Initialization.gvi” (original file)
  2. (Recommended) Add comments above the affected nodes that note the currently configured resource name as shown in Figure 40.


    Figure 40: “LTE DL RX FIFO Initialization.gvi” (after adding FIFO name comments)

  3. Select the “FPGA type“ constant and click Configure in the right-hand rail as shown in Figure 41.


    Figure 41: “LTE DL RX FIFO Initialization.gvi” - Reconfigure FPGA Type
  4. In the “FPGA Interface Dynamic Refnum Configuration“ dialog, click Import bitfile and navigate to the bitfile you just built in the last step of the second section, Migrate to the New USRP Interface.
  5. (Optional) With the “FPGA Interface Dynamic Refnum Configuration“ dialog still open, remove all unused resources by clicking the X symbol on the right side. This will not affect functionality but may make it easier to view used resources at a later time.
  6. Click OK in the “FPGA Interface Dynamic Refnum“ dialog.
  7. Select the first FIFO node and adopt the FIFO name as shown in Figure 42.



    Figure 42: “LTE DL RX FIFO Initialization.gvi” - Adopt FIFO name
  8. Repeat the previous step for all FIFO nodes in the current VI.

    Caution: Make sure to select the correct FIFO. Double-check if the name you selected matches the comment you added to the document in step 2.
  9. Repeat steps 1 through 8 for all VIs which contain a DMA FIFO node

 

Next Steps

Continue onto other sections of the LabVIEW Communications 1.1 to 2.0 Migration Guide for: 

The LabVIEW Communications product documentation provides detailed information in addition to the tasks discussed in this guide. Hardware manuals also contain valuable information about the features and performance characteristics of NI RIO devices.

The main NI support page, ni.com/support, provides quick access to manuals, KnowledgeBase documents, tutorials, example code, community forums, technical support, and customer service.

Was this information helpful?

Yes

No