-
Notifications
You must be signed in to change notification settings - Fork 611
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
Lexical scope is not properly checked for ports of submodules #4405
Comments
Yes, there's only scope checking for when's, and not layers (tested but also apparent from inspection re:WhenContext, so on). FWIW I think the checking is wrong among sibling blocks for the same when as well: //> using repository "sonatype-s01:snapshots"
//> using scala "2.13.14"
//> using dep "org.chipsalliance::chisel:7.0.0-M2+76-ecda00a5-SNAPSHOT"
//> using plugin "org.chipsalliance:::chisel-plugin:7.0.0-M2+76-ecda00a5-SNAPSHOT"
//> using options "-unchecked", "-deprecation", "-language:reflectiveCalls", "-feature", "-Xcheckinit", "-Xfatal-warnings", "-Ywarn-dead-code", "-Ywarn-unused", "-Ymacro-annotations"
import chisel3._
// _root_ disambiguates from package chisel3.util.circt if user imports chisel3.util._
import _root_.circt.stage.ChiselStage
class Child extends Module {
val in = IO(Input(UInt(8.W)))
val out = IO(Output(UInt(8.W)))
out := in
}
class Foo extends Module {
val in = IO(Input(UInt(8.W)))
val out = IO(Output(UInt(8.W)))
var c: Bool = null
when (true.B) {
c = WireInit(Bool(), true.B)
out := c
} .otherwise {
c := false.B
out := c
}
}
object Main extends App {
println(
ChiselStage.emitCHIRRTL(
gen = new Foo
)
)
println(
ChiselStage.emitSystemVerilog(
gen = new Foo,
firtoolOpts = Array("-disable-all-randomization", "-strip-debug-info")
)
)
} Which generates the following output:
As you say, probably motivates a scope overhaul 👍 . |
Thanks for the extra example! I think it's fine as part of this issue but feel free to file a separate one if you want. |
This is a good example of why we need to overhaul our lexical scope checking (usually called "visibility" within Chisel). We really ought to add a specific
Scope
datastructure that is used for all scopes (Module, when, and layer) rather than individual things for checking each one (and I think layer scopes aren't even properly checked at the moment!)Type of issue: Bug Report
Please provide the steps to reproduce the problem:
Consider the following Scala-CLI using latest main:
What is the current behavior?
This will print the buggy FIRRTL and show the firtool error:
What is the expected behavior?
Chisel should error
What is the use case for changing the behavior?
The text was updated successfully, but these errors were encountered: