| OLD | NEW |
| 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2014, 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" | 5 #include "vm/globals.h" |
| 6 #if defined(TARGET_ARCH_ARM64) | 6 #if defined(TARGET_ARCH_ARM64) |
| 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/longjump.h" | 10 #include "vm/longjump.h" |
| (...skipping 548 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 559 if (initialized) { | 559 if (initialized) { |
| 560 movk(reg, h3, 3); | 560 movk(reg, h3, 3); |
| 561 } else { | 561 } else { |
| 562 movz(reg, h3, 3); | 562 movz(reg, h3, 3); |
| 563 } | 563 } |
| 564 } | 564 } |
| 565 } | 565 } |
| 566 } | 566 } |
| 567 | 567 |
| 568 | 568 |
| 569 void Assembler::LoadDImmediate(VRegister vd, double immd, Register pp) { |
| 570 if (!fmovdi(vd, immd)) { |
| 571 int64_t imm = bit_cast<int64_t, double>(immd); |
| 572 LoadImmediate(TMP, imm, pp); |
| 573 fmovdr(vd, TMP); |
| 574 } |
| 575 } |
| 576 |
| 577 |
| 569 void Assembler::AddImmediate( | 578 void Assembler::AddImmediate( |
| 570 Register dest, Register rn, int64_t imm, Register pp) { | 579 Register dest, Register rn, int64_t imm, Register pp) { |
| 571 ASSERT(rn != TMP2); | 580 ASSERT(rn != TMP2); |
| 572 Operand op; | 581 Operand op; |
| 573 if (Operand::CanHold(imm, kXRegSizeInBits, &op) == Operand::Immediate) { | 582 if (Operand::CanHold(imm, kXRegSizeInBits, &op) == Operand::Immediate) { |
| 574 add(dest, rn, op); | 583 add(dest, rn, op); |
| 575 } else if (Operand::CanHold(-imm, kXRegSizeInBits, &op) == | 584 } else if (Operand::CanHold(-imm, kXRegSizeInBits, &op) == |
| 576 Operand::Immediate) { | 585 Operand::Immediate) { |
| 577 sub(dest, rn, op); | 586 sub(dest, rn, op); |
| 578 } else { | 587 } else { |
| (...skipping 425 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1004 str(TMP, Address(temp_reg, count_field_offset)); | 1013 str(TMP, Address(temp_reg, count_field_offset)); |
| 1005 ldr(TMP, Address(temp_reg, size_field_offset)); | 1014 ldr(TMP, Address(temp_reg, size_field_offset)); |
| 1006 add(TMP, TMP, Operand(size_reg)); | 1015 add(TMP, TMP, Operand(size_reg)); |
| 1007 str(TMP, Address(temp_reg, size_field_offset)); | 1016 str(TMP, Address(temp_reg, size_field_offset)); |
| 1008 } | 1017 } |
| 1009 } | 1018 } |
| 1010 | 1019 |
| 1011 } // namespace dart | 1020 } // namespace dart |
| 1012 | 1021 |
| 1013 #endif // defined TARGET_ARCH_ARM64 | 1022 #endif // defined TARGET_ARCH_ARM64 |
| OLD | NEW |