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

Side by Side Diff: runtime/vm/assembler_x64.cc

Issue 867383002: Implement bitLength intrinsic on x64. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 5 years, 11 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #include "vm/globals.h" // NOLINT 5 #include "vm/globals.h" // NOLINT
6 #if defined(TARGET_ARCH_X64) 6 #if defined(TARGET_ARCH_X64)
7 7
8 #include "vm/assembler.h" 8 #include "vm/assembler.h"
9 #include "vm/cpu.h" 9 #include "vm/cpu.h"
10 #include "vm/heap.h" 10 #include "vm/heap.h"
(...skipping 2379 matching lines...) Expand 10 before | Expand all | Expand 10 after
2390 } 2390 }
2391 2391
2392 2392
2393 void Assembler::notq(Register reg) { 2393 void Assembler::notq(Register reg) {
2394 AssemblerBuffer::EnsureCapacity ensured(&buffer_); 2394 AssemblerBuffer::EnsureCapacity ensured(&buffer_);
2395 EmitRegisterREX(reg, REX_W); 2395 EmitRegisterREX(reg, REX_W);
2396 EmitUint8(0xF7); 2396 EmitUint8(0xF7);
2397 EmitUint8(0xD0 | (reg & 7)); 2397 EmitUint8(0xD0 | (reg & 7));
2398 } 2398 }
2399 2399
2400
2401 void Assembler::bsrq(Register dst, Register src) {
2402 AssemblerBuffer::EnsureCapacity ensured(&buffer_);
2403 Operand operand(src);
2404 EmitOperandREX(dst, operand, REX_W);
2405 EmitUint8(0x0F);
2406 EmitUint8(0xBD);
2407 EmitOperand(dst & 7, operand);
2408 }
2409
2410
2400 void Assembler::btq(Register base, Register offset) { 2411 void Assembler::btq(Register base, Register offset) {
2401 AssemblerBuffer::EnsureCapacity ensured(&buffer_); 2412 AssemblerBuffer::EnsureCapacity ensured(&buffer_);
2402 Operand operand(base); 2413 Operand operand(base);
2403 EmitOperandREX(offset, operand, REX_W); 2414 EmitOperandREX(offset, operand, REX_W);
2404 EmitUint8(0x0F); 2415 EmitUint8(0x0F);
2405 EmitUint8(0xA3); 2416 EmitUint8(0xA3);
2406 EmitOperand(offset & 7, operand); 2417 EmitOperand(offset & 7, operand);
2407 } 2418 }
2408 2419
2409 2420
(...skipping 1536 matching lines...) Expand 10 before | Expand all | Expand 10 after
3946 3957
3947 3958
3948 const char* Assembler::FpuRegisterName(FpuRegister reg) { 3959 const char* Assembler::FpuRegisterName(FpuRegister reg) {
3949 ASSERT((0 <= reg) && (reg < kNumberOfXmmRegisters)); 3960 ASSERT((0 <= reg) && (reg < kNumberOfXmmRegisters));
3950 return xmm_reg_names[reg]; 3961 return xmm_reg_names[reg];
3951 } 3962 }
3952 3963
3953 } // namespace dart 3964 } // namespace dart
3954 3965
3955 #endif // defined TARGET_ARCH_X64 3966 #endif // defined TARGET_ARCH_X64
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698