180814287SRaphael Isemann //===-- RegisterNumber.cpp ------------------------------------------------===//
201c3243fSZachary Turner //
32946cd70SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
42946cd70SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
52946cd70SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
601c3243fSZachary Turner //
701c3243fSZachary Turner //===----------------------------------------------------------------------===//
801c3243fSZachary Turner
901c3243fSZachary Turner #include "lldb/Target/RegisterNumber.h"
1001c3243fSZachary Turner #include "lldb/Target/RegisterContext.h"
1101c3243fSZachary Turner #include "lldb/Target/Thread.h"
1201c3243fSZachary Turner
1301c3243fSZachary Turner using namespace lldb_private;
1401c3243fSZachary Turner
RegisterNumber(lldb_private::Thread & thread,lldb::RegisterKind kind,uint32_t num)1501c3243fSZachary Turner RegisterNumber::RegisterNumber(lldb_private::Thread &thread,
1601c3243fSZachary Turner lldb::RegisterKind kind, uint32_t num)
1701c3243fSZachary Turner : m_reg_ctx_sp(thread.GetRegisterContext()), m_regnum(num), m_kind(kind),
1801c3243fSZachary Turner m_kind_regnum_map(), m_name("") {
1901c3243fSZachary Turner if (m_reg_ctx_sp.get()) {
2001c3243fSZachary Turner const lldb_private::RegisterInfo *reginfo =
2101c3243fSZachary Turner m_reg_ctx_sp->GetRegisterInfoAtIndex(
2201c3243fSZachary Turner GetAsKind(lldb::eRegisterKindLLDB));
2301c3243fSZachary Turner if (reginfo && reginfo->name) {
2401c3243fSZachary Turner m_name = reginfo->name;
2501c3243fSZachary Turner }
2601c3243fSZachary Turner }
2701c3243fSZachary Turner }
2801c3243fSZachary Turner
RegisterNumber()29*9494c510SJonas Devlieghere RegisterNumber::RegisterNumber() : m_reg_ctx_sp(), m_kind_regnum_map() {}
3001c3243fSZachary Turner
init(lldb_private::Thread & thread,lldb::RegisterKind kind,uint32_t num)3101c3243fSZachary Turner void RegisterNumber::init(lldb_private::Thread &thread, lldb::RegisterKind kind,
3201c3243fSZachary Turner uint32_t num) {
3301c3243fSZachary Turner m_reg_ctx_sp = thread.GetRegisterContext();
3401c3243fSZachary Turner m_regnum = num;
3501c3243fSZachary Turner m_kind = kind;
3601c3243fSZachary Turner if (m_reg_ctx_sp.get()) {
3701c3243fSZachary Turner const lldb_private::RegisterInfo *reginfo =
3801c3243fSZachary Turner m_reg_ctx_sp->GetRegisterInfoAtIndex(
3901c3243fSZachary Turner GetAsKind(lldb::eRegisterKindLLDB));
4001c3243fSZachary Turner if (reginfo && reginfo->name) {
4101c3243fSZachary Turner m_name = reginfo->name;
4201c3243fSZachary Turner }
4301c3243fSZachary Turner }
4401c3243fSZachary Turner }
4501c3243fSZachary Turner
operator =(const RegisterNumber & rhs)4601c3243fSZachary Turner const RegisterNumber &RegisterNumber::operator=(const RegisterNumber &rhs) {
4701c3243fSZachary Turner m_reg_ctx_sp = rhs.m_reg_ctx_sp;
4801c3243fSZachary Turner m_regnum = rhs.m_regnum;
4901c3243fSZachary Turner m_kind = rhs.m_kind;
5001c3243fSZachary Turner for (auto it : rhs.m_kind_regnum_map)
5101c3243fSZachary Turner m_kind_regnum_map[it.first] = it.second;
5201c3243fSZachary Turner m_name = rhs.m_name;
5301c3243fSZachary Turner return *this;
5401c3243fSZachary Turner }
5501c3243fSZachary Turner
operator ==(RegisterNumber & rhs)5601c3243fSZachary Turner bool RegisterNumber::operator==(RegisterNumber &rhs) {
5701c3243fSZachary Turner if (IsValid() != rhs.IsValid())
5801c3243fSZachary Turner return false;
5901c3243fSZachary Turner
6001c3243fSZachary Turner if (m_kind == rhs.m_kind) {
61a6682a41SJonas Devlieghere return m_regnum == rhs.m_regnum;
6201c3243fSZachary Turner }
6301c3243fSZachary Turner
6401c3243fSZachary Turner uint32_t rhs_regnum = rhs.GetAsKind(m_kind);
6501c3243fSZachary Turner if (rhs_regnum != LLDB_INVALID_REGNUM) {
66a6682a41SJonas Devlieghere return m_regnum == rhs_regnum;
6701c3243fSZachary Turner }
6801c3243fSZachary Turner uint32_t lhs_regnum = GetAsKind(rhs.m_kind);
69a6682a41SJonas Devlieghere { return lhs_regnum == rhs.m_regnum; }
7001c3243fSZachary Turner return false;
7101c3243fSZachary Turner }
7201c3243fSZachary Turner
operator !=(RegisterNumber & rhs)7301c3243fSZachary Turner bool RegisterNumber::operator!=(RegisterNumber &rhs) { return !(*this == rhs); }
7401c3243fSZachary Turner
IsValid() const7501c3243fSZachary Turner bool RegisterNumber::IsValid() const {
7601c3243fSZachary Turner return m_reg_ctx_sp.get() && m_kind != lldb::kNumRegisterKinds &&
7701c3243fSZachary Turner m_regnum != LLDB_INVALID_REGNUM;
7801c3243fSZachary Turner }
7901c3243fSZachary Turner
GetAsKind(lldb::RegisterKind kind)8001c3243fSZachary Turner uint32_t RegisterNumber::GetAsKind(lldb::RegisterKind kind) {
8101c3243fSZachary Turner if (m_regnum == LLDB_INVALID_REGNUM)
8201c3243fSZachary Turner return LLDB_INVALID_REGNUM;
8301c3243fSZachary Turner
8401c3243fSZachary Turner if (kind == m_kind)
8501c3243fSZachary Turner return m_regnum;
8601c3243fSZachary Turner
8701c3243fSZachary Turner Collection::iterator iter = m_kind_regnum_map.find(kind);
8801c3243fSZachary Turner if (iter != m_kind_regnum_map.end()) {
8901c3243fSZachary Turner return iter->second;
9001c3243fSZachary Turner }
9101c3243fSZachary Turner uint32_t output_regnum = LLDB_INVALID_REGNUM;
9201c3243fSZachary Turner if (m_reg_ctx_sp &&
9301c3243fSZachary Turner m_reg_ctx_sp->ConvertBetweenRegisterKinds(m_kind, m_regnum, kind,
9401c3243fSZachary Turner output_regnum) &&
9501c3243fSZachary Turner output_regnum != LLDB_INVALID_REGNUM) {
9601c3243fSZachary Turner m_kind_regnum_map[kind] = output_regnum;
9701c3243fSZachary Turner }
9801c3243fSZachary Turner return output_regnum;
9901c3243fSZachary Turner }
10001c3243fSZachary Turner
GetRegisterNumber() const10101c3243fSZachary Turner uint32_t RegisterNumber::GetRegisterNumber() const { return m_regnum; }
10201c3243fSZachary Turner
GetRegisterKind() const10301c3243fSZachary Turner lldb::RegisterKind RegisterNumber::GetRegisterKind() const { return m_kind; }
10401c3243fSZachary Turner
GetName()10501c3243fSZachary Turner const char *RegisterNumber::GetName() { return m_name; }
106