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

Interface data width vs register width vs access width #100

Open
jscheid-ventana opened this issue Apr 18, 2024 · 1 comment
Open

Interface data width vs register width vs access width #100

jscheid-ventana opened this issue Apr 18, 2024 · 1 comment

Comments

@jscheid-ventana
Copy link

https://peakrdl-regblock.readthedocs.io/en/latest/cpuif/internal_protocol.html#read-response

Read data. The width of this is bus is determined by the size of the largest register in the design.

But the code looks at largest minimum access width:

https://github.com/SystemRDL/PeakRDL-regblock/blob/main/src/peakrdl_regblock/scan_design.py#L93

For example, a block has a mix of 1B and 2B registers, all specifying a "minimum access width" of one byte, the current code infers an 8b-bit data width. But this seems to contradict the first statement above, that the data with will be of the largest register in the design: 16 bits. The larger size allows "atomic" access to larger registers.

In this example, if the RDL is changed to specify "accesswidth=16" for the larger registers, other limitations come into play:

  • lose sub-register access capability
  • tool limitation on alignment of smaller registers

The first quote about should be clarified with current behavior, if intentional. But beyond that, I'm trying to understand whether this is a SystemRDL semantics problem, or a tool mistake, or a tool limitation, etc.

@jscheid-ventana
Copy link
Author

Depending on intent, the other option I can think of is to provide a "user data width" property to specify a minimum data width for the cpuif. That bypasses extracting it from SystemRDL semantics, if that's not otherwise clear at this time.

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

1 participant