[spirv-reader] Add FDiv
Change-Id: Ie24bb91276340afd77009165af471ce0f53cca39
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/19503
Reviewed-by: dan sinclair <dsinclair@google.com>
diff --git a/src/reader/spirv/function.cc b/src/reader/spirv/function.cc
index a1f92ef..0f24f12 100644
--- a/src/reader/spirv/function.cc
+++ b/src/reader/spirv/function.cc
@@ -46,6 +46,8 @@
return ast::BinaryOp::kSubtract;
case SpvOpFMul:
return ast::BinaryOp::kMultiply;
+ case SpvOpFDiv:
+ return ast::BinaryOp::kDivide;
default:
break;
}
diff --git a/src/reader/spirv/function_arithmetic_test.cc b/src/reader/spirv/function_arithmetic_test.cc
index 888bdbb..1643aa2 100644
--- a/src/reader/spirv/function_arithmetic_test.cc
+++ b/src/reader/spirv/function_arithmetic_test.cc
@@ -226,6 +226,19 @@
"__vec_2__f32", AstFor("v2float_50_60"), "multiply",
AstFor("v2float_60_50")}));
+INSTANTIATE_TEST_SUITE_P(
+ SpvParserTest_FDiv,
+ SpvBinaryTest,
+ ::testing::Values(
+ // Scalar float
+ BinaryData{"float", "float_50", "OpFDiv", "float_60", "__f32",
+ "ScalarConstructor{50.000000}", "divide",
+ "ScalarConstructor{60.000000}"},
+ // Vector float
+ BinaryData{"v2float", "v2float_50_60", "OpFDiv", "v2float_60_50",
+ "__vec_2__f32", AstFor("v2float_50_60"), "divide",
+ AstFor("v2float_60_50")}));
+
} // namespace
} // namespace spirv
} // namespace reader