xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/sse4a-upgrade.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=i386-unknown-unknown -mattr=+sse4a | FileCheck %s --check-prefix=X32
3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=i386-unknown-unknown -mattr=+sse4a,+avx | FileCheck %s --check-prefix=X32
4*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-unknown-unknown -mattr=+sse4a | FileCheck %s --check-prefix=X64
5*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-unknown-unknown -mattr=+sse4a,+avx | FileCheck %s --check-prefix=X64
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Workerdefine void @test_movntss(i8* %p, <4 x float> %a) nounwind optsize ssp {
8*9880d681SAndroid Build Coastguard Worker; X32-LABEL: test_movntss:
9*9880d681SAndroid Build Coastguard Worker; X32:       # BB#0:
10*9880d681SAndroid Build Coastguard Worker; X32-NEXT:    movl {{[0-9]+}}(%esp), %eax
11*9880d681SAndroid Build Coastguard Worker; X32-NEXT:    movntss %xmm0, (%eax)
12*9880d681SAndroid Build Coastguard Worker; X32-NEXT:    retl
13*9880d681SAndroid Build Coastguard Worker;
14*9880d681SAndroid Build Coastguard Worker; X64-LABEL: test_movntss:
15*9880d681SAndroid Build Coastguard Worker; X64:       # BB#0:
16*9880d681SAndroid Build Coastguard Worker; X64-NEXT:    movntss %xmm0, (%rdi)
17*9880d681SAndroid Build Coastguard Worker; X64-NEXT:    retq
18*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.x86.sse4a.movnt.ss(i8* %p, <4 x float> %a) nounwind
19*9880d681SAndroid Build Coastguard Worker  ret void
20*9880d681SAndroid Build Coastguard Worker}
21*9880d681SAndroid Build Coastguard Worker
22*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.x86.sse4a.movnt.ss(i8*, <4 x float>)
23*9880d681SAndroid Build Coastguard Worker
24*9880d681SAndroid Build Coastguard Workerdefine void @test_movntsd(i8* %p, <2 x double> %a) nounwind optsize ssp {
25*9880d681SAndroid Build Coastguard Worker; X32-LABEL: test_movntsd:
26*9880d681SAndroid Build Coastguard Worker; X32:       # BB#0:
27*9880d681SAndroid Build Coastguard Worker; X32-NEXT:    movl {{[0-9]+}}(%esp), %eax
28*9880d681SAndroid Build Coastguard Worker; X32-NEXT:    movntsd %xmm0, (%eax)
29*9880d681SAndroid Build Coastguard Worker; X32-NEXT:    retl
30*9880d681SAndroid Build Coastguard Worker;
31*9880d681SAndroid Build Coastguard Worker; X64-LABEL: test_movntsd:
32*9880d681SAndroid Build Coastguard Worker; X64:       # BB#0:
33*9880d681SAndroid Build Coastguard Worker; X64-NEXT:    movntsd %xmm0, (%rdi)
34*9880d681SAndroid Build Coastguard Worker; X64-NEXT:    retq
35*9880d681SAndroid Build Coastguard Worker  tail call void @llvm.x86.sse4a.movnt.sd(i8* %p, <2 x double> %a) nounwind
36*9880d681SAndroid Build Coastguard Worker  ret void
37*9880d681SAndroid Build Coastguard Worker}
38*9880d681SAndroid Build Coastguard Worker
39*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.x86.sse4a.movnt.sd(i8*, <2 x double>)
40