Skip to content

Commit

Permalink
MergeFunctions: Two different sized allocas are *not* the same
Browse files Browse the repository at this point in the history
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@237193 91177308-0d34-0410-b5e6-96231b3b80d8
  • Loading branch information
aschwaighofer committed May 12, 2015
1 parent 11fb964 commit 414a781
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 0 deletions.
9 changes: 9 additions & 0 deletions lib/Transforms/IPO/MergeFunctions.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -719,6 +719,15 @@ int FunctionComparator::cmpOperations(const Instruction *L,
R->getRawSubclassOptionalData()))
return Res;

if (const AllocaInst *AI = dyn_cast<AllocaInst>(L)) {
if (int Res = cmpTypes(AI->getAllocatedType(),
cast<AllocaInst>(R)->getAllocatedType()))
return Res;
if (int Res =
cmpNumbers(AI->getAlignment(), cast<AllocaInst>(R)->getAlignment()))
return Res;
}

// We have two instructions of identical opcode and #operands. Check to see
// if all operands are the same type
for (unsigned i = 0, e = L->getNumOperands(); i != e; ++i) {
Expand Down
33 changes: 33 additions & 0 deletions test/Transforms/MergeFunc/alloca.ll
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
; RUN: opt -mergefunc -S < %s | FileCheck %s

;; Make sure that two different sized allocas are not treated as equal.

target datalayout = "e-m:w-p:32:32-i64:64-f80:32-n8:16:32-S32"

%kv1 = type { i32, i32 }
%kv2 = type { i8 }


define void @a(i8 *%f) {
%v = alloca %kv1, align 8
%f_2 = bitcast i8* %f to void (%kv1 *)*
call void %f_2(%kv1 * %v)
call void %f_2(%kv1 * %v)
call void %f_2(%kv1 * %v)
call void %f_2(%kv1 * %v)
ret void
}

; CHECK-LABEL: define void @b
; CHECK-NOT: call @a
; CHECK: ret

define void @b(i8 *%f) {
%v = alloca %kv2, align 8
%f_2 = bitcast i8* %f to void (%kv2 *)*
call void %f_2(%kv2 * %v)
call void %f_2(%kv2 * %v)
call void %f_2(%kv2 * %v)
call void %f_2(%kv2 * %v)
ret void
}

0 comments on commit 414a781

Please sign in to comment.