OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/code-factory.h" | 5 #include "src/code-factory.h" |
6 #include "src/compiler/access-builder.h" | 6 #include "src/compiler/access-builder.h" |
7 #include "src/compiler/js-graph.h" | 7 #include "src/compiler/js-graph.h" |
8 #include "src/compiler/js-typed-lowering.h" | 8 #include "src/compiler/js-typed-lowering.h" |
9 #include "src/compiler/linkage.h" | 9 #include "src/compiler/linkage.h" |
10 #include "src/compiler/node-matchers.h" | 10 #include "src/compiler/node-matchers.h" |
(...skipping 814 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
825 HeapObjectMatcher mbase(base); | 825 HeapObjectMatcher mbase(base); |
826 if (mbase.HasValue() && mbase.Value().handle()->IsJSTypedArray()) { | 826 if (mbase.HasValue() && mbase.Value().handle()->IsJSTypedArray()) { |
827 Handle<JSTypedArray> const array = | 827 Handle<JSTypedArray> const array = |
828 Handle<JSTypedArray>::cast(mbase.Value().handle()); | 828 Handle<JSTypedArray>::cast(mbase.Value().handle()); |
829 if (!array->GetBuffer()->was_neutered()) { | 829 if (!array->GetBuffer()->was_neutered()) { |
830 array->GetBuffer()->set_is_neuterable(false); | 830 array->GetBuffer()->set_is_neuterable(false); |
831 BufferAccess const access(array->type()); | 831 BufferAccess const access(array->type()); |
832 size_t const k = ElementSizeLog2Of(access.machine_type()); | 832 size_t const k = ElementSizeLog2Of(access.machine_type()); |
833 double const byte_length = array->byte_length()->Number(); | 833 double const byte_length = array->byte_length()->Number(); |
834 CHECK_LT(k, arraysize(shifted_int32_ranges_)); | 834 CHECK_LT(k, arraysize(shifted_int32_ranges_)); |
835 if (key_type->Is(shifted_int32_ranges_[k]) && byte_length <= kMaxInt) { | 835 if (IsExternalArrayElementsKind(array->map()->elements_kind()) && |
| 836 key_type->Is(shifted_int32_ranges_[k]) && byte_length <= kMaxInt) { |
836 // JSLoadProperty(typed-array, int32) | 837 // JSLoadProperty(typed-array, int32) |
837 Handle<FixedTypedArrayBase> elements = | 838 Handle<ExternalArray> elements = |
838 Handle<FixedTypedArrayBase>::cast(handle(array->elements())); | 839 Handle<ExternalArray>::cast(handle(array->elements())); |
839 Node* buffer = jsgraph()->PointerConstant(elements->external_pointer()); | 840 Node* buffer = jsgraph()->PointerConstant(elements->external_pointer()); |
840 Node* length = jsgraph()->Constant(byte_length); | 841 Node* length = jsgraph()->Constant(byte_length); |
841 Node* effect = NodeProperties::GetEffectInput(node); | 842 Node* effect = NodeProperties::GetEffectInput(node); |
842 Node* control = NodeProperties::GetControlInput(node); | 843 Node* control = NodeProperties::GetControlInput(node); |
843 // Check if we can avoid the bounds check. | 844 // Check if we can avoid the bounds check. |
844 if (key_type->Min() >= 0 && key_type->Max() < array->length_value()) { | 845 if (key_type->Min() >= 0 && key_type->Max() < array->length_value()) { |
845 Node* load = graph()->NewNode( | 846 Node* load = graph()->NewNode( |
846 simplified()->LoadElement( | 847 simplified()->LoadElement( |
847 AccessBuilder::ForTypedArrayElement(array->type(), true)), | 848 AccessBuilder::ForTypedArrayElement(array->type(), true)), |
848 buffer, key, effect, control); | 849 buffer, key, effect, control); |
(...skipping 22 matching lines...) Expand all Loading... |
871 HeapObjectMatcher mbase(base); | 872 HeapObjectMatcher mbase(base); |
872 if (mbase.HasValue() && mbase.Value().handle()->IsJSTypedArray()) { | 873 if (mbase.HasValue() && mbase.Value().handle()->IsJSTypedArray()) { |
873 Handle<JSTypedArray> const array = | 874 Handle<JSTypedArray> const array = |
874 Handle<JSTypedArray>::cast(mbase.Value().handle()); | 875 Handle<JSTypedArray>::cast(mbase.Value().handle()); |
875 if (!array->GetBuffer()->was_neutered()) { | 876 if (!array->GetBuffer()->was_neutered()) { |
876 array->GetBuffer()->set_is_neuterable(false); | 877 array->GetBuffer()->set_is_neuterable(false); |
877 BufferAccess const access(array->type()); | 878 BufferAccess const access(array->type()); |
878 size_t const k = ElementSizeLog2Of(access.machine_type()); | 879 size_t const k = ElementSizeLog2Of(access.machine_type()); |
879 double const byte_length = array->byte_length()->Number(); | 880 double const byte_length = array->byte_length()->Number(); |
880 CHECK_LT(k, arraysize(shifted_int32_ranges_)); | 881 CHECK_LT(k, arraysize(shifted_int32_ranges_)); |
881 if (access.external_array_type() != kExternalUint8ClampedArray && | 882 if (IsExternalArrayElementsKind(array->map()->elements_kind()) && |
| 883 access.external_array_type() != kExternalUint8ClampedArray && |
882 key_type->Is(shifted_int32_ranges_[k]) && byte_length <= kMaxInt) { | 884 key_type->Is(shifted_int32_ranges_[k]) && byte_length <= kMaxInt) { |
883 // JSLoadProperty(typed-array, int32) | 885 // JSLoadProperty(typed-array, int32) |
884 Handle<FixedTypedArrayBase> elements = | 886 Handle<ExternalArray> elements = |
885 Handle<FixedTypedArrayBase>::cast(handle(array->elements())); | 887 Handle<ExternalArray>::cast(handle(array->elements())); |
886 Node* buffer = jsgraph()->PointerConstant(elements->external_pointer()); | 888 Node* buffer = jsgraph()->PointerConstant(elements->external_pointer()); |
887 Node* length = jsgraph()->Constant(byte_length); | 889 Node* length = jsgraph()->Constant(byte_length); |
888 Node* context = NodeProperties::GetContextInput(node); | 890 Node* context = NodeProperties::GetContextInput(node); |
889 Node* effect = NodeProperties::GetEffectInput(node); | 891 Node* effect = NodeProperties::GetEffectInput(node); |
890 Node* control = NodeProperties::GetControlInput(node); | 892 Node* control = NodeProperties::GetControlInput(node); |
891 // Convert to a number first. | 893 // Convert to a number first. |
892 if (!value_type->Is(Type::Number())) { | 894 if (!value_type->Is(Type::Number())) { |
893 Reduction number_reduction = ReduceJSToNumberInput(value); | 895 Reduction number_reduction = ReduceJSToNumberInput(value); |
894 if (number_reduction.Changed()) { | 896 if (number_reduction.Changed()) { |
895 value = number_reduction.replacement(); | 897 value = number_reduction.replacement(); |
(...skipping 811 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1707 } | 1709 } |
1708 | 1710 |
1709 | 1711 |
1710 MachineOperatorBuilder* JSTypedLowering::machine() const { | 1712 MachineOperatorBuilder* JSTypedLowering::machine() const { |
1711 return jsgraph()->machine(); | 1713 return jsgraph()->machine(); |
1712 } | 1714 } |
1713 | 1715 |
1714 } // namespace compiler | 1716 } // namespace compiler |
1715 } // namespace internal | 1717 } // namespace internal |
1716 } // namespace v8 | 1718 } // namespace v8 |
OLD | NEW |