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 #if V8_TARGET_ARCH_MIPS | 5 #if V8_TARGET_ARCH_MIPS |
6 | 6 |
7 #include "src/interface-descriptors.h" | 7 #include "src/interface-descriptors.h" |
8 | 8 |
9 namespace v8 { | 9 namespace v8 { |
10 namespace internal { | 10 namespace internal { |
(...skipping 363 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
374 }; | 374 }; |
375 data->InitializePlatformSpecific(arraysize(registers), registers); | 375 data->InitializePlatformSpecific(arraysize(registers), registers); |
376 } | 376 } |
377 | 377 |
378 void InterpreterPushArgsAndConstructDescriptor::InitializePlatformSpecific( | 378 void InterpreterPushArgsAndConstructDescriptor::InitializePlatformSpecific( |
379 CallInterfaceDescriptorData* data) { | 379 CallInterfaceDescriptorData* data) { |
380 Register registers[] = { | 380 Register registers[] = { |
381 a0, // argument count (not including receiver) | 381 a0, // argument count (not including receiver) |
382 a3, // new target | 382 a3, // new target |
383 a1, // constructor to call | 383 a1, // constructor to call |
384 a2, // allocation site feedback if available, undefined otherwise. | 384 a2 // address of the first argument |
385 t4 // address of the first argument | |
386 }; | 385 }; |
387 data->InitializePlatformSpecific(arraysize(registers), registers); | 386 data->InitializePlatformSpecific(arraysize(registers), registers); |
388 } | 387 } |
389 | 388 |
390 void InterpreterCEntryDescriptor::InitializePlatformSpecific( | 389 void InterpreterCEntryDescriptor::InitializePlatformSpecific( |
391 CallInterfaceDescriptorData* data) { | 390 CallInterfaceDescriptorData* data) { |
392 Register registers[] = { | 391 Register registers[] = { |
393 a0, // argument count (argc) | 392 a0, // argument count (argc) |
394 a2, // address of first argument (argv) | 393 a2, // address of first argument (argv) |
395 a1 // the runtime function to call | 394 a1 // the runtime function to call |
396 }; | 395 }; |
397 data->InitializePlatformSpecific(arraysize(registers), registers); | 396 data->InitializePlatformSpecific(arraysize(registers), registers); |
398 } | 397 } |
399 | 398 |
400 void ResumeGeneratorDescriptor::InitializePlatformSpecific( | 399 void ResumeGeneratorDescriptor::InitializePlatformSpecific( |
401 CallInterfaceDescriptorData* data) { | 400 CallInterfaceDescriptorData* data) { |
402 Register registers[] = { | 401 Register registers[] = { |
403 v0, // the value to pass to the generator | 402 v0, // the value to pass to the generator |
404 a1, // the JSGeneratorObject to resume | 403 a1, // the JSGeneratorObject to resume |
405 a2 // the resume mode (tagged) | 404 a2 // the resume mode (tagged) |
406 }; | 405 }; |
407 data->InitializePlatformSpecific(arraysize(registers), registers); | 406 data->InitializePlatformSpecific(arraysize(registers), registers); |
408 } | 407 } |
409 | 408 |
410 } // namespace internal | 409 } // namespace internal |
411 } // namespace v8 | 410 } // namespace v8 |
412 | 411 |
413 #endif // V8_TARGET_ARCH_MIPS | 412 #endif // V8_TARGET_ARCH_MIPS |
OLD | NEW |