mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-10-24 02:35:52 +00:00
Prevents UB for divide-by-zero and integer overflow when dividing Fixed: tint:1349 Change-Id: Ieef66d27d7aec3011628ced076b2bccc7770a8af Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/108925 Commit-Queue: Ben Clayton <bclayton@google.com> Reviewed-by: Dan Sinclair <dsinclair@chromium.org> Kokoro: Kokoro <noreply+kokoro@google.com>
98 lines
3.5 KiB
Plaintext
98 lines
3.5 KiB
Plaintext
; SPIR-V
|
|
; Version: 1.3
|
|
; Generator: Google Tint Compiler; 0
|
|
; Bound: 62
|
|
; Schema: 0
|
|
OpCapability Shader
|
|
OpMemoryModel Logical GLSL450
|
|
OpEntryPoint GLCompute %unused_entry_point "unused_entry_point"
|
|
OpExecutionMode %unused_entry_point LocalSize 1 1 1
|
|
OpName %a "a"
|
|
OpName %b "b"
|
|
OpName %unused_entry_point "unused_entry_point"
|
|
OpName %tint_div "tint_div"
|
|
OpName %lhs "lhs"
|
|
OpName %rhs "rhs"
|
|
OpName %tint_mod "tint_mod"
|
|
OpName %lhs_0 "lhs"
|
|
OpName %rhs_0 "rhs"
|
|
OpName %foo "foo"
|
|
OpName %maybe_zero "maybe_zero"
|
|
%int = OpTypeInt 32 1
|
|
%_ptr_Private_int = OpTypePointer Private %int
|
|
%4 = OpConstantNull %int
|
|
%a = OpVariable %_ptr_Private_int Private %4
|
|
%float = OpTypeFloat 32
|
|
%_ptr_Private_float = OpTypePointer Private %float
|
|
%8 = OpConstantNull %float
|
|
%b = OpVariable %_ptr_Private_float Private %8
|
|
%void = OpTypeVoid
|
|
%9 = OpTypeFunction %void
|
|
%13 = OpTypeFunction %int %int %int
|
|
%bool = OpTypeBool
|
|
%int_n2147483648 = OpConstant %int -2147483648
|
|
%int_n1 = OpConstant %int -1
|
|
%int_1 = OpConstant %int 1
|
|
%40 = OpTypeFunction %void %int
|
|
%unused_entry_point = OpFunction %void None %9
|
|
%12 = OpLabel
|
|
OpReturn
|
|
OpFunctionEnd
|
|
%tint_div = OpFunction %int None %13
|
|
%lhs = OpFunctionParameter %int
|
|
%rhs = OpFunctionParameter %int
|
|
%17 = OpLabel
|
|
%19 = OpIEqual %bool %rhs %4
|
|
%22 = OpIEqual %bool %lhs %int_n2147483648
|
|
%24 = OpIEqual %bool %rhs %int_n1
|
|
%25 = OpLogicalAnd %bool %22 %24
|
|
%26 = OpLogicalOr %bool %19 %25
|
|
%18 = OpSelect %int %26 %int_1 %rhs
|
|
%28 = OpSDiv %int %lhs %18
|
|
OpReturnValue %28
|
|
OpFunctionEnd
|
|
%tint_mod = OpFunction %int None %13
|
|
%lhs_0 = OpFunctionParameter %int
|
|
%rhs_0 = OpFunctionParameter %int
|
|
%32 = OpLabel
|
|
%34 = OpIEqual %bool %rhs_0 %4
|
|
%35 = OpIEqual %bool %lhs_0 %int_n2147483648
|
|
%36 = OpIEqual %bool %rhs_0 %int_n1
|
|
%37 = OpLogicalAnd %bool %35 %36
|
|
%38 = OpLogicalOr %bool %34 %37
|
|
%33 = OpSelect %int %38 %int_1 %rhs_0
|
|
%39 = OpSMod %int %lhs_0 %33
|
|
OpReturnValue %39
|
|
OpFunctionEnd
|
|
%foo = OpFunction %void None %40
|
|
%maybe_zero = OpFunctionParameter %int
|
|
%43 = OpLabel
|
|
%45 = OpLoad %int %a
|
|
%44 = OpFunctionCall %int %tint_div %45 %4
|
|
OpStore %a %44
|
|
%47 = OpLoad %int %a
|
|
%46 = OpFunctionCall %int %tint_mod %47 %4
|
|
OpStore %a %46
|
|
%49 = OpLoad %int %a
|
|
%48 = OpFunctionCall %int %tint_div %49 %maybe_zero
|
|
OpStore %a %48
|
|
%51 = OpLoad %int %a
|
|
%50 = OpFunctionCall %int %tint_mod %51 %maybe_zero
|
|
OpStore %a %50
|
|
%52 = OpLoad %float %b
|
|
%53 = OpFDiv %float %52 %8
|
|
OpStore %b %53
|
|
%54 = OpLoad %float %b
|
|
%55 = OpFRem %float %54 %8
|
|
OpStore %b %55
|
|
%56 = OpLoad %float %b
|
|
%57 = OpConvertSToF %float %maybe_zero
|
|
%58 = OpFDiv %float %56 %57
|
|
OpStore %b %58
|
|
%59 = OpLoad %float %b
|
|
%60 = OpConvertSToF %float %maybe_zero
|
|
%61 = OpFRem %float %59 %60
|
|
OpStore %b %61
|
|
OpReturn
|
|
OpFunctionEnd
|