1 ; RUN: not llc < %s -mtriple i386-unknown-linux-gnu -mattr +avx512vl -o /dev/null 2> %t 2 ; RUN: FileCheck %s --input-file %t 3 4 define <4 x float> @testxmm_1(<4 x float> %_xmm0, i64 %_l) { 5 ; CHECK: error: inline assembly requires more registers than available 6 entry: 7 %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) 8 ret <4 x float> %0 9 } 10 11 12 define <4 x float> @testxmm_2(<4 x float> %_xmm0, i64 %_l) { 13 ; CHECK: error: inline assembly requires more registers than available 14 entry: 15 %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) 16 ret <4 x float> %0 17 } 18 19 20 define <4 x float> @testxmm_3(<4 x float> %_xmm0, i64 %_l) { 21 ; CHECK: error: inline assembly requires more registers than available 22 entry: 23 %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) 24 ret <4 x float> %0 25 } 26 27 28 define i64 @testxmm_4(<4 x float> %_xmm0, i64 %_l) { 29 ; CHECK: error: inline assembly requires more registers than available 30 entry: 31 %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) 32 ret i64 %0 33 } 34 35 36 define <4 x float> @testxmm_5(<4 x float> %_xmm0, i64 %_l) { 37 ; CHECK: error: inline assembly requires more registers than available 38 entry: 39 %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) 40 ret <4 x float> %0 41 } 42 43 44 define <4 x float> @testxmm_6(<4 x float> %_xmm0, i64 %_l) { 45 ; CHECK: error: inline assembly requires more registers than available 46 entry: 47 %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) 48 ret <4 x float> %0 49 } 50 51 52 define <4 x float> @testxmm_7(<4 x float> %_xmm0, i64 %_l) { 53 ; CHECK: error: inline assembly requires more registers than available 54 entry: 55 %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) 56 ret <4 x float> %0 57 } 58 59 60 define <8 x float> @testymm_1(<8 x float> %_ymm0, <8 x float> %_ymm1) { 61 ; CHECK: error: inline assembly requires more registers than available 62 entry: 63 %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) 64 ret <8 x float> %0 65 } 66 67 68 define <8 x float> @testymm_2(<8 x float> %_ymm0, <8 x float> %_ymm1) { 69 ; CHECK: error: inline assembly requires more registers than available 70 entry: 71 %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) 72 ret <8 x float> %0 73 } 74 75 76 define <8 x float> @testymm_3(<8 x float> %_ymm0, <8 x float> %_ymm1) { 77 ; CHECK: error: inline assembly requires more registers than available 78 entry: 79 %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) 80 ret <8 x float> %0 81 } 82 83 84 define <8 x float> @testymm_4(<8 x float> %_ymm0, <8 x float> %_ymm1) { 85 ; CHECK: error: inline assembly requires more registers than available 86 entry: 87 %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) 88 ret <8 x float> %0 89 } 90 91 92 define <8 x float> @testymm_5(<8 x float> %_ymm0, <8 x float> %_ymm1) { 93 ; CHECK: error: inline assembly requires more registers than available 94 entry: 95 %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) 96 ret <8 x float> %0 97 } 98 99 100 define <8 x float> @testymm_6(<8 x float> %_ymm0, <8 x float> %_ymm1) { 101 ; CHECK: error: inline assembly requires more registers than available 102 entry: 103 %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) 104 ret <8 x float> %0 105 } 106 107 108 define <8 x float> @testymm_7(<8 x float> %_ymm0, <8 x float> %_ymm1) { 109 ; CHECK: error: inline assembly requires more registers than available 110 entry: 111 %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) 112 ret <8 x float> %0 113 } 114 115 116 define <8 x float> @testymm_8(<8 x float> %_ymm0, <8 x float> %_ymm1) { 117 ; CHECK: error: inline assembly requires more registers than available 118 entry: 119 %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) 120 ret <8 x float> %0 121 } 122 123 124 define <8 x float> @testymm_9(<8 x float> %_ymm0, <8 x float> %_ymm1) { 125 ; CHECK: error: inline assembly requires more registers than available 126 entry: 127 %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) 128 ret <8 x float> %0 129 } 130 131 132 define <8 x float> @testymm_10(<8 x float> %_ymm0, <8 x float> %_ymm1) { 133 ; CHECK: error: inline assembly requires more registers than available 134 entry: 135 %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) 136 ret <8 x float> %0 137 } 138 139