From: Bill Wendling Date: Tue, 23 Oct 2007 23:32:40 +0000 (+0000) Subject: If there's an unaligned memcpy to/from the stack, don't lower it. Just call the X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=8b1c68cee4ddf42b4b57d4224f945ad9e9d4a779;p=oota-llvm.git If there's an unaligned memcpy to/from the stack, don't lower it. Just call the memcpy library function instead. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43270 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp index 610c898d170..71999b44c1e 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp @@ -4329,6 +4329,19 @@ void SelectionDAGLowering::visitMemIntrinsic(CallInst &I, unsigned Op) { } } + // Check to see if there is an unaligned memcpy from/onto the stack. If + // so, then ignore it for the present. + if (Op1.getOpcode() == ISD::FrameIndex || + Op2.getOpcode() == ISD::FrameIndex) { + unsigned TotalSize = 0; + + for (unsigned i = 0; i < NumMemOps; i++) + TotalSize += MVT::getSizeInBits(MemOps[i]) / 8; + + if (TotalSize % Align != 0) + break; + } + for (unsigned i = 0; i < NumMemOps; i++) { MVT::ValueType VT = MemOps[i]; unsigned VTSize = MVT::getSizeInBits(VT) / 8; diff --git a/test/CodeGen/PowerPC/2007-10-23-UnalignedMemcpy.ll b/test/CodeGen/PowerPC/2007-10-23-UnalignedMemcpy.ll new file mode 100644 index 00000000000..c0cf201f72e --- /dev/null +++ b/test/CodeGen/PowerPC/2007-10-23-UnalignedMemcpy.ll @@ -0,0 +1,13 @@ +; RUN: llvm-as < %s | llc -mtriple=powerpc64-apple-darwin9 -o - | grep memcpy + +@C.0.1173 = external constant [33 x i8] ; <[33 x i8]*> [#uses=1] + +define void @Bork() { +entry: + %Qux = alloca [33 x i8] ; <[33 x i8]*> [#uses=1] + %Qux1 = bitcast [33 x i8]* %Qux to i8* ; [#uses=1] + call void @llvm.memcpy.i64( i8* %Qux1, i8* getelementptr ([33 x i8]* @C.0.1173, i32 0, i32 0), i64 33, i32 8 ) + ret void +} + +declare void @llvm.memcpy.i64(i8*, i8*, i64, i32)