-
Notifications
You must be signed in to change notification settings - Fork 309
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
[ImportVerilog] Add foreach statement support. #8017
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe you can refer to the implementation of Handle repeat loops
. We can pass the cond to the BB1 when we enter. I guess this method can reduce accessing memory(like read
and blokcing_assign
ops) frequently 🤔. WDYT @fabianschuiki?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please add a few annotations. It's important for others. And thanks for your work on this 😄.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM! Please wait for @fabianschuiki to review it again.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, with a small comment on error reporting. Thanks a lot for working on this! 🥳
if (stmt.loopDims[level].loopVar) | ||
return recursiveForeach(stmt, level); | ||
} | ||
return failure(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It might make sense to return success()
here since Slang probably already checks that there's at least one loopVar
, or if it doesn't it might still be correct to simply not do anything for a loop where no dimensions are actually looped over. If you want to return failure()
, it would be good to emit an error indicating to the user what happened. Otherwise the compiler will exit with a non-zero exit code, but potentially without explanation to the user, which would be bad.
Add forloop statement support, due to lack of dyn array support, currently static-length array is supported.