98 case AMDGPU::BI__builtin_amdgcn_wave_reduce_add_u32:
99 case AMDGPU::BI__builtin_amdgcn_wave_reduce_sub_u32:
100 case AMDGPU::BI__builtin_amdgcn_wave_reduce_min_i32:
101 case AMDGPU::BI__builtin_amdgcn_wave_reduce_min_u32:
102 case AMDGPU::BI__builtin_amdgcn_wave_reduce_max_i32:
103 case AMDGPU::BI__builtin_amdgcn_wave_reduce_max_u32:
104 case AMDGPU::BI__builtin_amdgcn_wave_reduce_and_b32:
105 case AMDGPU::BI__builtin_amdgcn_wave_reduce_or_b32:
106 case AMDGPU::BI__builtin_amdgcn_wave_reduce_xor_b32:
107 case AMDGPU::BI__builtin_amdgcn_wave_reduce_add_u64:
108 case AMDGPU::BI__builtin_amdgcn_wave_reduce_sub_u64:
109 case AMDGPU::BI__builtin_amdgcn_wave_reduce_min_i64:
110 case AMDGPU::BI__builtin_amdgcn_wave_reduce_min_u64:
111 case AMDGPU::BI__builtin_amdgcn_wave_reduce_max_i64:
112 case AMDGPU::BI__builtin_amdgcn_wave_reduce_max_u64:
113 case AMDGPU::BI__builtin_amdgcn_wave_reduce_and_b64:
114 case AMDGPU::BI__builtin_amdgcn_wave_reduce_or_b64:
115 case AMDGPU::BI__builtin_amdgcn_wave_reduce_xor_b64: {
116 cgm.errorNYI(
expr->getSourceRange(),
117 std::string(
"unimplemented AMDGPU builtin call: ") +
119 return mlir::Value{};
121 case AMDGPU::BI__builtin_amdgcn_div_scale:
122 case AMDGPU::BI__builtin_amdgcn_div_scalef: {
124 llvm::StringRef intrinsicName =
"amdgcn.div.scale";
129 auto i1Ty = builder.getUIntNTy(1);
130 cir::RecordType resTy = builder.getAnonRecordTy(
131 {x.getType(), i1Ty},
false,
false);
133 mlir::Value structResult =
134 cir::LLVMIntrinsicCallOp::create(builder,
getLoc(
expr->getExprLoc()),
135 builder.getStringAttr(intrinsicName),
139 mlir::Value result = cir::ExtractMemberOp::create(
140 builder,
getLoc(
expr->getExprLoc()), x.getType(), structResult, 0);
141 mlir::Value flag = cir::ExtractMemberOp::create(
142 builder,
getLoc(
expr->getExprLoc()), i1Ty, structResult, 1);
145 mlir::Value flagToStore =
146 cir::CastOp::create(builder,
getLoc(
expr->getExprLoc()), flagType,
147 cir::CastKind::int_to_bool, flag);
148 builder.createStore(
getLoc(
expr->getExprLoc()), flagToStore, flagOutPtr);
151 case AMDGPU::BI__builtin_amdgcn_div_fmas:
152 case AMDGPU::BI__builtin_amdgcn_div_fmasf: {
157 mlir::Value result = cir::LLVMIntrinsicCallOp::create(
159 builder.getStringAttr(
"amdgcn.div.fmas"),
160 src0.getType(), {src0, src1, src2, src3})
164 case AMDGPU::BI__builtin_amdgcn_ds_swizzle: {
167 return builder.emitIntrinsicCallOp(
getLoc(
expr->getExprLoc()),
168 "amdgcn.ds.swizzle", src0.getType(),
169 mlir::ValueRange{src0, src1});
171 case AMDGPU::BI__builtin_amdgcn_mov_dpp8:
172 case AMDGPU::BI__builtin_amdgcn_mov_dpp:
173 case AMDGPU::BI__builtin_amdgcn_update_dpp: {
174 cgm.errorNYI(
expr->getSourceRange(),
175 std::string(
"unimplemented AMDGPU builtin call: ") +
177 return mlir::Value{};
179 case AMDGPU::BI__builtin_amdgcn_permlane16:
180 case AMDGPU::BI__builtin_amdgcn_permlanex16:
181 case AMDGPU::BI__builtin_amdgcn_permlane64: {
182 cgm.errorNYI(
expr->getSourceRange(),
183 std::string(
"unimplemented AMDGPU builtin call: ") +
185 return mlir::Value{};
187 case AMDGPU::BI__builtin_amdgcn_readlane: {
190 return builder.emitIntrinsicCallOp(
getLoc(
expr->getExprLoc()),
191 "amdgcn.readlane", src0.getType(),
192 mlir::ValueRange{src0, src1});
194 case AMDGPU::BI__builtin_amdgcn_readfirstlane: {
196 return builder.emitIntrinsicCallOp(
getLoc(
expr->getExprLoc()),
197 "amdgcn.readfirstlane", src0.getType(),
198 mlir::ValueRange{src0});
200 case AMDGPU::BI__builtin_amdgcn_wave_shuffle: {
201 cgm.errorNYI(
expr->getSourceRange(),
202 std::string(
"unimplemented AMDGPU builtin call: ") +
204 return mlir::Value{};
206 case AMDGPU::BI__builtin_amdgcn_div_fixup:
207 case AMDGPU::BI__builtin_amdgcn_div_fixupf:
208 case AMDGPU::BI__builtin_amdgcn_div_fixuph: {
209 cgm.errorNYI(
expr->getSourceRange(),
210 std::string(
"unimplemented AMDGPU builtin call: ") +
212 return mlir::Value{};
214 case AMDGPU::BI__builtin_amdgcn_trig_preop:
215 case AMDGPU::BI__builtin_amdgcn_trig_preopf: {
216 cgm.errorNYI(
expr->getSourceRange(),
217 std::string(
"unimplemented AMDGPU builtin call: ") +
219 return mlir::Value{};
221 case AMDGPU::BI__builtin_amdgcn_rcp:
222 case AMDGPU::BI__builtin_amdgcn_rcpf:
223 case AMDGPU::BI__builtin_amdgcn_rcph:
224 case AMDGPU::BI__builtin_amdgcn_rcp_bf16: {
225 cgm.errorNYI(
expr->getSourceRange(),
226 std::string(
"unimplemented AMDGPU builtin call: ") +
228 return mlir::Value{};
230 case AMDGPU::BI__builtin_amdgcn_sqrt:
231 case AMDGPU::BI__builtin_amdgcn_sqrtf:
232 case AMDGPU::BI__builtin_amdgcn_sqrth:
233 case AMDGPU::BI__builtin_amdgcn_sqrt_bf16: {
234 cgm.errorNYI(
expr->getSourceRange(),
235 std::string(
"unimplemented AMDGPU builtin call: ") +
237 return mlir::Value{};
239 case AMDGPU::BI__builtin_amdgcn_rsq:
240 case AMDGPU::BI__builtin_amdgcn_rsqf:
241 case AMDGPU::BI__builtin_amdgcn_rsqh:
242 case AMDGPU::BI__builtin_amdgcn_rsq_bf16: {
243 cgm.errorNYI(
expr->getSourceRange(),
244 std::string(
"unimplemented AMDGPU builtin call: ") +
246 return mlir::Value{};
248 case AMDGPU::BI__builtin_amdgcn_rsq_clamp:
249 case AMDGPU::BI__builtin_amdgcn_rsq_clampf: {
250 cgm.errorNYI(
expr->getSourceRange(),
251 std::string(
"unimplemented AMDGPU builtin call: ") +
253 return mlir::Value{};
255 case AMDGPU::BI__builtin_amdgcn_sinf:
256 case AMDGPU::BI__builtin_amdgcn_sinh:
257 case AMDGPU::BI__builtin_amdgcn_sin_bf16: {
258 cgm.errorNYI(
expr->getSourceRange(),
259 std::string(
"unimplemented AMDGPU builtin call: ") +
261 return mlir::Value{};
263 case AMDGPU::BI__builtin_amdgcn_cosf:
264 case AMDGPU::BI__builtin_amdgcn_cosh:
265 case AMDGPU::BI__builtin_amdgcn_cos_bf16: {
266 cgm.errorNYI(
expr->getSourceRange(),
267 std::string(
"unimplemented AMDGPU builtin call: ") +
269 return mlir::Value{};
271 case AMDGPU::BI__builtin_amdgcn_dispatch_ptr: {
272 cgm.errorNYI(
expr->getSourceRange(),
273 std::string(
"unimplemented AMDGPU builtin call: ") +
275 return mlir::Value{};
277 case AMDGPU::BI__builtin_amdgcn_logf:
278 case AMDGPU::BI__builtin_amdgcn_log_bf16: {
279 cgm.errorNYI(
expr->getSourceRange(),
280 std::string(
"unimplemented AMDGPU builtin call: ") +
282 return mlir::Value{};
284 case AMDGPU::BI__builtin_amdgcn_exp2f:
285 case AMDGPU::BI__builtin_amdgcn_exp2_bf16: {
286 cgm.errorNYI(
expr->getSourceRange(),
287 std::string(
"unimplemented AMDGPU builtin call: ") +
289 return mlir::Value{};
291 case AMDGPU::BI__builtin_amdgcn_log_clampf: {
292 cgm.errorNYI(
expr->getSourceRange(),
293 std::string(
"unimplemented AMDGPU builtin call: ") +
295 return mlir::Value{};
297 case AMDGPU::BI__builtin_amdgcn_ldexp:
298 case AMDGPU::BI__builtin_amdgcn_ldexpf:
299 case AMDGPU::BI__builtin_amdgcn_ldexph: {
300 cgm.errorNYI(
expr->getSourceRange(),
301 std::string(
"unimplemented AMDGPU builtin call: ") +
303 return mlir::Value{};
305 case AMDGPU::BI__builtin_amdgcn_frexp_mant:
306 case AMDGPU::BI__builtin_amdgcn_frexp_mantf:
307 case AMDGPU::BI__builtin_amdgcn_frexp_manth: {
308 cgm.errorNYI(
expr->getSourceRange(),
309 std::string(
"unimplemented AMDGPU builtin call: ") +
311 return mlir::Value{};
313 case AMDGPU::BI__builtin_amdgcn_frexp_exp:
314 case AMDGPU::BI__builtin_amdgcn_frexp_expf:
315 case AMDGPU::BI__builtin_amdgcn_frexp_exph: {
316 cgm.errorNYI(
expr->getSourceRange(),
317 std::string(
"unimplemented AMDGPU builtin call: ") +
319 return mlir::Value{};
321 case AMDGPU::BI__builtin_amdgcn_fract:
322 case AMDGPU::BI__builtin_amdgcn_fractf:
323 case AMDGPU::BI__builtin_amdgcn_fracth: {
324 cgm.errorNYI(
expr->getSourceRange(),
325 std::string(
"unimplemented AMDGPU builtin call: ") +
327 return mlir::Value{};
329 case AMDGPU::BI__builtin_amdgcn_lerp: {
330 cgm.errorNYI(
expr->getSourceRange(),
331 std::string(
"unimplemented AMDGPU builtin call: ") +
333 return mlir::Value{};
335 case AMDGPU::BI__builtin_amdgcn_ubfe: {
336 cgm.errorNYI(
expr->getSourceRange(),
337 std::string(
"unimplemented AMDGPU builtin call: ") +
339 return mlir::Value{};
341 case AMDGPU::BI__builtin_amdgcn_sbfe: {
342 cgm.errorNYI(
expr->getSourceRange(),
343 std::string(
"unimplemented AMDGPU builtin call: ") +
345 return mlir::Value{};
347 case AMDGPU::BI__builtin_amdgcn_ballot_w32:
348 case AMDGPU::BI__builtin_amdgcn_ballot_w64: {
349 cgm.errorNYI(
expr->getSourceRange(),
350 std::string(
"unimplemented AMDGPU builtin call: ") +
352 return mlir::Value{};
354 case AMDGPU::BI__builtin_amdgcn_inverse_ballot_w32:
355 case AMDGPU::BI__builtin_amdgcn_inverse_ballot_w64: {
356 cgm.errorNYI(
expr->getSourceRange(),
357 std::string(
"unimplemented AMDGPU builtin call: ") +
359 return mlir::Value{};
361 case AMDGPU::BI__builtin_amdgcn_tanhf:
362 case AMDGPU::BI__builtin_amdgcn_tanhh:
363 case AMDGPU::BI__builtin_amdgcn_tanh_bf16: {
364 cgm.errorNYI(
expr->getSourceRange(),
365 std::string(
"unimplemented AMDGPU builtin call: ") +
367 return mlir::Value{};
369 case AMDGPU::BI__builtin_amdgcn_uicmp:
370 case AMDGPU::BI__builtin_amdgcn_uicmpl:
371 case AMDGPU::BI__builtin_amdgcn_sicmp:
372 case AMDGPU::BI__builtin_amdgcn_sicmpl: {
373 cgm.errorNYI(
expr->getSourceRange(),
374 std::string(
"unimplemented AMDGPU builtin call: ") +
376 return mlir::Value{};
378 case AMDGPU::BI__builtin_amdgcn_fcmp:
379 case AMDGPU::BI__builtin_amdgcn_fcmpf: {
380 cgm.errorNYI(
expr->getSourceRange(),
381 std::string(
"unimplemented AMDGPU builtin call: ") +
383 return mlir::Value{};
385 case AMDGPU::BI__builtin_amdgcn_class:
386 case AMDGPU::BI__builtin_amdgcn_classf:
387 case AMDGPU::BI__builtin_amdgcn_classh: {
388 cgm.errorNYI(
expr->getSourceRange(),
389 std::string(
"unimplemented AMDGPU builtin call: ") +
391 return mlir::Value{};
393 case AMDGPU::BI__builtin_amdgcn_fmed3f:
394 case AMDGPU::BI__builtin_amdgcn_fmed3h: {
395 cgm.errorNYI(
expr->getSourceRange(),
396 std::string(
"unimplemented AMDGPU builtin call: ") +
398 return mlir::Value{};
400 case AMDGPU::BI__builtin_amdgcn_ds_append:
401 case AMDGPU::BI__builtin_amdgcn_ds_consume: {
402 cgm.errorNYI(
expr->getSourceRange(),
403 std::string(
"unimplemented AMDGPU builtin call: ") +
405 return mlir::Value{};
407 case AMDGPU::BI__builtin_amdgcn_global_load_tr_b64_i32:
408 case AMDGPU::BI__builtin_amdgcn_global_load_tr_b64_v2i32:
409 case AMDGPU::BI__builtin_amdgcn_global_load_tr_b128_v4i16:
410 case AMDGPU::BI__builtin_amdgcn_global_load_tr_b128_v4f16:
411 case AMDGPU::BI__builtin_amdgcn_global_load_tr_b128_v4bf16:
412 case AMDGPU::BI__builtin_amdgcn_global_load_tr_b128_v8i16:
413 case AMDGPU::BI__builtin_amdgcn_global_load_tr_b128_v8f16:
414 case AMDGPU::BI__builtin_amdgcn_global_load_tr_b128_v8bf16:
415 case AMDGPU::BI__builtin_amdgcn_global_load_tr4_b64_v2i32:
416 case AMDGPU::BI__builtin_amdgcn_global_load_tr8_b64_v2i32:
417 case AMDGPU::BI__builtin_amdgcn_global_load_tr6_b96_v3i32:
418 case AMDGPU::BI__builtin_amdgcn_global_load_tr16_b128_v8i16:
419 case AMDGPU::BI__builtin_amdgcn_global_load_tr16_b128_v8f16:
420 case AMDGPU::BI__builtin_amdgcn_global_load_tr16_b128_v8bf16: {
421 cgm.errorNYI(
expr->getSourceRange(),
422 std::string(
"unimplemented AMDGPU builtin call: ") +
424 return mlir::Value{};
426 case AMDGPU::BI__builtin_amdgcn_ds_load_tr4_b64_v2i32:
427 case AMDGPU::BI__builtin_amdgcn_ds_load_tr8_b64_v2i32:
428 case AMDGPU::BI__builtin_amdgcn_ds_load_tr6_b96_v3i32:
429 case AMDGPU::BI__builtin_amdgcn_ds_load_tr16_b128_v8i16:
430 case AMDGPU::BI__builtin_amdgcn_ds_load_tr16_b128_v8f16:
431 case AMDGPU::BI__builtin_amdgcn_ds_load_tr16_b128_v8bf16: {
432 cgm.errorNYI(
expr->getSourceRange(),
433 std::string(
"unimplemented AMDGPU builtin call: ") +
435 return mlir::Value{};
437 case AMDGPU::BI__builtin_amdgcn_ds_read_tr4_b64_v2i32:
438 case AMDGPU::BI__builtin_amdgcn_ds_read_tr8_b64_v2i32:
439 case AMDGPU::BI__builtin_amdgcn_ds_read_tr6_b96_v3i32:
440 case AMDGPU::BI__builtin_amdgcn_ds_read_tr16_b64_v4f16:
441 case AMDGPU::BI__builtin_amdgcn_ds_read_tr16_b64_v4bf16:
442 case AMDGPU::BI__builtin_amdgcn_ds_read_tr16_b64_v4i16: {
443 cgm.errorNYI(
expr->getSourceRange(),
444 std::string(
"unimplemented AMDGPU builtin call: ") +
446 return mlir::Value{};
448 case AMDGPU::BI__builtin_amdgcn_global_load_monitor_b32:
449 case AMDGPU::BI__builtin_amdgcn_global_load_monitor_b64:
450 case AMDGPU::BI__builtin_amdgcn_global_load_monitor_b128:
451 case AMDGPU::BI__builtin_amdgcn_flat_load_monitor_b32:
452 case AMDGPU::BI__builtin_amdgcn_flat_load_monitor_b64:
453 case AMDGPU::BI__builtin_amdgcn_flat_load_monitor_b128: {
454 cgm.errorNYI(
expr->getSourceRange(),
455 std::string(
"unimplemented AMDGPU builtin call: ") +
457 return mlir::Value{};
459 case AMDGPU::BI__builtin_amdgcn_cluster_load_b32:
460 case AMDGPU::BI__builtin_amdgcn_cluster_load_b64:
461 case AMDGPU::BI__builtin_amdgcn_cluster_load_b128: {
462 cgm.errorNYI(
expr->getSourceRange(),
463 std::string(
"unimplemented AMDGPU builtin call: ") +
465 return mlir::Value{};
467 case AMDGPU::BI__builtin_amdgcn_load_to_lds: {
468 cgm.errorNYI(
expr->getSourceRange(),
469 std::string(
"unimplemented AMDGPU builtin call: ") +
471 return mlir::Value{};
473 case AMDGPU::BI__builtin_amdgcn_cooperative_atomic_load_32x4B:
474 case AMDGPU::BI__builtin_amdgcn_cooperative_atomic_store_32x4B:
475 case AMDGPU::BI__builtin_amdgcn_cooperative_atomic_load_16x8B:
476 case AMDGPU::BI__builtin_amdgcn_cooperative_atomic_store_16x8B:
477 case AMDGPU::BI__builtin_amdgcn_cooperative_atomic_load_8x16B:
478 case AMDGPU::BI__builtin_amdgcn_cooperative_atomic_store_8x16B: {
479 cgm.errorNYI(
expr->getSourceRange(),
480 std::string(
"unimplemented AMDGPU builtin call: ") +
482 return mlir::Value{};
484 case AMDGPU::BI__builtin_amdgcn_get_fpenv:
485 case AMDGPU::BI__builtin_amdgcn_set_fpenv: {
486 cgm.errorNYI(
expr->getSourceRange(),
487 std::string(
"unimplemented AMDGPU builtin call: ") +
489 return mlir::Value{};
491 case AMDGPU::BI__builtin_amdgcn_read_exec:
492 case AMDGPU::BI__builtin_amdgcn_read_exec_lo:
493 case AMDGPU::BI__builtin_amdgcn_read_exec_hi: {
494 cgm.errorNYI(
expr->getSourceRange(),
495 std::string(
"unimplemented AMDGPU builtin call: ") +
497 return mlir::Value{};
499 case AMDGPU::BI__builtin_amdgcn_image_bvh_intersect_ray:
500 case AMDGPU::BI__builtin_amdgcn_image_bvh_intersect_ray_h:
501 case AMDGPU::BI__builtin_amdgcn_image_bvh_intersect_ray_l:
502 case AMDGPU::BI__builtin_amdgcn_image_bvh_intersect_ray_lh: {
503 cgm.errorNYI(
expr->getSourceRange(),
504 std::string(
"unimplemented AMDGPU builtin call: ") +
506 return mlir::Value{};
508 case AMDGPU::BI__builtin_amdgcn_image_bvh8_intersect_ray:
509 case AMDGPU::BI__builtin_amdgcn_image_bvh_dual_intersect_ray: {
510 cgm.errorNYI(
expr->getSourceRange(),
511 std::string(
"unimplemented AMDGPU builtin call: ") +
513 return mlir::Value{};
515 case AMDGPU::BI__builtin_amdgcn_ds_bvh_stack_rtn:
516 case AMDGPU::BI__builtin_amdgcn_ds_bvh_stack_push4_pop1_rtn:
517 case AMDGPU::BI__builtin_amdgcn_ds_bvh_stack_push8_pop1_rtn:
518 case AMDGPU::BI__builtin_amdgcn_ds_bvh_stack_push8_pop2_rtn: {
519 cgm.errorNYI(
expr->getSourceRange(),
520 std::string(
"unimplemented AMDGPU builtin call: ") +
522 return mlir::Value{};
524 case AMDGPU::BI__builtin_amdgcn_image_load_1d_v4f32_i32:
525 case AMDGPU::BI__builtin_amdgcn_image_load_1d_v4f16_i32:
526 case AMDGPU::BI__builtin_amdgcn_image_load_1darray_v4f32_i32:
527 case AMDGPU::BI__builtin_amdgcn_image_load_1darray_v4f16_i32:
528 case AMDGPU::BI__builtin_amdgcn_image_load_2d_f32_i32:
529 case AMDGPU::BI__builtin_amdgcn_image_load_2d_v4f32_i32:
530 case AMDGPU::BI__builtin_amdgcn_image_load_2d_v4f16_i32:
531 case AMDGPU::BI__builtin_amdgcn_image_load_2darray_f32_i32:
532 case AMDGPU::BI__builtin_amdgcn_image_load_2darray_v4f32_i32:
533 case AMDGPU::BI__builtin_amdgcn_image_load_2darray_v4f16_i32:
534 case AMDGPU::BI__builtin_amdgcn_image_load_3d_v4f32_i32:
535 case AMDGPU::BI__builtin_amdgcn_image_load_3d_v4f16_i32:
536 case AMDGPU::BI__builtin_amdgcn_image_load_cube_v4f32_i32:
537 case AMDGPU::BI__builtin_amdgcn_image_load_cube_v4f16_i32:
538 case AMDGPU::BI__builtin_amdgcn_image_load_mip_1d_v4f32_i32:
539 case AMDGPU::BI__builtin_amdgcn_image_load_mip_1d_v4f16_i32:
540 case AMDGPU::BI__builtin_amdgcn_image_load_mip_2d_v4f32_i32:
541 case AMDGPU::BI__builtin_amdgcn_image_load_mip_2d_v4f16_i32:
542 case AMDGPU::BI__builtin_amdgcn_image_load_mip_2darray_f32_i32:
543 case AMDGPU::BI__builtin_amdgcn_image_load_mip_2darray_v4f32_i32:
544 case AMDGPU::BI__builtin_amdgcn_image_load_mip_2darray_v4f16_i32:
545 case AMDGPU::BI__builtin_amdgcn_image_load_mip_3d_v4f32_i32:
546 case AMDGPU::BI__builtin_amdgcn_image_load_mip_3d_v4f16_i32:
547 case AMDGPU::BI__builtin_amdgcn_image_load_mip_cube_v4f32_i32:
548 case AMDGPU::BI__builtin_amdgcn_image_load_mip_cube_v4f16_i32: {
549 cgm.errorNYI(
expr->getSourceRange(),
550 std::string(
"unimplemented AMDGPU builtin call: ") +
552 return mlir::Value{};
554 case AMDGPU::BI__builtin_amdgcn_image_store_1d_v4f32_i32:
555 case AMDGPU::BI__builtin_amdgcn_image_store_1d_v4f16_i32:
556 case AMDGPU::BI__builtin_amdgcn_image_store_1darray_v4f32_i32:
557 case AMDGPU::BI__builtin_amdgcn_image_store_1darray_v4f16_i32:
558 case AMDGPU::BI__builtin_amdgcn_image_store_2d_f32_i32:
559 case AMDGPU::BI__builtin_amdgcn_image_store_2d_v4f32_i32:
560 case AMDGPU::BI__builtin_amdgcn_image_store_2d_v4f16_i32:
561 case AMDGPU::BI__builtin_amdgcn_image_store_2darray_f32_i32:
562 case AMDGPU::BI__builtin_amdgcn_image_store_2darray_v4f32_i32:
563 case AMDGPU::BI__builtin_amdgcn_image_store_2darray_v4f16_i32:
564 case AMDGPU::BI__builtin_amdgcn_image_store_3d_v4f32_i32:
565 case AMDGPU::BI__builtin_amdgcn_image_store_3d_v4f16_i32:
566 case AMDGPU::BI__builtin_amdgcn_image_store_cube_v4f32_i32:
567 case AMDGPU::BI__builtin_amdgcn_image_store_cube_v4f16_i32:
568 case AMDGPU::BI__builtin_amdgcn_image_store_mip_1d_v4f32_i32:
569 case AMDGPU::BI__builtin_amdgcn_image_store_mip_1d_v4f16_i32:
570 case AMDGPU::BI__builtin_amdgcn_image_store_mip_1darray_v4f32_i32:
571 case AMDGPU::BI__builtin_amdgcn_image_store_mip_1darray_v4f16_i32:
572 case AMDGPU::BI__builtin_amdgcn_image_store_mip_2d_f32_i32:
573 case AMDGPU::BI__builtin_amdgcn_image_store_mip_2d_v4f32_i32:
574 case AMDGPU::BI__builtin_amdgcn_image_store_mip_2d_v4f16_i32:
575 case AMDGPU::BI__builtin_amdgcn_image_store_mip_2darray_f32_i32:
576 case AMDGPU::BI__builtin_amdgcn_image_store_mip_2darray_v4f32_i32:
577 case AMDGPU::BI__builtin_amdgcn_image_store_mip_2darray_v4f16_i32:
578 case AMDGPU::BI__builtin_amdgcn_image_store_mip_3d_v4f32_i32:
579 case AMDGPU::BI__builtin_amdgcn_image_store_mip_3d_v4f16_i32:
580 case AMDGPU::BI__builtin_amdgcn_image_store_mip_cube_v4f32_i32:
581 case AMDGPU::BI__builtin_amdgcn_image_store_mip_cube_v4f16_i32: {
582 cgm.errorNYI(
expr->getSourceRange(),
583 std::string(
"unimplemented AMDGPU builtin call: ") +
585 return mlir::Value{};
587 case AMDGPU::BI__builtin_amdgcn_image_sample_1d_v4f32_f32:
588 case AMDGPU::BI__builtin_amdgcn_image_sample_1d_v4f16_f32:
589 case AMDGPU::BI__builtin_amdgcn_image_sample_1darray_v4f32_f32:
590 case AMDGPU::BI__builtin_amdgcn_image_sample_1darray_v4f16_f32:
591 case AMDGPU::BI__builtin_amdgcn_image_sample_2d_f32_f32:
592 case AMDGPU::BI__builtin_amdgcn_image_sample_2d_v4f32_f32:
593 case AMDGPU::BI__builtin_amdgcn_image_sample_2d_v4f16_f32:
594 case AMDGPU::BI__builtin_amdgcn_image_sample_2darray_f32_f32:
595 case AMDGPU::BI__builtin_amdgcn_image_sample_2darray_v4f32_f32:
596 case AMDGPU::BI__builtin_amdgcn_image_sample_2darray_v4f16_f32:
597 case AMDGPU::BI__builtin_amdgcn_image_sample_3d_v4f32_f32:
598 case AMDGPU::BI__builtin_amdgcn_image_sample_3d_v4f16_f32:
599 case AMDGPU::BI__builtin_amdgcn_image_sample_cube_v4f32_f32:
600 case AMDGPU::BI__builtin_amdgcn_image_sample_cube_v4f16_f32:
601 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_1d_v4f32_f32:
602 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_1d_v4f16_f32:
603 case AMDGPU::BI__builtin_amdgcn_image_sample_l_1d_v4f32_f32:
604 case AMDGPU::BI__builtin_amdgcn_image_sample_l_1d_v4f16_f32:
605 case AMDGPU::BI__builtin_amdgcn_image_sample_d_1d_v4f32_f32:
606 case AMDGPU::BI__builtin_amdgcn_image_sample_d_1d_v4f16_f32:
607 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_2d_v4f32_f32:
608 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_2d_v4f16_f32:
609 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_2d_f32_f32:
610 case AMDGPU::BI__builtin_amdgcn_image_sample_l_2d_v4f32_f32:
611 case AMDGPU::BI__builtin_amdgcn_image_sample_l_2d_v4f16_f32:
612 case AMDGPU::BI__builtin_amdgcn_image_sample_l_2d_f32_f32:
613 case AMDGPU::BI__builtin_amdgcn_image_sample_d_2d_v4f32_f32:
614 case AMDGPU::BI__builtin_amdgcn_image_sample_d_2d_v4f16_f32:
615 case AMDGPU::BI__builtin_amdgcn_image_sample_d_2d_f32_f32:
616 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_3d_v4f32_f32:
617 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_3d_v4f16_f32:
618 case AMDGPU::BI__builtin_amdgcn_image_sample_l_3d_v4f32_f32:
619 case AMDGPU::BI__builtin_amdgcn_image_sample_l_3d_v4f16_f32:
620 case AMDGPU::BI__builtin_amdgcn_image_sample_d_3d_v4f32_f32:
621 case AMDGPU::BI__builtin_amdgcn_image_sample_d_3d_v4f16_f32:
622 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_cube_v4f32_f32:
623 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_cube_v4f16_f32:
624 case AMDGPU::BI__builtin_amdgcn_image_sample_l_cube_v4f32_f32:
625 case AMDGPU::BI__builtin_amdgcn_image_sample_l_cube_v4f16_f32:
626 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_1darray_v4f32_f32:
627 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_1darray_v4f16_f32:
628 case AMDGPU::BI__builtin_amdgcn_image_sample_l_1darray_v4f32_f32:
629 case AMDGPU::BI__builtin_amdgcn_image_sample_l_1darray_v4f16_f32:
630 case AMDGPU::BI__builtin_amdgcn_image_sample_d_1darray_v4f32_f32:
631 case AMDGPU::BI__builtin_amdgcn_image_sample_d_1darray_v4f16_f32:
632 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_2darray_v4f32_f32:
633 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_2darray_v4f16_f32:
634 case AMDGPU::BI__builtin_amdgcn_image_sample_lz_2darray_f32_f32:
635 case AMDGPU::BI__builtin_amdgcn_image_sample_l_2darray_v4f32_f32:
636 case AMDGPU::BI__builtin_amdgcn_image_sample_l_2darray_v4f16_f32:
637 case AMDGPU::BI__builtin_amdgcn_image_sample_l_2darray_f32_f32:
638 case AMDGPU::BI__builtin_amdgcn_image_sample_d_2darray_v4f32_f32:
639 case AMDGPU::BI__builtin_amdgcn_image_sample_d_2darray_v4f16_f32:
640 case AMDGPU::BI__builtin_amdgcn_image_sample_d_2darray_f32_f32: {
641 cgm.errorNYI(
expr->getSourceRange(),
642 std::string(
"unimplemented AMDGPU builtin call: ") +
644 return mlir::Value{};
646 case AMDGPU::BI__builtin_amdgcn_image_gather4_lz_2d_v4f32_f32: {
647 cgm.errorNYI(
expr->getSourceRange(),
648 std::string(
"unimplemented AMDGPU builtin call: ") +
650 return mlir::Value{};
652 case AMDGPU::BI__builtin_amdgcn_mfma_scale_f32_16x16x128_f8f6f4:
653 case AMDGPU::BI__builtin_amdgcn_mfma_scale_f32_32x32x64_f8f6f4: {
654 cgm.errorNYI(
expr->getSourceRange(),
655 std::string(
"unimplemented AMDGPU builtin call: ") +
657 return mlir::Value{};
659 case AMDGPU::BI__builtin_amdgcn_wmma_bf16_16x16x16_bf16_w32:
660 case AMDGPU::BI__builtin_amdgcn_wmma_bf16_16x16x16_bf16_tied_w32:
661 case AMDGPU::BI__builtin_amdgcn_wmma_bf16_16x16x16_bf16_w64:
662 case AMDGPU::BI__builtin_amdgcn_wmma_bf16_16x16x16_bf16_tied_w64:
663 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x16_f16_w32:
664 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x16_f16_tied_w32:
665 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x16_f16_w64:
666 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x16_f16_tied_w64:
667 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_bf16_w32:
668 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_bf16_w64:
669 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_f16_w32:
670 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_f16_w64:
671 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x16_iu4_w32:
672 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x16_iu4_w64:
673 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x16_iu8_w32:
674 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x16_iu8_w64:
675 case AMDGPU::BI__builtin_amdgcn_wmma_bf16_16x16x16_bf16_w32_gfx12:
676 case AMDGPU::BI__builtin_amdgcn_wmma_bf16_16x16x16_bf16_w64_gfx12:
677 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x16_f16_w32_gfx12:
678 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x16_f16_w64_gfx12:
679 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_bf16_w32_gfx12:
680 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_bf16_w64_gfx12:
681 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_f16_w32_gfx12:
682 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_f16_w64_gfx12:
683 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x16_iu4_w32_gfx12:
684 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x16_iu4_w64_gfx12:
685 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x16_iu8_w32_gfx12:
686 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x16_iu8_w64_gfx12:
687 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_fp8_fp8_w32_gfx12:
688 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_fp8_fp8_w64_gfx12:
689 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_fp8_bf8_w32_gfx12:
690 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_fp8_bf8_w64_gfx12:
691 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_bf8_fp8_w32_gfx12:
692 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_bf8_fp8_w64_gfx12:
693 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_bf8_bf8_w32_gfx12:
694 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x16_bf8_bf8_w64_gfx12:
695 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x32_iu4_w32_gfx12:
696 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x32_iu4_w64_gfx12: {
697 cgm.errorNYI(
expr->getSourceRange(),
698 std::string(
"unimplemented AMDGPU builtin call: ") +
700 return mlir::Value{};
702 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_f16_w32:
703 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_f16_w64:
704 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_bf16_w32:
705 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_bf16_w64:
706 case AMDGPU::BI__builtin_amdgcn_swmmac_f16_16x16x32_f16_w32:
707 case AMDGPU::BI__builtin_amdgcn_swmmac_f16_16x16x32_f16_w64:
708 case AMDGPU::BI__builtin_amdgcn_swmmac_bf16_16x16x32_bf16_w32:
709 case AMDGPU::BI__builtin_amdgcn_swmmac_bf16_16x16x32_bf16_w64:
710 case AMDGPU::BI__builtin_amdgcn_swmmac_i32_16x16x32_iu8_w32:
711 case AMDGPU::BI__builtin_amdgcn_swmmac_i32_16x16x32_iu8_w64:
712 case AMDGPU::BI__builtin_amdgcn_swmmac_i32_16x16x32_iu4_w32:
713 case AMDGPU::BI__builtin_amdgcn_swmmac_i32_16x16x32_iu4_w64:
714 case AMDGPU::BI__builtin_amdgcn_swmmac_i32_16x16x64_iu4_w32:
715 case AMDGPU::BI__builtin_amdgcn_swmmac_i32_16x16x64_iu4_w64:
716 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_fp8_fp8_w32:
717 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_fp8_fp8_w64:
718 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_fp8_bf8_w32:
719 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_fp8_bf8_w64:
720 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_bf8_fp8_w32:
721 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_bf8_fp8_w64:
722 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_bf8_bf8_w32:
723 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x32_bf8_bf8_w64: {
724 cgm.errorNYI(
expr->getSourceRange(),
725 std::string(
"unimplemented AMDGPU builtin call: ") +
727 return mlir::Value{};
729 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x4_f32:
730 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x32_bf16:
731 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x32_f16:
732 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x32_f16:
733 case AMDGPU::BI__builtin_amdgcn_wmma_bf16_16x16x32_bf16:
734 case AMDGPU::BI__builtin_amdgcn_wmma_bf16f32_16x16x32_bf16:
735 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x64_fp8_fp8:
736 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x64_fp8_bf8:
737 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x64_bf8_fp8:
738 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x64_bf8_bf8:
739 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x64_fp8_fp8:
740 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x64_fp8_bf8:
741 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x64_bf8_fp8:
742 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x64_bf8_bf8:
743 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x128_fp8_fp8:
744 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x128_fp8_bf8:
745 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x128_bf8_fp8:
746 case AMDGPU::BI__builtin_amdgcn_wmma_f16_16x16x128_bf8_bf8:
747 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x128_fp8_fp8:
748 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x128_fp8_bf8:
749 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x128_bf8_fp8:
750 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x128_bf8_bf8:
751 case AMDGPU::BI__builtin_amdgcn_wmma_i32_16x16x64_iu8:
752 case AMDGPU::BI__builtin_amdgcn_wmma_f32_16x16x128_f8f6f4:
753 case AMDGPU::BI__builtin_amdgcn_wmma_f32_32x16x128_f4:
754 case AMDGPU::BI__builtin_amdgcn_wmma_scale_f32_16x16x128_f8f6f4:
755 case AMDGPU::BI__builtin_amdgcn_wmma_scale16_f32_16x16x128_f8f6f4:
756 case AMDGPU::BI__builtin_amdgcn_wmma_scale_f32_32x16x128_f4:
757 case AMDGPU::BI__builtin_amdgcn_wmma_scale16_f32_32x16x128_f4: {
758 cgm.errorNYI(
expr->getSourceRange(),
759 std::string(
"unimplemented AMDGPU builtin call: ") +
761 return mlir::Value{};
763 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x64_f16:
764 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x64_bf16:
765 case AMDGPU::BI__builtin_amdgcn_swmmac_f16_16x16x64_f16:
766 case AMDGPU::BI__builtin_amdgcn_swmmac_bf16_16x16x64_bf16:
767 case AMDGPU::BI__builtin_amdgcn_swmmac_bf16f32_16x16x64_bf16:
768 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x128_fp8_fp8:
769 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x128_fp8_bf8:
770 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x128_bf8_fp8:
771 case AMDGPU::BI__builtin_amdgcn_swmmac_f32_16x16x128_bf8_bf8:
772 case AMDGPU::BI__builtin_amdgcn_swmmac_f16_16x16x128_fp8_fp8:
773 case AMDGPU::BI__builtin_amdgcn_swmmac_f16_16x16x128_fp8_bf8:
774 case AMDGPU::BI__builtin_amdgcn_swmmac_f16_16x16x128_bf8_fp8:
775 case AMDGPU::BI__builtin_amdgcn_swmmac_f16_16x16x128_bf8_bf8:
776 case AMDGPU::BI__builtin_amdgcn_swmmac_i32_16x16x128_iu8: {
777 cgm.errorNYI(
expr->getSourceRange(),
778 std::string(
"unimplemented AMDGPU builtin call: ") +
780 return mlir::Value{};
783 case AMDGPU::BI__builtin_amdgcn_workgroup_size_x:
784 case AMDGPU::BI__builtin_amdgcn_workgroup_size_y:
785 case AMDGPU::BI__builtin_amdgcn_workgroup_size_z: {
786 cgm.errorNYI(
expr->getSourceRange(),
787 std::string(
"unimplemented AMDGPU builtin call: ") +
789 return mlir::Value{};
791 case AMDGPU::BI__builtin_amdgcn_grid_size_x:
792 case AMDGPU::BI__builtin_amdgcn_grid_size_y:
793 case AMDGPU::BI__builtin_amdgcn_grid_size_z: {
794 cgm.errorNYI(
expr->getSourceRange(),
795 std::string(
"unimplemented AMDGPU builtin call: ") +
797 return mlir::Value{};
799 case AMDGPU::BI__builtin_r600_recipsqrt_ieee:
800 case AMDGPU::BI__builtin_r600_recipsqrt_ieeef: {
801 cgm.errorNYI(
expr->getSourceRange(),
802 std::string(
"unimplemented AMDGPU builtin call: ") +
804 return mlir::Value{};
806 case AMDGPU::BI__builtin_amdgcn_alignbit: {
807 cgm.errorNYI(
expr->getSourceRange(),
808 std::string(
"unimplemented AMDGPU builtin call: ") +
810 return mlir::Value{};
812 case AMDGPU::BI__builtin_amdgcn_fence: {
813 cgm.errorNYI(
expr->getSourceRange(),
814 std::string(
"unimplemented AMDGPU builtin call: ") +
816 return mlir::Value{};
818 case AMDGPU::BI__builtin_amdgcn_atomic_inc32:
819 case AMDGPU::BI__builtin_amdgcn_atomic_inc64:
820 case AMDGPU::BI__builtin_amdgcn_atomic_dec32:
821 case AMDGPU::BI__builtin_amdgcn_atomic_dec64:
822 case AMDGPU::BI__builtin_amdgcn_ds_atomic_fadd_f64:
823 case AMDGPU::BI__builtin_amdgcn_ds_atomic_fadd_f32:
824 case AMDGPU::BI__builtin_amdgcn_ds_atomic_fadd_v2f16:
825 case AMDGPU::BI__builtin_amdgcn_ds_atomic_fadd_v2bf16:
826 case AMDGPU::BI__builtin_amdgcn_ds_faddf:
827 case AMDGPU::BI__builtin_amdgcn_ds_fminf:
828 case AMDGPU::BI__builtin_amdgcn_ds_fmaxf:
829 case AMDGPU::BI__builtin_amdgcn_global_atomic_fadd_f32:
830 case AMDGPU::BI__builtin_amdgcn_global_atomic_fadd_f64:
831 case AMDGPU::BI__builtin_amdgcn_global_atomic_fadd_v2f16:
832 case AMDGPU::BI__builtin_amdgcn_flat_atomic_fadd_v2f16:
833 case AMDGPU::BI__builtin_amdgcn_flat_atomic_fadd_f32:
834 case AMDGPU::BI__builtin_amdgcn_flat_atomic_fadd_f64:
835 case AMDGPU::BI__builtin_amdgcn_global_atomic_fadd_v2bf16:
836 case AMDGPU::BI__builtin_amdgcn_flat_atomic_fadd_v2bf16:
837 case AMDGPU::BI__builtin_amdgcn_global_atomic_fmin_f64:
838 case AMDGPU::BI__builtin_amdgcn_global_atomic_fmax_f64:
839 case AMDGPU::BI__builtin_amdgcn_flat_atomic_fmin_f64:
840 case AMDGPU::BI__builtin_amdgcn_flat_atomic_fmax_f64: {
841 cgm.errorNYI(
expr->getSourceRange(),
842 std::string(
"unimplemented AMDGPU builtin call: ") +
844 return mlir::Value{};
846 case AMDGPU::BI__builtin_amdgcn_s_sendmsg_rtn:
847 case AMDGPU::BI__builtin_amdgcn_s_sendmsg_rtnl: {
848 cgm.errorNYI(
expr->getSourceRange(),
849 std::string(
"unimplemented AMDGPU builtin call: ") +
851 return mlir::Value{};
853 case AMDGPU::BI__builtin_amdgcn_permlane16_swap:
854 case AMDGPU::BI__builtin_amdgcn_permlane32_swap: {
855 cgm.errorNYI(
expr->getSourceRange(),
856 std::string(
"unimplemented AMDGPU builtin call: ") +
858 return mlir::Value{};
860 case AMDGPU::BI__builtin_amdgcn_bitop3_b32:
861 case AMDGPU::BI__builtin_amdgcn_bitop3_b16: {
862 cgm.errorNYI(
expr->getSourceRange(),
863 std::string(
"unimplemented AMDGPU builtin call: ") +
865 return mlir::Value{};
867 case AMDGPU::BI__builtin_amdgcn_make_buffer_rsrc: {
868 cgm.errorNYI(
expr->getSourceRange(),
869 std::string(
"unimplemented AMDGPU builtin call: ") +
871 return mlir::Value{};
873 case AMDGPU::BI__builtin_amdgcn_raw_buffer_store_b8:
874 case AMDGPU::BI__builtin_amdgcn_raw_buffer_store_b16:
875 case AMDGPU::BI__builtin_amdgcn_raw_buffer_store_b32:
876 case AMDGPU::BI__builtin_amdgcn_raw_buffer_store_b64:
877 case AMDGPU::BI__builtin_amdgcn_raw_buffer_store_b96:
878 case AMDGPU::BI__builtin_amdgcn_raw_buffer_store_b128: {
879 cgm.errorNYI(
expr->getSourceRange(),
880 std::string(
"unimplemented AMDGPU builtin call: ") +
882 return mlir::Value{};
884 case AMDGPU::BI__builtin_amdgcn_raw_buffer_load_b8:
885 case AMDGPU::BI__builtin_amdgcn_raw_buffer_load_b16:
886 case AMDGPU::BI__builtin_amdgcn_raw_buffer_load_b32:
887 case AMDGPU::BI__builtin_amdgcn_raw_buffer_load_b64:
888 case AMDGPU::BI__builtin_amdgcn_raw_buffer_load_b96:
889 case AMDGPU::BI__builtin_amdgcn_raw_buffer_load_b128: {
890 cgm.errorNYI(
expr->getSourceRange(),
891 std::string(
"unimplemented AMDGPU builtin call: ") +
893 return mlir::Value{};
895 case AMDGPU::BI__builtin_amdgcn_raw_ptr_buffer_atomic_add_i32: {
896 cgm.errorNYI(
expr->getSourceRange(),
897 std::string(
"unimplemented AMDGPU builtin call: ") +
899 return mlir::Value{};
901 case AMDGPU::BI__builtin_amdgcn_raw_ptr_buffer_atomic_fadd_f32:
902 case AMDGPU::BI__builtin_amdgcn_raw_ptr_buffer_atomic_fadd_v2f16: {
903 cgm.errorNYI(
expr->getSourceRange(),
904 std::string(
"unimplemented AMDGPU builtin call: ") +
906 return mlir::Value{};
908 case AMDGPU::BI__builtin_amdgcn_raw_ptr_buffer_atomic_fmin_f32:
909 case AMDGPU::BI__builtin_amdgcn_raw_ptr_buffer_atomic_fmin_f64: {
910 cgm.errorNYI(
expr->getSourceRange(),
911 std::string(
"unimplemented AMDGPU builtin call: ") +
913 return mlir::Value{};
915 case AMDGPU::BI__builtin_amdgcn_raw_ptr_buffer_atomic_fmax_f32:
916 case AMDGPU::BI__builtin_amdgcn_raw_ptr_buffer_atomic_fmax_f64: {
917 cgm.errorNYI(
expr->getSourceRange(),
918 std::string(
"unimplemented AMDGPU builtin call: ") +
920 return mlir::Value{};
922 case AMDGPU::BI__builtin_amdgcn_s_prefetch_data: {
923 cgm.errorNYI(
expr->getSourceRange(),
924 std::string(
"unimplemented AMDGPU builtin call: ") +
926 return mlir::Value{};
928 case Builtin::BIlogbf:
929 case Builtin::BI__builtin_logbf:
931 case Builtin::BIlogb:
932 case Builtin::BI__builtin_logb:
934 case Builtin::BIscalbnf:
935 case Builtin::BI__builtin_scalbnf:
936 case Builtin::BIscalbn:
937 case Builtin::BI__builtin_scalbn: {
939 *
this,
expr,
"ldexp",
"experimental.constrained.ldexp");