[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / CodeGen / Hexagon / vect / vect-load-v4i16.ll
blob546ffdd66ff8ea98a760d424130c0fde5fda3cb1
1 ; RUN: llc -march=hexagon -O0 -hexagon-align-loads=0 < %s | FileCheck %s
3 ; CHECK-LABEL: danny:
4 ; CHECK-DAG: [[T0:r[0-9]+]] = memuh(r0+#0)
5 ; CHECK-DAG: [[T1:r[0-9]+]] = memuh(r0+#2)
6 ; CHECK:     [[T0]] |= asl([[T1]],#16)
7 ; CHECK-DAG: [[T2:r[0-9]+]] = memuh(r0+#4)
8 ; CHECK-DAG: [[T3:r[0-9]+]] = memuh(r0+#6)
9 ; CHECK:     [[T2]] |= asl([[T3]],#16)
10 ; CHECK:     combine([[T2]],[[T0]])
11 define <4 x i16> @danny(<4 x i16>* %p) {
12   %t0 = load <4 x i16>, <4 x i16>* %p, align 2
13   ret <4 x i16> %t0
16 ; CHECK-LABEL: sammy:
17 ; CHECK-DAG: [[T0:r[0-9]+]] = memw(r0+#0)
18 ; CHECK-DAG: [[T1:r[0-9]+]] = memw(r0+#4)
19 ; CHECK:     combine([[T1]],[[T0]])
20 define <4 x i16> @sammy(<4 x i16>* %p) {
21   %t0 = load <4 x i16>, <4 x i16>* %p, align 4
22   ret <4 x i16> %t0