Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / Analysis / CostModel / SystemZ / struct-cost-crash.ll
blobbad23baff2d1c2243799ed3f574814badb161125
1 ; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 2
2 ; RUN: opt -passes="print<cost-model>" 2>&1 -disable-output < %s | FileCheck %s
4 ; Check that SystemZTTIImpl::getMemoryOpCost doesn't try to legalize structs,
5 ; which was failing llvm_unreachable in MVT::getVT.
7 target datalayout = "E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-v128:64-a:8:16-n32:64"
8 target triple = "s390x-unknown-linux-gnu"
10 declare { i64, i32 } @bar()
12 define i8 @foo() {
13 ; CHECK-LABEL: 'foo'
14 ; CHECK-NEXT:  Cost Model: Found an estimated cost of 1 for instruction: br label %1
15 ; CHECK-NEXT:  Cost Model: Found an estimated cost of 1 for instruction: %2 = call { i64, i32 } @bar()
16 ; CHECK-NEXT:  Cost Model: Found an estimated cost of 4 for instruction: store { i64, i32 } %2, ptr inttoptr (i64 16 to ptr), align 16
17 ; CHECK-NEXT:  Cost Model: Found an estimated cost of 1 for instruction: br label %1
19   br label %1
21 1:                                                ; preds = %1, %0
22   %2 = call { i64, i32 } @bar()
23   store { i64, i32 } %2, ptr inttoptr (i64 16 to ptr), align 16
24   br label %1