Skip to content

Commit

Permalink
optimizer: eliminate allocations (#42833)
Browse files Browse the repository at this point in the history
  • Loading branch information
aviatesk authored Oct 28, 2021
1 parent 6a9737d commit c054dbc
Showing 1 changed file with 11 additions and 25 deletions.
36 changes: 11 additions & 25 deletions base/compiler/ssair/passes.jl
Original file line number Diff line number Diff line change
Expand Up @@ -76,24 +76,17 @@ end

function compute_value_for_use(ir::IRCode, domtree::DomTree, allblocks::Vector{Int}, du::SSADefUse, phinodes::IdDict{Int, SSAValue}, fidx::Int, use_idx::Int)
# Find the first dominating def
curblock = stmtblock = block_for_inst(ir.cfg, use_idx)
curblock = find_curblock(domtree, allblocks, curblock)
defblockdefs = let curblock = curblock
Int[stmt for stmt in du.defs if block_for_inst(ir.cfg, stmt) == curblock]
end
def = 0
if !isempty(defblockdefs)
if curblock != stmtblock
# Find the last def in this block
def = 0
for x in defblockdefs
def = max(def, x)
end
else
# Find the last def before our use
def = 0
for x in defblockdefs
def = max(def, x >= use_idx ? 0 : x)
stmtblock = block_for_inst(ir.cfg, use_idx)
curblock = find_curblock(domtree, allblocks, stmtblock)
local def = 0
for idx in du.defs
if block_for_inst(ir.cfg, idx) == curblock
if curblock != stmtblock
# Find the last def in this block
def = max(def, idx)
else
# Find the last def before our use
def = max(def, idx >= use_idx ? 0 : idx)
end
end
end
Expand Down Expand Up @@ -564,15 +557,10 @@ a result of dead code elimination.
"""
function getfield_elim_pass!(ir::IRCode)
compact = IncrementalCompact(ir)
insertions = Vector{Any}()
defuses = IdDict{Int, Tuple{IdSet{Int}, SSADefUse}}()
lifting_cache = IdDict{Pair{AnySSAValue, Any}, AnySSAValue}()
revisit_worklist = Int[]
#ndone, nmax = 0, 200
for ((_, idx), stmt) in compact
isa(stmt, Expr) || continue
#ndone >= nmax && continue
#ndone += 1
result_t = compact_exprtype(compact, SSAValue(idx))
is_getfield = is_setfield = false
field_ordering = :unspecified
Expand Down Expand Up @@ -998,8 +986,6 @@ function adce_pass!(ir::IRCode)
end

function type_lift_pass!(ir::IRCode)
type_ctx_uses = Vector{Vector{Int}}[]
has_non_type_ctx_uses = IdSet{Int}()
lifted_undef = IdDict{Int, Any}()
insts = ir.stmts
for idx in 1:length(insts)
Expand Down

2 comments on commit c054dbc

@nanosoldier
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Executing the daily package evaluation, I will reply here when finished:

@nanosoldier runtests(ALL, isdaily = true)

@nanosoldier
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Your package evaluation job has completed - possible new issues were detected. A full report can be found here.

Please sign in to comment.