180H_FPGA时钟结构

时间:2022-11-27 12:56:35


PLL 端口信号解释

信号名

含义

PLL_PWD

power down

pll_rst

复位PLL

clkin_dsel

0:clkin1作为参考时钟;1:clkin2作为参考时钟

clkfb

外部反馈时钟输入

dyn_idiv[5:0]

动态 input divider(输入分频器) 分频系数 0:64分频;1:63分频;…

dyn_fdiv[5:0]

动态feedback divider(反馈分频器) 0:64分频;1:63分频;…

dyn_odiv[5:0]

动态clkout_0_divider (输出0分频器) 0:128分频;1:120分频;…8为步进

dyn_odiv2/3/4[5:0]

动态clkout_2/3/4_divider(输出2/3/4分频器) 0:128分频;1:126分频;…2为步进

dyn_phase1/2/3/4[3:0]

clkout_1/2/3/4动态相位:0:0度;1:22.5度;…22.5度为步进

reset_idiv

复位input divider(输入分频器)

reset_odiv

复位output divider(输出分频器)

clkout0/1/2/3/4_gate

gate(门控)对应输出时钟

pll_lock

锁定

clkout0/1/2/3/4

时钟输出

PLL 的输出频点计算

只看反馈时钟选择内部CLKOUT[1:0]情况。

divider模式 :clkout[0] = clkin x fdiv/idiv

divider模式 :[1] = 只是clkout[0]的移相

divider模式 :clkout[2]=clkin x fdiv /(idiv x odiv2)

divider模式 :clkout[3]= clkin x fdiv /(idiv x odiv3)

frac_divider模式:clkout[3]= 0.5 x clkin x fdiv x odiv0 /(idiv x ( clkout3_div125_m+clkout3_div125_n*0.125 ) );

注:(clkout3_div125_m,clkout3_div125_n) != (1,1)

clkout3 m(1~63) + (07)N.125小数分频;(1.0 (63+7x0.125) )

divider模式 :clkout[4]= clkin x fdiv /(idiv x odiv4)

cnt_divider模式 :clkout[4]= clkin x fdiv / (idiv x odiv4) x(1/2^33) x clkout4_div32bit_k

保证 : 2^33 / clkout4_div32bit_k是整数 那么 clkout4_div32bit_k必须是2的整数幂;clkout0/clkout4 divider<=50

结论:pll能保证clkfb时钟和clkin时钟的相位保持一致。

180H时钟概述

3种时钟类型

GCLK:global clk,基于象限。整个芯片分4象限;每个象限各有14个GCLK网络。
RCLK:regional clk,8个region,每个region各有2个RCLK
IO_CLK:专用于高速接口应用的器件每一侧(左侧除外)各有四个 IO CLK 网络。

2种时钟硬核

PLL:PGT180H 提供了 8 个 PLL,以 满足用户关于频率变化和相位调整的需求。
DLL:PGT180H 片内提供了 8 个DLL 为高速接口应用提供了延 迟锁相功能。

3种时钟IO类型

a)普通时钟输入管脚(共18个)
b)PLL 参考时钟输入管脚(仅限于 CLKOUT[0]和CLKOUT[1])
c)PLL 反馈输入时钟管脚
下文的时钟输入管脚(IO_CLK)指三者统称。

时钟输入管脚 既可以作为普通IO使用,又可以作为时钟输入使用。
当作为时钟输入使用的优点:避免普通布线资源带来的干扰。

时钟输入管脚可直接接入到内部所有时钟网络,包括 GLOBAL CLK,REGIONAL CLK 或 IO CLK; 从而减少干扰,提高时钟质量。时钟输入管脚可以是一对差分输入端口,也可以是一个单端输入端口; 选择单端输入时,仅仅 PAD T 可直接接入到内部时钟网络。

时钟输入管脚在哪?

BANK1/4/9/12 没有时钟输入管脚,其它 BANK 各有两个时钟输入管脚;整个芯片共有 18 个时钟输入管脚。

时钟输入管脚是否能调整输入时钟的延时(相位)?

CLKDELAY模块

180H_FPGA时钟结构


每个时钟输入管脚都有有 CLKDELAY模块,可以调整范围255 x 25ps的延时。

GCLK

不但时钟可以进入GCLK,而且fanout 较高的信号(如 CE/RS 信号)也可以用GCLK 来实现。

GCLK 的源有哪些?

180H_FPGA时钟结构


图中可以看到:时钟输入管脚、PLL 输出时钟、IOCLKDIV 输出时钟、HSST的输出时钟和内部逻辑信号都可以作为GCLK的源。

全局时钟输入源之间可能出现冲突。

USCM是什么?

USCM(User Select Clock Mux)为 GLOBAL CLK 提供了 clock gate 和 clock mux 的功能,它支持 CLKBUFG,CLKBUFGCE 以及 CLKBUFGMUX 三种模式。每个 GLOBAL CLK 网络均包含一个 USCM 模块,所以 Titan 系列产品共有 56 个 USCM 模块。

时钟资源在FPGA的位置布局

180H_FPGA时钟结构

RCLK

REGIONAL CLK 基于 Region 分布,每个 Region 有各自独立的 2 个 REGIONAL CLK 网络。除了驱动本地 Region,也可以通过 rhmux(regional horizontal mux)将水平方向相邻的两个 REGIONAL CLK联在一起作为一个大 Region 使用。
与 GLOBAL CLK 相比,REGIONAL CLK 的优点是延迟小,skew 小,但它分布范围有限;

RCLK的源有哪些?

180H_FPGA时钟结构

180H_FPGA时钟结构


只在region内部会多一个 DCC DIV 源。

IO_CLK

180H_FPGA时钟结构


可以看到有3个模块组成。

180H_FPGA时钟结构

ioclkbuf

相当于一个gate

ioclkmux

选择

ioclkdiv

分频比,“2”; “3.5”; “4”; “5”

为什么PLL_CLKOUT[2/3/4]不能连接到IO_CLK?

unknown

DDC(Dedicated DQS Circuit)是每个 IO GROUP 配有一个专用的 DQS 控制电路,主要用于 DDR memory 接口应用。
DCC(Dedicated CDR Circuit),为专用 CDR 电路,可用于高速异步输入接口应用。

PLL

180H_FPGA时钟结构


频率鉴相器(PFD)

CP(Charge Pump)

VCO 频率锁定在 600MHz~1.3GHz 之间。

反馈时钟为CLKOUT[0]时:

180H_FPGA时钟结构


180H_FPGA时钟结构

PLL的源有哪些?

180H_FPGA时钟结构


时钟源切换后需要对 PLL 复位以便它重新锁定。

PLL外部 FB的源有哪些?

180H_FPGA时钟结构

在 VCO 锁定 LOOP 内的时钟不能被 GATE:例如选择 CLKOUT[0]内部反馈时,该时钟输出不应被动态 GATE。
PLL 时钟输出端口 CLKOUT[1]~CLKOUT[4]均支持可选的相位调节功能,相位调整的粒度为 1/8个时钟周期。
PLL 的 CLKOUT[2]支持输出频率的进一步分频,CLKOUT[2]的分频比由 O2DIV 决定,选中时:
CLKOUT[2]的频率 = CLKOUT[0]的频率/O2DIV
CLKOUT[3]支持输出频率的进一步分频,包括 O3DIV 决定的分频和支持基于 0.125 的简
易小数分频。选择 O3DIV 模式时:
CLKOUT[3]的频率 = CLKOUT[0]的频率/O3DIV
选择基于 0.125 的简易小数分频模式时:
CLKOUT[3]的频率 = (VCO 频率/2)/(M+N*0.125)
其中 M=1,2 . . . 64, N=0,1,…7 (注:当 M=1 时 N!=0)
PLL 的 CLKOUT[4]支持输出频率的进一步分频,包括 O4DIV 决定的分频和支持基于 32bit 计数
器的简易小数分频。选择 O4DIV 模式时:
CLKOUT[4]的频率 = CLKOUT[0]的频率/O4DIV
选择基于 32bit 计数器的简易小数分频时:
CLKOUT[4]的频率 = VCO 的频率/(2^33/Delta)
Delta=1~(2^32-1)
如对 VCO 锁定 LOOP 内的
配置作动态修改后,需要对 PLL 复位。如对其它 output divider 配置作动态修改后,建议使用
RESET_ODIV 端口对分频计数器作复位,并在之后复位 PLL 输出驱动的相关逻辑,以避免死锁。

关键原则

PLL 的端口 CLKIN 和 CLKFB 相位对齐

DLL

PGT180H 芯片有 8 个 DLL,芯片左上角、左下角、右上角和右下角各有两个。DLL 的主要功能是动态锁定输入参考时钟的频率,输出该时钟周期的四分之一等效 delay step 数目。这个 Delay step可实时追踪温度和电压的变化

​[1] PGT180H时钟UG​​​​[2] 简述DLL与PLL的区别 ​