Skip to content

Commit

Permalink
optimize cached sources
Browse files Browse the repository at this point in the history
Otherwise we will see sources with complicated CFG for semi-concrete
calls. For the absolute consistency with the base compiler, we should
do the round-trip through `jl_compress_ir` to `jl_uncompress_ir` to
`inflate_ir`, but we can achieve the (theoretically) same effect by
doing `CC.compact!(CC.cfg_simplify!(ir))`.
  • Loading branch information
aviatesk committed Nov 22, 2023
1 parent 602d3a0 commit 258583e
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 5 deletions.
15 changes: 10 additions & 5 deletions src/interpreter.jl
Original file line number Diff line number Diff line change
Expand Up @@ -159,10 +159,11 @@ function CC.finish(state::InferenceState, interp::CthulhuInterpreter)
return res
end

function create_cthulhu_source(@nospecialize(x), effects::Effects)
isa(x, OptimizationState) || return x
ir = x.ir::IRCode
return OptimizedSource(ir, x.src, x.src.inlineable, effects)
function create_cthulhu_source(@nospecialize(opt), effects::Effects)
isa(opt, OptimizationState) || return opt
# get the (theoretically) same effect as the jl_compress_ir -> jl_uncompress_ir -> inflate_ir round-trip
ir = CC.compact!(CC.cfg_simplify!(CC.copy(opt.ir::IRCode)))
return OptimizedSource(ir, opt.src, opt.src.inlineable, effects)
end

@static if VERSION v"1.9-"
Expand Down Expand Up @@ -253,7 +254,11 @@ end
@static if VERSION v"1.11.0-DEV.737"
function CC.finish!(interp::CthulhuInterpreter, caller::InferenceState)
result = caller.result
result.src = create_cthulhu_source(result.src, result.ipo_effects)
opt = result.src
result.src = create_cthulhu_source(opt, result.ipo_effects)
if opt isa CC.OptimizationState
CC.ir_to_codeinf!(opt)
end
return nothing
end
else
Expand Down
16 changes: 16 additions & 0 deletions test/test_Cthulhu.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1015,4 +1015,20 @@ end
@test String(take!(io)) == ":toplevel(::Float64)::Float64"
end

@inline countvars50037(bitflags::Int, var::Int) = bitflags >> 0
let (interp, mi) = Cthulhu.mkinterp((Int,)) do var::Int
countvars50037(1, var)
end
key = nothing
for (mi, codeinst) in interp.opt
if mi.def.name === :countvars50037
key = mi
break
end
end
codeinst = interp.opt[key]
inferred = @atomic :monotonic codeinst.inferred
@test length(inferred.ir.cfg.blocks) == 1
end

end # module test_Cthulhu

0 comments on commit 258583e

Please sign in to comment.