Intel® FPGA SDK for OpenCL™: Intel® Arria® 10 GX FPGA Development Kit Reference Platform Porting Guide
                    
                        ID
                        683267
                    
                
                
                    Date
                    3/28/2022
                
                
                    Public
                
            
                
                    
                        1. Intel® FPGA SDK for OpenCL™ Intel® Arria® 10 GX FPGA Development Kit Reference Platform Porting Guide
                    
                    
                
                    
                        2. Developing Your Intel® Arria® 10 Custom Platform
                    
                    
                
                    
                        3. Intel® Arria® 10 GX FPGA Development Kit Reference Platform Design Architecture
                    
                    
                
                    
                    
                        4. Intel® FPGA SDK for OpenCL™ Intel® Arria® 10 GX FPGA Development Kit Reference Platform Porting Guide Archives
                    
                
                    
                    
                        5. Document Revision History for the Intel Arria 10 GX FPGA Development Kit Reference Platform Porting Guide
                    
                
            
        
                        
                        
                            
                            
                                1.1. Intel® Arria® 10 GX FPGA Development Kit Reference Platform: Prerequisites
                            
                        
                            
                                1.2. Features of the Intel® Arria® 10 GX FPGA Development Kit Reference Platform
                            
                            
                        
                            
                            
                                1.3. Contents of the Intel® Arria® 10 GX FPGA Development Kit Reference Platform
                            
                        
                            
                                1.4. Intel Arria 10 GX FPGA Development Kit Reference Platform BSP Changes Between Intel® Quartus® Prime Design Suite Releases
                            
                            
                        
                    
                
                                    
                                    
                                        
                                        
                                            1.4.1. BSP Changes from Intel® Quartus® Prime Design Suite Version 16.1 to Version 17.0
                                        
                                        
                                    
                                        
                                        
                                            1.4.2. BSP Changes from Intel® Quartus® Prime Design Suite Version 17.0 to Version 17.1
                                        
                                        
                                    
                                        
                                        
                                            1.4.3. BSP Changes from Intel® Quartus® Prime Design Suite Version 17.1 to Version 18.0
                                        
                                        
                                    
                                        
                                        
                                            1.4.4. BSP Changes from Intel® Quartus® Prime Design Suite Version 18.0 to Version 18.1
                                        
                                        
                                    
                                        
                                        
                                            1.4.5. BSP Changes from Intel® Quartus® Prime Design Suite Version 18.1 to Version 19.1
                                        
                                        
                                    
                                
                            
                        
                        
                            
                            
                                2.1. Initializing Your Intel® Arria® 10 Custom Platform
                            
                        
                            
                            
                                2.2. Modifying the Intel® Arria® 10 GX FPGA Development Kit Reference Platform Design
                            
                        
                            
                            
                                2.3. Integrating Your Intel® Arria® 10 Custom Platform with the Intel® FPGA SDK for OpenCL™
                            
                        
                            
                            
                                2.4. Setting up the Intel® Arria® 10 Custom Platform Software Development Environment
                            
                        
                            
                            
                                2.5. Establishing Intel® Arria® 10 Custom Platform Host Communication
                            
                        
                            
                            
                                2.6. Branding Your Intel® Arria® 10 Custom Platform
                            
                        
                            
                            
                                2.7. Changing the Device Part Number
                            
                        
                            
                            
                                2.8. Connecting the Memory in the Intel® Arria® 10 Custom Platform
                            
                        
                            
                            
                                2.9. Modifying the Kernel PLL Reference Clock
                            
                        
                            
                            
                                2.10. Integrating an OpenCL Kernel in Your Intel® Arria® 10 Custom Platform
                            
                        
                            
                                2.11. Guaranteeing Timing Closure in the Intel® Arria® 10 Custom Platform
                            
                            
                        
                            
                            
                                2.12. Troubleshooting Intel® Arria® 10 GX FPGA Development Kit Reference Platform Porting Issues
                            
                        
                    
                
                        
                        
                            
                                3.1. Host-to- Intel® Arria® 10 FPGA Communication over PCIe®
                            
                            
                        
                            
                                3.2. DDR4 as Global Memory for OpenCL Applications
                            
                            
                        
                            
                            
                                3.3. Host Connection to OpenCL Kernels
                            
                        
                            
                                3.4. Intel® Arria® 10 FPGA System Design
                            
                            
                        
                            
                            
                                3.5. Dynamic PLL Reconfiguration
                            
                        
                            
                                3.6. Guaranteed Timing Closure of the Intel® Arria® 10 GX FPGA Development Kit Reference Platform Design
                            
                            
                        
                            
                                3.7. Intel® Quartus® Prime Compilation Flow and Scripts
                            
                            
                        
                            
                            
                                3.8. Addition of Timing Constraints
                            
                        
                            
                                3.9. Connection of the Intel® Arria® 10 GX FPGA Development Kit Reference Platform to the Intel® FPGA SDK for OpenCL™
                            
                            
                        
                            
                                3.10. Intel® Arria® 10 FPGA Programming Flow
                            
                            
                        
                            
                            
                                3.11. Host-to-Device MMD Software Implementation
                            
                        
                            
                                3.12. Implementation of Intel® FPGA SDK for OpenCL™ Utilities
                            
                            
                        
                            
                            
                                3.13. Intel® Arria® 10 FPGA Development Kit Reference Platform Scripts
                            
                        
                            
                            
                                3.14. Considerations in Intel® Arria® 10 GX FPGA Development Kit Reference Platform Implementation
                            
                        
                    
                
                                    
                                    
                                        
                                        
                                            3.1.1. Instantiation of Intel® Arria® 10 PCIe* Hard IP with Direct Memory Access
                                        
                                        
                                    
                                        
                                        
                                            3.1.2. Device Identification Registers for Intel® Arria® 10 PCIe Hard IP
                                        
                                        
                                    
                                        
                                        
                                            3.1.3. Instantiation of the version_id Component
                                        
                                        
                                    
                                        
                                        
                                            3.1.4. Definitions of Intel® Arria® 10 FPGA Development Kit Reference Platform Hardware Constraints in Software Headers Files
                                        
                                        
                                    
                                        
                                        
                                            3.1.5. PCIe Kernel Driver for the Intel® Arria® 10 GX FPGA Development Kit Reference Platform
                                        
                                        
                                    
                                        
                                            3.1.6. Direct Memory Access
                                        
                                        
                                        
                                    
                                        
                                        
                                            3.1.7. Message Signaled Interrupt
                                        
                                        
                                    
                                        
                                        
                                            3.1.8. Partial Reconfiguration
                                        
                                        
                                    
                                        
                                        
                                            3.1.9. Cable Autodetect
                                        
                                        
                                    
                                        
                                            3.1.10. Host Channel
                                        
                                        
                                        
                                    
                                
                            3.12.5.1. Possible Errors After Running the diagnose Utility
 This section provides debugging steps to some of the errors you might encounter after implementing the diagnose utility. 
  
 
  Memory Module Not Plugged-in or a Loose Connection on the Board
    If the memory module is not plugged in or if there is a loose connection on the board, you might see errors similar to the following example:
    
 
   aocl diagnose: Running diagnose from 
aocl diagnose: failed 32 times. First error below:
Vendor: Intel Corporation
MMD INFO: [acla10_ref0] uniphy(s) did not calibrate. Expected 0 but read 2
MMD INFO: If there are more failures than Uniphy controllers connected, 
MMD INFO: ensure the uniphy_status core is correctly parameterized.Solution
Confirm that you have connected the memory board, power cable, and USB cable correctly as shown in Configuring and installing the Intel Arria 10 GX FPGA Development Kit board. If you have confirmed your connections and continue to get this error, the memory board might not be seated correctly in the HiLo connector.
Error While Loading Shared Libraries
When you execute diagnose all utility, you might see errors as shown in the following example:
$ aocl diagnose all
hld/board/a10_ref/linux64/libexec/diagnose: error while loading shared libraries: 
libaltera_a10_ref_mmd.so: cannot open shared object file: No such file or directorySolution
Ensure that you have set the PATH environment variable correctly.
export PATH=$PATH:$INTELFPGAOCLSDKROOT/bin:$QUARTUS_DIR/bin