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

sbt complains about feature warnings which are irrelevant to new users #45

Open
edwardcwang opened this issue Sep 26, 2018 · 2 comments
Assignees

Comments

@edwardcwang
Copy link
Contributor

Type of issue: bug report | feature request

Impact: no functional change

Development Phase: request

Please tell us about your environment: Chisel 3.1

What is the use case for changing the behavior?

Is there a way for us to suppress feature warnings (or at the very least "reflective access of structural type member" warnings) which are irrelevant to users?

Currently running sbt raises feature warnings to users by default:

[warn] there were 1 feature warnings; re-run with -feature for details
[warn] one warning found 

Enabling them leads sbt/scalac to complain excessively about accessing io fields, which is confusing to users since they have to wonder if this is a bug in their code (which it is not):

[warn] /.../src/main/scala/GCD.scala:32:6: reflective access of structural type member value outputGCD should be enabled
[warn] by making the implicit value scala.language.reflectiveCalls visible.
[warn]   io.outputGCD := x
[warn]      ^
[warn] /.../src/main/scala/GCD.scala:33:6: reflective access of structural type member value outputValid should be enabled
[warn] by making the implicit value scala.language.reflectiveCalls visible.
[warn]   io.outputValid := y === 0.U
[warn]      ^
[warn] 5 warnings found
[info] Done compiling.
[info] Compiling 1 Scala source to /.../target/scala-2.12/test-classes ...
[warn] /.../src/test/scala/GCDTester.scala:36:19: reflective access of structural type member value value1 should be enabled
[warn] by making the implicit value scala.language.reflectiveCalls visible.
[warn] This can be achieved by adding the import clause 'import scala.language.reflectiveCalls'
[warn] or by setting the compiler option -language:reflectiveCalls.
[warn] See the Scaladoc for value scala.language.reflectiveCalls for a discussion
[warn] why the feature should be explicitly enabled.
[warn]       poke(gcd.io.value1, i)
[warn]                   ^
[warn] /.../src/test/scala/GCDTester.scala:37:19: reflective access of structural type member value value2 should be enabled
[warn] by making the implicit value scala.language.reflectiveCalls visible.
[warn]       poke(gcd.io.value2, j)
@edwardcwang
Copy link
Contributor Author

Conclusion: add scalacOptions += "-language:reflectiveCalls" to the chisel template at some point, and maybe investigate why it's happening

@jackkoenig
Copy link
Contributor

jackkoenig commented Sep 26, 2018

The "why" is that standard Chisel style uses structural typing, eg.

val io = IO(new Bundle {
  val foo = Output(UInt(8.W))
})

accessing fields of structural types requires reflection, which is not available on all platforms (eg. ScalaJS)

@chick chick transferred this issue from chipsalliance/chisel Dec 18, 2018
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

No branches or pull requests

3 participants