当前位置: 首页 > news >正文

FPGA基础 -- Verilog 行为级建模之过程性结构

Verilog 中的“过程性结构(Procedural Constructs)”**,这是行为级建模的核心内容之一。


一、什么是过程性结构(Procedural Constructs)

过程性结构是 Verilog 中用来描述“按顺序执行”的语句块,通常出现在 alwaysinitial 块中。与数据流建模(assign)的并行逻辑不同,过程性结构是一种顺序执行的行为描述方式,更贴近软件语言中的过程控制逻辑。


二、基本过程性结构分类

类型关键字用途
顺序结构begin ... end组织多个语句顺序执行
条件结构if / if-else / case条件分支
循环结构for / while / repeat / forever多次执行语句块
并发结构fork ... join(仿真用)并发执行(testbench 中)

注意:综合工具仅支持有限子集,如 forif/case 的结构。whilerepeatforeverfork 一般只用于 testbench。


三、顺序结构:beginend

✅ 示例

always @(posedge clk) begina <= b;c <= d;
end
  • 多个语句按顺序执行;
  • 可嵌套使用。

四、条件结构详解

4.1 if / else

always @(posedge clk) beginif (en)q <= d;elseq <= 0;
end

4.2 多级嵌套 if-else if

if (a == 2)y <= 1;
else if (a == 3)y <= 2;
elsey <= 0;

⚠️ 注意:避免未完全覆盖条件会导致 latch 推断(不综合安全)


4.3 case 结构

case (sel)2'b00: y = a;2'b01: y = b;default: y = c;
endcase
casexcasez
类型支持通配符示例用途
casexx / z 都匹配casex(sel)适用于 don’t care
casez只 z 匹配casez(sel)保留 x 作为明确值
⚠️ 综合建议:
  • 尽量使用 casecasez
  • 始终写 default 分支;
  • 否则容易推断不完整组合逻辑(=> latch)。

五、循环结构详解

5.1 for 循环(唯一综合安全的循环)

integer i;
always @(posedge clk) beginfor (i = 0; i < 4; i = i + 1)sum[i] <= sum[i] + data[i];
end
综合时的行为:

综合工具会将循环展开为多个并行语句,所以 for 的次数必须是常数。

5.2 whilerepeatforever

仅用于仿真(initial block / testbench):

// while
while (a < 5) a = a + 1;// repeat
repeat (10) @(posedge clk) $display("Tick");// forever
forever beginclk = ~clk;#5;
end

六、组合逻辑中的过程性结构写法

组合逻辑 always 块写法建议:

always @(*) begincase (op)2'b00: y = a + b;2'b01: y = a - b;default: y = 0;endcase
end

⚠️ 注意事项:

  • 输入变化全部列入 @(*)
  • 所有输出变量都要在所有路径中赋值;
  • 否则综合工具会推断 latch(存储器件),不符合组合逻辑预期。

七、阻塞与非阻塞赋值的过程性差异

7.1 阻塞赋值 =

  • 左右同步执行,常用于组合逻辑
  • 有“顺序”语义(会等待执行完当前语句才继续)
a = b;
c = a; // 此处使用的是 b 的值

7.2 非阻塞赋值 <=

  • 同步赋值,常用于时序逻辑(寄存器更新)
  • 在时钟沿之后,所有赋值同时生效
a <= b;
c <= a; // 下一时钟时刻才会看到上一个周期的 b 和 a
综合建议:
场景建议赋值方式
时序逻辑(always @(posedge clk))非阻塞赋值 (<=)
组合逻辑(always @(*))阻塞赋值 (=)

八、综合常见错误总结

错误写法问题建议
if/case 不完整推断 latchdefault 分支或完整条件覆盖
混用 =<=时序混乱按规则区分阻塞/非阻塞
@(*) 中漏信号组合逻辑更新不全保证包含所有输入变量
使用 while / repeat不可综合仅用于 testbench

九、Testbench 中的过程结构支持

在 testbench 中,过程结构提供仿真流程控制:

initial beginrst_n = 0;#20 rst_n = 1;
endalways #5 clk = ~clk; // forever loop 替代

还可结合 fork ... join 实现并发仿真:

initial forkbegin #10 a = 1; endbegin #15 b = 1; end
join

十、实战建议与进阶方向

  1. 实践推荐:

    • 先用组合逻辑练习 if / case
    • 再通过寄存器实现 always @(posedge clk)
    • 理解 for 在综合后是硬件资源复制。
  2. 配合写 Testbench

    • 结合 initialforever 模拟时钟;
    • 观察行为过程性赋值的执行顺序。
  3. 进阶探索:

    • SystemVerilog always_comb / always_ff 精准区分组合与时序;
    • 掌握行为模型的 task / function 拆解方式。

相关文章:

  • 【深度学习】卷积神经网络(CNN):计算机视觉的革命性引擎
  • 从0开始学习R语言--Day27--空间自相关
  • Vue.js 按键修饰符详解:提升键盘事件处理效率
  • Vue添加图片作为水印
  • 24.分页查询
  • 26.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--单体转微服务--角色权限管理
  • Python Peewee库连接和操作MySQL数据库
  • CANFD加速是什么?和CANFD有什么区别?
  • redux
  • chili3d笔记18 出三视图调整
  • 从零接入高德路径规划2.0:实现精准物流距离计算实战
  • 侧信道攻击的评估指标
  • SpringBoot电脑商城项目--新增收获地址
  • springboot入门之路(一)
  • 【AI Study】第四天,Pandas(3)- 数据处理进阶
  • Redission实现的分布式锁的可重入性
  • Linux驱动学习day5
  • 利用Java进行验证码的实现——算数验证码
  • vue | vue 插件化机制,全局注册 和 局部注册
  • docker|redis的面试题——七道
  • 张家港企业网站设计/seo投放营销
  • 卓越网的企业类型和网站种类/wordpress免费建站
  • 网站建设找什么工作/百度新闻首页头条
  • 福永小学网站建设/网站搜索排名
  • 现在淘客做网站还行吗/搜索引擎优化的方式有哪些
  • b2c网站的销售设计流程/广告网址