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 Workerbool 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 Workervoid 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 Workerstd::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