[all-commits] [llvm/llvm-project] 544a6a: [InstCombine] combineLoadToOperationType(): don't ...
Roman Lebedev via All-commits
all-commits at lists.llvm.org
Sun Oct 11 10:25:11 PDT 2020
Branch: refs/heads/master
Home: https://github.com/llvm/llvm-project
Commit: 544a6aa2674e3875e4014eafb101a982f9296439
https://github.com/llvm/llvm-project/commit/544a6aa2674e3875e4014eafb101a982f9296439
Author: Roman Lebedev <lebedev.ri at gmail.com>
Date: 2020-10-11 (Sun, 11 Oct 2020)
Changed paths:
M clang/test/CodeGen/arm64_32-vaarg.c
M llvm/lib/Transforms/InstCombine/InstCombineLoadStoreAlloca.cpp
M llvm/test/Transforms/InstCombine/PR30597.ll
M llvm/test/Transforms/InstCombine/intptr1.ll
M llvm/test/Transforms/InstCombine/load-bitcast32.ll
M llvm/test/Transforms/InstCombine/load-bitcast64.ll
M llvm/test/Transforms/InstCombine/memset_chk-1.ll
Log Message:
-----------
[InstCombine] combineLoadToOperationType(): don't fold int<->ptr cast into load
And another step towards transforms not introducing inttoptr and/or
ptrtoint casts that weren't there already.
As we've been establishing (see D88788/D88789), if there is a int<->ptr cast,
it basically must stay as-is, we can't do much with it.
I've looked, and the most source of new such casts being introduces,
as far as i can tell, is this transform, which, ironically,
tries to reduce count of casts..
On vanilla llvm test-suite + RawSpeed, @ `-O3`, this results in
-33.58% less `IntToPtr`s (19014 -> 12629)
and +76.20% more `PtrToInt`s (18589 -> 32753),
which is an increase of +20.69% in total.
However just on RawSpeed, where i know there are basically
none `IntToPtr` in the original source code,
this results in -99.27% less `IntToPtr`s (2724 -> 20)
and +82.92% more `PtrToInt`s (4513 -> 8255).
which is again an increase of 14.34% in total.
To me this does seem like the step in the right direction,
we end up with strictly less `IntToPtr`, but strictly more `PtrToInt`,
which seems like a reasonable trade-off.
See https://reviews.llvm.org/D88860 / https://reviews.llvm.org/D88995
for some more discussion on the subject.
(Eventually, `CastInst::isNoopCast()`/`CastInst::isEliminableCastPair`
should be taught about this, yes)
Reviewed By: nlopes, nikic
Differential Revision: https://reviews.llvm.org/D88979
More information about the All-commits
mailing list