GTS Transceiver PHY User Guide: Agilex™ 5 FPGAs and SoCs
6.6. Hardware Testing the GTS PMA/FEC Direct PHY IP Example Design
You can perform hardware testing of the example design on the Agilex™ 5 FPGA E-Series 065B Premium Development Kit (ES1) board. You must select this development kit in the Select Board setting in the Example Design tab of the IP GUI, so that the reference clock and channel pin assignments are generated for the development kit’s hardware design by the Quartus® Prime software in the .qsf file.
#set_global_assignment -name POST_MODULE_SCRIPT_FILE "quartus_sh:board_assignments.tcl"
#set_global_assignment -name PRE_FLOW_SCRIPT_FILE "quartus_sh:board_assignments.tcl"After you have commented out the lines, you can set the pin assignments according to your board setup and the assignments are reflected in the example design.
Prior to the hardware testing, you need to ensure that the TX and RX serial data pin are connected correctly with external loopback module on the board. In addition, you should ensure that the system PLL, TX PLL and RX CDR PLL reference clock frequency is set correctly from the board clock source. You may also need to reconfigure the Agilex™ 5 FPGA E-Series 065B Premium Development Kit’s clock generator IC to ensure that the reference clock frequency matches the example design settings. You can find the instructions to make these change in the Agilex™ 5 FPGA E-Series 065B Premium Development Kit user guide.
- Internal serial loopback test
- External serial loopback test (with external loopback module connected)
- Navigate to the example design hardware directory, <design_example>/hwtest.
- Open Tools > System Debugging Tools > System Console
- Run the following command in System Console: 
      - source main.tclNote: Ensure that you are in the main hardware directory folder or else you may get a no source file found error.
 
- When you source the main.tcl, all the JTAG connections are listed on the console. You can also set the JTAG connections that you are using by using the following command: 
      - set_jtag <number_of appropriate_JTAG_master> Note: The set_jtag command places the Agilex™ 5 device on the JTAG chain. If you do not want to provide a reset when selecting JTAG, use the command, set_jtag_no_reset.
 
- You can use the following command in System Console to enable or disable the internal serial loopback mode when your design is 7Gbps and above. This command works only with your design with the RX auto adaptation mode enabled: run_test_silb The following figure displays the sample results of a successful run of the internal serial loopback test.Figure 99. Successful Hardware Testing Results For the Internal Serial Loopback Test
- You can use the following command in System Console to enable and disable the internal serial loopback mode when your design is below 7Gbps. This command works only with your design using the RX manual equalization mode (TX auto adaptation mode disabled). run_test_silb_bypass 
- You can use the following command in System Console to test the external serial loopback, if you have connected an external loopback module to the development kit. run_test_elb The following figure displays the sample results of a successful run of the external serial loopback test.Figure 100. Successful Hardware Testing Results For the External Serial Loopback Test