Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(609)

Side by Side Diff: src/code-stub-assembler.h

Issue 1904933002: Introduce bytecodes for assisting generator suspend and resume. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Nix Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | src/code-stub-assembler.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2016 the V8 project authors. All rights reserved. 1 // Copyright 2016 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 #ifndef V8_CODE_STUB_ASSEMBLER_H_ 5 #ifndef V8_CODE_STUB_ASSEMBLER_H_
6 #define V8_CODE_STUB_ASSEMBLER_H_ 6 #define V8_CODE_STUB_ASSEMBLER_H_
7 7
8 #include "src/compiler/code-assembler.h" 8 #include "src/compiler/code-assembler.h"
9 #include "src/objects.h" 9 #include "src/objects.h"
10 10
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
61 compiler::Node* SmiAddWithOverflow(compiler::Node* a, compiler::Node* b); 61 compiler::Node* SmiAddWithOverflow(compiler::Node* a, compiler::Node* b);
62 compiler::Node* SmiSub(compiler::Node* a, compiler::Node* b); 62 compiler::Node* SmiSub(compiler::Node* a, compiler::Node* b);
63 compiler::Node* SmiSubWithOverflow(compiler::Node* a, compiler::Node* b); 63 compiler::Node* SmiSubWithOverflow(compiler::Node* a, compiler::Node* b);
64 compiler::Node* SmiEqual(compiler::Node* a, compiler::Node* b); 64 compiler::Node* SmiEqual(compiler::Node* a, compiler::Node* b);
65 compiler::Node* SmiAboveOrEqual(compiler::Node* a, compiler::Node* b); 65 compiler::Node* SmiAboveOrEqual(compiler::Node* a, compiler::Node* b);
66 compiler::Node* SmiLessThan(compiler::Node* a, compiler::Node* b); 66 compiler::Node* SmiLessThan(compiler::Node* a, compiler::Node* b);
67 compiler::Node* SmiLessThanOrEqual(compiler::Node* a, compiler::Node* b); 67 compiler::Node* SmiLessThanOrEqual(compiler::Node* a, compiler::Node* b);
68 compiler::Node* SmiMin(compiler::Node* a, compiler::Node* b); 68 compiler::Node* SmiMin(compiler::Node* a, compiler::Node* b);
69 69
70 // Allocate an object of the given size. 70 // Allocate an object of the given size.
71 compiler::Node* Allocate(compiler::Node* size, AllocationFlags flags = kNone);
71 compiler::Node* Allocate(int size, AllocationFlags flags = kNone); 72 compiler::Node* Allocate(int size, AllocationFlags flags = kNone);
72 compiler::Node* InnerAllocate(compiler::Node* previous, int offset); 73 compiler::Node* InnerAllocate(compiler::Node* previous, int offset);
73 74
74 // Check a value for smi-ness 75 // Check a value for smi-ness
75 compiler::Node* WordIsSmi(compiler::Node* a); 76 compiler::Node* WordIsSmi(compiler::Node* a);
76 // Check that the value is a positive smi. 77 // Check that the value is a positive smi.
77 compiler::Node* WordIsPositiveSmi(compiler::Node* a); 78 compiler::Node* WordIsPositiveSmi(compiler::Node* a);
78 79
79 void BranchIfSmiLessThan(compiler::Node* a, compiler::Node* b, Label* if_true, 80 void BranchIfSmiLessThan(compiler::Node* a, compiler::Node* b, Label* if_true,
80 Label* if_false) { 81 Label* if_false) {
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
116 // Load the instance type of a map. 117 // Load the instance type of a map.
117 compiler::Node* LoadMapInstanceType(compiler::Node* map); 118 compiler::Node* LoadMapInstanceType(compiler::Node* map);
118 // Load the instance descriptors of a map. 119 // Load the instance descriptors of a map.
119 compiler::Node* LoadMapDescriptors(compiler::Node* map); 120 compiler::Node* LoadMapDescriptors(compiler::Node* map);
120 121
121 // Load the hash field of a name. 122 // Load the hash field of a name.
122 compiler::Node* LoadNameHash(compiler::Node* name); 123 compiler::Node* LoadNameHash(compiler::Node* name);
123 // Load the instance size of a Map. 124 // Load the instance size of a Map.
124 compiler::Node* LoadMapInstanceSize(compiler::Node* map); 125 compiler::Node* LoadMapInstanceSize(compiler::Node* map);
125 126
127 compiler::Node* AllocateUninitializedFixedArray(compiler::Node* length);
128
126 // Load an array element from a FixedArray. 129 // Load an array element from a FixedArray.
127 compiler::Node* LoadFixedArrayElementInt32Index(compiler::Node* object, 130 compiler::Node* LoadFixedArrayElementInt32Index(compiler::Node* object,
128 compiler::Node* int32_index, 131 compiler::Node* int32_index,
129 int additional_offset = 0); 132 int additional_offset = 0);
130 compiler::Node* LoadFixedArrayElementSmiIndex(compiler::Node* object, 133 compiler::Node* LoadFixedArrayElementSmiIndex(compiler::Node* object,
131 compiler::Node* smi_index, 134 compiler::Node* smi_index,
132 int additional_offset = 0); 135 int additional_offset = 0);
133 compiler::Node* LoadFixedArrayElementConstantIndex(compiler::Node* object, 136 compiler::Node* LoadFixedArrayElementConstantIndex(compiler::Node* object,
134 int index); 137 int index);
135 138
136 // Store the floating point value of a HeapNumber. 139 // Store the floating point value of a HeapNumber.
137 compiler::Node* StoreHeapNumberValue(compiler::Node* object, 140 compiler::Node* StoreHeapNumberValue(compiler::Node* object,
138 compiler::Node* value); 141 compiler::Node* value);
139 // Store a field to an object on the heap. 142 // Store a field to an object on the heap.
143 compiler::Node* StoreObjectField(
144 compiler::Node* object, int offset, compiler::Node* value);
140 compiler::Node* StoreObjectFieldNoWriteBarrier( 145 compiler::Node* StoreObjectFieldNoWriteBarrier(
141 compiler::Node* object, int offset, compiler::Node* value, 146 compiler::Node* object, int offset, compiler::Node* value,
142 MachineRepresentation rep = MachineRepresentation::kTagged); 147 MachineRepresentation rep = MachineRepresentation::kTagged);
143 // Store the Map of an HeapObject. 148 // Store the Map of an HeapObject.
144 compiler::Node* StoreMapNoWriteBarrier(compiler::Node* object, 149 compiler::Node* StoreMapNoWriteBarrier(compiler::Node* object,
145 compiler::Node* map); 150 compiler::Node* map);
146 // Store an array element to a FixedArray. 151 // Store an array element to a FixedArray.
147 compiler::Node* StoreFixedArrayElementInt32Index(compiler::Node* object, 152 compiler::Node* StoreFixedArrayElementInt32Index(compiler::Node* object,
148 compiler::Node* index, 153 compiler::Node* index,
149 compiler::Node* value); 154 compiler::Node* value);
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after
204 compiler::Node* AllocateRawUnaligned(compiler::Node* size_in_bytes, 209 compiler::Node* AllocateRawUnaligned(compiler::Node* size_in_bytes,
205 AllocationFlags flags, 210 AllocationFlags flags,
206 compiler::Node* top_adddress, 211 compiler::Node* top_adddress,
207 compiler::Node* limit_address); 212 compiler::Node* limit_address);
208 }; 213 };
209 214
210 } // namespace internal 215 } // namespace internal
211 } // namespace v8 216 } // namespace v8
212 217
213 #endif // V8_CODE_STUB_ASSEMBLER_H_ 218 #endif // V8_CODE_STUB_ASSEMBLER_H_
OLDNEW
« no previous file with comments | « no previous file | src/code-stub-assembler.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698