[llvm] [clang] split load to bytes to deduce load value (PR #72364)
via llvm-commits
llvm-commits at lists.llvm.org
Wed Nov 15 01:33:43 PST 2023
github-actions[bot] wrote:
<!--LLVM CODE FORMAT COMMENT: {clang-format}-->
:warning: C/C++ code formatter, clang-format found issues in your code. :warning:
<details>
<summary>
You can test this locally with the following command:
</summary>
``````````bash
git-clang-format --diff dedf2c6bb5193652f6ad7d9ff9e676624c2485b7 41a9dbd39fbb866e7fc090f82d58ee6364a7cfda -- clang/test/Frontend/optimization-remark-extra-analysis.c llvm/include/llvm/Transforms/Scalar/GVN.h llvm/lib/Transforms/Scalar/GVN.cpp
``````````
</details>
<details>
<summary>
View the diff from clang-format here.
</summary>
``````````diff
diff --git a/llvm/lib/Transforms/Scalar/GVN.cpp b/llvm/lib/Transforms/Scalar/GVN.cpp
index f64508a831..fc0b49bcd9 100644
--- a/llvm/lib/Transforms/Scalar/GVN.cpp
+++ b/llvm/lib/Transforms/Scalar/GVN.cpp
@@ -2163,10 +2163,10 @@ bool GVNPass::splitAndprocessLoad(LoadInst *L) {
// we update this byte by byte as we deduce the load value
APInt ConstructedValue = APInt::getZero(BW);
- for (unsigned i=0; i<BW/8; i++) {
+ for (unsigned i = 0; i < BW / 8; i++) {
Value *Offset = Constant::getIntegerValue(LTy, APInt(BW, i));
GetElementPtrInst *GEP = GetElementPtrInst::Create(
- ByteTy, Base, ArrayRef<Value*>(Offset), "", L);
+ ByteTy, Base, ArrayRef<Value *>(Offset), "", L);
LoadInst *ByteLoad = new LoadInst(ByteTy, GEP, "", L);
ByteLoad->setDebugLoc(L->getDebugLoc());
@@ -2186,22 +2186,21 @@ bool GVNPass::splitAndprocessLoad(LoadInst *L) {
}
auto ByteRes = AnalyzeLoadAvailability(ByteLoad, ByteDep, GEP);
- // If it doesn't reduce to a constant, give up. Creating the value at runtime by
- // shifting the bytes is not worth it to remove a load.
- if (ByteRes &&
- (ByteRes->isMemIntrinValue() ||
- (ByteRes->isSimpleValue() &&
- (isa<ConstantInt>(ByteRes->getSimpleValue()) ||
- isa<UndefValue>(ByteRes->getSimpleValue()))))) {
- Value *V = ByteRes->MaterializeAdjustedValue(ByteLoad, ByteLoad, *this);
- ConstantInt *ByteConst = dyn_cast<ConstantInt>(V);
- if (!ByteConst) {
- // replace undef with 0. This helps optimize cases where some bits of
- // load are constant integer, and some are undef. So we can optimize
- // the load to a particular integer.
- ByteConst = ConstantInt::get(ByteTy, 0);
- }
- ConstructedValue.insertBits(ByteConst->getValue(), 8*i);
+ // If it doesn't reduce to a constant, give up. Creating the value at
+ // runtime by shifting the bytes is not worth it to remove a load.
+ if (ByteRes && (ByteRes->isMemIntrinValue() ||
+ (ByteRes->isSimpleValue() &&
+ (isa<ConstantInt>(ByteRes->getSimpleValue()) ||
+ isa<UndefValue>(ByteRes->getSimpleValue()))))) {
+ Value *V = ByteRes->MaterializeAdjustedValue(ByteLoad, ByteLoad, *this);
+ ConstantInt *ByteConst = dyn_cast<ConstantInt>(V);
+ if (!ByteConst) {
+ // replace undef with 0. This helps optimize cases where some bits of
+ // load are constant integer, and some are undef. So we can optimize
+ // the load to a particular integer.
+ ByteConst = ConstantInt::get(ByteTy, 0);
+ }
+ ConstructedValue.insertBits(ByteConst->getValue(), 8 * i);
} else {
LLVM_DEBUG(dbgs() << "GVN split load: byte " << i
<< " did not reduce to a constant. Giving up");
``````````
</details>
https://github.com/llvm/llvm-project/pull/72364
More information about the llvm-commits
mailing list