OLD | NEW |
---|---|
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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/builtins.h" | 5 #include "src/builtins.h" |
6 | 6 |
7 #include "src/api.h" | 7 #include "src/api.h" |
8 #include "src/api-natives.h" | 8 #include "src/api-natives.h" |
9 #include "src/arguments.h" | 9 #include "src/arguments.h" |
10 #include "src/base/once.h" | 10 #include "src/base/once.h" |
11 #include "src/bootstrapper.h" | 11 #include "src/bootstrapper.h" |
12 #include "src/compiler/code-stub-assembler.h" | |
12 #include "src/dateparser-inl.h" | 13 #include "src/dateparser-inl.h" |
13 #include "src/elements.h" | 14 #include "src/elements.h" |
14 #include "src/frames-inl.h" | 15 #include "src/frames-inl.h" |
15 #include "src/gdb-jit.h" | 16 #include "src/gdb-jit.h" |
16 #include "src/ic/handler-compiler.h" | 17 #include "src/ic/handler-compiler.h" |
17 #include "src/ic/ic.h" | 18 #include "src/ic/ic.h" |
18 #include "src/isolate-inl.h" | 19 #include "src/isolate-inl.h" |
19 #include "src/messages.h" | 20 #include "src/messages.h" |
20 #include "src/profiler/cpu-profiler.h" | 21 #include "src/profiler/cpu-profiler.h" |
21 #include "src/property-descriptor.h" | 22 #include "src/property-descriptor.h" |
(...skipping 4141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
4163 void Builtins::Generate_InterruptCheck(MacroAssembler* masm) { | 4164 void Builtins::Generate_InterruptCheck(MacroAssembler* masm) { |
4164 masm->TailCallRuntime(Runtime::kInterrupt); | 4165 masm->TailCallRuntime(Runtime::kInterrupt); |
4165 } | 4166 } |
4166 | 4167 |
4167 | 4168 |
4168 void Builtins::Generate_StackCheck(MacroAssembler* masm) { | 4169 void Builtins::Generate_StackCheck(MacroAssembler* masm) { |
4169 masm->TailCallRuntime(Runtime::kStackGuard); | 4170 masm->TailCallRuntime(Runtime::kStackGuard); |
4170 } | 4171 } |
4171 | 4172 |
4172 | 4173 |
4174 void Builtins::Generate_AtomicsLoadCheck(MacroAssembler* masm) { | |
4175 using namespace compiler; | |
4176 Isolate* isolate = masm->isolate(); | |
4177 Zone zone; | |
4178 CodeStubAssembler a(isolate, &zone, 2, Code::ComputeFlags(Code::STUB), | |
4179 "AtomicsLoadCheck"); | |
4180 | |
4181 Node* param0 = a.Parameter(0); | |
4182 | |
4183 // Check if param0 is a heap object. | |
4184 CodeStubAssembler::Label is_heap_object, not_heap_object; | |
4185 a.Branch(a.IsHeapObject(param0), &is_heap_object, ¬_heap_object); | |
4186 a.Bind(¬_heap_object); | |
4187 a.TailCallRuntime(Runtime::kThrowNotIntegerSharedTypedArrayError, param0); | |
4188 a.Bind(&is_heap_object); | |
4189 | |
4190 // Check if param0's instance type is JSTypedArray. | |
4191 CodeStubAssembler::Label is_typed_array, not_typed_array; | |
4192 a.Branch( | |
4193 a.WordEqual(a.InstanceType(param0), a.Int32Constant(JS_TYPED_ARRAY_TYPE)), | |
4194 &is_typed_array, ¬_typed_array); | |
4195 a.Bind(¬_typed_array); | |
4196 a.TailCallRuntime(Runtime::kThrowNotIntegerSharedTypedArrayError, param0); | |
4197 a.Bind(&is_typed_array); | |
4198 | |
4199 // Check if param0's JSArrayBuffer is shared. | |
4200 CodeStubAssembler::Label is_shared, not_shared; | |
4201 Node* is_buffer_shared = a.BitFieldValue<JSArrayBuffer::IsShared>( | |
4202 a.LoadObjectField(a.LoadObjectField(param0, JSTypedArray::kBufferOffset), | |
4203 JSArrayBuffer::kBitFieldOffset)); | |
4204 a.Branch(is_buffer_shared, &is_shared, ¬_shared); | |
4205 a.Bind(¬_shared); | |
4206 a.TailCallRuntime(Runtime::kThrowNotIntegerSharedTypedArrayError, param0); | |
4207 a.Bind(&is_shared); | |
4208 | |
4209 // Check if param0's JSTypedArray element type is float32 or float64. | |
4210 CodeStubAssembler::Label is_float, not_float; | |
4211 Node* elements_instance_type = | |
4212 a.InstanceType(a.LoadObjectField(param0, JSObject::kElementsOffset)); | |
4213 a.Branch(a.WordOr(a.WordEqual(elements_instance_type, | |
4214 a.Int32Constant(FIXED_FLOAT32_ARRAY_TYPE)), | |
4215 a.WordEqual(elements_instance_type, | |
4216 a.Int32Constant(FIXED_FLOAT64_ARRAY_TYPE))), | |
4217 &is_float, ¬_float); | |
4218 a.Bind(&is_float); | |
4219 a.TailCallRuntime(Runtime::kThrowNotIntegerSharedTypedArrayError, param0); | |
4220 a.Bind(¬_float); | |
4221 | |
4222 // Check if the index is in bounds. If not, return undefined. | |
4223 CodeStubAssembler::Label in_bounds, not_in_bounds; | |
4224 Node* param1_int = | |
4225 a.SmiUntag(a.CallRuntime(Runtime::kToInteger, a.Parameter(1))); | |
Jarin
2016/02/08 10:25:04
How do you know that ToInteger returns a Smi? You
| |
4226 // TODO(binji): is length always a smi? | |
4227 Node* array_length = | |
4228 a.SmiUntag(a.LoadObjectField(param0, JSTypedArray::kLengthOffset)); | |
Jarin
2016/02/08 10:25:04
Same here.
| |
4229 a.Branch(a.WordOr(a.Int32LessThan(param1_int, a.Int32Constant(0)), | |
4230 a.Int32GreaterThanOrEqual(param1_int, array_length)), | |
4231 ¬_in_bounds, &in_bounds); | |
4232 a.Bind(¬_in_bounds); | |
4233 a.Return(a.UndefinedConstant()); | |
4234 a.Bind(&in_bounds); | |
4235 | |
4236 a.Return(a.SmiTag(a.Int32Constant(42))); | |
4237 | |
4238 masm->Jump(a.GenerateCode(), RelocInfo::CODE_TARGET); | |
4239 } | |
4240 | |
4241 | |
4173 #define DEFINE_BUILTIN_ACCESSOR_C(name, ignore) \ | 4242 #define DEFINE_BUILTIN_ACCESSOR_C(name, ignore) \ |
4174 Handle<Code> Builtins::name() { \ | 4243 Handle<Code> Builtins::name() { \ |
4175 Code** code_address = \ | 4244 Code** code_address = \ |
4176 reinterpret_cast<Code**>(builtin_address(k##name)); \ | 4245 reinterpret_cast<Code**>(builtin_address(k##name)); \ |
4177 return Handle<Code>(code_address); \ | 4246 return Handle<Code>(code_address); \ |
4178 } | 4247 } |
4179 #define DEFINE_BUILTIN_ACCESSOR_A(name, kind, state, extra) \ | 4248 #define DEFINE_BUILTIN_ACCESSOR_A(name, kind, state, extra) \ |
4180 Handle<Code> Builtins::name() { \ | 4249 Handle<Code> Builtins::name() { \ |
4181 Code** code_address = \ | 4250 Code** code_address = \ |
4182 reinterpret_cast<Code**>(builtin_address(k##name)); \ | 4251 reinterpret_cast<Code**>(builtin_address(k##name)); \ |
4183 return Handle<Code>(code_address); \ | 4252 return Handle<Code>(code_address); \ |
4184 } | 4253 } |
4185 #define DEFINE_BUILTIN_ACCESSOR_H(name, kind) \ | 4254 #define DEFINE_BUILTIN_ACCESSOR_H(name, kind) \ |
4186 Handle<Code> Builtins::name() { \ | 4255 Handle<Code> Builtins::name() { \ |
4187 Code** code_address = \ | 4256 Code** code_address = \ |
4188 reinterpret_cast<Code**>(builtin_address(k##name)); \ | 4257 reinterpret_cast<Code**>(builtin_address(k##name)); \ |
4189 return Handle<Code>(code_address); \ | 4258 return Handle<Code>(code_address); \ |
4190 } | 4259 } |
4191 BUILTIN_LIST_C(DEFINE_BUILTIN_ACCESSOR_C) | 4260 BUILTIN_LIST_C(DEFINE_BUILTIN_ACCESSOR_C) |
4192 BUILTIN_LIST_A(DEFINE_BUILTIN_ACCESSOR_A) | 4261 BUILTIN_LIST_A(DEFINE_BUILTIN_ACCESSOR_A) |
4193 BUILTIN_LIST_H(DEFINE_BUILTIN_ACCESSOR_H) | 4262 BUILTIN_LIST_H(DEFINE_BUILTIN_ACCESSOR_H) |
4194 BUILTIN_LIST_DEBUG_A(DEFINE_BUILTIN_ACCESSOR_A) | 4263 BUILTIN_LIST_DEBUG_A(DEFINE_BUILTIN_ACCESSOR_A) |
4195 #undef DEFINE_BUILTIN_ACCESSOR_C | 4264 #undef DEFINE_BUILTIN_ACCESSOR_C |
4196 #undef DEFINE_BUILTIN_ACCESSOR_A | 4265 #undef DEFINE_BUILTIN_ACCESSOR_A |
4197 | 4266 |
4198 | 4267 |
4199 } // namespace internal | 4268 } // namespace internal |
4200 } // namespace v8 | 4269 } // namespace v8 |
OLD | NEW |