[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / X86 / inline-asm-avx512vl-v-constraint-32bit.ll
blob7ca72a7007a44aadde8aceac60ee5ddd815e3057
1 ; RUN: not llc %s -verify-machineinstrs=0 -mtriple i386-unknown-linux-gnu -mattr +avx512vl -o /dev/null 2>&1 | FileCheck %s
3 define <4 x float> @testxmm_1(<4 x float> %_xmm0, i64 %_l) {
4 ; CHECK: error: inline assembly requires more registers than available
5 entry:
6   %0 = tail call <4 x float> asm "vmovhlps $1, $2, $0", "=v,v,v,~{xmm0},~{xmm1},~{xmm2},~{xmm3},~{xmm4},~{xmm5},~{xmm6},~{xmm7},~{dirflag},~{fpsr},~{flags}"(i64 %_l, <4 x float> %_xmm0)
7   ret <4 x float> %0
11 define <4 x float> @testxmm_2(<4 x float> %_xmm0, i64 %_l) {
12 ; CHECK: error: inline assembly requires more registers than available
13 entry:
14   %0 = tail call <4 x float> asm "vmovapd $1, $0", "=v,v,~{xmm0},~{xmm1},~{xmm2},~{xmm3},~{xmm4},~{xmm5},~{xmm6},~{xmm7},~{dirflag},~{fpsr},~{flags}"(i64 %_l)
15   ret <4 x float> %0
19 define <4 x float> @testxmm_3(<4 x float> %_xmm0, i64 %_l) {
20 ; CHECK: error: inline assembly requires more registers than available
21 entry:
22   %0 = tail call <4 x float> asm "vminpd $1, $2, $0", "=v,v,v,~{xmm0},~{xmm1},~{xmm2},~{xmm3},~{xmm4},~{xmm5},~{xmm6},~{xmm7},~{dirflag},~{fpsr},~{flags}"(i64 %_l, i64 %_l)
23   ret <4 x float> %0
27 define i64 @testxmm_4(<4 x float> %_xmm0, i64 %_l) {
28 ; CHECK: error: inline assembly requires more registers than available
29 entry:
30   %0 = tail call i64 asm "vmulsd $1, $2, $0", "=v,v,v,~{xmm0},~{xmm1},~{xmm2},~{xmm3},~{xmm4},~{xmm5},~{xmm6},~{xmm7},~{dirflag},~{fpsr},~{flags}"(i64 %_l, <4 x float> %_xmm0)
31   ret i64 %0
35 define <4 x float> @testxmm_5(<4 x float> %_xmm0, i64 %_l) {
36 ; CHECK: error: inline assembly requires more registers than available
37 entry:
38   %0 = tail call <4 x float> asm "vpabsq $1, $0", "=v,v,~{xmm0},~{xmm1},~{xmm2},~{xmm3},~{xmm4},~{xmm5},~{xmm6},~{xmm7},~{dirflag},~{fpsr},~{flags}"(i64 %_l)
39   ret <4 x float> %0
43 define <4 x float> @testxmm_6(<4 x float> %_xmm0, i64 %_l) {
44 ; CHECK: error: inline assembly requires more registers than available
45 entry:
46   %0 = tail call <4 x float> asm "vpandd $1, $2, $0", "=v,v,v,~{xmm0},~{xmm1},~{xmm2},~{xmm3},~{xmm4},~{xmm5},~{xmm6},~{xmm7},~{dirflag},~{fpsr},~{flags}"(<4 x float> %_xmm0, i64 %_l)
47   ret <4 x float> %0
51 define <4 x float> @testxmm_7(<4 x float> %_xmm0, i64 %_l) {
52 ; CHECK: error: inline assembly requires more registers than available
53 entry:
54   %0 = tail call <4 x float> asm "vpandnd $1, $2, $0", "=v,v,v,~{xmm0},~{xmm1},~{xmm2},~{xmm3},~{xmm4},~{xmm5},~{xmm6},~{xmm7},~{dirflag},~{fpsr},~{flags}"(<4 x float> %_xmm0, i64 %_l)
55   ret <4 x float> %0
59 define <8 x float> @testymm_1(<8 x float> %_ymm0, <8 x float> %_ymm1) {
60 ; CHECK: error: inline assembly requires more registers than available
61 entry:
62   %0 = tail call <8 x float> asm "vmovsldup $1, $0", "=v,v,~{ymm0},~{ymm1},~{ymm2},~{ymm3},~{ymm4},~{ymm5},~{ymm6},~{ymm7},~{dirflag},~{fpsr},~{flags}"(<8 x float> %_ymm1)
63   ret <8 x float> %0
67 define <8 x float> @testymm_2(<8 x float> %_ymm0, <8 x float> %_ymm1) {
68 ; CHECK: error: inline assembly requires more registers than available
69 entry:
70   %0 = tail call <8 x float> asm "vmovapd $1, $0", "=v,v,~{ymm0},~{ymm1},~{ymm2},~{ymm3},~{ymm4},~{ymm5},~{ymm6},~{ymm7},~{dirflag},~{fpsr},~{flags}"(<8 x float> %_ymm1)
71   ret <8 x float> %0
75 define <8 x float> @testymm_3(<8 x float> %_ymm0, <8 x float> %_ymm1) {
76 ; CHECK: error: inline assembly requires more registers than available
77 entry:
78   %0 = tail call <8 x float> asm "vminpd $1, $2, $0", "=v,v,v,~{ymm0},~{ymm1},~{ymm2},~{ymm3},~{ymm4},~{ymm5},~{ymm6},~{ymm7},~{dirflag},~{fpsr},~{flags}"(<8 x float> %_ymm1, <8 x float> %_ymm1)
79   ret <8 x float> %0
83 define <8 x float> @testymm_4(<8 x float> %_ymm0, <8 x float> %_ymm1) {
84 ; CHECK: error: inline assembly requires more registers than available
85 entry:
86   %0 = tail call <8 x float> asm "vpabsq $1, $0", "=v,v,~{ymm0},~{ymm1},~{ymm2},~{ymm3},~{ymm4},~{ymm5},~{ymm6},~{ymm7},~{dirflag},~{fpsr},~{flags}"(<8 x float> %_ymm1)
87   ret <8 x float> %0
91 define <8 x float> @testymm_5(<8 x float> %_ymm0, <8 x float> %_ymm1) {
92 ; CHECK: error: inline assembly requires more registers than available
93 entry:
94   %0 = tail call <8 x float> asm "vpandd $1, $2, $0", "=v,v,v,~{ymm0},~{ymm1},~{ymm2},~{ymm3},~{ymm4},~{ymm5},~{ymm6},~{ymm7},~{dirflag},~{fpsr},~{flags}"(<8 x float> %_ymm1, <8 x float> %_ymm0)
95   ret <8 x float> %0
99 define <8 x float> @testymm_6(<8 x float> %_ymm0, <8 x float> %_ymm1) {
100 ; CHECK: error: inline assembly requires more registers than available
101 entry:
102   %0 = tail call <8 x float> asm "vpandnd $1, $2, $0", "=v,v,v,~{ymm0},~{ymm1},~{ymm2},~{ymm3},~{ymm4},~{ymm5},~{ymm6},~{ymm7},~{dirflag},~{fpsr},~{flags}"(<8 x float> %_ymm1, <8 x float> %_ymm0)
103   ret <8 x float> %0
107 define <8 x float> @testymm_7(<8 x float> %_ymm0, <8 x float> %_ymm1) {
108 ; CHECK: error: inline assembly requires more registers than available
109 entry:
110   %0 = tail call <8 x float> asm "vpminud $1, $2, $0", "=v,v,v,~{ymm0},~{ymm1},~{ymm2},~{ymm3},~{ymm4},~{ymm5},~{ymm6},~{ymm7},~{dirflag},~{fpsr},~{flags}"(<8 x float> %_ymm1, <8 x float> %_ymm0)
111   ret <8 x float> %0
115 define <8 x float> @testymm_8(<8 x float> %_ymm0, <8 x float> %_ymm1) {
116 ; CHECK: error: inline assembly requires more registers than available
117 entry:
118   %0 = tail call <8 x float> asm "vpmaxsd $1, $2, $0", "=v,v,v,~{ymm0},~{ymm1},~{ymm2},~{ymm3},~{ymm4},~{ymm5},~{ymm6},~{ymm7},~{dirflag},~{fpsr},~{flags}"(<8 x float> %_ymm1, <8 x float> %_ymm0)
119   ret <8 x float> %0
123 define <8 x float> @testymm_9(<8 x float> %_ymm0, <8 x float> %_ymm1) {
124 ; CHECK: error: inline assembly requires more registers than available
125 entry:
126   %0 = tail call <8 x float> asm "vmovups $1, $0", "=v,v,~{ymm0},~{ymm1},~{ymm2},~{ymm3},~{ymm4},~{ymm5},~{ymm6},~{ymm7},~{dirflag},~{fpsr},~{flags}"(<8 x float> %_ymm1)
127   ret <8 x float> %0
131 define <8 x float> @testymm_10(<8 x float> %_ymm0, <8 x float> %_ymm1) {
132 ; CHECK: error: inline assembly requires more registers than available
133 entry:
134   %0 = tail call <8 x float> asm "vmovupd $1, $0", "=v,v,~{ymm0},~{ymm1},~{ymm2},~{ymm3},~{ymm4},~{ymm5},~{ymm6},~{ymm7},~{dirflag},~{fpsr},~{flags}"(<8 x float> %_ymm1)
135   ret <8 x float> %0