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

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

2025-06-26 11:53:23作者:冯爽妲Honey

CIRCT(Circuit IR Compilers and Tools)是一个开源的硬件编译器基础设施项目,旨在为芯片设计提供现代化的编译器工具链。该项目基于MLIR框架,为硬件设计领域带来了编译器技术的先进理念和方法论。最新发布的firtool-1.122.0版本带来了一系列重要的功能增强和优化,特别是在寄存器传输级(RTL)生成、内存分配和优化等方面有显著改进。

核心功能更新

本次版本在多个关键领域进行了功能增强:

  1. RTG(Register Transfer Generator)改进:测试匹配机制得到优化,新增了MemoryAllocation内存分配通道,并已集成到主流程中。这些改进使得寄存器传输级的生成更加高效和可靠。

  2. AIG(And-Inverter Graph)分析增强:新增了最长路径分析(LongestPathAnalysis)实现,这对于时序分析和优化具有重要意义,能够帮助设计者更好地理解电路的关键路径。

  3. FIRRTL优化:在模块去重(Dedup)方面,现在支持合并公共和私有模块(pub+priv模块),提高了代码复用率。同时,InjectDUT功能现在能够正确处理读写探针(rwprobes)的重新定位。

  4. LLHD(低级硬件描述)改进:引入了组合进程操作(combinational process op),替代了原有的执行区域,提供了更清晰的硬件行为描述方式。Mem2Reg现在支持llhd.sig.extract操作,增强了信号处理能力。

工具链优化

在工具链层面,本次更新也带来了多项优化:

  1. PyRTG改进:重构了目标和配置系统,新增了类型包装器支持,并实现了序列代码的惰性生成(lazy codegen),这些改进使得Python接口更加易用和高效。

  2. OM(Object Model)Python支持:现在支持将字符串和列表作为评估器参数,增强了Python绑定的灵活性。

  3. Seq模块优化:新增了对FirReg带有基于多路选择器(mux)常量驱动的规范化处理,提高了时序逻辑的综合质量。

技术影响与应用价值

这些更新对于硬件设计流程具有实际意义:

  1. 设计效率提升:模块去重和内存分配优化可以显著减少冗余代码,提高综合效率。

  2. 时序分析增强:最长路径分析的引入为时序收敛提供了更好的工具支持。

  3. 验证流程改进:测试匹配机制的优化使得验证环境与设计目标的对应关系更加清晰。

  4. 硬件建模灵活性:LLHD的组合进程操作提供了更自然的硬件行为描述方式。

总结

firtool-1.122.0版本的发布标志着CIRCT项目在硬件编译器技术上的持续进步。这些更新不仅提升了工具链的功能完整性,也为硬件设计者提供了更强大、更灵活的设计手段。特别是对RTL生成、时序分析和硬件建模的改进,将直接影响到芯片设计的生产效率和质量。对于使用MLIR进行硬件开发的研究人员和工程师来说,这个版本值得关注和升级。

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

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
179
263
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
871
515
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
131
184
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
346
380
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
334
1.09 K
harmony-utilsharmony-utils
harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
ArkTS
31
0
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.08 K
0
kernelkernel
deepin linux kernel
C
22
5
WxJavaWxJava
微信开发 Java SDK,支持微信支付、开放平台、公众号、视频号、企业微信、小程序等的后端开发,记得关注公众号及时接受版本更新信息,以及加入微信群进行深入讨论
Java
829
22
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
603
58