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

Side by Side Diff: src/x64/interface-descriptors-x64.cc

Issue 1402943002: [Interpreter] Support for operator new. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Fix rebasing error. Created 5 years, 2 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
OLDNEW
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_X64 5 #if V8_TARGET_ARCH_X64
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 370 matching lines...) Expand 10 before | Expand all | Expand 10 after
381 rbx // type vector 381 rbx // type vector
382 }; 382 };
383 data->InitializePlatformSpecific(arraysize(registers), registers); 383 data->InitializePlatformSpecific(arraysize(registers), registers);
384 } 384 }
385 385
386 386
387 void InterpreterPushArgsAndCallDescriptor::InitializePlatformSpecific( 387 void InterpreterPushArgsAndCallDescriptor::InitializePlatformSpecific(
388 CallInterfaceDescriptorData* data) { 388 CallInterfaceDescriptorData* data) {
389 Register registers[] = { 389 Register registers[] = {
390 rax, // argument count (not including receiver) 390 rax, // argument count (not including receiver)
391 rbx, // address of first argument 391 rbx, // address of first argument.
392 rdi // the target callable to be call 392 rdi // the constructor.
rmcilroy 2015/10/13 14:07:30 I don't think this change was intended?
oth 2015/10/14 08:40:09 Done. Darn!
393 }; 393 };
394 data->InitializePlatformSpecific(arraysize(registers), registers); 394 data->InitializePlatformSpecific(arraysize(registers), registers);
395 } 395 }
396
397
398 void InterpreterPushArgsAndConstructDescriptor::InitializePlatformSpecific(
399 CallInterfaceDescriptorData* data) {
400 Register registers[] = {
401 rax, // argument count (not including receiver)
402 rdx, // original constructor
403 rdi, // constructor
404 rbx, // address of first argument
405 };
406 data->InitializePlatformSpecific(arraysize(registers), registers);
407 }
396 408
397 409
398 void InterpreterCEntryDescriptor::InitializePlatformSpecific( 410 void InterpreterCEntryDescriptor::InitializePlatformSpecific(
399 CallInterfaceDescriptorData* data) { 411 CallInterfaceDescriptorData* data) {
400 Register registers[] = { 412 Register registers[] = {
401 rax, // argument count (argc) 413 rax, // argument count (argc)
402 r15, // address of first argument (argv) 414 r15, // address of first argument (argv)
403 rbx // the runtime function to call 415 rbx // the runtime function to call
404 }; 416 };
405 data->InitializePlatformSpecific(arraysize(registers), registers); 417 data->InitializePlatformSpecific(arraysize(registers), registers);
406 } 418 }
407 419
408 } // namespace internal 420 } // namespace internal
409 } // namespace v8 421 } // namespace v8
410 422
411 #endif // V8_TARGET_ARCH_X64 423 #endif // V8_TARGET_ARCH_X64
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698