博客
关于我
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/

    你可能感兴趣的文章
    PHP获取本周的每一天的时间
    查看>>
    php获取用户真实IP和防刷机制
    查看>>
    php获取网页内容的三种方法
    查看>>
    R-CNN算法优化策略
    查看>>
    PHP规范PSR0和PSR4的理解
    查看>>
    php解析ipa包,获取logo
    查看>>
    R&Rstudio安装各种包
    查看>>
    php设置cookie,在js中如何获取
    查看>>
    php设置socket超时时间
    查看>>
    php设计模式 萨莱 pdf,PHP设计模式 建造者模式
    查看>>
    PHP设计模式之----观察者模式
    查看>>
    php设计模式之装饰器模式
    查看>>
    R&Python Data Science系列:数据处理(5)--字符串函数基于R(一)
    查看>>
    PHP设计模式:观察者模式
    查看>>
    php访问mysql(1)
    查看>>
    php详细学习1
    查看>>
    php语言优劣
    查看>>
    PHP语言最优雅的支付SDK扩展包
    查看>>
    PHP请求https域名发生segment fault段错误
    查看>>
    PHP读写XML文件
    查看>>