aboutsummaryrefslogtreecommitdiff
path: root/tools/js-optimizer.js
diff options
context:
space:
mode:
authorAlon Zakai <alonzakai@gmail.com>2013-06-07 17:05:05 -0700
committerAlon Zakai <alonzakai@gmail.com>2013-06-07 17:05:05 -0700
commit6b93727b6e463c963197b700561840f82f95ec90 (patch)
treedb08e9bc85a04c9154c61f048d773da8e4a3c321 /tools/js-optimizer.js
parentac69304d5a3b0ce06877d0a37f48df07aff756f2 (diff)
ignore tempDoublePtr operations, they do not really alias memory
Diffstat (limited to 'tools/js-optimizer.js')
-rw-r--r--tools/js-optimizer.js12
1 files changed, 10 insertions, 2 deletions
diff --git a/tools/js-optimizer.js b/tools/js-optimizer.js
index 7e1d374f..5a202de9 100644
--- a/tools/js-optimizer.js
+++ b/tools/js-optimizer.js
@@ -1850,6 +1850,13 @@ var NODES_WITHOUT_ELIMINATION_SIDE_EFFECTS = set('name', 'num', 'string', 'binar
var IGNORABLE_ELIMINATOR_SCAN_NODES = set('num', 'toplevel', 'string', 'break', 'continue', 'dot'); // dot can only be STRING_TABLE.*
var ABORTING_ELIMINATOR_SCAN_NODES = set('new', 'object', 'function', 'defun', 'for', 'while', 'array', 'throw'); // we could handle some of these, TODO, but nontrivial (e.g. for while, the condition is hit multiple times after the body)
+function isTempDoublePtrAccess(node) { // these are used in bitcasts; they are not really affecting memory, and should cause no invalidation
+ assert(node[0] == 'sub');
+ return (node[2][0] == 'name' && node[2][1] == 'tempDoublePtr') ||
+ (node[2][0] == 'binary' && ((node[2][2][0] == 'name' && node[2][2][1] == 'tempDoublePtr') ||
+ (node[2][3][0] == 'name' && node[2][3][1] == 'tempDoublePtr')));
+}
+
function eliminate(ast, memSafe) {
// Find variables that have a single use, and if they can be eliminated, do so
traverseGeneratedFunctions(ast, function(func, type) {
@@ -2134,7 +2141,7 @@ function eliminate(ast, memSafe) {
if (allowTracking) track(name, node[3], node);
}
} else if (target[0] == 'sub') {
- if (!memoryInvalidated) {
+ if (!isTempDoublePtrAccess(target) && !memoryInvalidated) {
invalidateMemory();
memoryInvalidated = true;
}
@@ -2142,7 +2149,8 @@ function eliminate(ast, memSafe) {
} else if (type == 'sub') {
traverseInOrder(node[1], false, !memSafe); // evaluate inner
traverseInOrder(node[2]); // evaluate outer
- if (!ignoreSub) { // ignoreSub means we are a write (happening later), not a read
+ // ignoreSub means we are a write (happening later), not a read
+ if (!ignoreSub && !isTempDoublePtrAccess(node)) {
// do the memory access
if (!callsInvalidated) {
invalidateCalls();