1 ; RUN: llc -O2 < %s | FileCheck %s 2 ; ModuleID = 'bugpoint-reduced-simplified.bc' 3 target datalayout = "e-m:e-i64:64-n32:64" 4 target triple = "powerpc64le-grtev4-linux-gnu" 5 6 ; Function Attrs: nounwind 7 define void @_ZN10SubProcess19ScrubbedForkAndExecEiPiS0_PNS_7ResultsE() #0 align 2 { 8 ; CHECK: lis 3, 1234 9 ; CHECK-NOT: li 3 10 ; CHECK-NOT: ori 3 11 ; CHECK-NOT: addi 3 12 ; CHECK-NOT: addis 3 13 ; CHECK-NOT: lis 3 14 ; CHECK: sc 15 br i1 undef, label %1, label %2 16 17 ; <label>:1 ; preds = %0 18 br label %60 19 20 ; <label>:2 ; preds = %0 21 br i1 undef, label %3, label %4 22 23 ; <label>:3 ; preds = %2 24 unreachable 25 26 ; <label>:4 ; preds = %2 27 br i1 undef, label %.lr.ph111, label %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit 28 29 .lr.ph111: ; preds = %4 30 br label %5 31 32 _ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit: ; preds = %12, %4 33 br i1 undef, label %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19.preheader, label %13 34 35 ; <label>:5 ; preds = %12, %.lr.ph111 36 br i1 undef, label %6, label %9 37 38 ; <label>:6 ; preds = %5 39 br i1 undef, label %7, label %8 40 41 ; <label>:7 ; preds = %6 42 unreachable 43 44 ; <label>:8 ; preds = %6 45 br label %12 46 47 ; <label>:9 ; preds = %5 48 br i1 undef, label %10, label %11 49 50 ; <label>:10 ; preds = %9 51 br label %12 52 53 ; <label>:11 ; preds = %9 54 br label %12 55 56 ; <label>:12 ; preds = %11, %10, %8 57 br i1 undef, label %5, label %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit 58 59 ; <label>:13 ; preds = %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit 60 br i1 undef, label %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19.preheader, label %14 61 62 ; <label>:14 ; preds = %13 63 br label %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19.preheader 64 65 _ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19.preheader: ; preds = %14, %13, %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit 66 br i1 undef, label %_ZN10SubProcess12SafeSyscalls5closeEi.exit.preheader, label %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19._crit_edge 67 68 _ZN10SubProcess12SafeSyscalls5closeEi.exit.preheader: ; preds = %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19, %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19.preheader 69 br label %_ZN10SubProcess12SafeSyscalls5closeEi.exit 70 71 _ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19._crit_edge: ; preds = %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19, %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19.preheader 72 br i1 undef, label %15, label %19 73 74 _ZN10SubProcess12SafeSyscalls5closeEi.exit: ; preds = %_ZN10SubProcess12SafeSyscalls5closeEi.exit, %_ZN10SubProcess12SafeSyscalls5closeEi.exit.preheader 75 br i1 undef, label %_ZN10SubProcess12SafeSyscalls5closeEi.exit, label %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19 76 77 _ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19: ; preds = %_ZN10SubProcess12SafeSyscalls5closeEi.exit 78 br i1 undef, label %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19._crit_edge, label %_ZN10SubProcess12SafeSyscalls5closeEi.exit.preheader 79 80 ; <label>:15 ; preds = %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19._crit_edge 81 br label %16 82 83 ; <label>:16 ; preds = %17, %15 84 br i1 undef, label %17, label %.critedge.preheader 85 86 ; <label>:17 ; preds = %16 87 br i1 undef, label %16, label %.critedge.preheader 88 89 .critedge.preheader: ; preds = %17, %16 90 br label %.critedge 91 92 .critedge: ; preds = %18, %.critedge.preheader 93 br i1 undef, label %18, label %.critedge8 94 95 ; <label>:18 ; preds = %.critedge 96 br i1 undef, label %.critedge, label %.critedge8 97 98 .critedge8: ; preds = %18, %.critedge 99 br label %59 100 101 ; <label>:19 ; preds = %_ZN10SubProcess12SafeSyscalls11sigprocmaskEiPKNS0_15kernel_sigset_tEPS1_.exit19._crit_edge 102 br label %_ZN10SubProcess12SafeSyscalls5closeEi.exit22 103 104 _ZN10SubProcess12SafeSyscalls5closeEi.exit22: ; preds = %_ZN10SubProcess12SafeSyscalls5closeEi.exit22, %19 105 br i1 undef, label %_ZN10SubProcess12SafeSyscalls5closeEi.exit22, label %20 106 107 ; <label>:20 ; preds = %_ZN10SubProcess12SafeSyscalls5closeEi.exit22 108 %21 = alloca i8, i64 undef, align 1 109 br label %.thread.outer 110 111 .thread.outer: ; preds = %._crit_edge, %20 112 br label %.thread 113 114 .thread: ; preds = %45, %.thread.outer 115 call void @llvm.memset.p0i8.i64(i8* align 8 undef, i8 0, i64 56, i1 false) 116 store i8* %21, i8** undef, align 8 117 store i32 1073741824, i32* undef, align 8 118 %22 = call { i64, i64, i64, i64, i64, i64, i64 } asm sideeffect "sc\0A\09mfcr $0", "=&{r0},=&{r3},=&{r4},=&{r5},=&{r6},=&{r7},=&{r8},{r0},{r3},{r4},{r5},~{cr0},~{ctr},~{memory},~{r11},~{r12}"(i64 342, i64 80871424, i64 undef, i64 0) #2, !srcloc !1 119 br i1 undef, label %.lr.ph, label %.critedge15.preheader 120 121 .critedge15.preheader: ; preds = %_ZN10SubProcess12SafeSyscalls7recvmsgEiPNS0_13kernel_msghdrEi.exit.backedge, %.thread 122 br i1 undef, label %.lr.ph93.preheader, label %.critedge15._crit_edge 123 124 .lr.ph93.preheader: ; preds = %.critedge15.preheader 125 br label %.lr.ph93 126 127 .lr.ph: ; preds = %_ZN10SubProcess12SafeSyscalls7recvmsgEiPNS0_13kernel_msghdrEi.exit.backedge, %.thread 128 switch i32 undef, label %.critedge9 [ 129 i32 11, label %_ZN10SubProcess12SafeSyscalls7recvmsgEiPNS0_13kernel_msghdrEi.exit.backedge 130 i32 4, label %_ZN10SubProcess12SafeSyscalls7recvmsgEiPNS0_13kernel_msghdrEi.exit.backedge 131 ] 132 133 _ZN10SubProcess12SafeSyscalls7recvmsgEiPNS0_13kernel_msghdrEi.exit.backedge: ; preds = %.lr.ph, %.lr.ph 134 br i1 undef, label %.lr.ph, label %.critedge15.preheader 135 136 .critedge9: ; preds = %.lr.ph 137 unreachable 138 139 .critedge15._crit_edge: ; preds = %.critedge15, %.critedge15.preheader 140 br i1 undef, label %35, label %34 141 142 .lr.ph93: ; preds = %.critedge15, %.lr.ph93.preheader 143 switch i32 undef, label %33 [ 144 i32 0, label %23 145 i32 1, label %23 146 i32 2, label %23 147 i32 3, label %23 148 i32 4, label %23 149 i32 5, label %23 150 i32 6, label %23 151 i32 7, label %23 152 i32 8, label %27 153 i32 9, label %30 154 ] 155 156 ; <label>:23 ; preds = %.lr.ph93, %.lr.ph93, %.lr.ph93, %.lr.ph93, %.lr.ph93, %.lr.ph93, %.lr.ph93, %.lr.ph93 157 br i1 undef, label %24, label %.critedge15 158 159 ; <label>:24 ; preds = %23 160 br i1 undef, label %.critedge15, label %25 161 162 ; <label>:25 ; preds = %24 163 br i1 undef, label %.critedge15, label %26 164 165 ; <label>:26 ; preds = %25 166 unreachable 167 168 ; <label>:27 ; preds = %.lr.ph93 169 br i1 undef, label %.critedge15, label %28 170 171 ; <label>:28 ; preds = %27 172 br i1 undef, label %29, label %.critedge15 173 174 ; <label>:29 ; preds = %28 175 br label %.critedge15 176 177 ; <label>:30 ; preds = %.lr.ph93 178 br i1 undef, label %.critedge15, label %31 179 180 ; <label>:31 ; preds = %30 181 br i1 undef, label %32, label %.critedge15 182 183 ; <label>:32 ; preds = %31 184 br label %.critedge15 185 186 ; <label>:33 ; preds = %.lr.ph93 187 unreachable 188 189 .critedge15: ; preds = %32, %31, %30, %29, %28, %27, %25, %24, %23 190 br i1 undef, label %.lr.ph93, label %.critedge15._crit_edge 191 192 ; <label>:34 ; preds = %.critedge15._crit_edge 193 unreachable 194 195 ; <label>:35 ; preds = %.critedge15._crit_edge 196 br i1 undef, label %45, label %36 197 198 ; <label>:36 ; preds = %35 199 br i1 undef, label %37, label %38 200 201 ; <label>:37 ; preds = %36 202 br i1 undef, label %.preheader, label %38 203 204 .preheader: ; preds = %37 205 br i1 undef, label %.lr.ph101, label %._crit_edge 206 207 .lr.ph101: ; preds = %.preheader 208 br label %39 209 210 ; <label>:38 ; preds = %37, %36 211 unreachable 212 213 ; <label>:39 ; preds = %43, %.lr.ph101 214 br i1 undef, label %40, label %43 215 216 ; <label>:40 ; preds = %39 217 br i1 undef, label %_ZN10SubProcess12SafeSyscalls5fcntlEiil.exit17, label %41 218 219 ; <label>:41 ; preds = %40 220 unreachable 221 222 _ZN10SubProcess12SafeSyscalls5fcntlEiil.exit17: ; preds = %40 223 br i1 undef, label %42, label %_ZN10SubProcess12SafeSyscalls5fcntlEiil.exit 224 225 ; <label>:42 ; preds = %_ZN10SubProcess12SafeSyscalls5fcntlEiil.exit17 226 unreachable 227 228 _ZN10SubProcess12SafeSyscalls5fcntlEiil.exit: ; preds = %_ZN10SubProcess12SafeSyscalls5fcntlEiil.exit17 229 br i1 undef, label %.thread27, label %43 230 231 ; <label>:43 ; preds = %_ZN10SubProcess12SafeSyscalls5fcntlEiil.exit, %39 232 br i1 undef, label %39, label %._crit_edge 233 234 .thread27: ; preds = %_ZN10SubProcess12SafeSyscalls5fcntlEiil.exit 235 br label %58 236 237 ._crit_edge: ; preds = %43, %.preheader 238 br i1 undef, label %.thread.outer, label %44 239 240 ; <label>:44 ; preds = %._crit_edge 241 unreachable 242 243 ; <label>:45 ; preds = %35 244 br i1 undef, label %46, label %.thread 245 246 ; <label>:46 ; preds = %45 247 br i1 undef, label %48, label %47 248 249 ; <label>:47 ; preds = %46 250 unreachable 251 252 ; <label>:48 ; preds = %46 253 br i1 undef, label %55, label %49 254 255 ; <label>:49 ; preds = %48 256 br i1 undef, label %50, label %51 257 258 ; <label>:50 ; preds = %49 259 br label %52 260 261 ; <label>:51 ; preds = %49 262 br label %52 263 264 ; <label>:52 ; preds = %51, %50 265 br label %53 266 267 ; <label>:53 ; preds = %54, %52 268 br i1 undef, label %54, label %.critedge13 269 270 ; <label>:54 ; preds = %53 271 br i1 undef, label %53, label %.critedge13 272 273 .critedge13: ; preds = %54, %53 274 br label %58 275 276 ; <label>:55 ; preds = %48 277 br label %56 278 279 ; <label>:56 ; preds = %57, %55 280 br i1 undef, label %57, label %.critedge14 281 282 ; <label>:57 ; preds = %56 283 br i1 undef, label %56, label %.critedge14 284 285 .critedge14: ; preds = %57, %56 286 br label %58 287 288 ; <label>:58 ; preds = %.critedge14, %.critedge13, %.thread27 289 br label %59 290 291 ; <label>:59 ; preds = %58, %.critedge8 292 br label %60 293 294 ; <label>:60 ; preds = %59, %1 295 ret void 296 } 297 298 ; Function Attrs: nounwind argmemonly 299 declare void @llvm.memset.p0i8.i64(i8* nocapture, i8, i64, i1) #1 300 301 attributes #0 = { nounwind "disable-tail-calls"="false" "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="pwr8" "target-features"="+altivec,+bpermd,+crypto,+direct-move,+extdiv,+power8-vector,+vsx,-qpx" "unsafe-fp-math"="false" "use-soft-float"="false" } 302 attributes #1 = { nounwind argmemonly } 303 attributes #2 = { nounwind } 304 305 !1 = !{i32 -2140527538, i32 -2140527533} 306