1.   时钟资源概述

  时钟设施提供了一系列的低电容、低抖动的互联线,这些互联线非常适合于传输高频信号、最大量减小时钟抖动。这些连线资源可以和DCM、PLL等实现连接。

每一种Spartan-6芯片提供16个高速、低抖动的全局时钟资源用于优化性能;这些资源可以背Xilinx工具自动地使用,即使时钟频率相对较低,使用时钟资源来消除潜在的时序冒险仍然是十分重要的,

每一个Spartan-6 FPGA提供40个超高速、低抖动的IO局部时钟资源(32个BUFIO2S和8个BUFPLL)这些IO局部时钟资源是为IO Serializer和de-serializer电路服务的。

Spartan-6 FPGA的时钟资源主要由四种类型的连接器构成:

  • 全局时钟输入引脚(GCLK)
  • 全局时钟多路复用器(BUFG、BUFGMUX)
  • IO时钟缓冲器(BUFIO2、BUFIO2_2CLK、BUFPLL)
  • 水平方向时钟布线缓冲器(BUFH)

有两种类型的时钟网络:

  • 为FPGA内部逻辑资源提供低抖动时钟资源的全局时钟网络
  • 为SelectIIO逻辑资源提供高性能低抖动时钟资源的IO局部时钟网络

  BUFGMUX能够在两个全局时钟资源之间进行复用,也可以当做普通的BUFG时钟缓冲使用,这个时钟缓冲只能够直接驱动全局时钟布线资源,只能够驱动时钟输入;当然,FPGA内部逻辑触发器的时钟输入也可以来自那些普通的布线资源,不过那些普通的布线资源会具有较大的时钟抖动。

  BUFPLL和BUFIO2用来驱动IO局部时钟网络的时钟资源,这一特性限定了它们的使用目的,他们只能用于ISERDES或OSERDES这资源的输入时钟资源;

  BUFIO2能够驱动SDR和DDR的ISERDES2和OSERDES2的时钟,BUFIO2能够把GCLK或GTP_DUAL Tile的输入时钟布线到BUFG、DCM、PLL时钟输入。BUFIO2_2CLK能够用来代替BUFIO2s使用在DDR的ISERDES2和OSERDES2的设计时钟。

  类似地,BUFPLL可以驱动SDR时钟的IO时钟网络,BUFPLL将PLL的CLKOUT0或CLKOUT1和IO局部时钟网络连接起来。

  BUFH通过提供逻辑资源与全局时钟布线水平区域的连接,使得芯片总体的低抖动时钟资源更为丰富。

1.1.  全局时钟结构

图 1‑1全局时钟结构

  Spartan-6 FPGA的全局时钟网络由16个位于器件中心位置的BUFGMUX驱动,时钟的输入可以来自FPGA的上、下、左、右的bank,也可以来自PLL或DCM;16个BUFGMUX驱动vertical spine并经vertical spine 往南北方向传播,根据这条线路,时钟水平延伸至HCLK时钟列并经HCLK时钟列提供了访问局部逻辑原语的路径;每一个HCLK列左右两边各有16个水平时钟缓冲BUFH驱动左右逻辑资源。

图 1‑2BUFH时钟布线路径

  在Spartan-6 FPGA器件上,有32个GCLK输入,但是只有16个全局时钟缓冲,也就是说每一个全局时钟缓冲只能被2个GCLK中的一个驱动,在两个GCLK(假设为GCLK_A和GCLK_B共享BUFGMX_C)都需要使用的情况下,为了为用户提供更多的灵活性,可以让GCLK_A引脚布线到BUFGMUX_C,而GCLK_B使用BUFIO2间接地布线到另一个BUFGMUX_D。但是经过BUFIO2布线的时钟会出现延时。

表格 1‑1 Bank0和Bank1共享全局时钟资源不完全统计情况表

图 1‑3Bank0和Bank1的BUFGMUX的连接情况

图 1‑4Bank2和Bank3的BUFGMUX的连接情况

  对于使用GTP Transceiver的设计来说,每一个GTP参考时钟是和一个BUFIO2关联在一起的,这可能影响Bank0和Bank2上的全局时钟引脚的使用;对SDR接口来说,GCLK的引脚输入与的冲突如表格 1‑2所示,对DDR接口来说,GTP需要两个BUFIO2,因为DDR的需要将时钟反转,DDR接口对GCLK引脚输入的冲突如表格 1‑3所示。

表格 1‑2SDR接口使用中BUFIO2的输入冲突

表格 1‑3DDR接口使用中BUFIO2的输入冲突

1.2.  IO时钟结构

1‑5IO时钟结构

  所有的SelectIOn的逻辑资源(输入寄存器、输出寄存器、IDDR2、ODDR2、ISERDES2、OSERDES2)必须被来自BUFIO2的时钟驱动;每个BUFIO2时钟域有4个高速I时钟,由4个专用BUFIO2 缓冲驱动;Spartan6 FPGA有4个BUFIO2时钟域共32BUFIO2.

1‑6BUFIO2时钟域

2.   时钟输入

  时钟输入引脚接受外部时钟信号并且直接将其连接至BUFGMUX或者BUFIO2原语。当然,时钟引脚也可以用作普通IO。BUFIO2除了能将时钟输入到IO时钟网络,BUFIO2也提供了专用的接往PLL/DCM或BUFG的时钟路线

2‑1经BUFIO2布线的专用时钟输入

  对Spartan-6 FPGA而言,专用的时钟输入引脚位于芯片边沿的中心位置,下图例举了4Bank的Spartan-6 FPGA的时钟引脚布局。

2‑2四Bank Spartan-6 FPGA 时钟引脚布局

3.   时钟管理技术

  Spartan-6 FPGA的CMT(时钟管理单元)提供了非常灵活、高性能的时钟;Spartan-6 FPGA的CMT模块位于竖直的全局时钟树的中间列位置,每个CMT包含2个DCM、1个PLL。

3‑1Spartan-6 FPGA CMT位置图

3‑2CMT结构框图

3.1.  DCM的功能

  DCM:Digital Clock Management,数字时钟管理单元的英文缩写。DCM拥有先进的时钟能力可将时钟直接导入全局时钟分布网络,DCM可以解决各种各样的时钟问题,尤其是在高性能、高频率领域。

  • 消除了时钟抖动,提升了整个系统的性能
  • 调节一个时钟信号的相位
  • 对输入时钟进行倍频或分频,也能够通过动态或静态的提供乘除因子产生新的时钟频率。
  • 使时钟信号更健康,占空比稳定在50%
  • 镜像、转发、重缓冲一个时钟信号,对输入时钟信号进行去抖斜或转换成差分IO电平。
  • 时钟输入抖动过滤
  • 扩频时钟产生
  • 振荡器工作模式

3‑3DCM结构框图

3.2.  PLL的功能

  PLL:Phase-Locked Loop,锁相环的英文缩写。Spartan-6 FPGA器件包含6个CMT Tile。PLL的主要目的是作为外部时钟或内部时钟的抖动过滤器或频率合成器。

3‑4PLL结构框图

转载于:https://www.cnblogs.com/dhyc/p/3968729.html

Spartan6系列之Spartan6系列之芯片时钟资源深入详解相关推荐

  1. 深入剖析Redis系列(三) - Redis集群模式搭建与原理详解

    前言 在 Redis 3.0 之前,使用 哨兵(sentinel)机制来监控各个节点之间的状态.Redis Cluster 是 Redis 的 分布式解决方案,在 3.0 版本正式推出,有效地解决了 ...

  2. shell编程系列23--shell操作数据库实战之mysql命令参数详解

    shell编程系列23--shell操作数据库实战之mysql命令参数详解mysql命令参数详解-u 用户名-p 用户密码-h 服务器ip地址-D 连接的数据库-N 不输出列信息-B 使用tab键代替 ...

  3. SQL Server时间粒度系列----第4节季、年时间粒度详解

    本文目录列表: 1.SQL Server季时间粒度 2.SQL Server年时间粒度 3.总结语 4.参考清单列表 SQL Serve季时间粒度   季时间粒度也即是季度时间粒度.一年每3个月是一个 ...

  4. Mysql高手系列 - 第20篇:异常捕获及处理详解(实战经验)

    Mysql高手系列 - 第20篇:异常捕获及处理详解(实战经验) 参考文章: (1)Mysql高手系列 - 第20篇:异常捕获及处理详解(实战经验) (2)https://www.cnblogs.co ...

  5. 离线强化学习(Offline RL)系列3: (算法篇)策略约束 - BRAC算法原理详解与实现(经验篇)

    论文原文:[Yifan Wu, George Tucker, Ofir Nachum: "Behavior Regularized Offline Reinforcement Learnin ...

  6. [Pytorch系列-61]:循环神经网络 - 中文新闻文本分类详解-3-CNN网络训练与评估代码详解

    作者主页(文火冰糖的硅基工坊):文火冰糖(王文兵)的博客_文火冰糖的硅基工坊_CSDN博客 本文网址:https://blog.csdn.net/HiWangWenBing/article/detai ...

  7. 毫米波雷达系列 | 基于前后向空间平滑的MUSIC算法详解

    毫米波雷达系列 | 基于前后向空间平滑的MUSIC算法详解 文章目录 毫米波雷达系列 | 基于前后向空间平滑的MUSIC算法详解 DOA阵列模型 MUSIC算法 空间平滑算法 整体流程 仿真代码 忙了 ...

  8. [Pytorch系列-60]:循环神经网络 - 中文新闻文本分类详解-2-LSTM网络训练与评估代码详解

    作者主页(文火冰糖的硅基工坊):文火冰糖(王文兵)的博客_文火冰糖的硅基工坊_CSDN博客 本文网址:https://blog.csdn.net/HiWangWenBing/article/detai ...

  9. 离线强化学习(Offline RL)系列3: (算法篇)策略约束 - BEAR算法原理详解与实现

    论文信息:Stabilizing Off-Policy Q-Learning via Bootstrapping Error Reduction 本文由UC Berkeley的Sergey Levin ...

最新文章

  1. Java C# 加密解密类库
  2. MaxCompute Tunnel SDK数据上传利器——BufferedWriter使用指南
  3. WebView实例开发之人人网Oauth2认证
  4. Angular页面发生更新时,更新如何从view层传递到model层
  5. nltkdata路径设置linux,NLTK data路径设置
  6. java怎么一段字符串全为数字_java 如何判断一个字符串是数字
  7. 打开本机网页总有安全提示,怎么办?
  8. 精通Android自定义View(十五)invalidate方法和postInvalidate方法
  9. python写web自动化_jenkins+selenium+python实现web自动化测试
  10. 什么是ooa,oop
  11. Summernote个性化定制使用帮助(三)
  12. word转pdf时图片模糊+文字版权的有效处理方式——Microsoft Print to PDF(YYDS)
  13. 未来计算机的新技术有哪些,科技改变生活!人类未来的十大高科技生活
  14. Python Pyside2新手应用淘宝客API接口简单获取淘宝客大额推广优惠券的实现
  15. 苹果开发者账号续费提示“支付授权失败”的问题
  16. 计算机视觉书籍资源推荐_Computer Vision Principles, Algorithms, Applications, Learning
  17. 小米MIX 2还没上一代震撼,为什么却说雷军更自信了?
  18. 深度学习环境配置避坑-CUDA11.0+DGL1.8
  19. excel表格打印每页都有表头_表头如何自动编号?日常工作中的表格打印常见问题解答...
  20. 回溯法--深度优先搜索

热门文章

  1. 通过网页api接口获取网页数据
  2. 简师网:最适合女生报考的公务员三大职位!
  3. 【MATLAB编程实例练习】-(15)红绿色方块染色问题
  4. 如何快速掌握Vuex
  5. PBOC借记贷记应用终端规范文档,对名词解释
  6. vue uniapp实现分段器效果
  7. 【机器学习】-----PCA(主成分分析)
  8. 快速理解LAN、WAN和WLAN的区别? -- 转载
  9. 重磅直播|视觉惯性SLAM之多约束扩展卡尔曼滤波
  10. JS高阶编程之柯理化函数