[PATCH] D86005: [NewPM][LoopFullUnroll] Make LoopFullUnrollPass required
Yuanfang Chen via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Aug 21 15:07:52 PDT 2020
ychen added a comment.
In D86005#2231214 <https://reviews.llvm.org/D86005#2231214>, @aeubanks wrote:
> Assuming that LoopFullUnrollPass is always required to run on anything with `llvm.loop.unroll.full`, it doesn't make sense to make this part of the optnone pass instrumentation since we'd have to add the check to all the pass instrumentations, not just optnone. e.g. opt-bisect should never skip the pass either.
If `llvm.loop.unroll.full` is strong enough that it should override all existing and future pass skipping callbacks' decision, we could either just add it to all the relevant callbacks (probably adding some utility functions) or we just put it in `PassInstrumentation::runBeforePass`. I think it is more important to adhere to the separation of concerns and let pass do transformation while let PassInstrumentation handles all pass skipping. Another reason (not that it matters here) for PassInstrumentation to handle pass skipping is that it could maintain pipeline execution state while pass itself could not. i.e. you could say the third run of foo pass should be skipped.
> We could try going down that route. I'm not sure that the extra code is worth the complexity just to handle LoopFullUnrollPass. The only other thing I can think of like this is alwaysinline, but the inliners don't have dependent passes so those can just be marked required.
Maybe I miss some details. But I would think it shouldn't be more complex than the current approach.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D86005/new/
https://reviews.llvm.org/D86005
More information about the llvm-commits
mailing list