; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv64-unknown-unknown %s -o - | FileCheck %s ; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv64-unknown-unknown %s -o - -filetype=obj | spirv-val %} ; CHECK-DAG: OpName %[[#r1:]] "r1" ; CHECK-DAG: OpName %[[#r2:]] "r2" ; CHECK-DAG: OpName %[[#r3:]] "r3" ; CHECK-DAG: OpName %[[#r4:]] "r4" ; CHECK-DAG: OpName %[[#r5:]] "r5" ; CHECK-DAG: OpName %[[#r6:]] "r6" ; CHECK-NOT: OpDecorate %[[#r5]] FPRoundingMode ; CHECK-NOT: OpDecorate %[[#r6]] FPRoundingMode ; CHECK-DAG: OpDecorate %[[#r1]] FPRoundingMode RTE ; CHECK-DAG: OpDecorate %[[#r2]] FPRoundingMode RTZ ; CHECK-DAG: OpDecorate %[[#r4]] FPRoundingMode RTN ; CHECK-DAG: OpDecorate %[[#r3]] FPRoundingMode RTP ; CHECK: OpFAdd %[[#]] %[[#]] ; CHECK: OpFDiv %[[#]] %[[#]] ; CHECK: OpFSub %[[#]] %[[#]] ; CHECK: OpFMul %[[#]] %[[#]] ; CHECK: OpExtInst %[[#]] %[[#]] fma %[[#]] %[[#]] %[[#]] ; CHECK: OpFRem ; Function Attrs: norecurse nounwind strictfp define dso_local spir_kernel void @test(float %a, i32 %in, i32 %ui) { entry: %r1 = tail call float @llvm.experimental.constrained.fadd.f32(float %a, float %a, metadata !"round.tonearest", metadata !"fpexcept.strict") %r2 = tail call float @llvm.experimental.constrained.fdiv.f32(float %a, float %a, metadata !"round.towardzero", metadata !"fpexcept.strict") %r3 = tail call float @llvm.experimental.constrained.fsub.f32(float %a, float %a, metadata !"round.upward", metadata !"fpexcept.strict") %r4 = tail call float @llvm.experimental.constrained.fmul.f32(float %a, float %a, metadata !"round.downward", metadata !"fpexcept.strict") %r5 = tail call float @llvm.experimental.constrained.fma.f32(float %a, float %a, float %a, metadata !"round.dynamic", metadata !"fpexcept.strict") %r6 = tail call float @llvm.experimental.constrained.frem.f32(float %a, float %a, metadata !"round.dynamic", metadata !"fpexcept.strict") ret void } declare float @llvm.experimental.constrained.fadd.f32(float, float, metadata, metadata) declare float @llvm.experimental.constrained.fdiv.f32(float, float, metadata, metadata) declare float @llvm.experimental.constrained.fsub.f32(float, float, metadata, metadata) declare float @llvm.experimental.constrained.fmul.f32(float, float, metadata, metadata) declare float @llvm.experimental.constrained.fmuladd.f32(float, float, float, metadata, metadata) declare float @llvm.experimental.constrained.fma.f32(float, float, float, metadata, metadata) declare float @llvm.experimental.constrained.frem.f32(float, float, metadata, metadata)