首页 > 技术 > 内容

时序逻辑电路之时钟分频设计

时间:2026-01-24  作者:Diven  阅读:0

单片机一样,FPGA开发板上也都会配有晶振用来生成板载时钟。前一篇我们提到了小脚丫的固定板载时钟频率为12MHz,这个频率实际上就是作为我们的时间参考基准。正如歌里唱的那样:

嘀嗒嘀嗒嘀嗒嘀嗒

时针不停在转动

小脚丫只要在通电之后,内部时钟就会每隔83.8ns滴答一次。这个时间真的很快,连光速还没来得及跑出小区大门就被掐断了。那么问题来了:如果在某些应用场合中,我们不需要这么快的嘀嗒该怎么办?比如,我们想让小脚丫上的LED灯以可观察的频率闪烁,如1Hz,也就是1秒闪一下。

相信大家和我的想法一样,就一个字:等。既然一秒钟可以嘀嗒一千两百万次,那我们每次点亮LED之前就先等你跳一千两百万次好了,毕竟也不耗油。换句话说,就是把内部时钟频率放慢12,000,000倍。这个操作就叫做时钟分频,也就是我们今天要掌握的内容。

先说偶数分频,也就是说将内部时钟放慢的除数为偶数。在这里,我们只考虑占空比为50%的波形(高电平和低电平对半分)。图1中,我们设定内部时钟为我们的输入频率,也就是12MHz,那么如果想获得一个6MHz的输出频率,只需要等第二次上沿信号即可,因此分频除数为2。图1

如果想得到更低的输出频率,比如1MHz,则除数调整12;如果1KHz,除数调成12000,依次类推。 注意,这种方法只对除数为偶数的情况下才管用! 以下是生成1Hz输出的代码,于是我们将除数调成了12,000,000。

Module clkdivider(clock_in,clock_out);input clock_in;output reg clock_out;reg[23:0] counter=24'd0;paRAMeter DIVISOR = 24'd12000000;always @(posedge clock_in) begin counter <= counter + 24'd1; if(counter >= (DIVISOR-1)) counter <= 24' clock_out <= (counter< DIVISOR/2)?1'b1:1'b0; //条件赋值 endendModule

在代码中我们注意到了这一行代码:

reg[23:0] counter=240

这个实际上就是用于存储小脚丫固定时钟频率的一个数据格式,至于为什么是24位宽直接参考图2就可以。打开你们电脑里的计算器,调成码农模式即可。图2

再说奇数分频。比如说我们想获得一个4MHz的频率,按道理说我们把分频除数调成3即可。而实际上奇数分频的故事还是稍微多一点。我们看一下图3就明白了。图3

不难发现,当除数为奇数时,此刻对应的时间为内部时钟的下沿,如果仅靠上沿触发的话,此时输出是不会改变的。所以奇数分频需要经历上沿触发和下沿触发才能完成。还好,在Verilog里,我们先不用研究边沿触发的构造原理,只需要通过行为级描述即可直接完成指令:

always @(posedge clk) //上沿触发always @(negedge clk) //下沿触发

现在我们来看一个分频倍数为3的例子。图3中,不论输出信号是高电平还是低电平,都只涵盖了两个边沿信号,也就是说,不论是上沿还是下沿时钟,我们只需要分别等待2次触发后进行赋值即可。

module clk_div3(clk, clk_out);input clk;output clk_out;reg [1:0] pos_count, neg_count;wire [1:0] r_nxt;always @(posedge clk) //处理上沿时钟触发部分 if (pos_count ==2) //等待输入时钟上沿触发2次 pos_count <= 0; else pos_count <= pos_count +1;always @(negedge clk) //处理下沿时钟触发部分 if (neg_count ==2) //等待输入时钟下沿触发2次 neg_count <= 0; else neg_count <= neg_count +1;assign clk_out = ((pos_count == 2) | (neg_count == 2)); //每等待2次触发后进行赋值endmodule

了解了3倍分频之后,如何实现通用的奇数分频自然也就不在话下了,这一部分就交给愿意动手尝试的朋友们去自行练习了。

我们的任务是,让小脚丫上的L1-L4这四个灯以2Hz的频率闪烁,另外四个灯L5-L8分别以1Hz的频率闪烁,看看能否实现呢?

猜您喜欢


NTC热敏电阻(Negative Temperature Coefficient Thermistor)是温度传感器,应用于电子设备、家用电器及工业测温系统中。...
2025-04-19 14:00:05
电源管理是现代电子设备设计中重要的一部分,而单片电荷泵实用电路则以其简约高效的特性,为各种电子装置提供了理想的电源解决方案。无论是消费电子还是专业设备,单片电荷...
2024-02-11 00:00:00
应用于光控开关、光强检测、自动调光等领域。在众多光敏电阻品牌中,KOA(兴亚)很好的品质和技术优势受到关注。本文将详细介绍KOA(兴亚)光敏电阻的品牌区别,帮助...
2016-02-11 01:27:02
贴片电阻R220的标称阻值是22欧姆。 R代表小数点,后面的数字则表示有效数字。在这个例子中,220表示22 × 10^0,也就是22欧姆。实际测量中,电阻值会...
2024-11-29 10:26:38
熔断器作为关键组件,是不可少的配件。作为全球领先的电气保护解决方案提供商,Langlu 朗路国际很好的产品质量和创新技术,在熔断器市场上占据一席之地。本文将为您...
2020-06-26 03:38:30
名片夹/名片盒是专门用于存放和保护名片的工具。通常由纸质、塑料或皮革等材料制成,设计简约而实用。名片夹的主要功能是帮助用户整理和携带名片,避免名片在携带过程中被...
2016-05-16 00:00:00
PTC热敏电阻作为重要的温度保护元件,应用于各种电子设备中。Kyocera(京瓷)作为全球知名的电子元器件制造商,其生产的PTC热敏电阻以高品质和稳定性能。本文...
2012-02-01 00:31:31
SOT89-5是一种广泛应用于电子设备中的小型封装类型,特别适用于需要节省空间的应用场合。随着电子元件逐渐向小型化发展,SOT89-5凭借其优秀的性能和灵活的应...
2025-02-24 12:52:19
PDIP14_7Pin是一种常见的电子元件封装形式,广泛应用于集成电路(IC)设计和制造中。它的全称是“塑料双列直插封装14脚(14-PinDualIn-lin...
2025-02-24 14:40:07
随着电子产品的小型化和高性能化发展,贴片电阻作为基础电子元件,是不可少的配件。本文将重点介绍贴片电阻中的常见型号——R330,详细解析其基本概念、性能特点、应用...
2025-11-03 12:31:43