summaryrefslogtreecommitdiff
path: root/src/mir/optimise.cpp
diff options
context:
space:
mode:
authorJohn Hodge <tpg@mutabah.net>2017-02-05 11:33:39 +0800
committerJohn Hodge <tpg@mutabah.net>2017-02-05 11:33:39 +0800
commit16f5d2d847f51b530d8bcbf96cb610f48d4132be (patch)
tree1c38f8b0446b52d6b0c15e23f8a3070c379154ff /src/mir/optimise.cpp
parent9700e50573fb44cf30fa6247ef6ff43e44bb9e1f (diff)
downloadmrust-16f5d2d847f51b530d8bcbf96cb610f48d4132be.tar.gz
MIR Optimise - Treat asm! outputs as assignments
Diffstat (limited to 'src/mir/optimise.cpp')
-rw-r--r--src/mir/optimise.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/mir/optimise.cpp b/src/mir/optimise.cpp
index 0be5f88a..66260782 100644
--- a/src/mir/optimise.cpp
+++ b/src/mir/optimise.cpp
@@ -395,6 +395,8 @@ void MIR_Optimise(const StaticTraitResolve& resolve, const ::HIR::ItemPath& path
change_happened = true;
}
+ // TODO: Convert `&mut *mut_foo` into `mut_foo` if the source is movable and not used afterwards
+
// >> Propagate/remove dead assignments
while( MIR_Optimise_PropagateSingleAssignments(state, fcn) )
change_happened = true;
@@ -2138,6 +2140,11 @@ bool MIR_Optimise_GarbageCollect(::MIR::TypeResolve& state, ::MIR::Function& fcn
if( e->flag_idx != ~0u )
used_dfs.at(e->flag_idx) = true;
}
+ else if( const auto* e = stmt.opt_Asm() )
+ {
+ for(const auto& val : e->outputs)
+ assigned_lval(val.second);
+ }
else if( const auto* e = stmt.opt_SetDropFlag() )
{
if( e->other != ~0u )