跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
编程语言

Verilog 语法详解:核心定位与基础实战

Verilog 是硬件描述语言的核心标准,用于将代码映射为 FPGA 或 ASIC 电路。本文系统讲解其语法框架,涵盖模块定义、端口声明、数据类型及逻辑描述。重点区分线网型与寄存器型的硬件映射差异,解析组合逻辑与时序逻辑的编写规范,并指出常见错误如输出端口类型声明不当等。内容兼顾入门理解与工业实践,帮助开发者建立正确的并行硬件思维。

鲜活发布于 2026/3/28更新于 2026/6/216 浏览
Verilog 语法详解:核心定位与基础实战

Verilog 语法详解:核心定位与基础实战

一、Verilog 核心定位与语法框架

  1. 核心特点

    • 并行性:模块内的所有语句(如 assign、always 块)同时执行,对应硬件的并行工作,而非像软件那样按代码顺序串行执行。
    • 硬件映射:每段语法都对应明确的硬件结构。比如 reg 对应寄存器,wire 对应导线,逻辑运算符对应逻辑门。
    • 层次化:通过'模块定义 + 例化'实现复杂设计,这是构建大型数字系统的基础。
  2. 基本语法框架 Verilog 程序由模块(Module)组成,模块是最小的可综合单元。一个完整的 Verilog 代码结构通常包含宏定义、端口声明、内部信号和逻辑描述。

// 1. 宏定义(可选,全局生效)
`define WIDTH 8 // 大写命名,编译时替换

// 2. 模块定义(必须,可综合代码的核心)
module demo(
    // 端口列表:输入/输出/双向
    input [WIDTH-1:0] i_data,  // 输入端口(8 位)
    input i_clk,               // 时钟输入(1 位)
    input i_rst_n,             // 同步复位(低有效)
    output reg [WIDTH-1:0] o_data // 输出端口(寄存器型,8 位)
);

    // 3. 内部信号定义(wire/reg/parameter 等)
    wire [WIDTH-1:0] w_temp; // 线网型信号(导线)
    reg [3:0] r_cnt;         // 寄存器型信号(计数器)

    // 4. 逻辑描述(组合逻辑/时序逻辑)
    // 组合逻辑:assign 连续赋值(对应 wire)
    assign w_temp = i_data + 1'b1;

    // 时序逻辑:always 块(时钟触发,对应寄存器)
    always @(posedge i_clk) begin
        if (!i_rst_n) begin // 复位逻辑(优先级最高)
            o_data <= 8'd0;
            r_cnt <= 4'd0;
        end else begin
            o_data <= w_temp; // 寄存器赋值(<= 非阻塞赋值)
            r_cnt <= r_cnt + 1'b1;
        end
    end
endmodule // 模块结束(必须与 module 成对)

Verilog 是硬件描述语言(HDL)的核心标准之一,用于描述数字电路的结构和行为,最终映射为实际硬件(如 FPGA、ASIC)。与 C/C++ 等软件语言的'串行执行'不同,Verilog 的核心是'并行硬件映射'——代码的每一部分都对应具体的电路元件。

二、基础语法:模块与端口

  1. 模块定义(Module Definition) 模块是 Verilog 的基本单元,语法格式如下:
module 模块名 (
    端口 1,
    端口 2,
    ...
    端口 N
); // 端口声明 + 内部信号 + 逻辑描述
endmodule
*   **模块名**:大小写敏感,建议与文件名一致(如 `top.v` 对应模块 `top`)。
*   **端口列表**:必须在模块开头声明,或在模块内显式声明(推荐前者,可读性强)。

2. 端口类型与声明 端口按方向分为三类,需明确声明类型(input/output/inout)和位宽(默认 1 位):

端口类型功能描述硬件映射允许连接的信号
input模块输入(外部→模块)导线(wire)父模块的 wire/reg/常量
output模块输出(模块→外部)导线(wire)父模块的 wire(不可常量)
inout双向端口(模块↔外部)导线(wire)父模块的 wire(需三态)

端口声明示例:

// 方式 1:端口列表 + 内部声明(推荐)
module demo(
    input clk,          // 1 位输入(时钟)
    input [7:0] din,    // 8 位输入(数据)
    output [7:0] dout,  // 8 位输出(导线型)
    output reg [3:0] cnt, // 4 位输出(寄存器型)
    inout io_data       // 双向端口
);

// 方式 2:仅端口列表,内部声明(兼容旧语法)
module demo(clk, din, dout, cnt, io_data);
    input clk;
    input [7:0] din;
    output [7:0] dout;
    output reg [3:0] cnt;
    inout io_data;
endmodule

关键注意:

  • output 端口默认是 wire 型,若需要在 always 块中赋值(时序逻辑),需显式声明为 output reg。
  • inout 端口必须是 wire 型,需通过三态门控制方向,例如 assign io_data = en ? data : 1'bz。

三、核心数据类型

Verilog 数据类型分为线网型(Net)和寄存器型(Register),核心区别在于'是否存储数据',这直接对应硬件中的'导线'和'寄存器'。

  1. 线网型(Net):无存储,实时响应输入 线网型对应硬件中的'导线',必须通过 assign 连续赋值或模块输出驱动,无默认值(默认高阻 z)。

    常用线网类型:

    类型功能描述应用场景
    wire最常用,单驱动源组合逻辑输出、模块端口连接
    tri多驱动源(三态)双向总线(如地址总线)
    tri0下拉电阻(默认 0)复位信号(默认低)
    tri1上拉电阻(默认 1)使能信号(默认高)

    示例:

wire [7:0] data_w; // 8 位线网信号
tri bus;           // 三态总线

assign data_w = a + b;      // 连续赋值(wire 必须用 assign)
assign bus = en ? data : 1'bz; // 三态控制(en=1 时输出 data,否则高阻)
  1. 寄存器型(Register):有存储,时钟触发更新 寄存器型对应硬件中的'寄存器'或'触发器',需在 always 块中赋值,且通常对应触发器或锁存器。这类变量在仿真中会保持状态,直到被新值覆盖。

目录

  1. Verilog 语法详解:核心定位与基础实战
  2. 一、Verilog 核心定位与语法框架
  3. 二、基础语法:模块与端口
  4. 三、核心数据类型
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • Copilot、Codeium 等 AI 代码助手背后的技术原理
  • 2024 年中国 AI 大模型盘点:技术前沿与应用展望
  • 基于 WebGIS 与百度天气接口的复古天气预报系统构建
  • Qwen3-VL-WEBUI 多模态工具快速生成电商素材方案
  • Flutter 组件 sse_stream 在鸿蒙系统的适配与高并发背压处理方案
  • Python 爬取小红书笔记数据及词云可视化分析
  • 排序算法总结:直接插入、希尔、选择、堆、冒泡、快速、归并、计数及非递归实现
  • 2026 年春晚机器人行业观察:高成本曝光与落地关键
  • Arduino 基于 6.5 寸轮毂电机的智能动态跟随机器人底盘设计
  • 基于算法的 LLM 代码翻译新范式:解决意图丢失问题
  • 频率自适应多模态推荐的结构化谱推理
  • ROS 2 海龟仿真器运行与 ros2 run 命令详解
  • CSS 样式基础与布局实战指南
  • 转行Python是否可行?
  • verl 框架在客服机器人训练与部署中的实践
  • Python 模板化生成 JSON 的 3 种高阶方法
  • OpenClaw Scanner 开源安全检测工具技术解析与实操指南
  • 前端地图基本操作控制:平移、缩放、旋转与样式切换
  • Stable Diffusion 模型下载与自动化部署指南
  • 2025 强网杯 Web 安全解题思路汇总

相关免费在线工具

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online

  • Markdown转HTML

    将 Markdown(GFM)转为 HTML 片段,浏览器内 marked 解析;与 HTML转Markdown 互为补充。 在线工具,Markdown转HTML在线工具,online

  • HTML转Markdown

    将 HTML 片段转为 GitHub Flavored Markdown,支持标题、列表、链接、代码块与表格等;浏览器内处理,可链接预填。 在线工具,HTML转Markdown在线工具,online

  • JSON 压缩

    通过删除不必要的空白来缩小和压缩JSON。 在线工具,JSON 压缩在线工具,online

  • JSON美化和格式化

    将JSON字符串修饰为友好的可读格式。 在线工具,JSON美化和格式化在线工具,online