Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add the BLIF dialect. #8019

Open
wants to merge 15 commits into
base: main
Choose a base branch
from
Open

Add the BLIF dialect. #8019

wants to merge 15 commits into from

Conversation

darthscsi
Copy link
Contributor

The BLIF dialect implements the extended berkely logic interchange format. This is a format used by some OSS tools, such as some place-and-route tools. This is the format used by yosys to interchange with nextpnr.

Andrew Lenharth added 2 commits December 29, 2024 00:53
The BLIF dialect implements the extended berkely logic interchange format.  This is a format used by some OSS tools, such as some place-and-route tools.  This is the format used by yosys to interchange with nextpnr.
@darthscsi
Copy link
Contributor Author

Will join with #8018 to push an fpga-mapped design to nextpnr.

@darthscsi darthscsi marked this pull request as ready for review January 3, 2025 21:54
@darthscsi darthscsi mentioned this pull request Jan 5, 2025
Copy link
Contributor

@fabianschuiki fabianschuiki left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Haven't gone through every single line of code in detail, but having both import and export support for BLIF and a BLIF ingress/egress dialect is a really cool thing for CIRCT! 🥳

include "mlir/IR/EnumAttr.td"
include "mlir/IR/RegionKindInterface.td"

def ModelOp : BLIFOp<"model", [IsolatedFromAbove, RegionKindInterface, SingleBlockImplicitTerminator<"OutputOp">]> {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: overly long line

Comment on lines 34 to 37
OpBuilder<(ins "StringRef":$name,
"ArrayRef<StringRef>":$inputs,
"ArrayRef<StringRef>":$outputs,
"ArrayRef<StringRef>":$clocks)>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Omega-nit: " alignment

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants