xref: /llvm-project/llvm/test/Transforms/Scalarizer/store-bug.ll (revision 1bc9b67bd87d7ec51045951c93fd5db953faa745)
1; RUN: opt -passes='function(scalarizer<load-store>)' -S < %s | FileCheck %s
2target 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"
3
4; This input caused the scalarizer not to clear cached results
5; properly.
6;
7; Any regressions should trigger an assert in the scalarizer.
8
9define 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
16}
17
18define 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
25}
26