blob: 11314e08ed91a2adc51a62553d701ff56d833953 [file] [log] [blame]
Stuart Monteithb95a5342014-03-12 13:32:32 +00001/*
2 * Copyright (C) 2014 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ART_RUNTIME_ARCH_ARM64_CONTEXT_ARM64_H_
18#define ART_RUNTIME_ARCH_ARM64_CONTEXT_ARM64_H_
19
20#include "arch/context.h"
21#include "base/logging.h"
Andreas Gampe794ad762015-02-23 08:12:24 -080022#include "base/macros.h"
Stuart Monteithb95a5342014-03-12 13:32:32 +000023#include "registers_arm64.h"
24
25namespace art {
26namespace arm64 {
27
28class Arm64Context : public Context {
29 public:
30 Arm64Context() {
31 Reset();
32 }
33
34 ~Arm64Context() {}
35
Sebastien Hertz0bcb2902014-06-17 15:52:45 +020036 void Reset() OVERRIDE;
Stuart Monteithb95a5342014-03-12 13:32:32 +000037
Mathieu Chartier90443472015-07-16 20:32:27 -070038 void FillCalleeSaves(const StackVisitor& fr) OVERRIDE SHARED_REQUIRES(Locks::mutator_lock_);
Stuart Monteithb95a5342014-03-12 13:32:32 +000039
Sebastien Hertz0bcb2902014-06-17 15:52:45 +020040 void SetSP(uintptr_t new_sp) OVERRIDE {
Sebastien Hertz96ba8dc2015-01-22 18:57:14 +010041 SetGPR(SP, new_sp);
Stuart Monteithb95a5342014-03-12 13:32:32 +000042 }
43
Sebastien Hertz0bcb2902014-06-17 15:52:45 +020044 void SetPC(uintptr_t new_lr) OVERRIDE {
Andreas Gampe639bdd12015-06-03 11:22:45 -070045 SetGPR(kPC, new_lr);
46 }
47
48 void SetArg0(uintptr_t new_arg0_value) OVERRIDE {
49 SetGPR(X0, new_arg0_value);
Sebastien Hertz96ba8dc2015-01-22 18:57:14 +010050 }
51
52 bool IsAccessibleGPR(uint32_t reg) OVERRIDE {
Andreas Gampe639bdd12015-06-03 11:22:45 -070053 DCHECK_LT(reg, arraysize(gprs_));
Sebastien Hertz96ba8dc2015-01-22 18:57:14 +010054 return gprs_[reg] != nullptr;
Stuart Monteithb95a5342014-03-12 13:32:32 +000055 }
56
Sebastien Hertz0bcb2902014-06-17 15:52:45 +020057 uintptr_t* GetGPRAddress(uint32_t reg) OVERRIDE {
Andreas Gampe639bdd12015-06-03 11:22:45 -070058 DCHECK_LT(reg, arraysize(gprs_));
Stuart Monteithb95a5342014-03-12 13:32:32 +000059 return gprs_[reg];
60 }
61
Sebastien Hertz96ba8dc2015-01-22 18:57:14 +010062 uintptr_t GetGPR(uint32_t reg) OVERRIDE {
Andreas Gampe639bdd12015-06-03 11:22:45 -070063 // Note: PC isn't an available GPR (outside of internals), so don't allow retrieving the value.
Alexandre Rames37c92df2014-10-17 14:35:27 +010064 DCHECK_LT(reg, static_cast<uint32_t>(kNumberOfXRegisters));
Sebastien Hertz96ba8dc2015-01-22 18:57:14 +010065 DCHECK(IsAccessibleGPR(reg));
66 return *gprs_[reg];
Stuart Monteithb95a5342014-03-12 13:32:32 +000067 }
68
Sebastien Hertz96ba8dc2015-01-22 18:57:14 +010069 void SetGPR(uint32_t reg, uintptr_t value) OVERRIDE;
Sebastien Hertz0bcb2902014-06-17 15:52:45 +020070
Sebastien Hertz96ba8dc2015-01-22 18:57:14 +010071 bool IsAccessibleFPR(uint32_t reg) OVERRIDE {
Sebastien Hertz0bcb2902014-06-17 15:52:45 +020072 DCHECK_LT(reg, static_cast<uint32_t>(kNumberOfDRegisters));
Sebastien Hertz96ba8dc2015-01-22 18:57:14 +010073 return fprs_[reg] != nullptr;
Sebastien Hertz0bcb2902014-06-17 15:52:45 +020074 }
75
Sebastien Hertz96ba8dc2015-01-22 18:57:14 +010076 uintptr_t GetFPR(uint32_t reg) OVERRIDE {
77 DCHECK_LT(reg, static_cast<uint32_t>(kNumberOfDRegisters));
78 DCHECK(IsAccessibleFPR(reg));
79 return *fprs_[reg];
80 }
81
82 void SetFPR(uint32_t reg, uintptr_t value) OVERRIDE;
Sebastien Hertz0bcb2902014-06-17 15:52:45 +020083
84 void SmashCallerSaves() OVERRIDE;
Andreas Gampe794ad762015-02-23 08:12:24 -080085 NO_RETURN void DoLongJump() OVERRIDE;
Stuart Monteithb95a5342014-03-12 13:32:32 +000086
Andreas Gampe639bdd12015-06-03 11:22:45 -070087 static constexpr size_t kPC = kNumberOfXRegisters;
88
Stuart Monteithb95a5342014-03-12 13:32:32 +000089 private:
Andreas Gampe639bdd12015-06-03 11:22:45 -070090 // Pointers to register locations, initialized to null or the specific registers below. We need
91 // an additional one for the PC.
92 uintptr_t* gprs_[kNumberOfXRegisters + 1];
Stuart Monteithb95a5342014-03-12 13:32:32 +000093 uint64_t * fprs_[kNumberOfDRegisters];
Andreas Gampe639bdd12015-06-03 11:22:45 -070094 // Hold values for sp, pc and arg0 if they are not located within a stack frame.
95 uintptr_t sp_, pc_, arg0_;
Stuart Monteithb95a5342014-03-12 13:32:32 +000096};
97
98} // namespace arm64
99} // namespace art
100
101#endif // ART_RUNTIME_ARCH_ARM64_CONTEXT_ARM64_H_