From ea529d135487e725f2f49684270fbb46af45ceef Mon Sep 17 00:00:00 2001 From: Attila Szegedi Date: Wed, 11 Mar 2015 11:03:21 +0100 Subject: [PATCH] 8074484: More agressive value discarding Reviewed-by: hannesw, lagergren --- .../internal/codegen/CodeGenerator.java | 90 +++++++++++++------ .../codegen/CodeGeneratorLexicalContext.java | 25 ++++-- 2 files changed, 79 insertions(+), 36 deletions(-) diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/CodeGenerator.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/CodeGenerator.java index 8428dc99f12..fd627a6f1fb 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/CodeGenerator.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/CodeGenerator.java @@ -836,7 +836,7 @@ final class CodeGenerator extends NodeOperatorVisitor(new LexicalContext()) { @Override public boolean enterIdentNode(final IdentNode identNode) { @@ -1192,7 +1192,7 @@ final class CodeGenerator extends NodeOperatorVisitor methodEmitters = new ArrayDeque<>(); - /** The discard stack - whenever we enter a discard node we keep track of its return value status - - * i.e. should we keep it or throw it away */ - private final Deque discard = new ArrayDeque<>(); + /** The discard stack - whenever we evaluate an expression that will be discarded, we push it on this stack. Various + * implementations of expression code emitter can choose to emit code that'll discard the expression themselves, or + * ignore it in which case CodeGenerator.loadAndDiscard() will explicitly emit a pop instruction. */ + private final Deque discard = new ArrayDeque<>(); + private final Deque>> unwarrantedOptimismHandlers = new ArrayDeque<>(); private final Deque slotTypesDescriptors = new ArrayDeque<>(); @@ -270,16 +273,20 @@ final class CodeGeneratorLexicalContext extends LexicalContext { } } - void pushDiscard(final Node node) { - discard.push(node); + void pushDiscard(final Expression expr) { + discard.push(expr); } - Node popDiscard() { - return discard.pop(); + boolean popDiscardIfCurrent(final Expression expr) { + if (isCurrentDiscard(expr)) { + discard.pop(); + return true; + } + return false; } - Node getCurrentDiscard() { - return discard.peek(); + boolean isCurrentDiscard(final Expression expr) { + return discard.peek() == expr; } int quickSlot(final Type type) {