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/compiler/js-builtin-reducer.h" | 5 #include "src/compiler/js-builtin-reducer.h" |
6 | 6 |
7 #include "src/base/bits.h" | 7 #include "src/base/bits.h" |
| 8 #include "src/code-factory.h" |
8 #include "src/compilation-dependencies.h" | 9 #include "src/compilation-dependencies.h" |
9 #include "src/compiler/access-builder.h" | 10 #include "src/compiler/access-builder.h" |
10 #include "src/compiler/js-graph.h" | 11 #include "src/compiler/js-graph.h" |
| 12 #include "src/compiler/linkage.h" |
11 #include "src/compiler/node-matchers.h" | 13 #include "src/compiler/node-matchers.h" |
12 #include "src/compiler/node-properties.h" | 14 #include "src/compiler/node-properties.h" |
13 #include "src/compiler/simplified-operator.h" | 15 #include "src/compiler/simplified-operator.h" |
14 #include "src/compiler/type-cache.h" | 16 #include "src/compiler/type-cache.h" |
15 #include "src/compiler/types.h" | 17 #include "src/compiler/types.h" |
16 #include "src/objects-inl.h" | 18 #include "src/objects-inl.h" |
17 | 19 |
18 namespace v8 { | 20 namespace v8 { |
19 namespace internal { | 21 namespace internal { |
20 namespace compiler { | 22 namespace compiler { |
(...skipping 1702 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1723 | 1725 |
1724 ReplaceWithValue(node, value, effect, control); | 1726 ReplaceWithValue(node, value, effect, control); |
1725 return Replace(value); | 1727 return Replace(value); |
1726 } | 1728 } |
1727 } | 1729 } |
1728 } | 1730 } |
1729 | 1731 |
1730 return NoChange(); | 1732 return NoChange(); |
1731 } | 1733 } |
1732 | 1734 |
| 1735 // ES6 String.prototype.indexOf(searchString [, position]) |
| 1736 // #sec-string.prototype.indexof |
| 1737 Reduction JSBuiltinReducer::ReduceStringIndexOf(Node* node) { |
| 1738 int arg_count = node->op()->ValueInputCount(); |
| 1739 if (arg_count != 3 && arg_count != 4) return NoChange(); |
| 1740 Node* receiver; |
| 1741 if (!(receiver = GetStringWitness(node))) return NoChange(); |
| 1742 Node* search_string = NodeProperties::GetValueInput(node, 2); |
| 1743 if (!NodeProperties::GetType(search_string)->Is(Type::String())) { |
| 1744 return NoChange(); |
| 1745 } |
| 1746 // Replace the current JSFunctionCall to String.prototype.indexOf with a |
| 1747 // simple Call to the unchecked StringIndexOf builtin. |
| 1748 Callable callable = CodeFactory::StringIndexOf(isolate()); |
| 1749 const CallInterfaceDescriptor& descriptor = callable.descriptor(); |
| 1750 CallDescriptor* desc = |
| 1751 Linkage::GetStubCallDescriptor(isolate(), graph()->zone(), descriptor, |
| 1752 descriptor.GetStackParameterCount(), |
| 1753 CallDescriptor::kNoFlags, Operator::kPure); |
| 1754 Node* stub_code = jsgraph()->HeapConstant(callable.code()); |
| 1755 // The Call Operator doesn't require an effect nor a control input. |
| 1756 RelaxEffectsAndControls(node); |
| 1757 // Remove framestate since StringIndexOf cannot deopt. |
| 1758 node->RemoveInput(arg_count + 1); |
| 1759 // Remove the control input. |
| 1760 node->RemoveInput(arg_count + 2); |
| 1761 // Replace the JSFunction from the JSFunctionCall node with the CodeStub. |
| 1762 node->ReplaceInput(0, stub_code); |
| 1763 if (arg_count == 3) { |
| 1764 // Insert the missing position argument. |
| 1765 node->InsertInput(graph()->zone(), 3, jsgraph()->ZeroConstant()); |
| 1766 } |
| 1767 const Operator* op = common()->Call(desc); |
| 1768 node->TrimInputCount(op->ValueInputCount()); |
| 1769 NodeProperties::ChangeOp(node, op); |
| 1770 return Changed(node); |
| 1771 } |
| 1772 |
1733 Reduction JSBuiltinReducer::ReduceStringIterator(Node* node) { | 1773 Reduction JSBuiltinReducer::ReduceStringIterator(Node* node) { |
1734 if (Node* receiver = GetStringWitness(node)) { | 1774 if (Node* receiver = GetStringWitness(node)) { |
1735 Node* effect = NodeProperties::GetEffectInput(node); | 1775 Node* effect = NodeProperties::GetEffectInput(node); |
1736 Node* control = NodeProperties::GetControlInput(node); | 1776 Node* control = NodeProperties::GetControlInput(node); |
1737 | 1777 |
1738 Node* map = jsgraph()->HeapConstant( | 1778 Node* map = jsgraph()->HeapConstant( |
1739 handle(native_context()->string_iterator_map(), isolate())); | 1779 handle(native_context()->string_iterator_map(), isolate())); |
1740 | 1780 |
1741 // allocate new iterator | 1781 // allocate new iterator |
1742 effect = graph()->NewNode( | 1782 effect = graph()->NewNode( |
(...skipping 351 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2094 case kObjectCreate: | 2134 case kObjectCreate: |
2095 reduction = ReduceObjectCreate(node); | 2135 reduction = ReduceObjectCreate(node); |
2096 break; | 2136 break; |
2097 case kStringFromCharCode: | 2137 case kStringFromCharCode: |
2098 reduction = ReduceStringFromCharCode(node); | 2138 reduction = ReduceStringFromCharCode(node); |
2099 break; | 2139 break; |
2100 case kStringCharAt: | 2140 case kStringCharAt: |
2101 return ReduceStringCharAt(node); | 2141 return ReduceStringCharAt(node); |
2102 case kStringCharCodeAt: | 2142 case kStringCharCodeAt: |
2103 return ReduceStringCharCodeAt(node); | 2143 return ReduceStringCharCodeAt(node); |
| 2144 case kStringIndexOf: |
| 2145 return ReduceStringIndexOf(node); |
2104 case kStringIterator: | 2146 case kStringIterator: |
2105 return ReduceStringIterator(node); | 2147 return ReduceStringIterator(node); |
2106 case kStringIteratorNext: | 2148 case kStringIteratorNext: |
2107 return ReduceStringIteratorNext(node); | 2149 return ReduceStringIteratorNext(node); |
2108 case kDataViewByteLength: | 2150 case kDataViewByteLength: |
2109 return ReduceArrayBufferViewAccessor( | 2151 return ReduceArrayBufferViewAccessor( |
2110 node, JS_DATA_VIEW_TYPE, | 2152 node, JS_DATA_VIEW_TYPE, |
2111 AccessBuilder::ForJSArrayBufferViewByteLength()); | 2153 AccessBuilder::ForJSArrayBufferViewByteLength()); |
2112 case kDataViewByteOffset: | 2154 case kDataViewByteOffset: |
2113 return ReduceArrayBufferViewAccessor( | 2155 return ReduceArrayBufferViewAccessor( |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2170 return jsgraph()->simplified(); | 2212 return jsgraph()->simplified(); |
2171 } | 2213 } |
2172 | 2214 |
2173 JSOperatorBuilder* JSBuiltinReducer::javascript() const { | 2215 JSOperatorBuilder* JSBuiltinReducer::javascript() const { |
2174 return jsgraph()->javascript(); | 2216 return jsgraph()->javascript(); |
2175 } | 2217 } |
2176 | 2218 |
2177 } // namespace compiler | 2219 } // namespace compiler |
2178 } // namespace internal | 2220 } // namespace internal |
2179 } // namespace v8 | 2221 } // namespace v8 |
OLD | NEW |