Xilinx Spartan-6 使用 PLL IP 核

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

Xilinx Spartan-6 使用 PLL IP 核_第1张图片

2、在弹出的“New Source Wizard -> Select Source Type”下,如图 7.19 所示,选择文件类型为 “IP (CORE Generator & Architecture Wizard)”。“File name”可以给新创建的 PLL 取个名字,我们命名为“pll_controller”。“Location”即生成的新文件所有相关源文件的存储路径,默认即为当前工程路径下的一个名为“ipcore_dir”的文件夹中,通常我们不需要更改它。点击“Next”继续。

Xilinx Spartan-6 使用 PLL IP 核_第2张图片

3、点击 “Next”后,弹出选择 IP 的界面,接着进入“New Source Wizard -> Select IP”页面,选择 IP 核类型为“FPGA Features and Design -> Clocking -> Clocking Wizard”。点击“Next”继续。

Xilinx Spartan-6 使用 PLL IP 核_第3张图片

4、前面的配置信息在 “New Source Wizard Summary” 页面重新罗列供review。点击“Finish” 继续

Xilinx Spartan-6 使用 PLL IP 核_第4张图片

5、此时,我们注意到 Design 界面下有如图 7.22 所示的“Creating: pll_controller.xco”的提示信息,大家需要耐心等待一会,新建的 PLL 模块正在创建中,随后将会弹出 PLL 的配置页面。

Xilinx Spartan-6 使用 PLL IP 核_第5张图片

6、在弹出的 PLL 配置页面 Page1 中,主要设置“Input Clock Information”下的输入时钟频率,这里我们在“Value”下输入“25”MHz(外部 25MHz 输入)。其他的配置通常使用默认即可,大家也可以点击右下角的“Datasheet”查看文档,确认相关设置的具体含义。

Xilinx Spartan-6 使用 PLL IP 核_第6张图片

7、在 page2 中,我们设置 CLK_OUT1 的输出时钟频率为 12.5(单位:MHz),同时勾选 CLK_OUT2、CLK_OUT3 和 CLK_OUT4,并且分别设置它们的频率为 25、50 和 100(MHz)。

Xilinx Spartan-6 使用 PLL IP 核_第7张图片

8、Page3 中,如图 7.25 所示,勾选“RESET”和“LOCKED”这两个接口。RESET 即整个 PLL的复位信号,LOCKED 则是 PLL 输出时钟正常工作的指示信号。

Xilinx Spartan-6 使用 PLL IP 核_第8张图片

9、完成上面的配置,在 Page5 中,所有相关的配置信息都在此罗列出来了,供 review。

Xilinx Spartan-6 使用 PLL IP 核_第9张图片

10、与此同时,在 PLL 配置页面的右侧,所有可用于连接到我们的逻辑中的信号接口也都一览无余,非常直观。

Xilinx Spartan-6 使用 PLL IP 核_第10张图片

11、最后,在 page6 中,PLL 模块配置完成后,将会生成的所有相关源文件都罗列出来了。

Xilinx Spartan-6 使用 PLL IP 核_第11张图片

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

你可能感兴趣的:(Xilinx,FPGA)