// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --version 5 // REQUIRES: riscv-registered-target // RUN: %clang_cc1 -triple riscv64 -target-feature +v -target-feature +zvfbfmin \ // RUN: -target-feature +experimental-zvfofp8min -disable-O0-optnone \ // RUN: -emit-llvm %s -o - | opt -S -passes=mem2reg | \ // RUN: FileCheck --check-prefix=CHECK-RV64 %s #include // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3mf8_bf16mf4( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0:[0-9]+]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.nxv1bf16.nxv1i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16mf4_t test_vfwcvt_f_f_v_f8e4m3mf8_bf16mf4(vfloat8e4m3mf8_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3mf8_bf16mf4(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3mf4_bf16mf2( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.nxv2bf16.nxv2i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16mf2_t test_vfwcvt_f_f_v_f8e4m3mf4_bf16mf2(vfloat8e4m3mf4_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3mf4_bf16mf2(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3mf2_bf16m1( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.nxv4bf16.nxv4i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m1_t test_vfwcvt_f_f_v_f8e4m3mf2_bf16m1(vfloat8e4m3mf2_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3mf2_bf16m1(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3m1_bf16m2( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.nxv8bf16.nxv8i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m2_t test_vfwcvt_f_f_v_f8e4m3m1_bf16m2(vfloat8e4m3m1_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3m1_bf16m2(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3m2_bf16m4( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.nxv16bf16.nxv16i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m4_t test_vfwcvt_f_f_v_f8e4m3m2_bf16m4(vfloat8e4m3m2_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3m2_bf16m4(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3m4_bf16m8( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.nxv32bf16.nxv32i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m8_t test_vfwcvt_f_f_v_f8e4m3m4_bf16m8(vfloat8e4m3m4_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3m4_bf16m8(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3mf8_bf16mf4_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.mask.nxv1bf16.nxv1i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16mf4_t test_vfwcvt_f_f_v_f8e4m3mf8_bf16mf4_m(vbool64_t vm, vfloat8e4m3mf8_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3mf8_bf16mf4_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3mf4_bf16mf2_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.mask.nxv2bf16.nxv2i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16mf2_t test_vfwcvt_f_f_v_f8e4m3mf4_bf16mf2_m(vbool32_t vm, vfloat8e4m3mf4_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3mf4_bf16mf2_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3mf2_bf16m1_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.mask.nxv4bf16.nxv4i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m1_t test_vfwcvt_f_f_v_f8e4m3mf2_bf16m1_m(vbool16_t vm, vfloat8e4m3mf2_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3mf2_bf16m1_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3m1_bf16m2_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.mask.nxv8bf16.nxv8i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m2_t test_vfwcvt_f_f_v_f8e4m3m1_bf16m2_m(vbool8_t vm, vfloat8e4m3m1_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3m1_bf16m2_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3m2_bf16m4_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.mask.nxv16bf16.nxv16i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m4_t test_vfwcvt_f_f_v_f8e4m3m2_bf16m4_m(vbool4_t vm, vfloat8e4m3m2_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3m2_bf16m4_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e4m3m4_bf16m8_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.mask.nxv32bf16.nxv32i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m8_t test_vfwcvt_f_f_v_f8e4m3m4_bf16m8_m(vbool2_t vm, vfloat8e4m3m4_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e4m3m4_bf16m8_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2mf8_bf16mf4( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.nxv1bf16.nxv1i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16mf4_t test_vfwcvt_f_f_v_f8e5m2mf8_bf16mf4(vfloat8e5m2mf8_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2mf8_bf16mf4(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2mf4_bf16mf2( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.nxv2bf16.nxv2i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16mf2_t test_vfwcvt_f_f_v_f8e5m2mf4_bf16mf2(vfloat8e5m2mf4_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2mf4_bf16mf2(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2mf2_bf16m1( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.nxv4bf16.nxv4i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m1_t test_vfwcvt_f_f_v_f8e5m2mf2_bf16m1(vfloat8e5m2mf2_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2mf2_bf16m1(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2m1_bf16m2( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.nxv8bf16.nxv8i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m2_t test_vfwcvt_f_f_v_f8e5m2m1_bf16m2(vfloat8e5m2m1_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2m1_bf16m2(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2m2_bf16m4( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.nxv16bf16.nxv16i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m4_t test_vfwcvt_f_f_v_f8e5m2m2_bf16m4(vfloat8e5m2m2_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2m2_bf16m4(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2m4_bf16m8( // CHECK-RV64-SAME: [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.nxv32bf16.nxv32i8.i64( poison, [[VS2]], i64 [[VL]]) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m8_t test_vfwcvt_f_f_v_f8e5m2m4_bf16m8(vfloat8e5m2m4_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2m4_bf16m8(vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2mf8_bf16mf4_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.mask.nxv1bf16.nxv1i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16mf4_t test_vfwcvt_f_f_v_f8e5m2mf8_bf16mf4_m(vbool64_t vm, vfloat8e5m2mf8_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2mf8_bf16mf4_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2mf4_bf16mf2_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.mask.nxv2bf16.nxv2i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16mf2_t test_vfwcvt_f_f_v_f8e5m2mf4_bf16mf2_m(vbool32_t vm, vfloat8e5m2mf4_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2mf4_bf16mf2_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2mf2_bf16m1_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.mask.nxv4bf16.nxv4i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m1_t test_vfwcvt_f_f_v_f8e5m2mf2_bf16m1_m(vbool16_t vm, vfloat8e5m2mf2_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2mf2_bf16m1_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2m1_bf16m2_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.mask.nxv8bf16.nxv8i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m2_t test_vfwcvt_f_f_v_f8e5m2m1_bf16m2_m(vbool8_t vm, vfloat8e5m2m1_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2m1_bf16m2_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2m2_bf16m4_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.mask.nxv16bf16.nxv16i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m4_t test_vfwcvt_f_f_v_f8e5m2m2_bf16m4_m(vbool4_t vm, vfloat8e5m2m2_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2m2_bf16m4_m(vm, vs2, vl); } // CHECK-RV64-LABEL: define dso_local @test_vfwcvt_f_f_v_f8e5m2m4_bf16m8_m( // CHECK-RV64-SAME: [[VM:%.*]], [[VS2:%.*]], i64 noundef [[VL:%.*]]) #[[ATTR0]] { // CHECK-RV64-NEXT: [[ENTRY:.*:]] // CHECK-RV64-NEXT: [[TMP0:%.*]] = call @llvm.riscv.vfwcvt.f.f.v.alt.mask.nxv32bf16.nxv32i8.i64( poison, [[VS2]], [[VM]], i64 [[VL]], i64 3) // CHECK-RV64-NEXT: ret [[TMP0]] // vbfloat16m8_t test_vfwcvt_f_f_v_f8e5m2m4_bf16m8_m(vbool2_t vm, vfloat8e5m2m4_t vs2, size_t vl) { return __riscv_vfwcvt_f_f_v_f8e5m2m4_bf16m8_m(vm, vs2, vl); }