about summary refs log tree commit diff
path: root/src/optimize
diff options
context:
space:
mode:
authorCohenArthur <arthur.cohen@epita.fr>2020-08-23 18:16:36 +0200
committerCohenArthur <arthur.cohen@epita.fr>2020-08-23 18:16:36 +0200
commiteb6df58cdde7c4a83d960ba2e75f5c7421c94689 (patch)
tree12da0bf26f03e74948f86fbb1ef53a0070e3e73f /src/optimize
parentb0ea85fb837ab62cd032e18d1429f7b9e2f05726 (diff)
downloadrust-eb6df58cdde7c4a83d960ba2e75f5c7421c94689.tar.gz
rust-eb6df58cdde7c4a83d960ba2e75f5c7421c94689.zip
stack2reg: Remove clone() using filters
Diffstat (limited to 'src/optimize')
-rw-r--r--src/optimize/stack2reg.rs27
1 files changed, 12 insertions, 15 deletions
diff --git a/src/optimize/stack2reg.rs b/src/optimize/stack2reg.rs
index 2c8fe37a84f..72762f563d3 100644
--- a/src/optimize/stack2reg.rs
+++ b/src/optimize/stack2reg.rs
@@ -312,22 +312,19 @@ fn remove_unused_stack_addr_and_stack_load(opt_ctx: &mut OptimizeContext<'_>) {
     }
 
     // Replace all unused stack_addr and stack_load instructions with nop.
+    let mut func = &mut opt_ctx.ctx.func;
     for stack_slot_users in opt_ctx.stack_slot_usage_map.values_mut() {
-        for &inst in stack_slot_users.stack_addr.clone().iter() {
-            if stack_addr_load_insts_users.get(&inst).map(|users| users.is_empty()).unwrap_or(true) {
-                StackSlotUsage::remove_unused_stack_addr(&mut opt_ctx.ctx.func, inst);
-                stack_slot_users.stack_addr.remove(&inst);
-            }
-        }
-
-        /*
-        for &inst in stack_slot_users.stack_load.clone().iter() {
-            if stack_addr_load_insts_users.get(&inst).map(|users| users.is_empty()).unwrap_or(true) {
-                StackSlotUsage::remove_unused_load(&mut opt_ctx.ctx.func, inst);
-                stack_slot_users.stack_load.remove(&inst);
-            }
-        }
-        */
+        stack_slot_users
+            .stack_addr
+            .iter()
+            .filter(|inst| stack_addr_load_insts_users.get(inst).map(|users| users.is_empty()).unwrap_or(true))
+            .for_each(|inst| StackSlotUsage::remove_unused_stack_addr(&mut func, *inst));
+
+        stack_slot_users
+            .stack_load
+            .iter()
+            .filter(|inst| stack_addr_load_insts_users.get(inst).map(|users| users.is_empty()).unwrap_or(true))
+            .for_each(|inst| StackSlotUsage::remove_unused_load(&mut func, *inst));
     }
 }