Commit b12669b0 authored by verwaest's avatar verwaest Committed by Commit bot

Initialize num_heap_slots_ to MIN_CONTEXT_SLOTS in SetDefaults, make already_resolved_ debug-only

Variable alloction and block finalization may reset num_heap_slots_ to 0 later.

BUG=v8:5209

Review-Url: https://codereview.chromium.org/2257473002
Cr-Commit-Position: refs/heads/master@{#38687}
parent 058a7ee0
...@@ -80,8 +80,7 @@ Scope::Scope(Zone* zone, Scope* outer_scope, ScopeType scope_type) ...@@ -80,8 +80,7 @@ Scope::Scope(Zone* zone, Scope* outer_scope, ScopeType scope_type)
outer_scope_(outer_scope), outer_scope_(outer_scope),
variables_(zone), variables_(zone),
decls_(4, zone), decls_(4, zone),
scope_type_(scope_type), scope_type_(scope_type) {
already_resolved_(false) {
SetDefaults(); SetDefaults();
if (outer_scope == nullptr) { if (outer_scope == nullptr) {
// If the outer scope is null, this cannot be a with scope. The outermost // If the outer scope is null, this cannot be a with scope. The outermost
...@@ -125,19 +124,19 @@ Scope::Scope(Zone* zone, Scope* inner_scope, ScopeType scope_type, ...@@ -125,19 +124,19 @@ Scope::Scope(Zone* zone, Scope* inner_scope, ScopeType scope_type,
variables_(zone), variables_(zone),
decls_(0, zone), decls_(0, zone),
scope_info_(scope_info), scope_info_(scope_info),
scope_type_(scope_type), scope_type_(scope_type) {
already_resolved_(true) {
SetDefaults(); SetDefaults();
#ifdef DEBUG
already_resolved_ = true;
#endif
if (scope_type == WITH_SCOPE) { if (scope_type == WITH_SCOPE) {
DCHECK(scope_info.is_null()); DCHECK(scope_info.is_null());
// Ensure at least MIN_CONTEXT_SLOTS to indicate a materialized context.
num_heap_slots_ = Context::MIN_CONTEXT_SLOTS;
} else { } else {
scope_calls_eval_ = scope_info->CallsEval(); scope_calls_eval_ = scope_info->CallsEval();
language_mode_ = scope_info->language_mode(); language_mode_ = scope_info->language_mode();
num_heap_slots_ = scope_info->ContextLength(); num_heap_slots_ = scope_info->ContextLength();
DCHECK_LE(Context::MIN_CONTEXT_SLOTS, num_heap_slots_);
} }
DCHECK_LE(Context::MIN_CONTEXT_SLOTS, num_heap_slots_);
if (inner_scope != nullptr) AddInnerScope(inner_scope); if (inner_scope != nullptr) AddInnerScope(inner_scope);
} }
...@@ -159,11 +158,12 @@ Scope::Scope(Zone* zone, Scope* inner_scope, ...@@ -159,11 +158,12 @@ Scope::Scope(Zone* zone, Scope* inner_scope,
outer_scope_(nullptr), outer_scope_(nullptr),
variables_(zone), variables_(zone),
decls_(0, zone), decls_(0, zone),
scope_type_(CATCH_SCOPE), scope_type_(CATCH_SCOPE) {
already_resolved_(true) {
SetDefaults(); SetDefaults();
#ifdef DEBUG
already_resolved_ = true;
#endif
if (inner_scope != nullptr) AddInnerScope(inner_scope); if (inner_scope != nullptr) AddInnerScope(inner_scope);
num_heap_slots_ = Context::MIN_CONTEXT_SLOTS;
Variable* variable = Variable* variable =
variables_.Declare(zone, this, catch_variable_name, VAR, Variable::NORMAL, variables_.Declare(zone, this, catch_variable_name, VAR, Variable::NORMAL,
kCreatedInitialized); kCreatedInitialized);
...@@ -187,6 +187,7 @@ void DeclarationScope::SetDefaults() { ...@@ -187,6 +187,7 @@ void DeclarationScope::SetDefaults() {
void Scope::SetDefaults() { void Scope::SetDefaults() {
#ifdef DEBUG #ifdef DEBUG
scope_name_ = nullptr; scope_name_ = nullptr;
already_resolved_ = false;
#endif #endif
inner_scope_ = nullptr; inner_scope_ = nullptr;
sibling_ = nullptr; sibling_ = nullptr;
...@@ -197,7 +198,7 @@ void Scope::SetDefaults() { ...@@ -197,7 +198,7 @@ void Scope::SetDefaults() {
end_position_ = kNoSourcePosition; end_position_ = kNoSourcePosition;
num_stack_slots_ = 0; num_stack_slots_ = 0;
num_heap_slots_ = 0; num_heap_slots_ = Context::MIN_CONTEXT_SLOTS;
num_global_slots_ = 0; num_global_slots_ = 0;
language_mode_ = SLOPPY; language_mode_ = SLOPPY;
...@@ -379,7 +380,7 @@ void Scope::Analyze(ParseInfo* info) { ...@@ -379,7 +380,7 @@ void Scope::Analyze(ParseInfo* info) {
// 3) a function/eval in a scope that was already resolved. // 3) a function/eval in a scope that was already resolved.
DCHECK(scope->scope_type() == SCRIPT_SCOPE || DCHECK(scope->scope_type() == SCRIPT_SCOPE ||
scope->outer_scope()->scope_type() == SCRIPT_SCOPE || scope->outer_scope()->scope_type() == SCRIPT_SCOPE ||
scope->outer_scope()->already_resolved()); scope->outer_scope()->already_resolved_);
// Allocate the variables. // Allocate the variables.
{ {
...@@ -398,7 +399,7 @@ void Scope::Analyze(ParseInfo* info) { ...@@ -398,7 +399,7 @@ void Scope::Analyze(ParseInfo* info) {
} }
void DeclarationScope::DeclareThis(AstValueFactory* ast_value_factory) { void DeclarationScope::DeclareThis(AstValueFactory* ast_value_factory) {
DCHECK(!already_resolved()); DCHECK(!already_resolved_);
DCHECK(is_declaration_scope()); DCHECK(is_declaration_scope());
DCHECK(has_this_declaration()); DCHECK(has_this_declaration());
...@@ -480,7 +481,8 @@ Scope* Scope::FinalizeBlockScope() { ...@@ -480,7 +481,8 @@ Scope* Scope::FinalizeBlockScope() {
} }
PropagateUsageFlagsToScope(outer_scope_); PropagateUsageFlagsToScope(outer_scope_);
// This block does not need a context.
num_heap_slots_ = 0;
return NULL; return NULL;
} }
...@@ -533,9 +535,9 @@ void Scope::Snapshot::Reparent(DeclarationScope* new_parent) const { ...@@ -533,9 +535,9 @@ void Scope::Snapshot::Reparent(DeclarationScope* new_parent) const {
void Scope::ReplaceOuterScope(Scope* outer) { void Scope::ReplaceOuterScope(Scope* outer) {
DCHECK_NOT_NULL(outer); DCHECK_NOT_NULL(outer);
DCHECK_NOT_NULL(outer_scope_); DCHECK_NOT_NULL(outer_scope_);
DCHECK(!already_resolved()); DCHECK(!already_resolved_);
DCHECK(!outer->already_resolved()); DCHECK(!outer->already_resolved_);
DCHECK(!outer_scope_->already_resolved()); DCHECK(!outer_scope_->already_resolved_);
outer_scope_->RemoveInnerScope(this); outer_scope_->RemoveInnerScope(this);
outer->AddInnerScope(this); outer->AddInnerScope(this);
outer_scope_ = outer; outer_scope_ = outer;
...@@ -544,8 +546,8 @@ void Scope::ReplaceOuterScope(Scope* outer) { ...@@ -544,8 +546,8 @@ void Scope::ReplaceOuterScope(Scope* outer) {
void Scope::PropagateUsageFlagsToScope(Scope* other) { void Scope::PropagateUsageFlagsToScope(Scope* other) {
DCHECK_NOT_NULL(other); DCHECK_NOT_NULL(other);
DCHECK(!already_resolved()); DCHECK(!already_resolved_);
DCHECK(!other->already_resolved()); DCHECK(!other->already_resolved_);
if (uses_super_property()) other->RecordSuperPropertyUsage(); if (uses_super_property()) other->RecordSuperPropertyUsage();
if (calls_eval()) other->RecordEvalCall(); if (calls_eval()) other->RecordEvalCall();
} }
...@@ -639,7 +641,7 @@ Variable* Scope::Lookup(const AstRawString* name) { ...@@ -639,7 +641,7 @@ Variable* Scope::Lookup(const AstRawString* name) {
Variable* DeclarationScope::DeclareParameter( Variable* DeclarationScope::DeclareParameter(
const AstRawString* name, VariableMode mode, bool is_optional, bool is_rest, const AstRawString* name, VariableMode mode, bool is_optional, bool is_rest,
bool* is_duplicate, AstValueFactory* ast_value_factory) { bool* is_duplicate, AstValueFactory* ast_value_factory) {
DCHECK(!already_resolved()); DCHECK(!already_resolved_);
DCHECK(is_function_scope()); DCHECK(is_function_scope());
DCHECK(!is_optional || !is_rest); DCHECK(!is_optional || !is_rest);
Variable* var; Variable* var;
...@@ -669,7 +671,7 @@ Variable* DeclarationScope::DeclareParameter( ...@@ -669,7 +671,7 @@ Variable* DeclarationScope::DeclareParameter(
Variable* Scope::DeclareLocal(const AstRawString* name, VariableMode mode, Variable* Scope::DeclareLocal(const AstRawString* name, VariableMode mode,
InitializationFlag init_flag, Variable::Kind kind, InitializationFlag init_flag, Variable::Kind kind,
MaybeAssignedFlag maybe_assigned_flag) { MaybeAssignedFlag maybe_assigned_flag) {
DCHECK(!already_resolved()); DCHECK(!already_resolved_);
// This function handles VAR, LET, and CONST modes. DYNAMIC variables are // This function handles VAR, LET, and CONST modes. DYNAMIC variables are
// introduced during variable allocation, and TEMPORARY variables are // introduced during variable allocation, and TEMPORARY variables are
// allocated via NewTemporary(). // allocated via NewTemporary().
...@@ -718,7 +720,7 @@ Variable* Scope::NewTemporary(const AstRawString* name) { ...@@ -718,7 +720,7 @@ Variable* Scope::NewTemporary(const AstRawString* name) {
} }
void Scope::AddDeclaration(Declaration* declaration) { void Scope::AddDeclaration(Declaration* declaration) {
DCHECK(!already_resolved()); DCHECK(!already_resolved_);
decls_.Add(declaration, zone()); decls_.Add(declaration, zone());
} }
...@@ -1299,7 +1301,8 @@ Variable* Scope::LookupRecursive(VariableProxy* proxy, ...@@ -1299,7 +1301,8 @@ Variable* Scope::LookupRecursive(VariableProxy* proxy,
// scope, the associated variable has to be marked as potentially being // scope, the associated variable has to be marked as potentially being
// accessed from inside of an inner with scope (the property may not be in // accessed from inside of an inner with scope (the property may not be in
// the 'with' object). // the 'with' object).
if (var != nullptr && !already_resolved()) { if (var != nullptr && var->IsUnallocated()) {
DCHECK(!already_resolved_);
var->set_is_used(); var->set_is_used();
var->ForceContextAllocation(); var->ForceContextAllocation();
if (proxy->is_assigned()) var->set_maybe_assigned(); if (proxy->is_assigned()) var->set_maybe_assigned();
...@@ -1703,19 +1706,16 @@ void DeclarationScope::AllocateModuleVariables() { ...@@ -1703,19 +1706,16 @@ void DeclarationScope::AllocateModuleVariables() {
} }
void Scope::AllocateVariablesRecursively() { void Scope::AllocateVariablesRecursively() {
if (!already_resolved()) { DCHECK(!already_resolved_);
num_stack_slots_ = 0; DCHECK_EQ(0, num_stack_slots_);
}
// Allocate variables for inner scopes. // Allocate variables for inner scopes.
for (Scope* scope = inner_scope_; scope != nullptr; scope = scope->sibling_) { for (Scope* scope = inner_scope_; scope != nullptr; scope = scope->sibling_) {
scope->AllocateVariablesRecursively(); scope->AllocateVariablesRecursively();
} }
// If scope is already resolved, we still need to allocate DCHECK(!already_resolved_);
// variables in inner scopes which might not have been resolved yet. DCHECK_EQ(Context::MIN_CONTEXT_SLOTS, num_heap_slots_);
if (already_resolved()) return;
// The number of slots required for variables.
num_heap_slots_ = Context::MIN_CONTEXT_SLOTS;
// Allocate variables for this scope. // Allocate variables for this scope.
// Parameters must be allocated first, if any. // Parameters must be allocated first, if any.
......
...@@ -166,7 +166,7 @@ class Scope: public ZoneObject { ...@@ -166,7 +166,7 @@ class Scope: public ZoneObject {
// Note that we must not share the unresolved variables with // Note that we must not share the unresolved variables with
// the same name because they may be removed selectively via // the same name because they may be removed selectively via
// RemoveUnresolved(). // RemoveUnresolved().
DCHECK(!already_resolved()); DCHECK(!already_resolved_);
DCHECK_EQ(factory->zone(), zone()); DCHECK_EQ(factory->zone(), zone());
VariableProxy* proxy = VariableProxy* proxy =
factory->NewVariableProxy(name, kind, start_position, end_position); factory->NewVariableProxy(name, kind, start_position, end_position);
...@@ -176,7 +176,7 @@ class Scope: public ZoneObject { ...@@ -176,7 +176,7 @@ class Scope: public ZoneObject {
} }
void AddUnresolved(VariableProxy* proxy) { void AddUnresolved(VariableProxy* proxy) {
DCHECK(!already_resolved()); DCHECK(!already_resolved_);
DCHECK(!proxy->is_resolved()); DCHECK(!proxy->is_resolved());
proxy->set_next_unresolved(unresolved_); proxy->set_next_unresolved(unresolved_);
unresolved_ = proxy; unresolved_ = proxy;
...@@ -289,7 +289,7 @@ class Scope: public ZoneObject { ...@@ -289,7 +289,7 @@ class Scope: public ZoneObject {
// In some cases we want to force context allocation for a whole scope. // In some cases we want to force context allocation for a whole scope.
void ForceContextAllocation() { void ForceContextAllocation() {
DCHECK(!already_resolved()); DCHECK(!already_resolved_);
force_context_allocation_ = true; force_context_allocation_ = true;
} }
bool has_forced_context_allocation() const { bool has_forced_context_allocation() const {
...@@ -471,6 +471,10 @@ class Scope: public ZoneObject { ...@@ -471,6 +471,10 @@ class Scope: public ZoneObject {
// Debugging support. // Debugging support.
#ifdef DEBUG #ifdef DEBUG
const AstRawString* scope_name_; const AstRawString* scope_name_;
// True if it doesn't need scope resolution (e.g., if the scope was
// constructed based on a serialized scope info or a catch context).
bool already_resolved_ : 1;
#endif #endif
// Source positions. // Source positions.
...@@ -515,11 +519,6 @@ class Scope: public ZoneObject { ...@@ -515,11 +519,6 @@ class Scope: public ZoneObject {
bool force_eager_compilation_ : 1; bool force_eager_compilation_ : 1;
bool force_context_allocation_ : 1; bool force_context_allocation_ : 1;
// True if it doesn't need scope resolution (e.g., if the scope was
// constructed based on a serialized scope info or a catch context).
bool already_resolved_ : 1;
bool already_resolved() { return already_resolved_; }
// True if it holds 'var' declarations. // True if it holds 'var' declarations.
bool is_declaration_scope_ : 1; bool is_declaration_scope_ : 1;
...@@ -803,7 +802,7 @@ class DeclarationScope : public Scope { ...@@ -803,7 +802,7 @@ class DeclarationScope : public Scope {
// adjusting the scope of temporaries used when desugaring parameter // adjusting the scope of temporaries used when desugaring parameter
// initializers. // initializers.
void AddTemporary(Variable* var) { void AddTemporary(Variable* var) {
DCHECK(!already_resolved()); DCHECK(!already_resolved_);
// Temporaries are only placed in ClosureScopes. // Temporaries are only placed in ClosureScopes.
DCHECK_EQ(GetClosureScope(), this); DCHECK_EQ(GetClosureScope(), this);
temps_.Add(var, zone()); temps_.Add(var, zone());
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment