(* MARK_DEBUG=“true“ *)

Verilog/SystemVerilog 中,(* MARK_DEBUG="true" *)Xilinx Vivado 工具链 使用的属性语法,用于调试目的

一、语法和作用

复制代码
(* MARK_DEBUG="true" *)
wire [7:0] my_signal;

(* MARK_DEBUG="true" *)
reg [31:0] counter;

二、主要功能

1. 标记需要调试的信号

  • 告诉 Vivado 在综合时保留这些信号的完整性

  • 防止优化器删除或重命名这些信号

2. 在 ILAs 中自动连接

复制代码
module my_design(
    input clk,
    input rst,
    output [7:0] data_out
);

(* MARK_DEBUG="true" *) wire [7:0] internal_data;
(* MARK_DEBUG="true" *) reg [3:0] state;

// 你的设计代码...

endmodule

三、使用方法

方法1:内联属性

复制代码
module debug_example(
    input clk,
    input [7:0] data_in,
    output [7:0] data_out
);

(* MARK_DEBUG="true" *) wire [7:0] processed_data;
(* MARK_DEBUG="true" *) reg [2:0] current_state;

assign processed_data = data_in + 1;
assign data_out = processed_data;

always @(posedge clk) begin
    current_state <= current_state + 1;
end

endmodule

方法2:在端口声明中使用

复制代码
module top (
    input clk,
    (* MARK_DEBUG="true" *) input [7:0] debug_input,
    (* MARK_DEBUG="true" *) output [15:0] debug_output
);

四、Vivado 中的操作流程

  1. 添加 MARK_DEBUG 属性

  2. 综合设计

  3. 在 Vivado 中设置调试

    • 打开 Synthesized Design

    • 选择 "Set Up Debug"

    • 标记的信号会自动出现在调试列表中

  4. 实现设计并生成比特流

  5. 使用 ILA 核进行硬件调试

五、注意事项

  • 仅适用于 Xilinx Vivado,其他工具链使用不同的语法

  • 信号必须保持不被过度优化

  • 调试会占用额外的 FPGA 资源(ILA 核、块RAM等)

  • 在正式发布版本中建议移除这些属性

六、替代语法

对于其他工具链:

复制代码
// Intel Quartus
(* preserve *) wire [7:0] my_signal;

// 通用 SystemVerilog
/* synthesis keep */ wire [7:0] my_signal;

这个属性在 FPGA 调试中非常有用,可以方便地在硬件层面观察内部信号的行为。

相关推荐
SmartRadio6 小时前
CH585M+MK8000、DW1000 (UWB)+W25Q16的低功耗室内定位设计
c语言·开发语言·uwb
rfidunion6 小时前
QT5.7.0编译移植
开发语言·qt
rit84324996 小时前
MATLAB对组合巴克码抗干扰仿真的实现方案
开发语言·matlab
大、男人6 小时前
python之asynccontextmanager学习
开发语言·python·学习
hqwest6 小时前
码上通QT实战08--导航按钮切换界面
开发语言·qt·slot·信号与槽·connect·signals·emit
AC赳赳老秦7 小时前
DeepSeek 私有化部署避坑指南:敏感数据本地化处理与合规性检测详解
大数据·开发语言·数据库·人工智能·自动化·php·deepseek
不知道累,只知道类7 小时前
深入理解 Java 虚拟线程 (Project Loom)
java·开发语言
国强_dev8 小时前
Python 的“非直接原因”报错
开发语言·python
YMatrix 官方技术社区8 小时前
YMatrix 存储引擎解密:MARS3 存储引擎如何超越传统行存、列存实现“时序+分析“场景性能大幅提升?
开发语言·数据库·时序数据库·数据库架构·智慧工厂·存储引擎·ymatrix
玖疯子8 小时前
技术文章大纲:Bug悬案侦破大会
开发语言·ar