FPGA基础 -- Verilog常用关键字

Verilog 是一种硬件描述语言(HDL),用于描述和设计数字电路。下面是 Verilog 的常用语法和关键概念:


1. Verilog 设计结构

Verilog 代码通常由 模块(module) 组成,每个模块表示一个硬件单元,具有输入和输出端口。

verilog 复制代码
module and_gate (
    input wire a,       // 输入信号 a
    input wire b,       // 输入信号 b
    output wire y       // 输出信号 y
);
    assign y = a & b;   // 逻辑与操作
endmodule
  • module 定义一个模块
  • input / output 定义输入输出端口
  • assign 进行组合逻辑赋值

2. 变量类型

Verilog 变量用于存储信号值,常见变量类型:

  • wire ------ 组合逻辑信号(无存储能力)
  • reg ------ 触发器存储信号(用于时序逻辑)
  • integer ------ 存储整数(常用于循环变量)

示例:

verilog 复制代码
wire a, b, y;     // 组合逻辑信号
reg clk, rst;     // 时序信号
integer i;        // 整数变量

3. 组合逻辑

组合逻辑直接由输入信号决定输出信号,不依赖时钟。

3.1 assign 语句

verilog 复制代码
assign y = a & b;  // 逻辑与运算
assign s = a ^ b;  // 异或运算
assign c = (a & b) | (b & c_in) | (a & c_in);  // 组合逻辑表达式

3.2 always @(*) 组合逻辑块

verilog 复制代码
always @(*) begin
    y = a & b;  // 组合逻辑
end

4. 时序逻辑

时序逻辑依赖时钟信号,通常使用 always @(posedge clk) 定义。

verilog 复制代码
always @(posedge clk or negedge rst) begin
    if (!rst)
        q <= 0;  // 复位
    else
        q <= d;  // D 触发器
end
  • posedge clk 表示在 时钟上升沿 触发
  • negedge rst 表示 复位信号下降沿 触发
  • <= 非阻塞赋值(用于寄存器存储)

5. 条件语句

5.1 if-else 语句

verilog 复制代码
always @(posedge clk) begin
    if (a == 1'b1)
        y <= 1'b1;
    else
        y <= 1'b0;
end

5.2 case 语句

verilog 复制代码
always @(posedge clk) begin
    case (sel)
        2'b00: y <= a;
        2'b01: y <= b;
        2'b10: y <= c;
        default: y <= 0;
    endcase
end

6. 循环结构

6.1 for 循环

verilog 复制代码
integer i;
always @(posedge clk) begin
    for (i = 0; i < 8; i = i + 1) begin
        mem[i] <= data[i];
    end
end

6.2 while 循环

verilog 复制代码
integer i = 0;
always @(posedge clk) begin
    while (i < 8) begin
        mem[i] <= data[i];
        i = i + 1;
    end
end

7. 进程间通信

7.1 initial 语句

initial 语句在仿真时执行一次,常用于仿真测试。

verilog 复制代码
initial begin
    a = 0; b = 1;
    #10 a = 1;  // 10 时间单位后 a 变为 1
    #20 b = 0;  // 20 时间单位后 b 变为 0
end

7.2 always 语句

verilog 复制代码
always @(posedge clk) begin
    y <= a & b;
end

8. 任务和函数

8.1 task 任务

任务 task 可以有多个输入输出参数:

verilog 复制代码
task add;
    input a, b;
    output sum;
    begin
        sum = a + b;
    end
endtask

8.2 function 函数

function 只能返回一个值:

verilog 复制代码
function [3:0] add;
    input [3:0] a, b;
    add = a + b;
endfunction

9. 测试平台(Testbench)

测试平台 用于验证 Verilog 设计的正确性。

verilog 复制代码
module testbench;
    reg a, b;
    wire y;

    and_gate uut (.a(a), .b(b), .y(y));  // 连接被测模块

    initial begin
        a = 0; b = 0;
        #10 a = 1;
        #10 b = 1;
        #10 a = 0; b = 0;
        #10 $stop;  // 结束仿真
    end
endmodule

10. 关键语法总结

语法 说明 示例
module 定义模块 module my_module(); ... endmodule
input / output 端口定义 input a, b; output y;
wire 组合逻辑信号 wire a, b, y;
reg 时序逻辑信号 reg clk, rst;
assign 组合逻辑赋值 assign y = a & b;
always @(*) 组合逻辑块 always @(*) y = a & b;
always @(posedge clk) 时序逻辑块 always @(posedge clk) q <= d;
if-else 条件判断 if (a) y = 1; else y = 0;
case 多路选择 case(sel) 2'b00: y = a; endcase
for 循环 for (i = 0; i < 8; i = i + 1)
task 任务 task add(input a, b, output sum);
function 函数 function [3:0] add(input [3:0] a, b);
initial 初始化块 initial begin a = 0; #10 a = 1; end

总结

  1. Verilog 是硬件描述语言(HDL),主要用于 FPGA/ASIC 设计
  2. 使用 module 组织代码,每个模块表示一个硬件单元
  3. wire 表示组合逻辑,reg 表示寄存器存储
  4. 组合逻辑使用 assignalways @(*),时序逻辑使用 always @(posedge clk)
  5. 支持 if-elsecasefor 等控制结构
  6. initial 用于仿真,always 用于时序逻辑
  7. taskfunction 提供代码复用能力
  8. 测试平台 testbench 用于验证设计
相关推荐
s090713610 小时前
ZYNQ无SD卡纯NAND Flash启动Linux全攻略
linux·fpga开发·zynq·nand flash启动
jjinl12 小时前
AG32VF407RGT6 开发流程记录
fpga开发
FPGA小迷弟12 小时前
FPGA面试题汇总整理(一)
学习·fpga开发·verilog·fpga
Z22ZHaoGGGG12 小时前
verilog 资源占用少的滤波方法
fpga开发
S&Z346312 小时前
[SZ901]FPGA 下载器硬件介绍
fpga开发
GateWorld14 小时前
FPGA内部模块详解之四 算力引擎——数字信号处理单元(DSP Slice)深度解析
fpga开发·dsp
weiyvyy15 小时前
嵌入式硬件接口开发的核心原则
驱动开发·单片机·嵌入式硬件·fpga开发·硬件架构·硬件工程
Kong_199415 小时前
芯片开发学习笔记·二十一——primetime静态时序分析
fpga开发·芯片开发
S&Z346316 小时前
[SZ901] 多路FPGA 网络下载器总览
网络·fpga开发
Shang1809893572621 小时前
SSD202D星宸科技SigmaStar一颗高度集成的嵌入式智能触控显示板解决方案SSD202集成了硬件H.264/H.265视频解码器、内置了DDR
科技·嵌入式硬件·fpga开发·ssd202d嵌入式智能显示