xref: /aosp_15_r20/art/runtime/arch/riscv64/registers_riscv64.cc (revision 795d594fd825385562da6b089ea9b2033f3abf5a)
1*795d594fSAndroid Build Coastguard Worker /*
2*795d594fSAndroid Build Coastguard Worker  * Copyright (C) 2023 The Android Open Source Project
3*795d594fSAndroid Build Coastguard Worker  *
4*795d594fSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*795d594fSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*795d594fSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*795d594fSAndroid Build Coastguard Worker  *
8*795d594fSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*795d594fSAndroid Build Coastguard Worker  *
10*795d594fSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*795d594fSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*795d594fSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*795d594fSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*795d594fSAndroid Build Coastguard Worker  * limitations under the License.
15*795d594fSAndroid Build Coastguard Worker  */
16*795d594fSAndroid Build Coastguard Worker 
17*795d594fSAndroid Build Coastguard Worker #include "registers_riscv64.h"
18*795d594fSAndroid Build Coastguard Worker 
19*795d594fSAndroid Build Coastguard Worker #include <ostream>
20*795d594fSAndroid Build Coastguard Worker 
21*795d594fSAndroid Build Coastguard Worker namespace art HIDDEN {
22*795d594fSAndroid Build Coastguard Worker namespace riscv64 {
23*795d594fSAndroid Build Coastguard Worker 
24*795d594fSAndroid Build Coastguard Worker static const char* kXRegisterNames[] = {"zero", "ra", "sp",  "gp",  "tp", "t0", "t1", "t2",
25*795d594fSAndroid Build Coastguard Worker                                         "fp",   "s1", "a0",  "a1",  "a2", "a3", "a4", "a5",
26*795d594fSAndroid Build Coastguard Worker                                         "a6",   "a7", "s2",  "s3",  "s4", "s5", "s6", "s7",
27*795d594fSAndroid Build Coastguard Worker                                         "s8",   "s9", "s10", "s11", "t3", "t4", "t5", "t6"};
28*795d594fSAndroid Build Coastguard Worker 
29*795d594fSAndroid Build Coastguard Worker static const char* kFRegisterNames[] = {"ft0", "ft1", "ft2",  "ft3",  "ft4", "ft5", "ft6",  "ft7",
30*795d594fSAndroid Build Coastguard Worker                                         "fs0", "fs1", "fa0",  "fa1",  "fa2", "fa3", "fa4",  "fa5",
31*795d594fSAndroid Build Coastguard Worker                                         "fa6", "fa7", "fs2",  "fs3",  "fs4", "fs5", "fs6",  "fs7",
32*795d594fSAndroid Build Coastguard Worker                                         "fs8", "fs9", "fs10", "fs11", "ft8", "ft9", "ft10", "ft11"};
33*795d594fSAndroid Build Coastguard Worker 
34*795d594fSAndroid Build Coastguard Worker static const char* kVRegisterNames[] = {"v0",  "v1",  "v2",  "v3",  "v4",  "v5",  "v6",  "v7",
35*795d594fSAndroid Build Coastguard Worker                                         "v8",  "v9",  "v10", "v11", "v12", "v13", "v14", "v15",
36*795d594fSAndroid Build Coastguard Worker                                         "v16", "v17", "v18", "v19", "v20", "v21", "v22", "v23",
37*795d594fSAndroid Build Coastguard Worker                                         "v24", "v25", "v26", "v27", "v28", "v29", "v30", "v31"};
38*795d594fSAndroid Build Coastguard Worker 
operator <<(std::ostream & os,const XRegister & rhs)39*795d594fSAndroid Build Coastguard Worker std::ostream& operator<<(std::ostream& os, const XRegister& rhs) {
40*795d594fSAndroid Build Coastguard Worker   if (rhs >= Zero && rhs < kNumberOfXRegisters) {
41*795d594fSAndroid Build Coastguard Worker     os << kXRegisterNames[rhs];
42*795d594fSAndroid Build Coastguard Worker   } else {
43*795d594fSAndroid Build Coastguard Worker     os << "XRegister[" << static_cast<int>(rhs) << "]";
44*795d594fSAndroid Build Coastguard Worker   }
45*795d594fSAndroid Build Coastguard Worker   return os;
46*795d594fSAndroid Build Coastguard Worker }
47*795d594fSAndroid Build Coastguard Worker 
operator <<(std::ostream & os,const FRegister & rhs)48*795d594fSAndroid Build Coastguard Worker std::ostream& operator<<(std::ostream& os, const FRegister& rhs) {
49*795d594fSAndroid Build Coastguard Worker   if (rhs >= FT0 && rhs < kNumberOfFRegisters) {
50*795d594fSAndroid Build Coastguard Worker     os << kFRegisterNames[rhs];
51*795d594fSAndroid Build Coastguard Worker   } else {
52*795d594fSAndroid Build Coastguard Worker     os << "FRegister[" << static_cast<int>(rhs) << "]";
53*795d594fSAndroid Build Coastguard Worker   }
54*795d594fSAndroid Build Coastguard Worker   return os;
55*795d594fSAndroid Build Coastguard Worker }
56*795d594fSAndroid Build Coastguard Worker 
operator <<(std::ostream & os,const VRegister & rhs)57*795d594fSAndroid Build Coastguard Worker std::ostream& operator<<(std::ostream& os, const VRegister& rhs) {
58*795d594fSAndroid Build Coastguard Worker   if (rhs >= V0 && rhs < kNumberOfVRegisters) {
59*795d594fSAndroid Build Coastguard Worker     os << kVRegisterNames[rhs];
60*795d594fSAndroid Build Coastguard Worker   } else {
61*795d594fSAndroid Build Coastguard Worker     os << "VRegister[" << static_cast<int>(rhs) << "]";
62*795d594fSAndroid Build Coastguard Worker   }
63*795d594fSAndroid Build Coastguard Worker   return os;
64*795d594fSAndroid Build Coastguard Worker }
65*795d594fSAndroid Build Coastguard Worker 
66*795d594fSAndroid Build Coastguard Worker }  // namespace riscv64
67*795d594fSAndroid Build Coastguard Worker }  // namespace art
68