0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

FPGA零基础学习之Vivado-锁相环使用教程

FPGA技术江湖 来源:FPGA技术江湖 2023-05-31 17:42 次阅读

大侠好,欢迎来到FPGA技术江湖。本系列将带来FPGA的系统性学习,从最基本的数字电路基础开始,最详细操作步骤,最直白的言语描述,手把手的“傻瓜式”讲解,让电子信息通信类专业学生、初入职场小白及打算进阶提升的职业开发者都可以有系统性学习的机会。

系统性的掌握技术开发以及相关要求,对个人就业以及职业发展都有着潜在的帮助,希望对大家有所帮助。本次带来Vivado系列,锁相环使用教程。话不多说,上货。

锁相环使用教程

锁相环是我们比较常用的IP核之一。PLL的英文全称是Phase locked loop即锁相环,是一种反馈电路。具有分频、倍频、相位偏移和占空比可调的功能。在XILINX 7系列芯片时钟资源包含了时钟管理单元CMT,每一个CMT都是由一个MMCM和一个PLL组成。对于使用者来说,当我们实现简单的分频时,设计者可以通过写代码的方式来进行分频,但是对于复杂的设计,比如倍频、相位偏移等设计时,写代码的方式就显得力不从心。此时就体现了学习锁相环的必要性。接下来我们一起了解一下锁相环的使用。

PLL锁相环由以下几部分组成:前置分频计数器、相位频率检测器电路、电荷泵、环路滤波器、压控振荡器、反馈乘法器计数器和后置分频计数器。在工作室,相位频率检测器检测其参考频率和反馈信号之间的相位差和频率差,控制电荷泵和环路滤波器将相位差转换为控制电压,压控振荡器根据不同的控制电压产生不同的振荡频率从而影响反馈信号的相位和频率。在参考频率和反馈信号具有相同的频率和相位后,就认为PLL处于锁相的状态。

本次实验我们将输出四个不同的频率波形,其中有两个相位相差180°。其中四个频率分别为100MHZ,30MHZ,10MHZ,10MHZ_180。

接下来我们首先先新建一个工程:

4825faa2-ff8d-11ed-90ce-dac502259ad0.png

首先选择新建工程,在此之前,新建工程的介绍已经给大家详细介绍过了,在此就不在重复介绍,新建好之后,如下图:

483b3aac-ff8d-11ed-90ce-dac502259ad0.png

大家可以在工程总览中看到工程的信息。

我们在左侧菜单栏里面选中IP Catalog

485b17a0-ff8d-11ed-90ce-dac502259ad0.png

打开之后搜索clock,如下图:

4866fff2-ff8d-11ed-90ce-dac502259ad0.png

双击打开此选项,弹出如图界面:

487b4c50-ff8d-11ed-90ce-dac502259ad0.png

我们需要在此界面做一些配置,IP核的名字我们可以修改,但是要符合起名字的规则,当然也可以不做修改。在时钟特征里面,我们保持默认选项即可。输入时钟我们需要修改,我们开发板的晶振是50MHz,所以此处频率我们改为50MHz。

489af302-ff8d-11ed-90ce-dac502259ad0.png

输入时钟设置好之后,我们设置第二个配置界面。按照我们提前规定好的输出频率去设置。

48b3b41e-ff8d-11ed-90ce-dac502259ad0.png

需要添加额外的时钟的时候,在对应的选项前面勾选上,设置好对应的输出。clk_out4是10MHz偏移180度的波形,所以在相位偏移选项里面设置成180度。

其他界面没有需要设置的内容,我们直接点击OK即可。然后会弹出提示框。这个提示框是确认是否给IP核新建路径,在此我们点击OK。

48c214c8-ff8d-11ed-90ce-dac502259ad0.png

48d8bf7a-ff8d-11ed-90ce-dac502259ad0.png

此处我们也保持默认然后点击Generate

生成好之后,在源文件界面会看到我们生成的IP核。

48e76ee4-ff8d-11ed-90ce-dac502259ad0.png

接下来我们写个顶层文件,调用一下我们的IP核,然后做个仿真看一下我们的输出波形。

顶层代码如下:

1 module pll( 2 3 input wire clk, 4 input wire rst_n, 5 output wire clk_100m, 6 output wire clk_30m, 7 output wire clk_10m, 8 output wire clk_10m_180, 9 output wire locked 10 ); 11 12 clk_wiz_0 clk_wiz_0_inst 13 ( 14 // Clock out ports 15 .clk_out1(clk_100m), // output clk_out1 16 .clk_out2(clk_30m), // output clk_out2 17 .clk_out3(clk_10m), // output clk_out3 18 .clk_out4(clk_10m_180), // output clk_out4 19 // Status and control signals 20 .reset(~rst_n), // input reset 21 .locked(locked), // output locked 22 // Clock in ports 23 .clk_in1(clk)); // input clk_in1 24 25endmodule

在顶层文件当中,我们需要例化我们的IP核,那么我们需要先打开IP Sources,我们会看到我们新建的IP,然后点开之后会看到第一个选项Instantiation template,打开之后又会看到一个.veo文件,双击打开就可以看到我们ip核的例化头文件。如图所示:

48f8a22c-ff8d-11ed-90ce-dac502259ad0.png

我们将头文件直接复制粘贴到我们的顶层文件当中,然后修改括号里面的端口名。修改好之后就是我们顶层文件的样子。

接下来是我们的仿真文件,代码如下:

1 `timescale 1ns / 1ps 2 3 module pll_tb; 4 5 reg clk; 6 reg rst_n; 7 wire clk_100m; 8 wire clk_30m; 9 wire clk_10m; 10 wire clk_10m_180; 11 wire locked; 12 13 initial begin 14 rst_n = 0; 15 clk = 0; 16 #105; 17 rst_n = 1; 18 #10000; 19 $stop; 20 end 21 22 always #10 clk = ~clk; 23 24 pll pll_inst( 25 26 .clk (clk ), 27 .rst_n (rst_n ), 28 .clk_100m (clk_100m ), 29 .clk_30m (clk_30m ), 30 .clk_10m (clk_10m ), 31 .clk_10m_180 (clk_10m_180), 32 .locked (locked ) 33 ); 34 35 endmodule

代码编译没有问题之后,我们打开仿真波形观察现象:

49145cce-ff8d-11ed-90ce-dac502259ad0.png

观察波形可以看出,在复位结束之后的一段时间内,输出是没有波形的,在这段时间,IP核的输出还不稳定,所以看不到波形,在黄色光标处,locked信号拉高,此时表明输出稳定,我们观察后续波形的周期,跟我们定义的频率正好对应。

审核编辑 :李倩

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1625

    文章

    21663

    浏览量

    601659
  • 锁相环
    +关注

    关注

    35

    文章

    583

    浏览量

    87687
  • 振荡器
    +关注

    关注

    28

    文章

    3811

    浏览量

    138858

原文标题:FPGA零基础学习之Vivado-锁相环使用教程

文章出处:【微信号:HXSLH1010101010,微信公众号:FPGA技术江湖】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    锁相环电路

    锁相环电路 锁相环
    发表于 09-25 14:28 7181次阅读
    <b class='flag-5'>锁相环</b>电路

    什么是锁相环 锁相环的组成 锁相环选型原则有哪些呢?

    大家都知道锁相环很重要,它是基石,锁相环决定了收发系统的基础指标,那么如此重要的锁相环选型原则有哪些呢?
    的头像 发表于 08-01 09:37 5324次阅读
    什么是<b class='flag-5'>锁相环</b> <b class='flag-5'>锁相环</b>的组成 <b class='flag-5'>锁相环</b>选型原则有哪些呢?

    有关fpga中的锁相环

    fpga中的用锁相环产生时钟信号相比于用计数器进行分频有哪些优点,看fpga锁相环的结构,其前期的输入信号和后期的输出信号不也是通过计数器进行分频实现的吗
    发表于 10-06 10:46

    至芯昭哥带你学FPGAFPGA_100天之旅_锁相环

    至芯昭哥带你学FPGAFPGA_100天之旅_锁相环
    发表于 08-20 12:39

    FPGA零基学习Vivado-锁相环使用教程

    及打算进阶提升的职业开发者都可以有系统性学习的机会。 系统性的掌握技术开发以及相关要求,对个人就业以及职业发展都有着潜在的帮助,希望对大家有所帮助。本次带来Vivado系列,锁相环使用教程。话不多
    发表于 06-14 18:09

    模拟锁相环应用实验

    一、实验目的1、掌握模拟锁相环的组成及工作原理。2、学习用集成锁相环构成锁相解调电路。3、学习用集成锁相
    发表于 03-22 11:44 127次下载

    基于FPGA的全数字锁相环设计

    基于FPGA的全数字锁相环设计:
    发表于 06-26 17:30 141次下载
    基于<b class='flag-5'>FPGA</b>的全数字<b class='flag-5'>锁相环</b>设计

    锁相环(PLL),锁相环(PLL)是什么意思

    锁相环(PLL),锁相环(PLL)是什么意思 PLL的概念 我们所说的PLL。其
    发表于 03-23 10:47 6117次阅读

    锁相环

    锁相环英文为PLL,即PLL锁相环。可以分为模拟锁相环和数字锁相环。两种分类的锁相环原理有较大区别,通过不同的
    发表于 10-26 12:40
    <b class='flag-5'>锁相环</b>

    基于FPGA的数字锁相环设计与实现

    基于FPGA的数字锁相环设计与实现技术论文
    发表于 10-30 10:38 9次下载

    FPGA实现数字锁相环

    Xilinx FPGA工程例子源码:用FPGA实现数字锁相环
    发表于 06-07 15:07 38次下载

    详解FPGA数字锁相环平台

    一、设计目标 基于锁相环的理论,以载波恢复为依托搭建数字锁相环平台,并在FPGA中实现锁相环的基本功能。 在
    发表于 10-16 11:36 18次下载
    详解<b class='flag-5'>FPGA</b>数字<b class='flag-5'>锁相环</b>平台

    如何使用FPGA实现高性能全数字锁相环的设计

    本文提出了一种适用范围广泛的全数字锁相环(ADPLL)实现方法.在锁相环输入频率未知的情况下,实现锁相锁频功能。本文从全数字锁相环的基本实现方式入手.进行改进,并使用VH DL语言建模
    发表于 01-26 15:03 65次下载
    如何使用<b class='flag-5'>FPGA</b>实现高性能全数字<b class='flag-5'>锁相环</b>的设计

    基于FPGA的宽频带数字锁相环的设计与实现简介

    基于FPGA的宽频带数字锁相环的设计与实现简介说明。
    发表于 06-01 09:41 26次下载

    基于FPGA的高性能全数字锁相环

    基于FPGA的高性能全数字锁相环
    发表于 06-08 11:09 45次下载