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