博客
关于我
ZYNQ开发实例之布局约束
阅读量:544 次
发布时间:2019-03-08

本文共 1160 字,大约阅读时间需要 3 分钟。

在FPGA设计中,时钟管理器是实现系统时钟需求的关键组件。本文将通过一个实际案例,指导如何通过约束文件消除时钟资源不足的警告,并优化时钟网络布局。

案例背景

在一个FPGA设计项目中,系统警告“Q平台资源不足”,这意味着当前时钟管理器(如PLL,MMCM等)无法满足系统时间需求。为了更好地理解问题,以下步骤会展示如何定位和解决此问题。

分配时钟管理器

  • 分配时钟管理器

    确定各时钟管理器负责的时钟网络。例如:

    • A1分配到MMCM1
    • A2分配到PLL
    • A3分配到MMCM2

    这种分配方式要求每个时钟管理器的时钟输入不会互相干扰,确保信号路径的干净。

  • 定位时钟管理器

    确认各MMCM和PLL的位置,避免其在板上密集布局导致信号衰减或干扰。例如:

    • MMCM1位于MMCME2_ADV_X1Y3
    • PLL位于PLLE2_ADV_X1Y2
    • MMCM2位于MMCME2_ADV_X1Y2

    通过检查这些位置,确保它们有足够的空间和足够的引脚可用。

  • 序列问题

    在实际设计中,序列编排可能导致时钟资源冲突。例如,若某个时钟网络请求多个时钟管理器访问同一引脚,这会导致矛盾。检查时钟网络路径,确保没有多个输入信号连接到同一输出引脚。

    添加约束

    通过在用户自定义约束文件中添加位置约束,确保时钟管理器不会相互干扰或重叠。例如:

    • set_property LOC MMCME2_ADV_X1Y3 [get_cells u_clk/U_CLK_CM1/u_CM1/inst/mmcm_adv_inst]
    • set_property LOC PLLE2_ADV_X1Y2 [get_cells u_dataProcess/u_dataProcess_1dfft_2/u_ad_interface_1_5/u_mmcm_ad_I/inst/plle2_adv_inst]
    • set_property LOC MMCME2_ADV_X1Y2 [get_cells u_dataProcess/u_dataProcess_1dfft_2/u_ad_interface_1_5/u_mmcm_ad_Q/inst/mmcm_adv_inst]

    验证约束效果

    在添加约束后,通过运行布局布局分析,确保时钟管理器的位置和资源使用情况没有冲突。使用工具核查目标器件路径,确保每个时钟网络的连接是唯一的且不受干扰。

    收益

    通过添加位置约束,我们:

    • 确保了每个时钟管理器的引脚和资源没有冲突
    • 统一了时钟网络的布局,避免未来的信号干扰
    • 提高了设计的可维护性和可扩展性

    这个优化步骤帮助我实现了对时钟资源的有效管理,消除了“Q平台资源不足”的警告,提升了系统的整体性能。

    结论

    合理规划时钟管理器的布局,通过位置约束确保他们能够独立运行,是确保FPGA设计稳定且高效的关键步骤。

    转载地址:http://jzfiz.baihongyu.com/

    你可能感兴趣的文章
    NodeJS 导入导出模块的方法( 代码演示 )
    查看>>
    nodejs 的 Buffer 详解
    查看>>
    nodejs 读取xlsx文件内容
    查看>>
    nodejs 运行CMD命令
    查看>>
    nodejs-mime类型
    查看>>
    NodeJs——(11)控制权转移next
    查看>>
    NodeJS、NPM安装配置步骤(windows版本)
    查看>>
    NodeJS、NPM安装配置步骤(windows版本)
    查看>>
    nodejs与javascript中的aes加密
    查看>>
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    Nodejs中的fs模块的使用
    查看>>
    nodejs包管理工具对比:npm、Yarn、cnpm、npx
    查看>>
    NodeJs单元测试之 API性能测试
    查看>>
    nodejs图片转换字节保存
    查看>>
    nodejs字符与字节之间的转换
    查看>>
    NodeJs学习笔记001--npm换源
    查看>>
    NodeJs学习笔记002--npm常用命令详解
    查看>>
    nodejs学习笔记一——nodejs安装
    查看>>
    nodejs封装http请求
    查看>>
    nodejs常用组件
    查看>>