llvm/llvm/test/CodeGen/SystemZ/splitMove_undefReg_mverifier_2.ll

; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z13 -verify-machineinstrs -disable-lsr | FileCheck %s
;
; Regression test for a machine verifier complaint discovered with llvm-stress.
; Test that splitting of a 128 bit store does not result in use of undef phys reg.
; This test case involved spilling of 128 bits, where the data operand was killed.

define void @autogen_SD15107(ptr, ptr, ptr, i32, i64, i8) {
; CHECK: .text
BB:
  %A4 = alloca double
  %A1 = alloca i32
  %L = load i8, ptr %0
  br label %CF331

CF331:                                            ; preds = %CF331, %BB
  %Shuff = shufflevector <8 x i8> zeroinitializer, <8 x i8> zeroinitializer, <8 x i32> <i32 undef, i32 undef, i32 1, i32 3, i32 5, i32 7, i32 9, i32 11>
  %L5 = load i8, ptr %0
  %FC9 = fptosi float 0xC59D259100000000 to i8
  %Shuff13 = shufflevector <8 x i64> zeroinitializer, <8 x i64> zeroinitializer, <8 x i32> <i32 10, i32 undef, i32 14, i32 0, i32 undef, i32 4, i32 6, i32 8>
  %Tr = trunc <8 x i16> zeroinitializer to <8 x i1>
  %Sl16 = select i1 true, i64 448097, i64 253977
  %E18 = extractelement <2 x i1> zeroinitializer, i32 1
  br i1 %E18, label %CF331, label %CF350

CF350:                                            ; preds = %CF331
  %Cmp22 = icmp slt i8 %L, -1
  br label %CF

CF:                                               ; preds = %CF333, %CF364, %CF, %CF350
  %Shuff25 = shufflevector <16 x i1> zeroinitializer, <16 x i1> zeroinitializer, <16 x i32> <i32 25, i32 27, i32 29, i32 31, i32 1, i32 undef, i32 undef, i32 7, i32 9, i32 11, i32 undef, i32 15, i32 17, i32 19, i32 21, i32 23>
  %B27 = mul <8 x i8> zeroinitializer, %Shuff
  %L31 = load i8, ptr %0
  store i8 %L5, ptr %0
  %E32 = extractelement <8 x i64> %Shuff13, i32 5
  %Sl37 = select i1 %E18, ptr %2, ptr %2
  %E40 = extractelement <8 x i64> %Shuff13, i32 4
  %I42 = insertelement <8 x i64> %Shuff13, i64 0, i32 1
  %Sl44 = select i1 true, ptr %A4, ptr %A4
  %L46 = load i64, ptr %Sl37
  br i1 undef, label %CF, label %CF335

CF335:                                            ; preds = %CF335, %CF
  %Shuff48 = shufflevector <8 x i16> zeroinitializer, <8 x i16> zeroinitializer, <8 x i32> <i32 undef, i32 15, i32 undef, i32 3, i32 5, i32 7, i32 9, i32 11>
  %B50 = sub <8 x i64> undef, zeroinitializer
  %Se = sext i1 %Cmp22 to i64
  %Cmp52 = icmp ule i64 %E40, 184653
  br i1 %Cmp52, label %CF335, label %CF364

CF364:                                            ; preds = %CF335
  store i64 %E32, ptr %Sl37
  %B57 = udiv <8 x i64> %I42, %B50
  %L61 = load i64, ptr %Sl37
  %Sl65 = select i1 undef, i1 %Cmp52, i1 true
  br i1 %Sl65, label %CF, label %CF333

CF333:                                            ; preds = %CF364
  %Cmp66 = fcmp uge float 0x474A237E00000000, undef
  br i1 %Cmp66, label %CF, label %CF324

CF324:                                            ; preds = %CF358, %CF360, %CF333
  %L67 = load i64, ptr %Sl37
  %Sl73 = select i1 %E18, i8 %L, i8 %L31
  %ZE = zext i1 true to i32
  %Cmp81 = icmp ult i64 184653, %L46
  br label %CF346

CF346:                                            ; preds = %CF363, %CF346, %CF324
  %L82 = load double, ptr %Sl44
  store i64 %Se, ptr %Sl37
  br i1 undef, label %CF346, label %CF363

CF363:                                            ; preds = %CF346
  %I85 = insertelement <8 x i64> undef, i64 0, i32 4
  %Se86 = sext i1 %Cmp81 to i64
  %Cmp88 = icmp eq <16 x i1> zeroinitializer, undef
  %Shuff91 = shufflevector <8 x i64> %B57, <8 x i64> %I42, <8 x i32> <i32 1, i32 undef, i32 5, i32 7, i32 undef, i32 11, i32 13, i32 undef>
  %Sl95 = select i1 undef, i8 -1, i8 %5
  store i8 %FC9, ptr %0
  %Sl102 = select i1 %Sl65, float 0x3AAFABC380000000, float undef
  %L104 = load i64, ptr %Sl37
  store i8 %Sl95, ptr %0
  br i1 undef, label %CF346, label %CF360

CF360:                                            ; preds = %CF363
  %I107 = insertelement <16 x i1> undef, i1 %Sl65, i32 3
  %B108 = fdiv float undef, %Sl102
  %FC109 = sitofp <16 x i1> %Shuff25 to <16 x float>
  %Cmp111 = icmp slt i8 %Sl73, %Sl95
  br i1 %Cmp111, label %CF324, label %CF344

CF344:                                            ; preds = %CF344, %CF360
  store i64 %4, ptr %Sl37
  br i1 undef, label %CF344, label %CF358

CF358:                                            ; preds = %CF344
  %B116 = add i8 29, %5
  %Sl118 = select i1 %Cmp81, <8 x i1> undef, <8 x i1> %Tr
  %L120 = load i16, ptr undef
  store i8 %FC9, ptr %0
  %E121 = extractelement <16 x i1> %Shuff25, i32 3
  br i1 %E121, label %CF324, label %CF325

CF325:                                            ; preds = %CF362, %CF358
  %I123 = insertelement <8 x i16> undef, i16 %L120, i32 0
  %Sl125 = select i1 undef, i32 undef, i32 199785
  %Cmp126 = icmp ule <16 x i1> undef, %Cmp88
  br label %CF356

CF356:                                            ; preds = %CF356, %CF325
  %FC131 = sitofp <8 x i8> %B27 to <8 x double>
  store i8 %Sl73, ptr %0
  store i64 396197, ptr %Sl37
  %L150 = load i64, ptr %Sl37
  %Cmp157 = icmp ult i64 %L150, %L61
  br i1 %Cmp157, label %CF356, label %CF359

CF359:                                            ; preds = %CF359, %CF356
  %B162 = srem <8 x i64> %I85, %Shuff13
  %Tr163 = trunc i64 %Se to i8
  %Sl164 = select i1 %Cmp52, ptr %A1, ptr %1
  store i64 %E32, ptr undef
  %I168 = insertelement <8 x i16> %I123, i16 undef, i32 5
  %Se170 = sext i1 %Cmp81 to i32
  %Cmp172 = icmp uge i8 %Sl73, %Sl73
  br i1 %Cmp172, label %CF359, label %CF362

CF362:                                            ; preds = %CF359
  store i16 0, ptr undef
  store i64 448097, ptr %Sl37
  %E189 = extractelement <8 x i16> %Shuff48, i32 6
  %Sl194 = select i1 %Cmp111, i8 29, i8 0
  %Cmp195 = icmp eq i32 %ZE, %ZE
  br i1 %Cmp195, label %CF325, label %CF326

CF326:                                            ; preds = %CF342, %CF362
  store i64 %L104, ptr undef
  br label %CF342

CF342:                                            ; preds = %CF326
  %Cmp203 = icmp ule i1 %Cmp195, %E18
  br i1 %Cmp203, label %CF326, label %CF337

CF337:                                            ; preds = %CF342
  br label %CF327

CF327:                                            ; preds = %CF336, %CF355, %CF327, %CF337
  store i64 %Se86, ptr undef
  %Tr216 = trunc i64 184653 to i16
  %Sl217 = select i1 %Cmp157, <4 x i1> undef, <4 x i1> undef
  %Cmp218 = icmp slt i32 undef, %Se170
  br i1 %Cmp218, label %CF327, label %CF355

CF355:                                            ; preds = %CF327
  %E220 = extractelement <16 x i1> %Cmp126, i32 3
  br i1 %E220, label %CF327, label %CF340

CF340:                                            ; preds = %CF355
  %Sl224 = select i1 %Sl65, double undef, double 0xBE278346AB25A5C4
  br label %CF334

CF334:                                            ; preds = %CF343, %CF334, %CF340
  %L226 = load i64, ptr undef
  store i32 %3, ptr %Sl164
  %Cmp233 = icmp uge i16 %Tr216, %L120
  br i1 %Cmp233, label %CF334, label %CF354

CF354:                                            ; preds = %CF334
  store i64 %L226, ptr %Sl37
  %Cmp240 = icmp uge i1 %Cmp52, undef
  %Shuff243 = shufflevector <16 x i1> %I107, <16 x i1> undef, <16 x i32> <i32 28, i32 30, i32 undef, i32 2, i32 4, i32 6, i32 8, i32 10, i32 12, i32 14, i32 16, i32 18, i32 20, i32 22, i32 24, i32 undef>
  %B245 = fmul <16 x float> %FC109, %FC109
  br label %CF343

CF343:                                            ; preds = %CF354
  %Cmp248 = icmp sgt i8 0, %B116
  br i1 %Cmp248, label %CF334, label %CF336

CF336:                                            ; preds = %CF343
  store i64 %E32, ptr undef
  br i1 undef, label %CF327, label %CF328

CF328:                                            ; preds = %CF345, %CF336
  br label %CF345

CF345:                                            ; preds = %CF328
  %E257 = extractelement <4 x i1> %Sl217, i32 2
  br i1 %E257, label %CF328, label %CF338

CF338:                                            ; preds = %CF345
  %Sl261 = select i1 %E121, <8 x i16> zeroinitializer, <8 x i16> undef
  %Cmp262 = icmp sgt i8 undef, %Sl194
  br label %CF329

CF329:                                            ; preds = %CF339, %CF348, %CF357, %CF338
  store i64 %L67, ptr %Sl37
  br label %CF357

CF357:                                            ; preds = %CF329
  %Cmp275 = icmp ne i1 %Cmp203, %Sl65
  br i1 %Cmp275, label %CF329, label %CF348

CF348:                                            ; preds = %CF357
  %Shuff286 = shufflevector <8 x i16> undef, <8 x i16> %Sl261, <8 x i32> <i32 6, i32 8, i32 10, i32 12, i32 undef, i32 0, i32 2, i32 4>
  %Cmp291 = icmp ne i32 %Sl125, undef
  br i1 %Cmp291, label %CF329, label %CF339

CF339:                                            ; preds = %CF348
  %Cmp299 = fcmp ugt double %L82, undef
  br i1 %Cmp299, label %CF329, label %CF330

CF330:                                            ; preds = %CF361, %CF330, %CF339
  %E301 = extractelement <8 x double> %FC131, i32 3
  store i64 %Sl16, ptr %Sl37
  %Se313 = sext <8 x i1> %Sl118 to <8 x i32>
  %Cmp315 = icmp sgt i8 %Tr163, %L
  br i1 %Cmp315, label %CF330, label %CF361

CF361:                                            ; preds = %CF330
  store i16 %L120, ptr undef
  %Shuff318 = shufflevector <8 x i64> %B162, <8 x i64> undef, <8 x i32> <i32 8, i32 10, i32 12, i32 14, i32 0, i32 2, i32 4, i32 6>
  %ZE321 = zext i16 %E189 to i64
  %Sl322 = select i1 %Cmp240, i1 %Cmp262, i1 %Cmp291
  br i1 %Sl322, label %CF330, label %CF351

CF351:                                            ; preds = %CF361
  store double %Sl224, ptr %Sl44
  store i32 %ZE, ptr %Sl164
  ret void
}