OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 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 #ifndef V8_ARM64_MACRO_ASSEMBLER_ARM64_H_ | 5 #ifndef V8_ARM64_MACRO_ASSEMBLER_ARM64_H_ |
6 #define V8_ARM64_MACRO_ASSEMBLER_ARM64_H_ | 6 #define V8_ARM64_MACRO_ASSEMBLER_ARM64_H_ |
7 | 7 |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "v8globals.h" | 10 #include "v8globals.h" |
(...skipping 596 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
607 | 607 |
608 ~PushPopQueue() { | 608 ~PushPopQueue() { |
609 ASSERT(queued_.empty()); | 609 ASSERT(queued_.empty()); |
610 } | 610 } |
611 | 611 |
612 void Queue(const CPURegister& rt) { | 612 void Queue(const CPURegister& rt) { |
613 size_ += rt.SizeInBytes(); | 613 size_ += rt.SizeInBytes(); |
614 queued_.push_back(rt); | 614 queued_.push_back(rt); |
615 } | 615 } |
616 | 616 |
617 void PushQueued(); | 617 enum PreambleDirective { |
| 618 WITH_PREAMBLE, |
| 619 SKIP_PREAMBLE |
| 620 }; |
| 621 void PushQueued(PreambleDirective preamble_directive = WITH_PREAMBLE); |
618 void PopQueued(); | 622 void PopQueued(); |
619 | 623 |
620 private: | 624 private: |
621 MacroAssembler* masm_; | 625 MacroAssembler* masm_; |
622 int size_; | 626 int size_; |
623 std::vector<CPURegister> queued_; | 627 std::vector<CPURegister> queued_; |
624 }; | 628 }; |
625 | 629 |
626 // Poke 'src' onto the stack. The offset is in bytes. | 630 // Poke 'src' onto the stack. The offset is in bytes. |
627 // | 631 // |
(...skipping 1377 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2005 | 2009 |
2006 // Return true if the sequence is a young sequence geneated by | 2010 // Return true if the sequence is a young sequence geneated by |
2007 // EmitFrameSetupForCodeAgePatching. Otherwise, this method asserts that the | 2011 // EmitFrameSetupForCodeAgePatching. Otherwise, this method asserts that the |
2008 // sequence is a code age sequence (emitted by EmitCodeAgeSequence). | 2012 // sequence is a code age sequence (emitted by EmitCodeAgeSequence). |
2009 static bool IsYoungSequence(Isolate* isolate, byte* sequence); | 2013 static bool IsYoungSequence(Isolate* isolate, byte* sequence); |
2010 | 2014 |
2011 // Jumps to found label if a prototype map has dictionary elements. | 2015 // Jumps to found label if a prototype map has dictionary elements. |
2012 void JumpIfDictionaryInPrototypeChain(Register object, Register scratch0, | 2016 void JumpIfDictionaryInPrototypeChain(Register object, Register scratch0, |
2013 Register scratch1, Label* found); | 2017 Register scratch1, Label* found); |
2014 | 2018 |
| 2019 // Perform necessary maintenance operations before a push or after a pop. |
| 2020 // |
| 2021 // Note that size is specified in bytes. |
| 2022 void PushPreamble(Operand total_size); |
| 2023 void PopPostamble(Operand total_size); |
| 2024 |
| 2025 void PushPreamble(int count, int size) { PushPreamble(count * size); } |
| 2026 void PopPostamble(int count, int size) { PopPostamble(count * size); } |
| 2027 |
2015 private: | 2028 private: |
2016 // Helpers for CopyFields. | 2029 // Helpers for CopyFields. |
2017 // These each implement CopyFields in a different way. | 2030 // These each implement CopyFields in a different way. |
2018 void CopyFieldsLoopPairsHelper(Register dst, Register src, unsigned count, | 2031 void CopyFieldsLoopPairsHelper(Register dst, Register src, unsigned count, |
2019 Register scratch1, Register scratch2, | 2032 Register scratch1, Register scratch2, |
2020 Register scratch3, Register scratch4, | 2033 Register scratch3, Register scratch4, |
2021 Register scratch5); | 2034 Register scratch5); |
2022 void CopyFieldsUnrolledPairsHelper(Register dst, Register src, unsigned count, | 2035 void CopyFieldsUnrolledPairsHelper(Register dst, Register src, unsigned count, |
2023 Register scratch1, Register scratch2, | 2036 Register scratch1, Register scratch2, |
2024 Register scratch3, Register scratch4); | 2037 Register scratch3, Register scratch4); |
2025 void CopyFieldsUnrolledHelper(Register dst, Register src, unsigned count, | 2038 void CopyFieldsUnrolledHelper(Register dst, Register src, unsigned count, |
2026 Register scratch1, Register scratch2, | 2039 Register scratch1, Register scratch2, |
2027 Register scratch3); | 2040 Register scratch3); |
2028 | 2041 |
2029 // The actual Push and Pop implementations. These don't generate any code | 2042 // The actual Push and Pop implementations. These don't generate any code |
2030 // other than that required for the push or pop. This allows | 2043 // other than that required for the push or pop. This allows |
2031 // (Push|Pop)CPURegList to bundle together run-time assertions for a large | 2044 // (Push|Pop)CPURegList to bundle together run-time assertions for a large |
2032 // block of registers. | 2045 // block of registers. |
2033 // | 2046 // |
2034 // Note that size is per register, and is specified in bytes. | 2047 // Note that size is per register, and is specified in bytes. |
2035 void PushHelper(int count, int size, | 2048 void PushHelper(int count, int size, |
2036 const CPURegister& src0, const CPURegister& src1, | 2049 const CPURegister& src0, const CPURegister& src1, |
2037 const CPURegister& src2, const CPURegister& src3); | 2050 const CPURegister& src2, const CPURegister& src3); |
2038 void PopHelper(int count, int size, | 2051 void PopHelper(int count, int size, |
2039 const CPURegister& dst0, const CPURegister& dst1, | 2052 const CPURegister& dst0, const CPURegister& dst1, |
2040 const CPURegister& dst2, const CPURegister& dst3); | 2053 const CPURegister& dst2, const CPURegister& dst3); |
2041 | 2054 |
2042 // Perform necessary maintenance operations before a push or after a pop. | |
2043 // | |
2044 // Note that size is specified in bytes. | |
2045 void PushPreamble(Operand total_size); | |
2046 void PopPostamble(Operand total_size); | |
2047 | |
2048 void PushPreamble(int count, int size) { PushPreamble(count * size); } | |
2049 void PopPostamble(int count, int size) { PopPostamble(count * size); } | |
2050 | |
2051 // Call Printf. On a native build, a simple call will be generated, but if the | 2055 // Call Printf. On a native build, a simple call will be generated, but if the |
2052 // simulator is being used then a suitable pseudo-instruction is used. The | 2056 // simulator is being used then a suitable pseudo-instruction is used. The |
2053 // arguments and stack (csp) must be prepared by the caller as for a normal | 2057 // arguments and stack (csp) must be prepared by the caller as for a normal |
2054 // AAPCS64 call to 'printf'. | 2058 // AAPCS64 call to 'printf'. |
2055 // | 2059 // |
2056 // The 'args' argument should point to an array of variable arguments in their | 2060 // The 'args' argument should point to an array of variable arguments in their |
2057 // proper PCS registers (and in calling order). The argument registers can | 2061 // proper PCS registers (and in calling order). The argument registers can |
2058 // have mixed types. The format string (x0) should not be included. | 2062 // have mixed types. The format string (x0) should not be included. |
2059 void CallPrintf(int arg_count = 0, const CPURegister * args = NULL); | 2063 void CallPrintf(int arg_count = 0, const CPURegister * args = NULL); |
2060 | 2064 |
(...skipping 244 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2305 #error "Unsupported option" | 2309 #error "Unsupported option" |
2306 #define CODE_COVERAGE_STRINGIFY(x) #x | 2310 #define CODE_COVERAGE_STRINGIFY(x) #x |
2307 #define CODE_COVERAGE_TOSTRING(x) CODE_COVERAGE_STRINGIFY(x) | 2311 #define CODE_COVERAGE_TOSTRING(x) CODE_COVERAGE_STRINGIFY(x) |
2308 #define __FILE_LINE__ __FILE__ ":" CODE_COVERAGE_TOSTRING(__LINE__) | 2312 #define __FILE_LINE__ __FILE__ ":" CODE_COVERAGE_TOSTRING(__LINE__) |
2309 #define ACCESS_MASM(masm) masm->stop(__FILE_LINE__); masm-> | 2313 #define ACCESS_MASM(masm) masm->stop(__FILE_LINE__); masm-> |
2310 #else | 2314 #else |
2311 #define ACCESS_MASM(masm) masm-> | 2315 #define ACCESS_MASM(masm) masm-> |
2312 #endif | 2316 #endif |
2313 | 2317 |
2314 #endif // V8_ARM64_MACRO_ASSEMBLER_ARM64_H_ | 2318 #endif // V8_ARM64_MACRO_ASSEMBLER_ARM64_H_ |
OLD | NEW |