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

Add caching of identical instance bodies #949

Open
MikePopoloski opened this issue Apr 7, 2024 · 3 comments
Open

Add caching of identical instance bodies #949

MikePopoloski opened this issue Apr 7, 2024 · 3 comments

Comments

@MikePopoloski
Copy link
Owner

Support caching instance bodies and skipping over identical copies when elaborating, to save time. Expose this functionality so that downstream consumers of the AST can easily do the same.

Note that the tricky detail here is figuring out how to handle hierarchical references into and out of the cached instances.

@yanggeorge
Copy link

yanggeorge commented Apr 29, 2024

It is better that elabarated AST only keeps one instance of those identical instances, then visiting the AST will be faster.

@likeamahoney
Copy link
Contributor

My hash suggestion - #1088 (comment)

@MikePopoloski
Copy link
Owner Author

This can now be turned on with a compilation flag, with a caveat that it can cause some multi-driven errors to not be issued correctly. Things to handle before it's fully robust:

  • Assignments through interface ports need to be reapplied to specific instances being connected
  • Any upward hierarchical references that extend out of the cached instance need to be re-resolved, and the resolved types must match, otherwise we can't use the cache entry
  • Downward hierarchical references into such instances need to be accounted for
  • Bind directives needs to be accounted for
  • Defparams need to be accounted for
  • Configuration rules need to be accounted for

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants