Skip to content

NetFPGA SUME Reference Learning Switch

Salvator Galea edited this page Jul 12, 2021 · 9 revisions

Name

reference_switch

Location

projects/reference_switch

IP Cores

Software

Description

The division of the hardware into modules was hinted at in the previous section. Understanding these modules is essential in making the most of the available designs. The reference projects in NetFPGA platform, including the Switch, all follow the same modular structure. This design is a pipeline where each stage is a separate module.

Packets first enter the device through the nf_10g_interface module, which is an IP that combines Xilinx AXI 10G Ethernet subsystem, in addition to an AXI4-Stream adapter. There are 4 such module instances in the design, one per port. The packets arriving from the external SFP ports are processed by the PMA and PCS parts of the 10G Ethernet core, are next read in by Xilinx 10G MAC (within the same core). Every incoming packet is annotated with metadata and is finally transformed into 256-bit AXI4-Stream. The TX side follows the exact same path but in the opposite direction.

The nf_10g_interface modules RX connect next to the input arbiter module. The input arbiter has four input interfaces: four from the nf_10g_interface modules and one from a DMA module (to be described later on). Each input to the arbiter connects to an input queue, which is in fact a small fall-through FIFO. The simple arbiter rotates between all the input queues in a round robin manner, each time selecting a non-empty queue and writing one full packet from it to the next stage in the data-path, which is the output port lookup module.

The output port lookup module is responsible for deciding which port a packet goes out of. After that decision is made, the packet is then handed to the output queues module. The lookup module implements a simple learning CAM, implemented using Xilinx's CAM core. Packets with unknown destination MAC address are broadcasted.

Once a packet arrives to the output_queues module, it already has a marked destination (provided on a side channel - The TUSER field). According to the destination it is entered to a dedicated output queue. There are five such output queues: one per each 10G port and one to the DMA block. Note that a packet may be dropped if its output queue is full or almost full. When a packet reaches the head of its output queue, it is sent to the corresponding output port, being either an nf_10g_interface module or the DMA module. The output queues are arranged in an interleaved order: one physical Ethernet port, one DMA port etc. Even queues are therefore assigned to physical Ethernet ports, and odd queues are assigned to the virtual DMA ports.

The DMA module serves as a DMA engine for the reference switch design. It includes Xilinx' PCIe core, a DMA engine and AXI4 Interconnect module. To the other NetFPGA modules it exposes AXIS (master+slave) interfaces for sending/receiving packets, as well as a AXI4-LITE master interface through which all AXI registers can be accessed from the host (over PCIe). To this end it connects to the axi_interconnect module. In the Reference Switch design the DMA module is used only for register access.

The reference Switch design implements a Xilinx Microblaze subsystem, including also a BRAM memory block and its controller. This module is currently used only for clock configuration. For more information, please refer to the Microblaze reference links provided above.

Simulating Switch with TCAM's

Testing

  1. Make sure you clone the latest version of the NetFPGA package. Please ensure that you have the necessary packages installed. The current testing infrastructure is Python based.
git clone https://github.com/NetFPGA/NetFPGA-SUME-live.git
  1. Make sure the ~/tools/settings.sh file is updated in your system.

Check if the variables like SUME_FOLDER, NF_DESIGN_DIR are set in the right path, e.g.:

export NF_PROJECT_NAME=reference_switch

Try to do an echo $SUME_FOLDER , echo $NF_DESIGN_DIR refer to the path you want.

To set up the environment variables, source both relevant settings files, e.g.:

source ~/NetFPGA-SUME-live/tools/settings.sh
source /opt/Xilinx/Vivado/2016.4/settings64.sh
  1. Do a make only the first time when you have a fresh repository. It is not necessary to repeat this make every time you want to build a new project unless you have made any changes to the IP cores.
[root@nf-test109 ~]# cd $SUME_FOLDER 
[root@nf-test109 NetFPGA-SUME-live]# make 
  1. Please follow the instructions in the CAM wiki page.
    Note: The CAM core must be generated prior to running this project.

  2. Program the FPGA with the right bitfile using XMD (Xilinx tool).

  • If you want to run the Hardware tests with the pre-existing bitfile provided in the base repo:
[root@nf-test109 reference_switch]# cd bitfiles
[root@nf-test109 bitfiles]# xmd

On the xmd console, use fpga -f reference_switch.bit to program the FPGA with the bitfile. Reboot the machine.

  • If you want to create your own bitfile and run the Hardware tests:
[root@nf-test109 reference_switch]# make
[root@nf-test109 reference_switch]# cd bitfiles
[root@nf-test109 bitfiles]# xmd

On the xmd console, use fpga -f reference_switch.bit to program the FPGA with the bitfile. Reboot the machine.

  1. Check if the bit file is loaded using the following command.
[root@nf-test109 scripts]# lspci –vxx | grep Xilinx

If you don't see the Xilinx device, you need to reprogram the FPGA and reboot as mentioned earlier.

  1. Build the driver for the NetFPGA SUME board.
[root@nf-test109 ~]# cd $DRIVER_FOLDER
[root@nf-test109 sume_riffa_v1_0_0]# make all
[root@nf-test109 sume_riffa_v1_0_0]# make install
[root@nf-test109 sume_riffa_v1_0_0]# modprobe sume_riffa

Then run ifconfig -a to check if you are able to see the 'nfX' interfaces.

  1. Running the test

The top level file nf_test.py file can be found inside NetFPGA-SUME-live/tools/scripts. Tests are run using the nf_test.py command followed by the arguments indicating if it is a hardware or simulation test and what is the specific test that we would like to run. So when running the test, test mode should be specified (sim or hw). For instance:

[root@nf-test109 scripts]#./nf_test.py hw --major learning --minor sw 

or

[root@nf-test109 scripts]#./nf_test.py sim --major learning --minor sw 

For a complete list of arguments type ./nf_test.py --help.

You can find more information related to hardware and simulation tests here:

The test infrastructure is based on the python. You can find the tests inside the projects/{project_name}/test folder.

Testing hardware using two or more machines

To run the test, you need two machines, A and B. Let's say Machine A is equipped with NetFPGA and Machine B is equipped with a third-party 10G dual-port NIC.

Download the reference_switch bitfile from projects/reference_switch/bitfiles/reference_switch.bit. (Refer to Acceptance Test Manual if you don't know how to download the bitfile and/or not setup JTAG cable yet.)

Connect Machine A and Machine B using two 10G cables. Assume we use nf0 (the port farthest from the PCI Express) and nf1 on Machine A and eth1 and eth2 on Machine B. Generate packets from eth1 with given MAC addresses (let's say, dest-MAC = x and src-MAC = y). Check that all the NetFPGA physical ports send back the packet. Then, generate from eth2 packets with dest-MAC = y and src-MAC = x. You will be able to see that only nf0 will forward back packets.

Notes

  • Critical messages of the following type should be ignored, as this is handles outside the block design: [BD 41-1348] Reset pin /dma_sub/axi_interconnect_0/M00_ARESETN (associated clock /dma_sub/axi_interconnect_0/M00_ACLK) is connected to asynchronous reset source /axis_datapath_aresetn. This may prevent design from meeting timing. Please add Processor System Reset module to create a reset that is synchronous to the associated clock source /axis_datapath_aclk.

  • Warnings of the following type should currently be ignored, it is a known issue with the block design which does not affect the functionality: [Synth 8-689] width (12) of port connection 'M00_AXI_araddr' does not match port width (32) of module 'control_sub' ["/root/NetFPGA-SUME-dev/projects/reference_switch/hw/hdl/top.v":674]

  • Any questions regarding RIFFA DMA and associated warnings should be referred to the RIFFA development team. Note that the design currently uses the DMA only for register access.


Clone this wiki locally