PLL(Phase Locked Loop):为锁相回路或锁相环,是常常用到的 IP,用来统整合时脉讯号,能够以输入的基准时钟信号为基础,输出分频或者倍频的信号,以供芯片内部多个模块的使用(不同的时钟)。
下面就以 Spartan-6 (xc6slx9)为模板,创建一个 PLL IP 来使用(既然是 SP-6 那么就是用的 ISE 了)。
外部输入 25MHz 接到全局时钟输入口。目标是配置 25MHz 的 PLL 输入,分别产生 2 分频、1分频、2倍频、4倍频的时钟信号,即 12.5MHz、25MHz、50MHz、100MHz 分别供计数器模块,并驱动 LED 等闪烁;
创建过程为:
1、工程文件中,Design->Implementation 任意空白处右键,选择 New Source
2、在弹出的“New Source Wizard -> Select Source Type”下,如图 7.19 所示,选择文件类型为 “IP (CORE Generator & Architecture Wizard)”。“File name”可以给新创建的 PLL 取个名字,我们命名为“pll_controller”。“Location”即生成的新文件所有相关源文件的存储路径,默认即为当前工程路径下的一个名为“ipcore_dir”的文件夹中,通常我们不需要更改它。点击“Next”继续。
3、点击 “Next”后,弹出选择 IP 的界面,接着进入“New Source Wizard -> Select IP”页面,选择 IP 核类型为“FPGA Features and Design -> Clocking -> Clocking Wizard”。点击“Next”继续。
4、前面的配置信息在 “New Source Wizard Summary” 页面重新罗列供review。点击“Finish” 继续
5、此时,我们注意到 Design 界面下有如图 7.22 所示的“Creating: pll_controller.xco”的提示信息,大家需要耐心等待一会,新建的 PLL 模块正在创建中,随后将会弹出 PLL 的配置页面。
6、在弹出的 PLL 配置页面 Page1 中,主要设置“Input Clock Information”下的输入时钟频率,这里我们在“Value”下输入“25”MHz(外部 25MHz 输入)。其他的配置通常使用默认即可,大家也可以点击右下角的“Datasheet”查看文档,确认相关设置的具体含义。
7、在 page2 中,我们设置 CLK_OUT1 的输出时钟频率为 12.5(单位:MHz),同时勾选 CLK_OUT2、CLK_OUT3 和 CLK_OUT4,并且分别设置它们的频率为 25、50 和 100(MHz)。
8、Page3 中,如图 7.25 所示,勾选“RESET”和“LOCKED”这两个接口。RESET 即整个 PLL的复位信号,LOCKED 则是 PLL 输出时钟正常工作的指示信号。
9、完成上面的配置,在 Page5 中,所有相关的配置信息都在此罗列出来了,供 review。
10、与此同时,在 PLL 配置页面的右侧,所有可用于连接到我们的逻辑中的信号接口也都一览无余,非常直观。
11、最后,在 page6 中,PLL 模块配置完成后,将会生成的所有相关源文件都罗列出来了。
12、最后,我们可以点击 PLL 配置页面右下角的“Generate”生成当前配置
13、在在“Design -> Implementation”中出现了刚刚配置的 pll_controller 模块,选中它,然后在“Processes”中,我们可以双击“View HDL Instantiation Template”打开 PLL文件的例化模板,pll_controller.veo,直接拖动到最下面:
//----------- Begin Cut here for INSTANTIATION Template ---// INST_TAG
pll_controller instance_name
(// Clock in ports
.CLK_IN1(CLK_IN1), // IN
// Clock out ports
.CLK_OUT1(CLK_OUT1), // OUT
.CLK_OUT2(CLK_OUT2), // OUT
.CLK_OUT3(CLK_OUT3), // OUT
.CLK_OUT4(CLK_OUT4), // OUT
// Status and control signals
.RESET(RESET),// IN
.LOCKED(LOCKED)); // OUT
// INST_TAG_END ------ End INSTANTIATION Template ---------
这个就是例化的模板了!
一些参考:
https://blog.csdn.net/Reborn_Lee/article/details/81451946