首页
/ CIRCT项目firtool-1.104.0版本发布:硬件编译工具链的重要更新

CIRCT项目firtool-1.104.0版本发布:硬件编译工具链的重要更新

2025-06-26 22:00:39作者:柯茵沙

CIRCT(Circuit IR Compilers and Tools)是一个开源的硬件设计工具链项目,它基于MLIR框架构建,旨在为硬件设计提供现代化的编译器基础设施。该项目由LLVM社区支持,专注于将高级硬件描述语言转换为可综合的RTL代码,并优化中间表示(IR)。

本次发布的firtool-1.104.0版本带来了多项重要改进和新功能,主要集中在FIRRTL(Flexible Intermediate Representation for RTL)编译流程、ESI(Embedded System Integration)基础设施、RTG(Register Transfer Generator)测试框架以及验证相关功能的增强。下面我们将详细解析这次更新的技术亮点。

FIRRTL编译流程的改进

在FIRRTL编译方面,本次更新有几个值得关注的优化:

  1. 内存银行配置的灵活性增强:现在支持通过属性为操作指定细粒度的内存银行配置,这使得内存分区策略可以更加精确地控制。开发者可以为特定内存操作附加属性来定义其银行维度,而不必全局统一设置。

  2. XMR(跨模块引用)处理的完善:LowerXMR过程现在会处理所有模块,确保跨模块引用的解析更加全面和可靠。这一改进减少了因XMR处理不完整而导致的潜在问题。

  3. 初始化逻辑优化:在SCFToCalyx转换过程中,移除了冗余的init_xxx_instance调用,简化了生成的代码结构,提高了编译效率。

  4. IMCP(Inter-Module Constant Propagation)增强:对于包含未知符号使用的模块端口,现在会进行过定义处理,提高了常量传播的鲁棒性。

ESI基础设施的显著增强

嵌入式系统集成(ESI)部分迎来了多项重要更新:

  1. 主机内存写入路径的齿轮箱支持:为hostmem写入路径添加了齿轮箱(gearbox)功能,使得不同时钟域之间的数据传输更加可靠。

  2. 多客户端写入复用:hostmem现在支持多个写入客户端的复用,提高了系统资源的利用率。

  3. 字节使能支持:在cosim hostmem中增加了字节使能功能,使得内存访问控制更加精细。

  4. XRT BSP支持:新增了对Xilinx运行时(XRT)板级支持包(BSP)的主机内存写入功能,扩展了硬件加速平台的兼容性。

验证功能的扩展

验证相关功能得到了显著增强:

  1. 合约(Contract)支持:新增了LowerContractsPass和StripContractsPass,前者将verif.contract操作转换为对应的断言逻辑,后者则提供移除合约的选项。ExportVerilog现在将verif.contract视为无操作(no-op),保持向后兼容。

  2. 形式验证文档完善:增加了关于circt-bmc使用的详细说明,帮助开发者更好地利用有界模型检查工具进行硬件验证。

RTG测试框架的多项改进

寄存器传输生成器(RTG)测试框架迎来了大量更新:

  1. 指令集增强:新增了多种指令支持,包括分支指令、算术指令和存储指令,丰富了测试用例的表达能力。

  2. 寄存器分配:引入了简单的线性扫描寄存器分配算法,提高了生成代码的质量。

  3. 标签支持:在ISA汇编发射和精化过程中增加了对标签的支持,使得控制流更加清晰。

  4. 立即数表示:改进了立即数的表示方法,增强了指令的灵活性。

  5. 寄存器类型扩展:精化过程现在支持固定寄存器和虚拟寄存器,提供了更灵活的寄存器分配策略。

其他重要改进

  1. 随机化内存初始化:为生成的内存添加了随机初始化逻辑,提高了测试的覆盖率和可靠性。

  2. 方言清理:新增了移除OM和Emit方言操作的pass,帮助简化最终的输出代码。

  3. LLHD优化:在初始化'dontCare'表之前添加了maxPrimitives检查,避免了潜在的错误。

技术影响与展望

firtool-1.104.0版本的发布标志着CIRCT项目在硬件编译工具链领域的持续进步。特别是ESI基础设施的增强,为异构计算和硬件加速提供了更加完善的解决方案。验证功能的扩展也显示出项目对硬件正确性的高度重视。

RTG测试框架的改进使得硬件设计验证更加便捷,而FIRRTL编译流程的优化则进一步提高了生成代码的质量和编译效率。这些更新共同推动着CIRCT向成为工业级硬件编译工具链的目标迈进。

对于硬件开发者而言,这个版本提供了更多工具来应对复杂的设计挑战,特别是在涉及多时钟域、验证和测试等方面。随着这些功能的成熟,CIRCT有望在FPGA和ASIC设计流程中扮演更加重要的角色。

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
156
247
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
775
477
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
117
172
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
137
256
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
320
1.05 K
open-eBackupopen-eBackup
open-eBackup是一款开源备份软件,采用集群高扩展架构,通过应用备份通用框架、并行备份等技术,为主流数据库、虚拟化、文件系统、大数据等应用提供E2E的数据备份、恢复等能力,帮助用户实现关键数据高效保护。
HTML
114
77
csv4cjcsv4cj
一个支持csv文件的读写、解析的库
Cangjie
11
3
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
79
2
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.04 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
378
363