summaryrefslogtreecommitdiff
path: root/src/passes/OptimizeCasts.cpp
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2023-05-18 14:58:05 -0700
committerGitHub <noreply@github.com>2023-05-18 14:58:05 -0700
commite42a58696059fd1cadcf25e10223b979214984b3 (patch)
treebf6315fb91307451ac95ff170594ff1d61c2eb0a /src/passes/OptimizeCasts.cpp
parent8ec55f6ac81f4b0d67e3ab8ca14736ff3fbdc671 (diff)
downloadbinaryen-e42a58696059fd1cadcf25e10223b979214984b3.tar.gz
binaryen-e42a58696059fd1cadcf25e10223b979214984b3.tar.bz2
binaryen-e42a58696059fd1cadcf25e10223b979214984b3.zip
Improve TODO docs in OptimizeCasts (#5732)
Diffstat (limited to 'src/passes/OptimizeCasts.cpp')
-rw-r--r--src/passes/OptimizeCasts.cpp24
1 files changed, 17 insertions, 7 deletions
diff --git a/src/passes/OptimizeCasts.cpp b/src/passes/OptimizeCasts.cpp
index 854110157..8f13981bf 100644
--- a/src/passes/OptimizeCasts.cpp
+++ b/src/passes/OptimizeCasts.cpp
@@ -72,13 +72,23 @@
// sense in new pass anyhow, and things should be simpler overall to keep such
// casts all in one pass, here.
//
-// TODO: Move casts earlier in a basic block as well, at least in traps-never-
-// happen mode where we can assume they never fail.
-// TODO: Look past individual basic blocks?
-// TODO: Look at LocalSet as well and not just Get. That would add some overlap
-// with the other passes mentioned above, but once we do things like
-// moving casts earlier as in the other TODO, we'd be doing uniquely
-// useful things with LocalSet here.
+// TODO: 1. Move casts earlier in a basic block as well, at least in
+// traps-never-happen mode where we can assume they never fail, and
+// perhaps in other situations too.
+// TODO: 2. Look past individual basic blocks? This may be worth considering
+// given the pattern of a cast appearing in an if condition that is
+// then used in an if arm, for example, where simple dominance shows
+// the cast can be reused.
+// TODO: 3. Look at LocalSet as well and not just Get. That would add some
+// overlap with the other passes mentioned above (SimplifyLocals and
+// RedundantSetElimination also track sets and can switch a get to use
+// a better set's index when that refines the type). But once we do the
+// first two TODOs above then we'd be adding some novel things here,
+// as we could optimize "backwards" as well (TODO 1) and past basic
+// blocks (TODO 2, though RedundantSetElimination does that as well).
+// However, we should consider whether improving those other passes
+// might make more sense (as it would help more than casts, if we could
+// make them operate "backwards" and/or past basic blocks).
//
#include "ir/linear-execution.h"