ZYNQ 中 AXI BRAM 的使用详细的说明。

ZYNQ 中 AXI BRAM 的使用详细的说明。


🧩 1. 基本概念

  • BRAM (Block RAM)
    FPGA 内部的片上存储器,容量一般在几 KB 到几百 KB,速度快,延迟低。
  • AXI BRAM Controller
    一个桥接 IP,用来把 AXI 总线协议 (PS 侧)转换为 BRAM 接口信号(PL 侧)。这样,PS 就能像访问内存一样访问 FPGA 内部的 BRAM。
  • 支持协议
    • AXI4-Lite:单次读写,适合控制寄存器。
    • AXI4:支持突发传输,适合数据块读写。

⚙️ 2. 使用流程

(1) Vivado 硬件设计

  1. Block Design 中添加:
    • AXI BRAM Controller IP
    • BRAM Generator IP
  2. 将 AXI BRAM Controller 的 AXI 接口 连接到 ZYNQ PS 的 M_AXI_GP0/GP1
  3. Address Editor 中分配地址空间,例如:
    • 基地址:0x4000_0000
    • 大小:8KB
  4. 生成 bitstream 并导出硬件到 SDK/Vitis。

(2) BRAM 配置

  • 端口模式
    • 单端口:一个读写口。
    • 简单双端口:一个读口,一个写口。
    • 真双端口:两个独立读写口,可并行访问。
  • 位宽与深度
    可配置,如 32-bit × 2048 深度。

(3) 软件访问方式

在 Linux 或裸机环境下,PS 可以通过 AXI 总线访问 BRAM。

  • 裸机 (SDK/Vitis)

    直接用指针访问分配的地址空间:

    c 复制代码
    #define BRAM_BASE 0x40000000
    volatile int *bram_ptr = (int *)BRAM_BASE;
    bram_ptr[0] = 0x12345678;   // 写入
    int val = bram_ptr[0];      // 读取
  • Linux 环境

    1. /dev/mem 映射

      c 复制代码
      int fd = open("/dev/mem", O_RDWR|O_SYNC);
      void *map_base = mmap(0, 8192, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0x40000000);
      volatile int *bram_ptr = (volatile int *)map_base;
      bram_ptr[0] = 0x55AA55AA;
    2. UIO 驱动

      • Vivado 中配置 BRAM 为 UIO 设备。
      • Linux 下通过 /dev/uioX 访问。
    3. 自定义驱动

      • 编写字符设备驱动,封装读写接口,适合复杂应用。

📊 3. 应用场景

  • PS ↔ PL 数据交互
    例如:PS 接收网络数据,写入 BRAM,PL 逻辑再读取处理。
  • 缓存/缓冲区
    在高速数据流中,BRAM 作为临时存储,减少 DDR 访问延迟。
  • 共享内存
    PS 与 PL 共享 BRAM,实现双向通信。
  • 数据搬移
    BRAM 作为中间缓冲区,配合 DMA 实现高速数据传输。

🔑 4. 注意事项

  • 位宽匹配:AXI 总线位宽与 BRAM 位宽需一致。
  • 地址对齐:访问时必须按字对齐,否则可能出错。
  • 容量限制:BRAM 容量有限,适合小数据块缓存,不适合大规模存储。
  • 性能优化:双端口模式可提高并行度;突发传输可提升带宽。

📝 总结

在 ZYNQ 中,AXI BRAM 控制器是 PS 与 PL 高效交互的关键机制

  • 硬件上:通过 Vivado 配置 AXI BRAM Controller + BRAM Generator,分配地址空间。
  • 软件上:通过裸机指针访问或 Linux 下的 /dev/mem、UIO、自定义驱动来读写。
  • 应用上:适合高速缓存、共享内存、数据缓冲等场景。

相关推荐
坏孩子的诺亚方舟3 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐3 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐3 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH4 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
火花页.4 天前
【正点原子ZYNQ领航者7020】AXI GPIO与EMIO联合自行编写的verilog模块完成按键控制LED以及LED闪烁
zynq
zlinear数据采集卡4 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安4 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐5 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯5 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客5 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c