xref: /aosp_15_r20/art/compiler/utils/riscv64/managed_register_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 "managed_register_riscv64.h"
18*795d594fSAndroid Build Coastguard Worker 
19*795d594fSAndroid Build Coastguard Worker #include "base/globals.h"
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 
Overlaps(const Riscv64ManagedRegister & other) const24*795d594fSAndroid Build Coastguard Worker bool Riscv64ManagedRegister::Overlaps(const Riscv64ManagedRegister& other) const {
25*795d594fSAndroid Build Coastguard Worker   if (IsNoRegister() || other.IsNoRegister()) {
26*795d594fSAndroid Build Coastguard Worker     return false;
27*795d594fSAndroid Build Coastguard Worker   }
28*795d594fSAndroid Build Coastguard Worker   CHECK(IsValidManagedRegister());
29*795d594fSAndroid Build Coastguard Worker   CHECK(other.IsValidManagedRegister());
30*795d594fSAndroid Build Coastguard Worker 
31*795d594fSAndroid Build Coastguard Worker   return Equals(other);
32*795d594fSAndroid Build Coastguard Worker }
33*795d594fSAndroid Build Coastguard Worker 
Print(std::ostream & os) const34*795d594fSAndroid Build Coastguard Worker void Riscv64ManagedRegister::Print(std::ostream& os) const {
35*795d594fSAndroid Build Coastguard Worker   if (!IsValidManagedRegister()) {
36*795d594fSAndroid Build Coastguard Worker     os << "No Register";
37*795d594fSAndroid Build Coastguard Worker   } else if (IsXRegister()) {
38*795d594fSAndroid Build Coastguard Worker     os << "XRegister: " << static_cast<int>(AsXRegister());
39*795d594fSAndroid Build Coastguard Worker   } else if (IsFRegister()) {
40*795d594fSAndroid Build Coastguard Worker     os << "FRegister: " << static_cast<int>(AsFRegister());
41*795d594fSAndroid Build Coastguard Worker   } else {
42*795d594fSAndroid Build Coastguard Worker     os << "??: " << RegId();
43*795d594fSAndroid Build Coastguard Worker   }
44*795d594fSAndroid Build Coastguard Worker }
45*795d594fSAndroid Build Coastguard Worker 
operator <<(std::ostream & os,const Riscv64ManagedRegister & reg)46*795d594fSAndroid Build Coastguard Worker std::ostream& operator<<(std::ostream& os, const Riscv64ManagedRegister& reg) {
47*795d594fSAndroid Build Coastguard Worker   reg.Print(os);
48*795d594fSAndroid Build Coastguard Worker   return os;
49*795d594fSAndroid Build Coastguard Worker }
50*795d594fSAndroid Build Coastguard Worker 
51*795d594fSAndroid Build Coastguard Worker }  // namespace riscv64
52*795d594fSAndroid Build Coastguard Worker }  // namespace art
53