diff options
author | Chris Lattner <sabre@nondot.org> | 2006-04-17 22:26:56 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2006-04-17 22:26:56 +0000 |
commit | 36dd7c98d1a148e240d94bf4d6989682868c35a5 (patch) | |
tree | 60b43d2143f638af819853a46ef58eb304c6ecb4 /llvm/lib/Transforms/Scalar/InstructionCombining.cpp | |
parent | 916ae0775ebc9bc59198eee6b9ead6f0505a7f45 (diff) | |
download | bcm5719-llvm-36dd7c98d1a148e240d94bf4d6989682868c35a5.tar.gz bcm5719-llvm-36dd7c98d1a148e240d94bf4d6989682868c35a5.zip |
Turn x86 unaligned load/store intrinsics into aligned load/store instructions
if the pointer is known aligned.
llvm-svn: 27781
Diffstat (limited to 'llvm/lib/Transforms/Scalar/InstructionCombining.cpp')
-rw-r--r-- | llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index 4a0bbf714e5..be3868dca8c 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp @@ -5471,7 +5471,11 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) { default: break; case Intrinsic::ppc_altivec_lvx: case Intrinsic::ppc_altivec_lvxl: - // Turn lvx -> load if the pointer is known aligned. + case Intrinsic::x86_sse_loadu_ps: + case Intrinsic::x86_sse2_loadu_pd: + case Intrinsic::x86_sse2_loadu_dq: + // Turn PPC lvx -> load if the pointer is known aligned. + // Turn X86 loadups -> load if the pointer is known aligned. if (GetKnownAlignment(II->getOperand(1), TD) >= 16) { Value *Ptr = InsertCastBefore(II->getOperand(1), PointerType::get(II->getType()), CI); @@ -5487,6 +5491,17 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) { return new StoreInst(II->getOperand(1), Ptr); } break; + case Intrinsic::x86_sse_storeu_ps: + case Intrinsic::x86_sse2_storeu_pd: + case Intrinsic::x86_sse2_storeu_dq: + case Intrinsic::x86_sse2_storel_dq: + // Turn X86 storeu -> store if the pointer is known aligned. + if (GetKnownAlignment(II->getOperand(1), TD) >= 16) { + const Type *OpPtrTy = PointerType::get(II->getOperand(2)->getType()); + Value *Ptr = InsertCastBefore(II->getOperand(1), OpPtrTy, CI); + return new StoreInst(II->getOperand(2), Ptr); + } + break; case Intrinsic::ppc_altivec_vperm: // Turn vperm(V1,V2,mask) -> shuffle(V1,V2,mask) if mask is a constant. if (ConstantPacked *Mask = dyn_cast<ConstantPacked>(II->getOperand(3))) { |