Skip to content

Xilinx FPGA AXI4总线(四)——自定义 AXI-Lite 接口的 IP 及源码分析

  • Version
    • linhuangnan
    • 2024-03-11
    • AXI总线
    • review

Info

  • 在 Vivado 中自定义 AXI4-Lite 接口的 IP,实现一个简单的 LED 控制功能

  • 并将其挂载到 AXI Interconnect 总线互联结构上,通过 ZYNQ 主机控制

  • 对 Xilinx 提供的整个 AXI4-Lite 源码进行分析。

378

封装 AXI-Lite 协议的 IP

1. 新建一个工程

2. 打包 IP 工程

Tools 下选择创建并打包一个新的 IP。

379

选择创建一个新的带AXI4总线的 IP。

380

IP命名。

381

IP 的 AXI4-Lite 总线的配置

(1)选择 Lite 总线;

(2)选择 Slave 设备从机模式,这里考虑到我们的实际应用,以 ZYNQ 的 PS 做主机 Master,来读写自定义的从机LED IP;

(3)数据位宽 32-bit;

(4)内部寄存器最少为4个,这里选择4,实际上本例中只使用了 1 个,这里的 4 就代表内部由 4 个 32 位的寄存器,依次命名为 slv_reg0 ~ slv_reg3。

按照微机寻址的思想,当找到设备的基地址后,加上偏移地址能够找到设备的内部寄存器。这里,当偏移地址为 0 时,表示 slv_reg0,偏移地址为 4 时(4 个字节,32-bit),表示 slv_reg1,8 代表 slv_reg3,12 代表 slv_reg4。

例子中只使用 slv_reg0,偏移地址为0,这个在 ZYNQ 的 PS 端编程时使用。

382

上述配置完成后,编辑IP,会自动打开一个新的工程,在 AXI-Lite 接口协议基础上,添加自定义的端口和用户逻辑。

383

3. 修改 IP

打开底层的代码,在第18行添加自己需要的输出端口

ZC706的 PL 侧有 4 个 LED 可供操作,这里定义输出 4 位去控制 LED。

384

中间的实现逻辑先不看,是 AXI-Lite 协议中的 Valid、Ready 握手信号的产生以及读、写、响应等操作,后面再进行具体的分析。

找到尾部第401行,添加用户逻辑,上面我们已经说了PS 侧向 slv_reg0 写入 LED 的控制信息,这里从 slv_reg 读出控制信息,低 4 位为需要的有效控制信息。

385

完成底层的端口和用户逻辑后,在顶层中第 18 行也加入输出端口,并在例化底层时第 51 行将新加入的端口进行连接。

386

387

修改后,打包 IP 时可能出现如 1处所示的编辑图样,在 2 处点击蓝色字体会自动更新,点击 3 处打包。

388

使用自定义的 AXI-Lite的IP

找到开始时的新建工程,新建一个 Block Design 原理图设计文件,添加 IP 时就可以搜索到自定义的 LED_MyIP_Lite。

389

添加 ZYNQ,使用自动连接会自动添加复位逻辑和 AXI总线互联结构,添加一个 ILA 集成逻辑分析仪,并设置成 AXI4 LITE 接口,引出 LED 输出,原理图文件右键生成顶层 wrapper。

390

对 ILA 的配置

391

新建约束文件,增加 4 个 LED的物理约束,由于使用的是 Xilinx 的 FPGA评估版,其他引脚的约束已经由系统自动完成。

392

可以打开阅读一下 Xilinx 给的一些约束,如下图所示,首先对时钟频率和抖动进行时序约束,然后对输入输出引脚进行物理约束,最重要的是“电平标准”和“引脚位置”

393

综合、布局布线、生成 bitstream 后,导出硬件到 SDK。

新建 SDK 工程,加入代码如下,设置基地址和偏移地址。

394

运行结果

Run As 下载观察流水灯效果。

Debug As 下载,Vivado 中连接硬件,打开 ILA。

对于写事务,设置 WVALID和 WREADY 两个均为 1 时触发

对于读事务,设置检测 RVALID 和 RREADY 都为 1,两个断点处单步运行

(1)初始化

395

(2)写事务

写事务涉及到写地址通道、写数据通道和写响应通道。测试时,ZYNQ 的 PS 主机向 slv_reg0 写 1。

396

(3)读事务

读事务涉及到读地址通道和读数据通道。测试时,ZYNQ 的 PS 主机向 slv_reg0 写 1,然后读取该寄存器。

397

AXI4-Lite源码分析

(1)写事务

写事务涉及到写地址通道、写数据通道和写响应通道。

(a)AWADDR[3:0] 写地址

AWADDR[3:0] = 0,表示写 slv_reg0。

主机(ZYNQ的PS)给出从机的基地址 0x43C00000 和 偏移地址 0x0,其中基地址主要用于对整个从机的寻址,偏移地址用于对从机内部寄存器的寻址。

偏移地址为0,对应 AXI_AWADDR[3:0] = 0,在 32 位 WDATA 写数据配置下,AXI_AWADDR[3:2] 表示选择写哪个寄存器,

=0 时写 slv_reg0;

=1 时写 slv_reg1;

=2 时写 slv_reg2;

=3 时写 slv_reg3;

对应到 AXI_AWADDR[3:0] 就是 0 / 4 / 8 / 12。

398

(b)AWPORT[2:0] 写保护

AWPORT[2:0] = 1,即 3'b001,表示特权且安全的写入数据信息。

AWPORT[2:0] 提供三种级别的写入保护,提供用于禁止非法传输事务的访问权限:

399

(c)AWREADY 和 WREADY 准备好

根据 Xilinx 的 AXI-Lite 源码,对于从机部分,当检测到主机发出的 AWVALID 写地址有效 和 WVALID 写数据有效同时有效的下一个时钟的上升沿,将从机部分的 AWREADY 和 WREADY 拉起接收写地址和写数据。

对 AWREADY 写地址准备好:

400

对 WREADY 写数据准备好: