mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 20:23:11 +01:00
457191ce8d
r237193 fix handling of alloca size / align in MergeFunctions, but only tested one and didn't follow FunctionComparator::cmpOperations's usual comparison pattern. It also didn't update Instruction.cpp:haveSameSpecialState which I'll do separately. llvm-svn: 266022
62 lines
1.4 KiB
LLVM
62 lines
1.4 KiB
LLVM
; RUN: opt -mergefunc -S < %s | FileCheck %s
|
|
|
|
;; Make sure that two different 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 }
|
|
%kv3 = type { i64, i64 }
|
|
|
|
; Size difference.
|
|
|
|
; CHECK-LABEL: define void @size1
|
|
; CHECK-NOT: call void @
|
|
define void @size1(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 @size2
|
|
; CHECK-NOT: call void @
|
|
define void @size2(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
|
|
}
|
|
|
|
; Alignment difference.
|
|
|
|
; CHECK-LABEL: define void @align1
|
|
; CHECK-NOT: call void @
|
|
define void @align1(i8 *%f) {
|
|
%v = alloca %kv3, align 8
|
|
%f_2 = bitcast i8* %f to void (%kv3 *)*
|
|
call void %f_2(%kv3 * %v)
|
|
call void %f_2(%kv3 * %v)
|
|
call void %f_2(%kv3 * %v)
|
|
call void %f_2(%kv3 * %v)
|
|
ret void
|
|
}
|
|
|
|
; CHECK-LABEL: define void @align2
|
|
; CHECK-NOT: call void @
|
|
define void @align2(i8 *%f) {
|
|
%v = alloca %kv3, align 16
|
|
%f_2 = bitcast i8* %f to void (%kv3 *)*
|
|
call void %f_2(%kv3 * %v)
|
|
call void %f_2(%kv3 * %v)
|
|
call void %f_2(%kv3 * %v)
|
|
call void %f_2(%kv3 * %v)
|
|
ret void
|
|
}
|