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

FPGA基础 -- Verilog 的属性(Attributes)

Verilog 的属性(Attributes) 的系统化培训内容,适用于希望深入理解属性如何在综合、仿真和工具指示中使用的专业工程师。内容将涵盖:属性的定义、语法、使用场景、典型示例、工具兼容性与注意事项。


一、什么是 Verilog 的属性(Attribute)

Verilog 的属性是附加在语句或对象上的元信息(Metadata)不会改变功能行为,但用于指导综合器、仿真器或其他EDA工具的行为,例如:优化、保留、资源映射、布局布线等。

**形象类比:**属性类似于 C 语言中的 __attribute__,或 Python 中的装饰器 @property


二、Verilog 属性的语法

Verilog 的属性语法标准为:

(* attribute_name = value, attribute_name2 = value2 *) module_name ...

🔹 语法规则说明:

  • 属性前后用 (* ... *) 包裹。

  • 支持多个属性同时声明,属性间用逗号隔开。

  • 可以附加在:

    • module 定义上
    • wire/reg/parameter/port 定义上
    • always/assign/process 块上
    • 实例化语句上

三、常见的 Verilog 属性及用途分类

1. 保留/不优化类属性

属性含义说明
keep保留信号,禁止优化器移除未使用信号
keep_hierarchy保留层级结构,不对模块进行层级合并
dont_touch不允许综合器优化该对象
preserve_signal在仿真/布局布线阶段保留该信号

📌 示例:

(* keep = "true" *) wire clk_internal;
(* dont_touch = "true" *) reg [7:0] debug_data;

2. 时序与布线类属性

属性含义说明
max_fanout限制该信号的扇出数量
max_delay指定最大路径延迟
min_delay指定最小路径延迟
clock_signal声明该信号为时钟信号,有利于工具识别并特殊处理

📌 示例:

(* max_fanout = 8 *) wire ctrl_sig;

3. 综合优化建议类属性

属性含义说明
async_reg声明该寄存器为异步域跨时钟寄存器,用于CDC优化
shreg_extract指示是否将移位寄存器提取为 SRL(Shift Register LUT)
ram_style强制指定综合器将存储器推导为 block/distributed RAM
rom_style同上,应用于 ROM 指示

📌 示例:

(* async_reg = "true" *) reg sync_stage1, sync_stage2;
(* ram_style = "block" *) reg [7:0] memory_array [0:255];

4. 约束布局布线/区域属性

这些主要用于 Vivado 的 pblock、区域约束等。

属性含义说明
loc强制指定元件位置(常用于 IOB、BRAM、DSP)
box_type指定约束边界类型(硬/软)
belBasic Element Location(用于逻辑资源的绑定)

📌 示例(Vivado):

(* loc = "SLICE_X12Y34" *) reg my_reg;

四、属性兼容性与工具支持情况

工具名称属性支持情况说明
Vivado属性使用最广泛,如 keep, dont_touch, async_reg
Quartus Prime使用类似但部分为专用语法,如 syn_keep, noprune
Diamond支持 Lattice 特定属性,如 syn_keep, syn_ramstyle
Yosys支持部分属性,推荐结合 (* keep *)(* blackbox *)

💡 建议:

  • 交叉平台时使用 标准属性名(如 keep, ram_style)。
  • 针对特定工具使用官方文档推荐的属性组合,例如 Quartus 中使用 // synthesis keep 注释式属性。

五、实际工程中的使用案例

🎯 案例 1:防止移位寄存器被优化掉

(* keep = "true", shreg_extract = "no" *) reg [3:0] delay_chain;

🎯 案例 2:声明异步跨时钟同步寄存器

(* async_reg = "true" *) reg sync_stage1, sync_stage2;

🎯 案例 3:强制推导为 Block RAM

(* ram_style = "block" *) reg [15:0] buffer [0:1023];

六、注意事项

  • 属性不会改变 RTL 语义,仅为工具提供优化/保留/映射建议
  • 有些属性只有在综合阶段生效,仿真器会忽略。
  • 属性值应为字符串,推荐加双引号(如 "true")。
  • 不同工具的属性名略有不同,应查看工具链官方支持手册。

七、小结

内容要点
属性用途控制综合/布局布线/优化行为
语法形式(* 属性名 = 值 *)
常用属性keep, dont_touch, ram_style, async_reg
兼容建议使用标准属性 + 查阅各厂商工具文档
http://www.lqws.cn/news/459793.html

相关文章:

  • Spring Boot + MyBatis + Vue:从零到一构建全栈应用
  • FastJSON 或 Jackson 等库序列化 LocalDateTime 时,默认会将其转换为时间戳(毫秒数)
  • postgresql 函数调试
  • FastAPI lifespan示例
  • 《道德经》:探寻古老智慧中的哲学之光
  • 将无序json数据转换为excel表格形式
  • 一生一芯 PA2 RTFSC
  • 5.基于神经网络的时间序列预测
  • 数据库中间件ShardingSphere5
  • Vue学习笔记
  • Dify动手实战教程(进阶-知识库:新生入学指南)
  • 让大模型“更懂人话”:对齐训练(RLHF DPO)全流程实战解析
  • 《王者荣耀》系统架构深度技术解析
  • 进阶五 按键切换不同led流水效果
  • 李宏毅 《生成式人工智能导论》| 第6讲-第8讲:大语言模型修炼史
  • 关于ubuntu环境下vscode进行debug的随笔
  • 【工具教程】识别PDF中文字内容,根据文字内容对PDF批量重命名,提取识别PDF内容给图片重新命名的操作步骤和注意事项
  • 第十三章 模板
  • 机器学习流量识别(pytorch+NSL-KDD+多分类建模)
  • 自动化性能回退机制——蓝绿部署与灰度发布
  • 前端 CSS 框架:分类、选择与应用
  • 「AI高校」| 《清华大学:AI赋能教育高考志愿填报工具使用指南》
  • 新品上市 | 尺寸小且具有丰富接口的读卡器:RFID高频系列CK-FR06
  • MySQL之事务深度解析
  • django FileSystemStorage is located outside of the base path component
  • Android Studio报错:Could not move temporary workspace () to immutable location
  • NY339NY341美光固态闪存NW841NW843
  • MySQL入门初解
  • 数据分析和可视化:Py爬虫-XPath解析章节要点总结
  • 【Dify学习笔记】:RagFlow接入Dify基础教程