[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / Transforms / InstSimplify / ConstProp / bitcast.ll
blob19165da28bba9f04a9a380985a4bbeece1b15d7f
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -instsimplify -S | FileCheck %s
3 ; PR2165
5 define <1 x i64> @test1() {
6 ; CHECK-LABEL: @test1(
7 ; CHECK-NEXT:    ret <1 x i64> <i64 63>
9   %A = bitcast i64 63 to <1 x i64>
10   ret <1 x i64> %A
13 ; Ensure that a FP source operand isn't propagated to an icmp.
15 @a = external global i16, align 1
16 @b = external global i16, align 1
18 define i1 @bad_icmp_constexpr_bitcast() {
19 ; CHECK-LABEL: @bad_icmp_constexpr_bitcast(
20 ; CHECK-NEXT:    ret i1 icmp eq (i32 ptrtoint (i16* @a to i32), i32 bitcast (float fadd (float bitcast (i32 ptrtoint (i16* @b to i32) to float), float 2.000000e+00) to i32))
22   %cmp = icmp eq i32 ptrtoint (i16* @a to i32), bitcast (float fadd (float bitcast (i32 ptrtoint (i16* @b to i32) to float), float 2.0) to i32)
23   ret i1 %cmp
26 ; Ensure that an integer source operand isn't propagated to a fcmp.
28 @c = external global i16, align 1
29 @d = external global i16, align 1
31 define i1 @bad_fcmp_constexpr_bitcast() {
32 ; CHECK-LABEL: @bad_fcmp_constexpr_bitcast(
33 ; CHECK-NEXT:    ret i1 fcmp oeq (float bitcast (i32 ptrtoint (i16* @c to i32) to float), float bitcast (i32 add (i32 ptrtoint (i16* @d to i32), i32 2) to float))
35   %cmp = fcmp oeq float bitcast (i32 ptrtoint (i16* @c to i32) to float), bitcast (i32 add (i32 ptrtoint (i16* @d to i32), i32 2) to float)
36   ret i1 %cmp
39 ; Ensure that an "ordered and equal" fcmp of a ConstantExpr to itself is not folded, since the ConstantExpr may be a NaN.
41 define i1 @fcmp_constexpr_oeq(float %conv) {
42 ; CHECK-LABEL: @fcmp_constexpr_oeq(
43 ; CHECK-NEXT:    ret i1 fcmp oeq (float bitcast (i32 ptrtoint (i16* @a to i32) to float), float bitcast (i32 ptrtoint (i16* @a to i32) to float))
45   %cmp = fcmp oeq float bitcast (i32 ptrtoint (i16* @a to i32) to float), bitcast (i32 ptrtoint (i16* @a to i32) to float)
46   ret i1 %cmp
49 ; Ensure that an "unordered or not equal" fcmp of a ConstantExpr to itself is not folded, since the ConstantExpr may be a NaN.
51 define i1 @fcmp_constexpr_une(float %conv) {
52 ; CHECK-LABEL: @fcmp_constexpr_une(
53 ; CHECK-NEXT:    ret i1 fcmp une (float bitcast (i32 ptrtoint (i16* @a to i32) to float), float bitcast (i32 ptrtoint (i16* @a to i32) to float))
55   %cmp = fcmp une float bitcast (i32 ptrtoint (i16* @a to i32) to float), bitcast (i32 ptrtoint (i16* @a to i32) to float)
56   ret i1 %cmp
59 define i1 @fcmp_constexpr_ueq(float %conv) {
60 ; CHECK-LABEL: @fcmp_constexpr_ueq(
61 ; CHECK-NEXT:    ret i1 true
63   %cmp = fcmp ueq float bitcast (i32 ptrtoint (i16* @a to i32) to float), bitcast (i32 ptrtoint (i16* @a to i32) to float)
64   ret i1 %cmp
67 define i1 @fcmp_constexpr_one(float %conv) {
68 ; CHECK-LABEL: @fcmp_constexpr_one(
69 ; CHECK-NEXT:    ret i1 false
71   %cmp = fcmp one float bitcast (i32 ptrtoint (i16* @a to i32) to float), bitcast (i32 ptrtoint (i16* @a to i32) to float)
72   ret i1 %cmp
75 %T = type { i8 }
76 @G = external global %T
78 define i8* @bitcast_to_gep() {
79 ; CHECK-LABEL: @bitcast_to_gep(
80 ; CHECK-NEXT:    ret i8* getelementptr inbounds (%T, %T* @G, i32 0, i32 0)
82   %p = bitcast %T* @G to i8*
83   ret i8* %p
86 define i8 addrspace(1)* @addrspacecast_to_gep() {
87 ; CHECK-LABEL: @addrspacecast_to_gep(
88 ; CHECK-NEXT:    ret i8 addrspace(1)* addrspacecast (i8* getelementptr inbounds (%T, %T* @G, i32 0, i32 0) to i8 addrspace(1)*)
90   %p = addrspacecast %T* @G to i8 addrspace(1)*
91   ret i8 addrspace(1)* %p