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 // address of the first argument | 384 a2, // allocation site feedback if available, undefined otherwise. |
| 385 t4 // address of the first argument |
385 }; | 386 }; |
386 data->InitializePlatformSpecific(arraysize(registers), registers); | 387 data->InitializePlatformSpecific(arraysize(registers), registers); |
387 } | 388 } |
388 | 389 |
389 void InterpreterCEntryDescriptor::InitializePlatformSpecific( | 390 void InterpreterCEntryDescriptor::InitializePlatformSpecific( |
390 CallInterfaceDescriptorData* data) { | 391 CallInterfaceDescriptorData* data) { |
391 Register registers[] = { | 392 Register registers[] = { |
392 a0, // argument count (argc) | 393 a0, // argument count (argc) |
393 a2, // address of first argument (argv) | 394 a2, // address of first argument (argv) |
394 a1 // the runtime function to call | 395 a1 // the runtime function to call |
395 }; | 396 }; |
396 data->InitializePlatformSpecific(arraysize(registers), registers); | 397 data->InitializePlatformSpecific(arraysize(registers), registers); |
397 } | 398 } |
398 | 399 |
399 void ResumeGeneratorDescriptor::InitializePlatformSpecific( | 400 void ResumeGeneratorDescriptor::InitializePlatformSpecific( |
400 CallInterfaceDescriptorData* data) { | 401 CallInterfaceDescriptorData* data) { |
401 Register registers[] = { | 402 Register registers[] = { |
402 v0, // the value to pass to the generator | 403 v0, // the value to pass to the generator |
403 a1, // the JSGeneratorObject to resume | 404 a1, // the JSGeneratorObject to resume |
404 a2 // the resume mode (tagged) | 405 a2 // the resume mode (tagged) |
405 }; | 406 }; |
406 data->InitializePlatformSpecific(arraysize(registers), registers); | 407 data->InitializePlatformSpecific(arraysize(registers), registers); |
407 } | 408 } |
408 | 409 |
409 } // namespace internal | 410 } // namespace internal |
410 } // namespace v8 | 411 } // namespace v8 |
411 | 412 |
412 #endif // V8_TARGET_ARCH_MIPS | 413 #endif // V8_TARGET_ARCH_MIPS |
OLD | NEW |