[Frontend] Remove unused includes (NFC) (#116927)
[llvm-project.git] / llvm / test / CodeGen / X86 / avx10_2satcvtds-x64-intrinsics.ll
blobf5be929bc85ce9e7b2a98e7d42f344307dc9bff2
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 3
2 ; RUN: llc < %s -verify-machineinstrs -mtriple=x86_64-unknown-unknown --show-mc-encoding -mattr=+avx10.2-256 | FileCheck %s
4 define i64 @test_x86_avx512_vcvttsd2si64(<2 x double> %a0) {
5 ; CHECK-LABEL: test_x86_avx512_vcvttsd2si64:
6 ; CHECK:       # %bb.0:
7 ; CHECK-NEXT:    vcvttsd2sis %xmm0, %rcx # encoding: [0x62,0xf5,0xff,0x08,0x6d,0xc8]
8 ; CHECK-NEXT:    vcvttsd2sis {sae}, %xmm0, %rax # encoding: [0x62,0xf5,0xff,0x18,0x6d,0xc0]
9 ; CHECK-NEXT:    addq %rcx, %rax # encoding: [0x48,0x01,0xc8]
10 ; CHECK-NEXT:    retq # encoding: [0xc3]
11   %res0 = call i64 @llvm.x86.avx10.vcvttsd2sis64(<2 x double> %a0, i32 4) ;
12   %res1 = call i64 @llvm.x86.avx10.vcvttsd2sis64(<2 x double> %a0, i32 8) ;
13   %res2 = add i64 %res0, %res1
14   ret i64 %res2
16 declare i64 @llvm.x86.avx10.vcvttsd2sis64(<2 x double>, i32) nounwind readnone
18 define i64 @test_x86_avx512_vcvttsd2usi64(<2 x double> %a0) {
19 ; CHECK-LABEL: test_x86_avx512_vcvttsd2usi64:
20 ; CHECK:       # %bb.0:
21 ; CHECK-NEXT:    vcvttsd2usis %xmm0, %rcx # encoding: [0x62,0xf5,0xff,0x08,0x6c,0xc8]
22 ; CHECK-NEXT:    vcvttsd2usis {sae}, %xmm0, %rax # encoding: [0x62,0xf5,0xff,0x18,0x6c,0xc0]
23 ; CHECK-NEXT:    addq %rcx, %rax # encoding: [0x48,0x01,0xc8]
24 ; CHECK-NEXT:    retq # encoding: [0xc3]
25   %res0 = call i64 @llvm.x86.avx10.vcvttsd2usis64(<2 x double> %a0, i32 4) ;
26   %res1 = call i64 @llvm.x86.avx10.vcvttsd2usis64(<2 x double> %a0, i32 8) ;
27   %res2 = add i64 %res0, %res1
28   ret i64 %res2
30 declare i64 @llvm.x86.avx10.vcvttsd2usis64(<2 x double>, i32) nounwind readnone
32 define i64 @test_x86_avx512_vcvttss2sis64(<4 x float> %a0) {
33 ; CHECK-LABEL: test_x86_avx512_vcvttss2sis64:
34 ; CHECK:       # %bb.0:
35 ; CHECK-NEXT:    vcvttss2sis %xmm0, %rcx # encoding: [0x62,0xf5,0xfe,0x08,0x6d,0xc8]
36 ; CHECK-NEXT:    vcvttss2sis {sae}, %xmm0, %rax # encoding: [0x62,0xf5,0xfe,0x18,0x6d,0xc0]
37 ; CHECK-NEXT:    addq %rcx, %rax # encoding: [0x48,0x01,0xc8]
38 ; CHECK-NEXT:    retq # encoding: [0xc3]
39   %res0 = call i64 @llvm.x86.avx10.vcvttss2sis64(<4 x float> %a0, i32 4) ;
40   %res1 = call i64 @llvm.x86.avx10.vcvttss2sis64(<4 x float> %a0, i32 8) ;
41   %res2 = add i64 %res0, %res1
42   ret i64 %res2
44 declare i64 @llvm.x86.avx10.vcvttss2sis64(<4 x float>, i32) nounwind readnone
46 define i64 @test_x86_avx512_vcvttss2usis64(<4 x float> %a0) {
47 ; CHECK-LABEL: test_x86_avx512_vcvttss2usis64:
48 ; CHECK:       # %bb.0:
49 ; CHECK-NEXT:    vcvttss2usis %xmm0, %rcx # encoding: [0x62,0xf5,0xfe,0x08,0x6c,0xc8]
50 ; CHECK-NEXT:    vcvttss2usis {sae}, %xmm0, %rax # encoding: [0x62,0xf5,0xfe,0x18,0x6c,0xc0]
51 ; CHECK-NEXT:    addq %rcx, %rax # encoding: [0x48,0x01,0xc8]
52 ; CHECK-NEXT:    retq # encoding: [0xc3]
53   %res0 = call i64 @llvm.x86.avx10.vcvttss2usis64(<4 x float> %a0, i32 4) ;
54   %res1 = call i64 @llvm.x86.avx10.vcvttss2usis64(<4 x float> %a0, i32 8) ;
55   %res2 = add i64 %res0, %res1
56   ret i64 %res2
58 declare i64 @llvm.x86.avx10.vcvttss2usis64(<4 x float>, i32) nounwind readnone