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

    你可能感兴趣的文章
    No Datastore Session bound to thread, and configuration does not allow creation of non-transactional
    查看>>
    No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
    查看>>
    No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbalanc
    查看>>
    No mapping found for HTTP request with URI [/...] in DispatcherServlet with name ...的解决方法
    查看>>
    No mapping found for HTTP request with URI [/logout.do] in DispatcherServlet with name 'springmvc'
    查看>>
    No module named 'crispy_forms'等使用pycharm开发
    查看>>
    No module named cv2
    查看>>
    No module named tensorboard.main在安装tensorboardX的时候遇到的问题
    查看>>
    No module named ‘MySQLdb‘错误解决No module named ‘MySQLdb‘错误解决
    查看>>
    No new migrations found. Your system is up-to-date.
    查看>>
    No qualifying bean of type XXX found for dependency XXX.
    查看>>
    No resource identifier found for attribute 'srcCompat' in package的解决办法
    查看>>
    no session found for current thread
    查看>>
    No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
    查看>>
    NO.23 ZenTaoPHP目录结构
    查看>>
    NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
    查看>>
    NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
    查看>>
    Node JS: < 一> 初识Node JS
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>