Skip to content

Commit

Permalink
fix #34288, method errors in nothrow inference of division intrinsics
Browse files Browse the repository at this point in the history
  • Loading branch information
JeffBezanson committed Jun 10, 2021
1 parent 7d2e640 commit 699d4a0
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 3 deletions.
37 changes: 34 additions & 3 deletions base/compiler/tfuncs.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1568,6 +1568,38 @@ end

# Query whether the given intrinsic is nothrow

function _nthbit(x, n)
shr = Intrinsics.lshr_int(x, n-1)
if Core.sizeof(x) == 1
Intrinsics.bitcast(Bool, shr)
else
Intrinsics.trunc_int(Bool, shr)
end
end
_nthbit(x::Bool, n) = x
_nbits(x) = Core.sizeof(x)*8
_nbits(x::Bool) = 1
function _iszero(x)
for i = 1:_nbits(x)
_nthbit(x, i) && return false
end
return true
end
function _isneg1(x)
for i = 1:_nbits(x)
_nthbit(x, i) || return false
end
return true
end
function _istypemin(x)
n = _nbits(x)
_nthbit(x, n) || return false
for i = 1:n-1
_nthbit(x, n) && return false
end
return true
end

function intrinsic_nothrow(f::IntrinsicFunction, argtypes::Array{Any, 1})
# First check that we have the correct number of arguments
iidx = Int(reinterpret(Int32, f::IntrinsicFunction)) + 1
Expand All @@ -1594,11 +1626,10 @@ function intrinsic_nothrow(f::IntrinsicFunction, argtypes::Array{Any, 1})
return false
end
den_val = argtypes[2].val
den_val !== zero(typeof(den_val)) || return false
_iszero(den_val) && return false
f !== Intrinsics.checked_sdiv_int && return true
# Nothrow as long as we additionally don't do typemin(T)/-1
return den_val !== -1 || (isa(argtypes[1], Const) &&
argtypes[1].val !== typemin(typeof(den_val)))
return !_isneg1(den_val) || (isa(argtypes[1], Const) && !_istypemin(argtypes[1].val))
end
if f === Intrinsics.pointerref
# Nothrow as long as the types are ok. N.B.: dereferencability is not
Expand Down
4 changes: 4 additions & 0 deletions test/compiler/inference.jl
Original file line number Diff line number Diff line change
Expand Up @@ -3319,3 +3319,7 @@ end |> first === Tuple{Int, String}
# issue #40804
@test Base.return_types(()) do; ===(); end == Any[Union{}]
@test Base.return_types(()) do; typeassert(); end == Any[Union{}]

primitive type UInt24ish 24 end
f34288(x) = Core.Intrinsics.checked_sdiv_int(x, Core.Intrinsics.trunc_int(UInt24ish, 0))
@test Base.return_types(f34288, (UInt24ish,)) == Any[UInt24ish]

0 comments on commit 699d4a0

Please sign in to comment.