Multi Channel DMA IP for PCI Express* Design Example User Guide
                    
                        ID
                        683517
                    
                
                
                    Date
                    8/04/2025
                
                
                    Public
                
            
                                    
                                    
                                        
                                        
                                            3.5.1. Hardware Requirements
                                        
                                        
                                    
                                        
                                        
                                            3.5.2. Software Requirements
                                        
                                        
                                    
                                        
                                        
                                            3.5.3. Set Up the Hardware and Program the FPGA
                                        
                                        
                                    
                                        
                                        
                                            3.5.4. Configuration Changes from BIOS
                                        
                                        
                                    
                                        
                                        
                                            3.5.5. Installing the Required Kernel Version for Ubuntu v24.04
                                        
                                        
                                    
                                        
                                        
                                            3.5.6. Set the Boot Parameters
                                        
                                        
                                    
                                        
                                            3.5.7. MCDMA Custom Driver
                                        
                                        
                                        
                                    
                                        
                                            3.5.8. MCDMA DPDK Poll Mode Driver
                                        
                                        
                                        
                                    
                                        
                                            3.5.9. MCDMA Kernel Mode Network Device Driver
                                        
                                        
                                        
                                    
                                
                            2.1.6. Design Example Driver Support
The table below summarizes the driver support for the MCDMA design example variants. It uses the following acronyms:
- User Space I/O (UIO): A kernel base module that the PCIe device uses to expose its resources to the user space.
- Virtual Function I/O (VFIO) driver: An IOMMU/device-agnostic framework for exposing direct device access to the user space in a secure, IOMMU-protected environment.
- Data Plane Development Kit (DPDK): Consists of libraries to accelerate packet processing workloads running on a wide variety of CPU architectures.
| Parameter | Custom Driver | DPDK Driver | Kernel Mode Netdev Driver | 
|---|---|---|---|
| Description | Also known as the user mode driver, this driver is created to support both UIO and VFIO base kernelmodules. This driver provides custom APIs and can be used without depending on any framework. | This DPDK Poll Mode Driver (PMD) uses the DPDK framework. The PMD will expose the device as an ethernet device. It supports both UIO and VFIO base kernel modules. Existing DPDK applications can be integrated with the MCDMA PMD. | Kernel Mode Netdev Driver exposes the MCDMA IP as a Network Device and enables standard applications to perform network data transfers using the Linux network stack. | 
| Directory/Driver Path | <example_design>/pX_software/user | <example_design>/pX_software/dpdk | <example design>/pX_software/kernel/ | 
| SR-IOV Support | Yes | Yes | Yes | 
| Multi channel DMA Avalon-MM DMA Design Example | Yes, up to 2K Channels | Yes, up to 2K Channels | No | 
| Multi channel DMA Avalon-MM DMA with SRIOV Design Example | Yes, up to 2K Channels | Yes, up to 2K Channels | No | 
| BAM+BAS+MCDMA Avalon-MM DMA Design Example | Yes, up to 2K Channels | Yes, up to 2K Channels | No | 
| BAM+BAS+MCDMA Avalon-MM DMA with SR-IOV Design Example | Yes, up to 2K Channels | Yes, up to 2K Channels | No | 
| Multi channel DMA Avalon-MM PIO using MQDMA Bypass Mode Design Example | Yes | Yes | No | 
| Multi channel DMA Avalon-ST 1-port PIO using MQDMA Bypass Mode Design Example | Yes | Yes | Yes | 
| BAM+BAS+MCDMA Avalon-MM PIO using MQDMA Bypass Mode Design Example | Yes | Yes | No | 
| BAM+BAS+MCDMA Avalon-ST 1-Port PIO using MQDMA Bypass Mode Design Example | Yes | Yes | No | 
| Bursting Master PIO using MQDMA Bypass Mode Design Example | Yes | Yes | No | 
| Bursting Slave PIO using MQDMA Bypass Mode Design Example | Yes | Yes | No | 
| BAM+BAS PIO using MQDMA Bypass Mode Design Example | Yes | Yes | No | 
| Data Mover Only PIO using MQDMA Bypass Mode Design Example | Yes | No | No | 
| Multi channel DMA Avalon 1-port Device-side Packet Loopback Design Example | Yes | Yes, 256 channels | Yes, support 4 PFs, 64 channel per PF | 
| Multi channel DMA Avalon 1-port Device-side Packet Loopback with SRIOV Design Example | Yes | Yes, 256 channels | No | 
| Multi channel DMA Avalon1-port Packet Generate/ Check Design Example | Yes | Yes, 256 channels | No | 
| Multi channel DMA Avalon 1-port Packet Generate/ Check with SR-IOV Design Example | Yes | No | No | 
| BAM+BAS Traffic Generator/Checker Design Example | Yes | Yes | No | 
| Data Mover Only External Descriptor Controller Design Example | Yes | No | No | 
   Note:
   
  The software directory is created multiple times depending on the Hard IP mode selected (1x16, 2x8 or 4x4) for Quartus® Prime Pro Edition v23.3 onwards.
The p0_software folder is generated for the 1x16 Hard IP mode.
The p1_software folder is generated for the 2x8 Hard IP mode.
The p2_software and p3_software folders are generated only for the 4x4 Hard IP mode.
   Note: You must use the corresponding software folder with each IP port.