[llvm] 389ed47 - [BPF] Remove unnecessary BitCast operations (#131260)
via llvm-commits
llvm-commits at lists.llvm.org
Fri Mar 14 07:53:33 PDT 2025
Author: yonghong-song
Date: 2025-03-14T07:53:29-07:00
New Revision: 389ed474e81f402294a1dc03a5ea7b039a523965
URL: https://github.com/llvm/llvm-project/commit/389ed474e81f402294a1dc03a5ea7b039a523965
DIFF: https://github.com/llvm/llvm-project/commit/389ed474e81f402294a1dc03a5ea7b039a523965.diff
LOG: [BPF] Remove unnecessary BitCast operations (#131260)
In [1], Nikita Popov spotted that two BitCast operations are not needed
with opaque pointers. So remove these two BitCast operations and adjust
corresponding comments as well.
[1] https://github.com/llvm/llvm-project/pull/130722
Co-authored-by: Yonghong Song <yonghong.song at linux.dev>
Added:
Modified:
llvm/lib/Target/BPF/BPFAbstractMemberAccess.cpp
Removed:
################################################################################
diff --git a/llvm/lib/Target/BPF/BPFAbstractMemberAccess.cpp b/llvm/lib/Target/BPF/BPFAbstractMemberAccess.cpp
index 77ed246edbadf..3b336f87c9b34 100644
--- a/llvm/lib/Target/BPF/BPFAbstractMemberAccess.cpp
+++ b/llvm/lib/Target/BPF/BPFAbstractMemberAccess.cpp
@@ -1102,39 +1102,26 @@ bool BPFAbstractMemberAccess::transformGEPChain(CallInst *Call,
// %4 = bitcast %struct.net_device** %dev1 to i64*
// it is transformed to:
// %6 = load llvm.sk_buff:0:50$0:0:0:2:0
- // %7 = bitcast %struct.sk_buff* %2 to i8*
- // %8 = getelementptr i8, i8* %7, %6
- // %9 = bitcast i8* %8 to i64*
- // using %9 instead of %4
+ // %8 = getelementptr i8, i8* %2, %6
+ // using %8 instead of %4
// The original Call inst is removed.
// Load the global variable.
auto *LDInst = new LoadInst(Type::getInt64Ty(BB->getContext()), GV, "",
Call->getIterator());
- // Generate a BitCast
- auto *BCInst = new BitCastInst(
- Base, PointerType::get(BB->getContext(),
- Base->getType()->getPointerAddressSpace()));
- BCInst->insertBefore(Call->getIterator());
-
// Generate a GetElementPtr
- auto *GEP = GetElementPtrInst::Create(Type::getInt8Ty(BB->getContext()),
- BCInst, LDInst);
+ auto *GEP = GetElementPtrInst::Create(Type::getInt8Ty(BB->getContext()), Base,
+ LDInst);
GEP->insertBefore(Call->getIterator());
- // Generate a BitCast
- auto *BCInst2 = new BitCastInst(GEP, Call->getType());
- BCInst2->insertBefore(Call->getIterator());
-
// For the following code,
// Block0:
// ...
// if (...) goto Block1 else ...
// Block1:
// %6 = load llvm.sk_buff:0:50$0:0:0:2:0
- // %7 = bitcast %struct.sk_buff* %2 to i8*
- // %8 = getelementptr i8, i8* %7, %6
+ // %8 = getelementptr i8, i8* %2, %6
// ...
// goto CommonExit
// Block2:
@@ -1142,8 +1129,7 @@ bool BPFAbstractMemberAccess::transformGEPChain(CallInst *Call,
// if (...) goto Block3 else ...
// Block3:
// %6 = load llvm.bpf_map:0:40$0:0:0:2:0
- // %7 = bitcast %struct.sk_buff* %2 to i8*
- // %8 = getelementptr i8, i8* %7, %6
+ // %8 = getelementptr i8, i8* %2, %6
// ...
// goto CommonExit
// CommonExit
@@ -1157,8 +1143,7 @@ bool BPFAbstractMemberAccess::transformGEPChain(CallInst *Call,
// Block_Common:
// PHI = [llvm.sk_buff:0:50$0:0:0:2:0, llvm.bpf_map:0:40$0:0:0:2:0]
// %6 = load PHI
- // %7 = bitcast %struct.sk_buff* %2 to i8*
- // %8 = getelementptr i8, i8* %7, %6
+ // %8 = getelementptr i8, i8* %2, %6
// ...
// goto CommonExit
// For the above code, we cannot perform proper relocation since
@@ -1173,7 +1158,7 @@ bool BPFAbstractMemberAccess::transformGEPChain(CallInst *Call,
// This approach is also used in other places when global var
// representing a relocation is used.
Instruction *PassThroughInst =
- BPFCoreSharedInfo::insertPassThrough(M, BB, BCInst2, Call);
+ BPFCoreSharedInfo::insertPassThrough(M, BB, GEP, Call);
Call->replaceAllUsesWith(PassThroughInst);
Call->eraseFromParent();
More information about the llvm-commits
mailing list