[FIRRTL] Make memory matadata work with layers #7789
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Extend the existing notion of how memory metadata is generated to work for memories that are under layers. Use an interpretation of the "design" excluding layers. In effect, memories which are under layers now generate metadata as if that instantiation was in the test harness.
I note that the current behavior here is inconsistent. The metadata generation behavior is different for a memory which is partially in the design (it has instances which are in the design and not in the design) compared to a memory which is wholly not in the design. However, this is the exact same behavior as before this change.
The details of what happens here are somewhat complex. For documentation of the current behavior, see the tests that accompany this commit.
In the future, this behavior should be changed to be dramatically simpler.