; RUN: split-file %s %t ; RUN: not llc < %t/float8e4m3.ll -mtriple=x86_64-unknown-unknown 2>&1 | FileCheck %s --check-prefix=E4M3 ; RUN: not llc < %t/float8e3m4.ll -mtriple=x86_64-unknown-unknown 2>&1 | FileCheck %s --check-prefix=E3M4 ; RUN: not llc < %t/float8e5m2fnuz.ll -mtriple=x86_64-unknown-unknown 2>&1 | FileCheck %s --check-prefix=E5M2FNUZ ; RUN: not llc < %t/float8e4m3fnuz.ll -mtriple=x86_64-unknown-unknown 2>&1 | FileCheck %s --check-prefix=E4M3FNUZ ; RUN: not llc < %t/float8e4m3b11fnuz.ll -mtriple=x86_64-unknown-unknown 2>&1 | FileCheck %s --check-prefix=E4M3B11FNUZ ; RUN: not llc < %t/float8e8m0fnu.ll -mtriple=x86_64-unknown-unknown 2>&1 | FileCheck %s --check-prefix=E8M0FNU ; Test that llvm.convert.from.arbitrary.fp emits an error for formats that pass ; verifier validation but are not yet implemented in SelectionDAGBuilder. ;--- float8e4m3.ll ; E4M3: error: convert_from_arbitrary_fp: not implemented format 'Float8E4M3' declare float @llvm.convert.from.arbitrary.fp.f32.i8(i8, metadata) define float @from_f8e4m3(i8 %v) { %r = call float @llvm.convert.from.arbitrary.fp.f32.i8( i8 %v, metadata !"Float8E4M3") ret float %r } ;--- float8e3m4.ll ; E3M4: error: convert_from_arbitrary_fp: not implemented format 'Float8E3M4' declare float @llvm.convert.from.arbitrary.fp.f32.i8(i8, metadata) define float @from_f8e3m4(i8 %v) { %r = call float @llvm.convert.from.arbitrary.fp.f32.i8( i8 %v, metadata !"Float8E3M4") ret float %r } ;--- float8e5m2fnuz.ll ; E5M2FNUZ: error: convert_from_arbitrary_fp: not implemented format 'Float8E5M2FNUZ' declare float @llvm.convert.from.arbitrary.fp.f32.i8(i8, metadata) define float @from_f8e5m2fnuz(i8 %v) { %r = call float @llvm.convert.from.arbitrary.fp.f32.i8( i8 %v, metadata !"Float8E5M2FNUZ") ret float %r } ;--- float8e4m3fnuz.ll ; E4M3FNUZ: error: convert_from_arbitrary_fp: not implemented format 'Float8E4M3FNUZ' declare float @llvm.convert.from.arbitrary.fp.f32.i8(i8, metadata) define float @from_f8e4m3fnuz(i8 %v) { %r = call float @llvm.convert.from.arbitrary.fp.f32.i8( i8 %v, metadata !"Float8E4M3FNUZ") ret float %r } ;--- float8e4m3b11fnuz.ll ; E4M3B11FNUZ: error: convert_from_arbitrary_fp: not implemented format 'Float8E4M3B11FNUZ' declare float @llvm.convert.from.arbitrary.fp.f32.i8(i8, metadata) define float @from_f8e4m3b11fnuz(i8 %v) { %r = call float @llvm.convert.from.arbitrary.fp.f32.i8( i8 %v, metadata !"Float8E4M3B11FNUZ") ret float %r } ;--- float8e8m0fnu.ll ; E8M0FNU: error: convert_from_arbitrary_fp: not implemented format 'Float8E8M0FNU' declare float @llvm.convert.from.arbitrary.fp.f32.i8(i8, metadata) define float @from_f8e8m0fnu(i8 %v) { %r = call float @llvm.convert.from.arbitrary.fp.f32.i8( i8 %v, metadata !"Float8E8M0FNU") ret float %r }