1 // RUN
: %clang_cc1 -triple amdgcn-- -target-cpu gfx908 -verify -S -o - %s
3 #pragma OPENCL EXTENSION cl_khr_fp64
:enable
5 typedef float v4f __attribute__
((ext_vector_type(4)));
6 typedef float v16f __attribute__
((ext_vector_type(16)));
7 typedef float v32f __attribute__
((ext_vector_type(32)));
8 typedef half v4h __attribute__
((ext_vector_type(4)));
9 typedef half v16h __attribute__
((ext_vector_type(16)));
10 typedef half v32h __attribute__
((ext_vector_type(32)));
11 typedef int v4i __attribute__
((ext_vector_type(4)));
12 typedef int v16i __attribute__
((ext_vector_type(16)));
13 typedef int v32i __attribute__
((ext_vector_type(32)));
14 typedef short v2s __attribute__
((ext_vector_type(2)));
15 typedef short v4s __attribute__
((ext_vector_type(4)));
16 typedef short v16s __attribute__
((ext_vector_type(16)));
17 typedef short v32s __attribute__
((ext_vector_type(32)));
18 typedef double v4d __attribute__
((ext_vector_type(4)));
21 void test_mfma_f32_32x32x1f32
(global v32f
* out
, float a
, float b
, v32f c
, int d
)
23 *out
= __builtin_amdgcn_mfma_f32_32x32x1f32
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x1f32' must be a constant integer}}
24 *out
= __builtin_amdgcn_mfma_f32_32x32x1f32
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x1f32' must be a constant integer}}
25 *out
= __builtin_amdgcn_mfma_f32_32x32x1f32
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x1f32' must be a constant integer}}
28 void test_mfma_f32_16x16x1f32
(global v16f
* out
, float a
, float b
, v16f c
, int d
)
30 *out
= __builtin_amdgcn_mfma_f32_16x16x1f32
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x1f32' must be a constant integer}}
31 *out
= __builtin_amdgcn_mfma_f32_16x16x1f32
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x1f32' must be a constant integer}}
32 *out
= __builtin_amdgcn_mfma_f32_16x16x1f32
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x1f32' must be a constant integer}}
35 void test_mfma_f32_4x4x1f32
(global v4f
* out
, float a
, float b
, v4f c
, int d
)
37 *out
= __builtin_amdgcn_mfma_f32_4x4x1f32
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_4x4x1f32' must be a constant integer}}
38 *out
= __builtin_amdgcn_mfma_f32_4x4x1f32
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_4x4x1f32' must be a constant integer}}
39 *out
= __builtin_amdgcn_mfma_f32_4x4x1f32
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_4x4x1f32' must be a constant integer}}
42 void test_mfma_f32_32x32x2f32
(global v16f
* out
, float a
, float b
, v16f c
, int d
)
44 *out
= __builtin_amdgcn_mfma_f32_32x32x2f32
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x2f32' must be a constant integer}}
45 *out
= __builtin_amdgcn_mfma_f32_32x32x2f32
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x2f32' must be a constant integer}}
46 *out
= __builtin_amdgcn_mfma_f32_32x32x2f32
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x2f32' must be a constant integer}}
49 void test_mfma_f32_16x16x4f32
(global v4f
* out
, float a
, float b
, v4f c
, int d
)
51 *out
= __builtin_amdgcn_mfma_f32_16x16x4f32
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x4f32' must be a constant integer}}
52 *out
= __builtin_amdgcn_mfma_f32_16x16x4f32
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x4f32' must be a constant integer}}
53 *out
= __builtin_amdgcn_mfma_f32_16x16x4f32
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x4f32' must be a constant integer}}
56 void test_mfma_f32_32x32x4f16
(global v32f
* out
, v4h a
, v4h b
, v32f c
, int d
)
58 *out
= __builtin_amdgcn_mfma_f32_32x32x4f16
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x4f16' must be a constant integer}}
59 *out
= __builtin_amdgcn_mfma_f32_32x32x4f16
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x4f16' must be a constant integer}}
60 *out
= __builtin_amdgcn_mfma_f32_32x32x4f16
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x4f16' must be a constant integer}}
63 void test_mfma_f32_16x16x4f16
(global v16f
* out
, v4h a
, v4h b
, v16f c
, int d
)
65 *out
= __builtin_amdgcn_mfma_f32_16x16x4f16
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x4f16' must be a constant integer}}
66 *out
= __builtin_amdgcn_mfma_f32_16x16x4f16
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x4f16' must be a constant integer}}
67 *out
= __builtin_amdgcn_mfma_f32_16x16x4f16
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x4f16' must be a constant integer}}
70 void test_mfma_f32_4x4x4f16
(global v4f
* out
, v4h a
, v4h b
, v4f c
, int d
)
72 *out
= __builtin_amdgcn_mfma_f32_4x4x4f16
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_4x4x4f16' must be a constant integer}}
73 *out
= __builtin_amdgcn_mfma_f32_4x4x4f16
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_4x4x4f16' must be a constant integer}}
74 *out
= __builtin_amdgcn_mfma_f32_4x4x4f16
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_4x4x4f16' must be a constant integer}}
77 void test_mfma_f32_32x32x8f16
(global v16f
* out
, v4h a
, v4h b
, v16f c
, int d
)
79 *out
= __builtin_amdgcn_mfma_f32_32x32x8f16
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x8f16' must be a constant integer}}
80 *out
= __builtin_amdgcn_mfma_f32_32x32x8f16
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x8f16' must be a constant integer}}
81 *out
= __builtin_amdgcn_mfma_f32_32x32x8f16
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x8f16' must be a constant integer}}
84 void test_mfma_f32_16x16x16f16
(global v4f
* out
, v4h a
, v4h b
, v4f c
, int d
)
86 *out
= __builtin_amdgcn_mfma_f32_16x16x16f16
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x16f16' must be a constant integer}}
87 *out
= __builtin_amdgcn_mfma_f32_16x16x16f16
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x16f16' must be a constant integer}}
88 *out
= __builtin_amdgcn_mfma_f32_16x16x16f16
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x16f16' must be a constant integer}}
91 void test_mfma_i32_32x32x4i8
(global v32i
* out
, int a
, int b
, v32i c
, int d
)
93 *out
= __builtin_amdgcn_mfma_i32_32x32x4i8
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_32x32x4i8' must be a constant integer}}
94 *out
= __builtin_amdgcn_mfma_i32_32x32x4i8
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_32x32x4i8' must be a constant integer}}
95 *out
= __builtin_amdgcn_mfma_i32_32x32x4i8
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_32x32x4i8' must be a constant integer}}
98 void test_mfma_i32_16x16x4i8
(global v16i
* out
, int a
, int b
, v16i c
, int d
)
100 *out
= __builtin_amdgcn_mfma_i32_16x16x4i8
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_16x16x4i8' must be a constant integer}}
101 *out
= __builtin_amdgcn_mfma_i32_16x16x4i8
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_16x16x4i8' must be a constant integer}}
102 *out
= __builtin_amdgcn_mfma_i32_16x16x4i8
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_16x16x4i8' must be a constant integer}}
105 void test_mfma_i32_4x4x4i8
(global v4i
* out
, int a
, int b
, v4i c
, int d
)
107 *out
= __builtin_amdgcn_mfma_i32_4x4x4i8
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_4x4x4i8' must be a constant integer}}
108 *out
= __builtin_amdgcn_mfma_i32_4x4x4i8
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_4x4x4i8' must be a constant integer}}
109 *out
= __builtin_amdgcn_mfma_i32_4x4x4i8
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_4x4x4i8' must be a constant integer}}
112 void test_mfma_i32_32x32x8i8
(global v16i
* out
, int a
, int b
, v16i c
, int d
)
114 *out
= __builtin_amdgcn_mfma_i32_32x32x8i8
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_32x32x8i8' must be a constant integer}}
115 *out
= __builtin_amdgcn_mfma_i32_32x32x8i8
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_32x32x8i8' must be a constant integer}}
116 *out
= __builtin_amdgcn_mfma_i32_32x32x8i8
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_32x32x8i8' must be a constant integer}}
119 void test_mfma_i32_16x16x16i8
(global v4i
* out
, int a
, int b
, v4i c
, int d
)
121 *out
= __builtin_amdgcn_mfma_i32_16x16x16i8
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_16x16x16i8' must be a constant integer}}
122 *out
= __builtin_amdgcn_mfma_i32_16x16x16i8
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_16x16x16i8' must be a constant integer}}
123 *out
= __builtin_amdgcn_mfma_i32_16x16x16i8
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_i32_16x16x16i8' must be a constant integer}}
126 void test_mfma_f32_32x32x2bf16
(global v32f
* out
, v2s a
, v2s b
, v32f c
, int d
)
128 *out
= __builtin_amdgcn_mfma_f32_32x32x2bf16
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x2bf16' must be a constant integer}}
129 *out
= __builtin_amdgcn_mfma_f32_32x32x2bf16
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x2bf16' must be a constant integer}}
130 *out
= __builtin_amdgcn_mfma_f32_32x32x2bf16
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x2bf16' must be a constant integer}}
133 void test_mfma_f32_16x16x2bf16
(global v16f
* out
, v2s a
, v2s b
, v16f c
, int d
)
135 *out
= __builtin_amdgcn_mfma_f32_16x16x2bf16
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x2bf16' must be a constant integer}}
136 *out
= __builtin_amdgcn_mfma_f32_16x16x2bf16
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x2bf16' must be a constant integer}}
137 *out
= __builtin_amdgcn_mfma_f32_16x16x2bf16
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x2bf16' must be a constant integer}}
140 void test_mfma_f32_4x4x2bf16
(global v4f
* out
, v2s a
, v2s b
, v4f c
, int d
)
142 *out
= __builtin_amdgcn_mfma_f32_4x4x2bf16
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_4x4x2bf16' must be a constant integer}}
143 *out
= __builtin_amdgcn_mfma_f32_4x4x2bf16
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_4x4x2bf16' must be a constant integer}}
144 *out
= __builtin_amdgcn_mfma_f32_4x4x2bf16
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_4x4x2bf16' must be a constant integer}}
147 void test_mfma_f32_32x32x4bf16
(global v16f
* out
, v2s a
, v2s b
, v16f c
, int d
)
149 *out
= __builtin_amdgcn_mfma_f32_32x32x4bf16
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x4bf16' must be a constant integer}}
150 *out
= __builtin_amdgcn_mfma_f32_32x32x4bf16
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x4bf16' must be a constant integer}}
151 *out
= __builtin_amdgcn_mfma_f32_32x32x4bf16
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_32x32x4bf16' must be a constant integer}}
154 void test_mfma_f32_16x16x8bf16
(global v4f
* out
, v2s a
, v2s b
, v4f c
, int d
)
156 *out
= __builtin_amdgcn_mfma_f32_16x16x8bf16
(a, b
, c
, d
, 0, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x8bf16' must be a constant integer}}
157 *out
= __builtin_amdgcn_mfma_f32_16x16x8bf16
(a, b
, c
, 0, d
, 0); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x8bf16' must be a constant integer}}
158 *out
= __builtin_amdgcn_mfma_f32_16x16x8bf16
(a, b
, c
, 0, 0, d
); // expected-error{{argument to '__builtin_amdgcn_mfma_f32_16x16x8bf16' must be a constant integer}}