【FPGA 开发教程】基于 ALINX FPGA 开发板实现 USB3.2 高速通信(Z7-P+FL2010)

教程目的

基于 ALINX FPGA 开发板FL2010 USB3.2 子卡 实现高速数据通信。

介绍子卡硬件特性、主控芯片功能、FMC 接口连接方式、数据传输模式,为后续基于 USB3.2 的实际应用开发提供基础。


FL2010 USB3.2 子卡

ALINX FL2010 子卡是 USB3.2 FMC 通信模块,与 ALINX FPGA 开发板配合使用,可实现 USB3.2 数据通信。

  • 主控芯片 :采用英飞凌 CYUSB4024-FCAXI 芯片,内部集成 ARM 架构 CPU 和 USB 控制器,负责 USB3.2 数据传输。
  • 连接方式 :通过 FMC 接口与 FPGA 载板相连,通过 16 对 LVDS 数据通道与 FPGA 进行通信。
  • 供电方式:可通过 USB3.2 接口供电。
  • 调试接口:板载 Debug 口,用于输出串口调试信息。
  • 产品官网www.alinx.com(FL2010)
  • 开发资源 :更多开发信息请参考英飞凌官网:www.infineon.cn

FL2010 与 FPGA 开发板的连接

FL2010 子板通过 FMC 接口与 FPGA 开发板连接,支持两种数据通信模式:

模式 差分数据通道数 Lane 速率
Wide Link 16 对 594 Mbps
Narrow Link 8 对 594 Mbps
  • 数据恢复方式 :可通过原语 ISERDES3BITSLIP 实现数据传输。
  • 工程实现 :示例工程中例化了 High Speed SelectIO IP 核,用于统一管理上述原语。

(CYUSB4024-FCAXI 与 FPGA 连接的接口示意图)

FL2010 子卡接口信号说明

1. LVDS 数据与控制信号

信号名 方向 功能描述
P0D0P ~ P0D7P FPGA → CYUSB4024 Port0 的 8 对差分数据线
P1D0P ~ P1D7P FPGA → CYUSB4024 Port1 的 8 对差分数据线
P0CP, P1CP FPGA → CYUSB4024 控制字符输入

2. LVDS 模式下的控制信号

  • p0ctl0 ~ p0ctl4:LVDS 模式下不使用。
  • p0ctl5 :CYUSB4024 → FPGA,link_ready 信号,用于数据链路训练。
  • p0ctl6 :CYUSB4024 → FPGA,buffer_ready 信号,用于数据传输控制。

Port1 的控制信号(p1ctl0 ~ p1ctl6)定义与 Port0 相同。

3. 信号使用规则

  • Wide Link 模式:仅使用 Port0 的控制信号(p0ctl)。
  • Narrow Link 模式
    • 若选择 Port0,使用 p0ctl;
    • 若选择 Port1,使用 p1ctl。

FPGA 作为从机工作

在 demo 中,FPGA 作为 CYUSB4024-FCAXI 的 从机 工作。两者之间还需要 I2C 通信,FPGA 作为 I2C 从机,响应读写请求并访问内部寄存器。寄存器的内容由 CYUSB4024 执行的固件(firmware)决定。

I2C 两根控制线的连接位置如图示:

上电复位要求

FL2010 子卡上电时,FPGA 需要提供一个 低电平有效 的复位信号,具体引脚位置如图示。

硬件设计约束

  • 差分对的数据线必须连接到 FPGA 的 HP Bank
  • 一个 Port 的所有差分线(数据线+控制字符线)必须位于 同一 Bank

FPGA 工程介绍

FPGA 工程包含三个主要部分:

  1. 时钟模块

    根据 Lane 速率 594 Mbps 计算,参考时钟应为 74.25 MHz

  2. FL2010 对接模块

    实现 LVDS 通信的逻辑。

  3. High Speed SelectIO IP

    由于 demo 基于 Z7-P 开发板,Port0 位于 Bank64,Port1 位于 Bank65,需例化 两个 High Speed SelectIO IP(单个 IP 只能配置一个 Bank)。

工程结构如图示:

FL2010 对接模块也包含三个部分:

  1. 图像生成
  2. I2C 从机应答模拟
  3. FL2010 软件协议解析

图像通过控制 test_pattern_generator 生成彩条,FL2010 接收到彩条之后模拟成相机传输图像给 USB 3.2 的 host 设备。

FL2010 子卡对接模块包含以下几个子控制模块:

1. Device Selection DSM

  • 功能:设备选择,最多支持 8 路设备通过 LVDS 信号线串行传输。
  • 工作流程
    • 工程烧录后,先进行 PHY 训练 ,完成后进行 Link 训练
    • 训练完成后进入设备遍历状态,以帧为单位遍历设备。

状态机切换方式如图示:

注:对于 Low Power 状态,实际未做任何操作,因为 demo 使用 LVDS 模式;demo 中仅使用一路输入。

  • 功能:实现 PHY 训练和 Link 训练。
  • 流程
    • FL2010 通过 I2C 下发 4 字节训练数据(写入寄存器)。
    • 本模块按顺序发送训练数据,无需等待子卡反馈。
    • 训练完成时通过 I2C 下发 complete 信号。

状态机切换方式如图示:

3. Frame Data Transmitter FSM

  • 功能:帧数据打包传输。
  • 触发条件 :收到 Device Selection 模块的 device_serve 信号。部分状态切换取决于 FL2010 子卡的固件配置。

4. Initial Socket Sequence FSM

  • 功能:决定初始化顺序,分配初始的线程和 socket 地址。
  • 工作 :在 Frame Data Transmitter FSM 的 init_socket_seq 状态下工作。

状态机切换方式如图示:

5. Frame Header Transmitter FSM

  • 功能:配置帧头部信息。
  • 工作 :在 Frame Data Transmitter FSM 进入 TX_FRAME_HEADER_INFO 后开始工作。

状态机切换方式如图示:

6. LVDS Data Packet Transmitter FSM

  • 功能:实现数据的组包传输。

状态机如图示:

7. Frame End Sequence FSM

  • 功能:每帧结尾时发送帧结尾信号。

状态机如图示:

FL2010 部分固件 (Firmware) 编译步骤

  1. 打开 Eclipse,选择工作空间(Workspace)。
  1. 选择 New Application
  1. BSP 这里选择 FX20
  1. 在下一个页面选择 UVC_UAC_4K_camera
  1. 打开该工程的 makefile 文件。
  1. 设置模式参数:
    • WL_EN = 1:表示开启 Wide Link 模式(此时需将 port1_en 设为 0)。

Demo 复现

固件下载到 FL2010 子卡(通过 USB 烧录)

  1. 工程编译后,在 build 文件夹中找到生成的 .hex 文件,将这个文件通过FX Control Center 软件下载到板子上。
  1. FMC 子卡上插入跳帽。
  1. TypeC 口插入 USB 线连接电脑,按下子卡上的 KEY1 ,再按下 Key2,然后先松开 Key1 再松 Key2。出现软件界面如下:
  1. 单击 EZ_USB FX BOOT LOADER
  2. 选择 Program → Internal Flash
  1. 选择编译生成的 .hex 文件,等待烧录完成。

上板运行

  1. 将 FL2010 FMC 子板连接到 ALINX 开发板,Debug 口链接串口,TypeC 口链接电脑,板卡上电。
  1. 从 Vitis 烧录 FPGA 程序。

    注:如果 Windows 相机未打开,会打印相应提示:

此时打开 Windows 相机应用,显示彩条画面。

相关推荐
熠速2 小时前
PolarBox高性能实时仿真系统
arm开发·fpga开发·嵌入式实时数据库·硬件在环半实物仿真
南檐巷上学3 小时前
基于Zynq-7020的带有正弦波发生器的8051软核设计
单片机·嵌入式硬件·fpga开发·fpga
思尔芯S2C3 小时前
FPGA原型验证中的内存模型应用:基于DDR5的Linux系统启动与测试
fpga开发·内存模型·ddr4·ddr5·memory model·hbm3·prototyping
hai31524754312 小时前
RISC-V CVA6 AXI适配器+DMA桥蜂鸟E203处理器的总线接口单元(BIU)仲裁器
驱动开发·fpga开发·硬件架构·硬件工程·精益工程
高速上的乌龟17 小时前
Lattice LFCPNX-100 HSB+Fpga开发详解:2.3 Hololink 顶层模块深度全解析
linux·fpga开发
Ricky055321 小时前
搭载实时 FPGA 处理系统的航天器上用于海上监视的超分辨率YOLO目标检测技术(意大利2026年研究)
yolo·目标检测·fpga开发
kaizq1 天前
在线设计模仿平台StepFPGA应用实践
fpga开发·verilog编程·在线设计仿真·小脚丫stepfpga·图形化设计·risc-v_soc·ima-copilot-ds
cjie2211 天前
图像缩放需要哪些参数和端口
计算机视觉·fpga开发
思尔芯S2C1 天前
FPGA Prototyping That Creates Useful Pre-Silicon Evidence
fpga开发