Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / Transforms / SROA / vector-promotion-different-size.ll
blob869b711b89b18b593aeec3a6465c45c5a3476961
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -passes='sroa<preserve-cfg>' -S | FileCheck %s --check-prefixes=CHECK,CHECK-PRESERVE-CFG
3 ; RUN: opt < %s -passes='sroa<modify-cfg>' -S | FileCheck %s --check-prefixes=CHECK,CHECK-MODIFY-CFG
4 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-n8:16:32:64"
6 define <4 x i1> @vector_bitcast() {
7 ; CHECK-LABEL: @vector_bitcast(
8 ; CHECK-NEXT:    [[A:%.*]] = alloca <3 x i1>, align 1
9 ; CHECK-NEXT:    store <3 x i1> <i1 true, i1 false, i1 true>, ptr [[A]], align 1
10 ; CHECK-NEXT:    [[A_0_VEC:%.*]] = load <4 x i1>, ptr [[A]], align 1
11 ; CHECK-NEXT:    ret <4 x i1> [[A_0_VEC]]
13   %a = alloca <3 x i1>
14   store <3 x i1> <i1 1,i1 0,i1 1>, ptr %a
15   %vec = load <4 x i1>, ptr %a
16   ret <4 x i1> %vec
19 define <64 x i16> @vector_bitcast_2(<32 x i16> %v) {
20 ; CHECK-LABEL: @vector_bitcast_2(
21 ; CHECK-NEXT:    [[P:%.*]] = alloca <32 x i16>, align 64
22 ; CHECK-NEXT:    store <32 x i16> [[V:%.*]], ptr [[P]], align 64
23 ; CHECK-NEXT:    [[P_0_LOAD:%.*]] = load <64 x i16>, ptr [[P]], align 64
24 ; CHECK-NEXT:    ret <64 x i16> [[P_0_LOAD]]
26   %p = alloca <32 x i16>
27   store <32 x i16> %v, ptr %p
28   %load = load <64 x i16>, ptr %p
29   ret <64 x i16> %load
31 ;; NOTE: These prefixes are unused and the list is autogenerated. Do not add tests below this line:
32 ; CHECK-MODIFY-CFG: {{.*}}
33 ; CHECK-PRESERVE-CFG: {{.*}}