[PATCH] D107677: Prevent machine licm if remattable with a vreg use
Stanislav Mekhanoshin via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Aug 10 15:28:24 PDT 2021
rampitec added a comment.
In D107677#2938247 <https://reviews.llvm.org/D107677#2938247>, @rampitec wrote:
> In D107677#2936366 <https://reviews.llvm.org/D107677#2936366>, @dmgreen wrote:
>
>> This does effect the ARM backend, apparently at some point it obtained the ability to hoist VCTP instructions which take a register use. I'm not sure if that really fits the definition of trivially rematerializable though, from the code comment on isTriviallyReMaterializable. (But I'm not sure that comment is up to date.)
>
> I am also looking at the D87280 <https://reviews.llvm.org/D87280> which has enabled rematerialization of VCTP. It looks like the tests there want it to be rematerialized, effectively sunk into a loop body, and not hoisted. I am not sure if such hoisting (which will happen less frequently if ever after this patch) considered a good thing. My impression from the D87280 <https://reviews.llvm.org/D87280> and its description that it would not be desired.
Looking more into that I do not think VCTP was ever hoisted pre-RA. It shall not pass `MachineLoop::isLoopInvariant()` check because of the physreg P0 def, unless P0 is dead.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D107677/new/
https://reviews.llvm.org/D107677
More information about the llvm-commits
mailing list