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

JIT: Consolidate block pred iterator logic #111009

Merged
merged 2 commits into from
Jan 6, 2025

Conversation

amanasifkhalid
Copy link
Member

Move most of the nested iterator class logic in PredEdgeList/PredBlockList to a generic base class, and implement subclasses that specify the yield type (flow edge or basic block) and whether edits are allowed. This allows us to add a pred edge iterator that tolerates edits with minimal code duplication.

@dotnet-issue-labeler dotnet-issue-labeler bot added the area-CodeGen-coreclr CLR JIT compiler in src/coreclr/src/jit and related components such as SuperPMI label Dec 31, 2024
Copy link
Contributor

Tagging subscribers to this area: @JulieLeeMSFT, @jakobbotsch
See info in area-owners.md if you want to be subscribed.

@amanasifkhalid
Copy link
Member Author

From the TP diffs, I suspect MSVC isn't devirtualizing the operator* calls, though it probably makes sense to just move this method to the subclasses entirely, and remove the IteratorType template variable.

@amanasifkhalid
Copy link
Member Author

cc @dotnet/jit-contrib, @AndyAyersMS PTAL. No diffs. Thanks!

@amanasifkhalid amanasifkhalid merged commit c3445c7 into dotnet:main Jan 6, 2025
104 of 108 checks passed
@amanasifkhalid amanasifkhalid deleted the pred-iterators branch January 6, 2025 15:41
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area-CodeGen-coreclr CLR JIT compiler in src/coreclr/src/jit and related components such as SuperPMI
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants