Commit e3905047 authored by bmeurer's avatar bmeurer Committed by Commit bot

[turbofan] Initial support for inline allocations of arrays.

Add support for using inline allocations for arrays in lowering of
JSCreateArray when target equals new.target.  Currently we are only
concerend with the straight-forward Array() and Array(length) cases,
but at some point TurboFan should also be able to support the more
complex initializing cases.

R=mvstanton@chromium.org
BUG=v8:4470
LOG=n

Review URL: https://codereview.chromium.org/1465203002

Cr-Commit-Position: refs/heads/master@{#32191}
parent d705e1ab
...@@ -275,12 +275,20 @@ FieldAccess AccessBuilder::ForSharedFunctionInfoTypeFeedbackVector() { ...@@ -275,12 +275,20 @@ FieldAccess AccessBuilder::ForSharedFunctionInfoTypeFeedbackVector() {
// static // static
ElementAccess AccessBuilder::ForFixedArrayElement() { ElementAccess AccessBuilder::ForFixedArrayElement() {
ElementAccess access = {kTaggedBase, FixedArray::kHeaderSize, Type::Any(), ElementAccess access = {kTaggedBase, FixedArray::kHeaderSize, Type::Tagged(),
kMachAnyTagged}; kMachAnyTagged};
return access; return access;
} }
// static
ElementAccess AccessBuilder::ForFixedDoubleArrayElement() {
ElementAccess access = {kTaggedBase, FixedDoubleArray::kHeaderSize,
TypeCache::Get().kFloat64, kMachFloat64};
return access;
}
// static // static
ElementAccess AccessBuilder::ForTypedArrayElement(ExternalArrayType type, ElementAccess AccessBuilder::ForTypedArrayElement(ExternalArrayType type,
bool is_external) { bool is_external) {
......
...@@ -108,6 +108,9 @@ class AccessBuilder final : public AllStatic { ...@@ -108,6 +108,9 @@ class AccessBuilder final : public AllStatic {
// Provides access to FixedArray elements. // Provides access to FixedArray elements.
static ElementAccess ForFixedArrayElement(); static ElementAccess ForFixedArrayElement();
// Provides access to FixedDoubleArray elements.
static ElementAccess ForFixedDoubleArrayElement();
// Provides access to Fixed{type}TypedArray and External{type}Array elements. // Provides access to Fixed{type}TypedArray and External{type}Array elements.
static ElementAccess ForTypedArrayElement(ExternalArrayType type, static ElementAccess ForTypedArrayElement(ExternalArrayType type,
bool is_external); bool is_external);
......
This diff is collapsed.
...@@ -15,6 +15,7 @@ namespace internal { ...@@ -15,6 +15,7 @@ namespace internal {
// Forward declarations. // Forward declarations.
class CompilationDependencies; class CompilationDependencies;
class Factory; class Factory;
class TypeCache;
namespace compiler { namespace compiler {
...@@ -86,12 +87,17 @@ class JSTypedLowering final : public AdvancedReducer { ...@@ -86,12 +87,17 @@ class JSTypedLowering final : public AdvancedReducer {
Reduction ReduceInt32Binop(Node* node, const Operator* intOp); Reduction ReduceInt32Binop(Node* node, const Operator* intOp);
Reduction ReduceUI32Shift(Node* node, Signedness left_signedness, Reduction ReduceUI32Shift(Node* node, Signedness left_signedness,
const Operator* shift_op); const Operator* shift_op);
Reduction ReduceNewArray(Node* node, Node* length, int capacity,
Handle<AllocationSite> site);
Node* Word32Shl(Node* const lhs, int32_t const rhs); Node* Word32Shl(Node* const lhs, int32_t const rhs);
Node* AllocateArguments(Node* effect, Node* control, Node* frame_state); Node* AllocateArguments(Node* effect, Node* control, Node* frame_state);
Node* AllocateAliasedArguments(Node* effect, Node* control, Node* frame_state, Node* AllocateAliasedArguments(Node* effect, Node* control, Node* frame_state,
Node* context, Handle<SharedFunctionInfo>, Node* context, Handle<SharedFunctionInfo>,
bool* has_aliased_arguments); bool* has_aliased_arguments);
Node* AllocateElements(Node* effect, Node* control,
ElementsKind elements_kind, int capacity,
PretenureFlag pretenure);
Factory* factory() const; Factory* factory() const;
Graph* graph() const; Graph* graph() const;
...@@ -112,6 +118,7 @@ class JSTypedLowering final : public AdvancedReducer { ...@@ -112,6 +118,7 @@ class JSTypedLowering final : public AdvancedReducer {
Flags flags_; Flags flags_;
JSGraph* jsgraph_; JSGraph* jsgraph_;
Type* shifted_int32_ranges_[4]; Type* shifted_int32_ranges_[4];
TypeCache const& type_cache_;
}; };
DEFINE_OPERATORS_FOR_FLAGS(JSTypedLowering::Flags) DEFINE_OPERATORS_FOR_FLAGS(JSTypedLowering::Flags)
......
...@@ -94,6 +94,10 @@ class TypeCache final { ...@@ -94,6 +94,10 @@ class TypeCache final {
Type* const kStringLengthType = Type* const kStringLengthType =
CreateNative(CreateRange(0.0, String::kMaxLength), Type::TaggedSigned()); CreateNative(CreateRange(0.0, String::kMaxLength), Type::TaggedSigned());
// When initializing arrays, we'll unfold the loop if the number of
// elements is known to be of this type.
Type* const kElementLoopUnrollType = CreateRange(0.0, 16.0);
#define TYPED_ARRAY(TypeName, type_name, TYPE_NAME, ctype, size) \ #define TYPED_ARRAY(TypeName, type_name, TYPE_NAME, ctype, size) \
Type* const k##TypeName##Array = CreateArray(k##TypeName); Type* const k##TypeName##Array = CreateArray(k##TypeName);
TYPED_ARRAYS(TYPED_ARRAY) TYPED_ARRAYS(TYPED_ARRAY)
......
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