OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 the V8 project authors. All rights reserved. |
2 // | 2 // |
3 // Redistribution and use in source and binary forms, with or without | 3 // Redistribution and use in source and binary forms, with or without |
4 // modification, are permitted provided that the following conditions are | 4 // modification, are permitted provided that the following conditions are |
5 // met: | 5 // met: |
6 // | 6 // |
7 // * Redistributions of source code must retain the above copyright | 7 // * Redistributions of source code must retain the above copyright |
8 // notice, this list of conditions and the following disclaimer. | 8 // notice, this list of conditions and the following disclaimer. |
9 // * Redistributions in binary form must reproduce the above | 9 // * Redistributions in binary form must reproduce the above |
10 // copyright notice, this list of conditions and the following | 10 // copyright notice, this list of conditions and the following |
(...skipping 873 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
884 bool Assembler::is_const_pool_blocked() const { | 884 bool Assembler::is_const_pool_blocked() const { |
885 return (const_pool_blocked_nesting_ > 0) || | 885 return (const_pool_blocked_nesting_ > 0) || |
886 (pc_offset() < no_const_pool_before_); | 886 (pc_offset() < no_const_pool_before_); |
887 } | 887 } |
888 | 888 |
889 | 889 |
890 bool Assembler::IsConstantPoolAt(Instruction* instr) { | 890 bool Assembler::IsConstantPoolAt(Instruction* instr) { |
891 // The constant pool marker is made of two instructions. These instructions | 891 // The constant pool marker is made of two instructions. These instructions |
892 // will never be emitted by the JIT, so checking for the first one is enough: | 892 // will never be emitted by the JIT, so checking for the first one is enough: |
893 // 0: ldr xzr, #<size of pool> | 893 // 0: ldr xzr, #<size of pool> |
894 bool result = instr->IsLdrLiteralX() && (instr->Rt() == xzr.code()); | 894 bool result = instr->IsLdrLiteralX() && (instr->Rt() == kZeroRegCode); |
895 | 895 |
896 // It is still worth asserting the marker is complete. | 896 // It is still worth asserting the marker is complete. |
897 // 4: blr xzr | 897 // 4: blr xzr |
898 DCHECK(!result || (instr->following()->IsBranchAndLinkToRegister() && | 898 DCHECK(!result || (instr->following()->IsBranchAndLinkToRegister() && |
899 instr->following()->Rn() == xzr.code())); | 899 instr->following()->Rn() == kZeroRegCode)); |
900 | 900 |
901 return result; | 901 return result; |
902 } | 902 } |
903 | 903 |
904 | 904 |
905 int Assembler::ConstantPoolSizeAt(Instruction* instr) { | 905 int Assembler::ConstantPoolSizeAt(Instruction* instr) { |
906 #ifdef USE_SIMULATOR | 906 #ifdef USE_SIMULATOR |
907 // Assembler::debug() embeds constants directly into the instruction stream. | 907 // Assembler::debug() embeds constants directly into the instruction stream. |
908 // Although this is not a genuine constant pool, treat it like one to avoid | 908 // Although this is not a genuine constant pool, treat it like one to avoid |
909 // disassembling the constants. | 909 // disassembling the constants. |
(...skipping 2275 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3185 movz(scratch, (target_offset >> 16) & 0xFFFF, 16); | 3185 movz(scratch, (target_offset >> 16) & 0xFFFF, 16); |
3186 movk(scratch, (target_offset >> 32) & 0xFFFF, 32); | 3186 movk(scratch, (target_offset >> 32) & 0xFFFF, 32); |
3187 DCHECK((target_offset >> 48) == 0); | 3187 DCHECK((target_offset >> 48) == 0); |
3188 add(rd, rd, scratch); | 3188 add(rd, rd, scratch); |
3189 } | 3189 } |
3190 | 3190 |
3191 | 3191 |
3192 } } // namespace v8::internal | 3192 } } // namespace v8::internal |
3193 | 3193 |
3194 #endif // V8_TARGET_ARCH_ARM64 | 3194 #endif // V8_TARGET_ARCH_ARM64 |
OLD | NEW |