Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / Transforms / Scalarizer / store-bug.ll
blob1fccdc624e4930745ef575aa1696ccddc321b322
1 ; RUN: opt -passes='function(scalarizer)' -scalarize-load-store -S < %s | FileCheck %s
2 target datalayout = "e-p:64:64:64-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:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
4 ; This input caused the scalarizer not to clear cached results
5 ; properly.
7 ; Any regressions should trigger an assert in the scalarizer.
9 define void @func(<4 x float> %val, ptr %ptr) {
10   store <4 x float> %val, ptr %ptr
11   ret void
12 ; CHECK: store float %val.i0, ptr %ptr, align 16
13 ; CHECK: store float %val.i1, ptr %ptr.i1, align 4
14 ; CHECK: store float %val.i2, ptr %ptr.i2, align 8
15 ; CHECK: store float %val.i3, ptr %ptr.i3, align 4
18 define void @func.copy(<4 x float> %val, ptr %ptr) {
19   store <4 x float> %val, ptr %ptr
20   ret void
21 ; CHECK: store float %val.i0, ptr %ptr, align 16
22 ; CHECK: store float %val.i1, ptr %ptr.i1, align 4
23 ; CHECK: store float %val.i2, ptr %ptr.i2, align 8
24 ; CHECK: store float %val.i3, ptr %ptr.i3, align 4