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