接触fpga一段时间,也能写点跑点吧......试试系统地康康呢~这个需要耐心但是回报巨大的工作。正原子&&小梅哥
15_语法篇:Verilog高级知识点_哔哩哔哩_bilibili
1Verilog基础
Verilog程序框架:模块的结构
data:image/s3,"s3://crabby-images/0130d/0130d687c78de3bd819f8e5b572bc83fc3df3f4d" alt=""
类比:c语言的基础单位是函数
一个流水灯实验的example
data:image/s3,"s3://crabby-images/e5285/e5285061c2c242020bc272c205f40d0844a954f2" alt=""
counter即是内部信号声明
模块的调用
data:image/s3,"s3://crabby-images/31252/312525cc302b4cd7fb9b13dda2a4a3bd6e57abf6" alt=""
data:image/s3,"s3://crabby-images/9b4e1/9b4e149a133a6da5ff643596094ce1d83c5368f8" alt=""
例化中的参数传递问题
在Verilog中,#(.PARAM_NAME(VALUE))
是一种参数化实例化(parameterized instantiation)语法,用于在实例化模块时传递参数。具体来说,它用于在实例化某个模块时,覆盖该模块中定义的默认参数值。
假设我们有一个模块Timer
,其定义如下:
module Timer #(parameter MAX_NUM = 100) (
input wire clk,
input wire reset,
output reg [7:0] count
);
always @(posedge clk or posedge reset) begin
if (reset)
count <= 0;
else if (count < MAX_NUM )
count <= count + 1;
else
count <= 0;
end
endmodule
在这个模块中,MAX_NUM
是一个参数,默认值为100。如果我们在实例化这个模块时,希望将MAX_NUM
的值改为某个不同的值,例如TIME_SHOW
,我们可以使用参数化实例化语法来实现。
module TopModule (
input wire clk,
input wire reset,
output wire [7:0] timer_count
);
// Parameterized instantiation
Timer #(.MAX_NUM(TIME_SHOW)) timer_instance (
.clk(clk),
.reset(reset),
.count(timer_count)
);
endmodule
结构语句
initial
data:image/s3,"s3://crabby-images/6b764/6b764f4311a00248a1d31c72094f8581fda8f828" alt=""
#20:延时20个单位的时间
data:image/s3,"s3://crabby-images/ae7d0/ae7d09a44351602088a417b0b6afd7129c7f7703" alt=""
延时了20个单位后又延时了10个单位又延时了30个单位......
timescale
时间单位是通过timescale
指令设置的。在你的Verilog文件中添加适当的timescale
指令,可以明确定义时间单位和时间精度,从而确定延时语句(如#20
)的具体含义。
`timescale 1ns / 1ps指令设置时间单位为1纳秒,时间精度为1皮秒。
#10
表示延时10纳秒。
always
data:image/s3,"s3://crabby-images/0262b/0262bc4a310273bc577ea8f6aed6d795e9c997a7" alt=""
data:image/s3,"s3://crabby-images/acd19/acd19751d9a28f9ef9ea42fcc8aa1c2fa7d7e734" alt=""
组合逻辑vs时序逻辑
data:image/s3,"s3://crabby-images/74037/7403759f17a5f282fd297e0e4b2be1e51c1f90a6" alt=""
赋值语句:阻塞语句和非阻塞语句
data:image/s3,"s3://crabby-images/079fb/079fb320d9a4d82a986372417dd970ec4482a77f" alt=""
data:image/s3,"s3://crabby-images/bee2b/bee2bc2247bf9212f531f2315a2a6ff31dffc08e" alt=""
data:image/s3,"s3://crabby-images/c7a9c/c7a9c1ee8155c37af79fc6b358c9cfd68a3e36fb" alt=""
条件语句
if else
data:image/s3,"s3://crabby-images/6914e/6914efc70e90473e1a5b2141f90d18fe671ad6e3" alt=""
data:image/s3,"s3://crabby-images/e7f0c/e7f0c3041a32b27c15dae8660b15da455fcb6baa" alt=""
case
'bx:默认32位
data:image/s3,"s3://crabby-images/bce16/bce16227c71ba1575b8e4c9472954f418f54cee5" alt=""
状态机
状态机的概念
状态机是Verilog中很常见的一种语法结构。
data:image/s3,"s3://crabby-images/876b1/876b1c634bf1542628060100b42663c828e371fb" alt=""
首先,我们在什么时候需要用状态机捏?一个密码锁的example:
data:image/s3,"s3://crabby-images/7920b/7920b0808ed816122051f1f65144f5f361f57e22" alt=""
状态机的模型
data:image/s3,"s3://crabby-images/91f08/91f08e89bfc1f26c53e04ceac52f04258f745b14" alt=""
moore状态机是mealy状态机的一个特例
状态机的设计
八股文。写就有分。
data:image/s3,"s3://crabby-images/04c1e/04c1e2deea02f0cd766c766ff081c24a20504d12" alt=""
example:推荐独热码
latch:会导致电路毛刺很多
产生latch的原因:1case情况没给完全2if没有对应的else
data:image/s3,"s3://crabby-images/95192/951927a1140065828e87ee215e0e4ba36a0a4021" alt=""
2ADDA
AD_OTR:指示位,模拟量超出量程了!
data:image/s3,"s3://crabby-images/7b800/7b800a82836effbda48ec34d2a8eb151f16daf89" alt=""
3串口通讯发送原理
data:image/s3,"s3://crabby-images/030c1/030c1bae38f0be6e13ee9e03d94333fb444ebdca" alt=""
data:image/s3,"s3://crabby-images/fb0d4/fb0d4a92a9259f555336d4c9a62f90f261f50346" alt=""