File: 2012-01-23-PostRA-LICM.ll

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,998,520 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (121 lines) | stat: -rw-r--r-- 6,529 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
; RUN: llc < %s -mcpu=cortex-a8 -verify-machineinstrs
; PR11829
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:64:128-a0:0:64-n32-S64"
target triple = "armv7-none-linux-gnueabi"

define arm_aapcs_vfpcc void @foo(ptr nocapture %arg) nounwind uwtable align 2 {
bb:
  br i1 undef, label %bb1, label %bb2

bb1:                                              ; preds = %bb
  unreachable

bb2:                                              ; preds = %bb
  br label %bb3

bb3:                                              ; preds = %bb4, %bb2
  %tmp = icmp slt i32 undef, undef
  br i1 %tmp, label %bb4, label %bb67

bb4:                                              ; preds = %bb3
  %tmp5 = load <4 x i32>, ptr undef, align 16
  %tmp6 = and <4 x i32> %tmp5, <i32 8388607, i32 8388607, i32 8388607, i32 8388607>
  %tmp7 = or <4 x i32> %tmp6, <i32 1065353216, i32 1065353216, i32 1065353216, i32 1065353216>
  %tmp8 = bitcast <4 x i32> %tmp7 to <4 x float>
  %constexpr = bitcast <4 x float> <float 1.000000e+00, float 1.000000e+00, float 1.000000e+00, float 1.000000e+00> to i128
  %constexpr1 = lshr i128 %constexpr, 64
  %constexpr2 = trunc i128 %constexpr1 to i64
  %constexpr3 = zext i64 %constexpr2 to i128
  %constexpr4 = shl i128 %constexpr3, 64
  %constexpr5 = bitcast <4 x float> <float 1.000000e+00, float 1.000000e+00, float 1.000000e+00, float 1.000000e+00> to i128
  %constexpr6 = trunc i128 %constexpr5 to i64
  %constexpr7 = zext i64 %constexpr6 to i128
  %or = or i128 %constexpr4, %constexpr7
  %bc = bitcast i128 %or to <4 x float>
  %tmp9 = fsub <4 x float> %tmp8, %bc
  %tmp10 = fmul <4 x float> undef, %tmp9
  %tmp11 = fadd <4 x float> undef, %tmp10
  %tmp12 = bitcast <4 x float> zeroinitializer to i128
  %tmp13 = lshr i128 %tmp12, 64
  %tmp14 = trunc i128 %tmp13 to i64
  %tmp15 = insertvalue [2 x i64] undef, i64 %tmp14, 1
  %tmp16 = call <4 x float> @llvm.arm.neon.vrecpe.v4f32(<4 x float> %tmp11) #3
  %tmp17 = call <4 x float> @llvm.arm.neon.vrecps.v4f32(<4 x float> %tmp16, <4 x float> %tmp11) #3
  %tmp18 = fmul <4 x float> %tmp17, %tmp16
  %tmp19 = call <4 x float> @llvm.arm.neon.vrecps.v4f32(<4 x float> %tmp18, <4 x float> %tmp11) #3
  %tmp20 = fmul <4 x float> %tmp19, %tmp18
  %tmp21 = fmul <4 x float> %tmp20, zeroinitializer
  %tmp22 = call <4 x float> @llvm.arm.neon.vmins.v4f32(<4 x float> %tmp21, <4 x float> undef) #3
  call arm_aapcs_vfpcc void @bar(ptr null, ptr undef, ptr undef, [2 x i64] zeroinitializer) #3
  %tmp23 = bitcast <4 x float> %tmp22 to i128
  %tmp24 = trunc i128 %tmp23 to i64
  %tmp25 = insertvalue [2 x i64] undef, i64 %tmp24, 0
  %tmp26 = insertvalue [2 x i64] %tmp25, i64 0, 1
  %tmp27 = load float, ptr undef, align 4
  %tmp28 = insertelement <4 x float> undef, float %tmp27, i32 3
  %tmp29 = load <4 x i32>, ptr undef, align 16
  %tmp30 = and <4 x i32> %tmp29, <i32 8388607, i32 8388607, i32 8388607, i32 8388607>
  %tmp31 = or <4 x i32> %tmp30, <i32 1065353216, i32 1065353216, i32 1065353216, i32 1065353216>
  %tmp32 = bitcast <4 x i32> %tmp31 to <4 x float>
  %constexpr8 = bitcast <4 x float> <float 1.000000e+00, float 1.000000e+00, float 1.000000e+00, float 1.000000e+00> to i128
  %constexpr9 = lshr i128 %constexpr8, 64
  %constexpr10 = trunc i128 %constexpr9 to i64
  %constexpr11 = zext i64 %constexpr10 to i128
  %constexpr12 = shl i128 %constexpr11, 64
  %constexpr13 = bitcast <4 x float> <float 1.000000e+00, float 1.000000e+00, float 1.000000e+00, float 1.000000e+00> to i128
  %constexpr14 = trunc i128 %constexpr13 to i64
  %constexpr15 = zext i64 %constexpr14 to i128
  %or2 = or i128 %constexpr12, %constexpr15
  %bc2 = bitcast i128 %or2 to <4 x float>
  %tmp33 = fsub <4 x float> %tmp32, %bc2
  %tmp34 = call <4 x float> @llvm.arm.neon.vrecps.v4f32(<4 x float> undef, <4 x float> %tmp28) #3
  %tmp35 = fmul <4 x float> %tmp34, undef
  %tmp36 = fmul <4 x float> %tmp35, undef
  %tmp37 = call arm_aapcs_vfpcc ptr undef(ptr undef) #3
  %tmp38 = load float, ptr undef, align 4
  %tmp39 = insertelement <2 x float> undef, float %tmp38, i32 0
  %tmp40 = call arm_aapcs_vfpcc ptr undef(ptr undef) #3
  %tmp41 = load float, ptr undef, align 4
  %tmp42 = insertelement <4 x float> undef, float %tmp41, i32 3
  %tmp43 = shufflevector <2 x float> %tmp39, <2 x float> undef, <4 x i32> zeroinitializer
  %tmp44 = fmul <4 x float> %tmp33, %tmp43
  %tmp45 = fadd <4 x float> %tmp42, %tmp44
  %tmp46 = fsub <4 x float> %tmp45, undef
  %tmp47 = fmul <4 x float> %tmp46, %tmp36
  %tmp48 = fadd <4 x float> undef, %tmp47
  %tmp49 = call arm_aapcs_vfpcc ptr undef(ptr undef) #3
  %tmp50 = load float, ptr undef, align 4
  %tmp51 = insertelement <4 x float> undef, float %tmp50, i32 3
  %tmp52 = call arm_aapcs_vfpcc ptr null(ptr undef) #3
  %tmp54 = load float, ptr %tmp52, align 4
  %tmp55 = insertelement <4 x float> undef, float %tmp54, i32 3
  %tmp56 = fsub <4 x float> <float 1.000000e+00, float 1.000000e+00, float 1.000000e+00, float 1.000000e+00>, %tmp22
  %tmp57 = call <4 x float> @llvm.arm.neon.vmins.v4f32(<4 x float> %tmp56, <4 x float> %tmp55) #3
  %tmp58 = fmul <4 x float> undef, %tmp57
  %tmp59 = fsub <4 x float> %tmp51, %tmp48
  %tmp60 = fsub <4 x float> <float 1.000000e+00, float 1.000000e+00, float 1.000000e+00, float 1.000000e+00>, %tmp58
  %tmp61 = fmul <4 x float> %tmp59, %tmp60
  %tmp62 = fadd <4 x float> %tmp48, %tmp61
  call arm_aapcs_vfpcc void @baz(ptr undef, ptr undef, [2 x i64] %tmp26, ptr undef)
  %tmp63 = bitcast <4 x float> %tmp62 to i128
  %tmp64 = lshr i128 %tmp63, 64
  %tmp65 = trunc i128 %tmp64 to i64
  %tmp66 = insertvalue [2 x i64] zeroinitializer, i64 %tmp65, 1
  call arm_aapcs_vfpcc void @quux(ptr undef, ptr undef, [2 x i64] undef, ptr undef, [2 x i64] %tmp66, ptr undef, ptr undef, [2 x i64] %tmp26, [2 x i64] %tmp15, ptr undef)
  br label %bb3

bb67:                                             ; preds = %bb3
  ret void
}

declare arm_aapcs_vfpcc void @bar(ptr, ptr, ptr, [2 x i64])

declare arm_aapcs_vfpcc void @baz(ptr, ptr nocapture, [2 x i64], ptr nocapture) nounwind uwtable inlinehint align 2

declare arm_aapcs_vfpcc void @quux(ptr, ptr, [2 x i64], ptr nocapture, [2 x i64], ptr nocapture, ptr nocapture, [2 x i64], [2 x i64], ptr nocapture) nounwind uwtable inlinehint align 2

declare <4 x float> @llvm.arm.neon.vmins.v4f32(<4 x float>, <4 x float>) nounwind readnone

declare <4 x float> @llvm.arm.neon.vrecps.v4f32(<4 x float>, <4 x float>) nounwind readnone

declare <4 x float> @llvm.arm.neon.vrecpe.v4f32(<4 x float>) nounwind readnone