a0c3797461
TBR=bmeurer@chromium.org,leszeks@chromium.org Bug: v8:9247 Change-Id: I8d14d0192ea8c705f8274e8e61a162531826edb6 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1624220 Reviewed-by: Yang Guo <yangguo@chromium.org> Reviewed-by: Hannes Payer <hpayer@chromium.org> Reviewed-by: Andreas Haas <ahaas@chromium.org> Cr-Commit-Position: refs/heads/master@{#61769}
139 lines
5.4 KiB
C++
139 lines
5.4 KiB
C++
// Copyright 2015 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef V8_COMPILER_COMPILATION_DEPENDENCIES_H_
|
|
#define V8_COMPILER_COMPILATION_DEPENDENCIES_H_
|
|
|
|
#include "src/compiler/js-heap-broker.h"
|
|
#include "src/objects/objects.h"
|
|
#include "src/zone/zone-containers.h"
|
|
|
|
namespace v8 {
|
|
namespace internal {
|
|
namespace compiler {
|
|
|
|
class SlackTrackingPrediction {
|
|
public:
|
|
SlackTrackingPrediction(MapRef initial_map, int instance_size);
|
|
|
|
int inobject_property_count() const { return inobject_property_count_; }
|
|
int instance_size() const { return instance_size_; }
|
|
|
|
private:
|
|
int instance_size_;
|
|
int inobject_property_count_;
|
|
};
|
|
|
|
// Collects and installs dependencies of the code that is being generated.
|
|
class V8_EXPORT_PRIVATE CompilationDependencies : public ZoneObject {
|
|
public:
|
|
CompilationDependencies(JSHeapBroker* broker, Zone* zone);
|
|
|
|
V8_WARN_UNUSED_RESULT bool Commit(Handle<Code> code);
|
|
|
|
// Return the initial map of {function} and record the assumption that it
|
|
// stays the initial map.
|
|
MapRef DependOnInitialMap(const JSFunctionRef& function);
|
|
|
|
// Return the "prototype" property of the given function and record the
|
|
// assumption that it doesn't change.
|
|
ObjectRef DependOnPrototypeProperty(const JSFunctionRef& function);
|
|
|
|
// Record the assumption that {map} stays stable.
|
|
void DependOnStableMap(const MapRef& map);
|
|
|
|
// Record the assumption that {target_map} can be transitioned to, i.e., that
|
|
// it does not become deprecated.
|
|
void DependOnTransition(const MapRef& target_map);
|
|
|
|
// Return the pretenure mode of {site} and record the assumption that it does
|
|
// not change.
|
|
AllocationType DependOnPretenureMode(const AllocationSiteRef& site);
|
|
|
|
// Record the assumption that the field representation of a field does not
|
|
// change. The field is identified by the arguments.
|
|
void DependOnFieldRepresentation(const MapRef& map, int descriptor);
|
|
|
|
// Record the assumption that the field type of a field does not change. The
|
|
// field is identified by the arguments.
|
|
void DependOnFieldType(const MapRef& map, int descriptor);
|
|
|
|
// Return a field's constness and, if kConst, record the assumption that it
|
|
// remains kConst. The field is identified by the arguments.
|
|
//
|
|
// For arrays, arguments objects and value wrappers, only consider the field
|
|
// kConst if the map is stable (and register stability dependency in that
|
|
// case). This is to ensure that fast elements kind transitions cannot be
|
|
// used to mutate fields without deoptimization of the dependent code.
|
|
PropertyConstness DependOnFieldConstness(const MapRef& map, int descriptor);
|
|
|
|
// Record the assumption that neither {cell}'s {CellType} changes, nor the
|
|
// {IsReadOnly()} flag of {cell}'s {PropertyDetails}.
|
|
void DependOnGlobalProperty(const PropertyCellRef& cell);
|
|
|
|
// Return the validity of the given protector and, if true, record the
|
|
// assumption that the protector remains valid.
|
|
bool DependOnProtector(const PropertyCellRef& cell);
|
|
|
|
// Convenience wrappers around {DependOnProtector}.
|
|
bool DependOnArrayBufferDetachingProtector();
|
|
bool DependOnArrayIteratorProtector();
|
|
bool DependOnArraySpeciesProtector();
|
|
bool DependOnNoElementsProtector();
|
|
bool DependOnPromiseHookProtector();
|
|
bool DependOnPromiseSpeciesProtector();
|
|
bool DependOnPromiseThenProtector();
|
|
|
|
// Record the assumption that {site}'s {ElementsKind} doesn't change.
|
|
void DependOnElementsKind(const AllocationSiteRef& site);
|
|
|
|
// For each given map, depend on the stability of (the maps of) all prototypes
|
|
// up to (and including) the {last_prototype}.
|
|
template <class MapContainer>
|
|
void DependOnStablePrototypeChains(
|
|
MapContainer const& receiver_maps, WhereToStart start,
|
|
base::Optional<JSObjectRef> last_prototype =
|
|
base::Optional<JSObjectRef>());
|
|
|
|
// Like DependOnElementsKind but also applies to all nested allocation sites.
|
|
void DependOnElementsKinds(const AllocationSiteRef& site);
|
|
|
|
// Predict the final instance size for {function}'s initial map and record
|
|
// the assumption that this prediction is correct. In addition, register
|
|
// the initial map dependency. This method returns the {function}'s the
|
|
// predicted minimum slack instance size count (wrapped together with
|
|
// the corresponding in-object property count for convenience).
|
|
SlackTrackingPrediction DependOnInitialMapInstanceSizePrediction(
|
|
const JSFunctionRef& function);
|
|
|
|
// The methods below allow for gathering dependencies without actually
|
|
// recording them. They can be recorded at a later time (or they can be
|
|
// ignored). For example,
|
|
// DependOnTransition(map);
|
|
// is equivalent to:
|
|
// RecordDependency(TransitionDependencyOffTheRecord(map));
|
|
class Dependency;
|
|
void RecordDependency(Dependency const* dependency);
|
|
Dependency const* TransitionDependencyOffTheRecord(
|
|
const MapRef& target_map) const;
|
|
Dependency const* FieldRepresentationDependencyOffTheRecord(
|
|
const MapRef& map, int descriptor) const;
|
|
Dependency const* FieldTypeDependencyOffTheRecord(const MapRef& map,
|
|
int descriptor) const;
|
|
|
|
// Exposed only for testing purposes.
|
|
bool AreValid() const;
|
|
|
|
private:
|
|
Zone* const zone_;
|
|
JSHeapBroker* const broker_;
|
|
ZoneForwardList<Dependency const*> dependencies_;
|
|
};
|
|
|
|
} // namespace compiler
|
|
} // namespace internal
|
|
} // namespace v8
|
|
|
|
#endif // V8_COMPILER_COMPILATION_DEPENDENCIES_H_
|