xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/2012-01-11-split-cv.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mattr=+avx -mtriple=i686-unknown-unknown | FileCheck %s
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workerdefine void @add18i16(<18 x i16>* nocapture sret %ret, <18 x i16>* %bp) nounwind {
5*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: add18i16:
6*9880d681SAndroid Build Coastguard Worker; CHECK:       # BB#0:
7*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %eax
8*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %ecx
9*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:    vmovups (%ecx), %ymm0
10*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:    movl 32(%ecx), %ecx
11*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:    movl %ecx, 32(%eax)
12*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:    vmovups %ymm0, (%eax)
13*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:    vzeroupper
14*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:    retl $4
15*9880d681SAndroid Build Coastguard Worker;
16*9880d681SAndroid Build Coastguard Worker  %b = load <18 x i16>, <18 x i16>* %bp, align 16
17*9880d681SAndroid Build Coastguard Worker  %x = add <18 x i16> zeroinitializer, %b
18*9880d681SAndroid Build Coastguard Worker  store <18 x i16> %x, <18 x i16>* %ret, align 16
19*9880d681SAndroid Build Coastguard Worker  ret void
20*9880d681SAndroid Build Coastguard Worker}
21*9880d681SAndroid Build Coastguard Worker
22