18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Mapping of DWARF debug register numbers into register names. 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Copyright (C) 2010 Will Deacon, ARM Ltd. 68c2ecf20Sopenharmony_ci */ 78c2ecf20Sopenharmony_ci 88c2ecf20Sopenharmony_ci#include <stddef.h> 98c2ecf20Sopenharmony_ci#include <linux/stringify.h> 108c2ecf20Sopenharmony_ci#include <dwarf-regs.h> 118c2ecf20Sopenharmony_ci 128c2ecf20Sopenharmony_cistruct pt_regs_dwarfnum { 138c2ecf20Sopenharmony_ci const char *name; 148c2ecf20Sopenharmony_ci unsigned int dwarfnum; 158c2ecf20Sopenharmony_ci}; 168c2ecf20Sopenharmony_ci 178c2ecf20Sopenharmony_ci#define REG_DWARFNUM_NAME(r, num) {.name = r, .dwarfnum = num} 188c2ecf20Sopenharmony_ci#define GPR_DWARFNUM_NAME(num) \ 198c2ecf20Sopenharmony_ci {.name = __stringify(%r##num), .dwarfnum = num} 208c2ecf20Sopenharmony_ci#define REG_DWARFNUM_END {.name = NULL, .dwarfnum = 0} 218c2ecf20Sopenharmony_ci 228c2ecf20Sopenharmony_ci/* 238c2ecf20Sopenharmony_ci * Reference: 248c2ecf20Sopenharmony_ci * http://infocenter.arm.com/help/topic/com.arm.doc.ihi0040a/IHI0040A_aadwarf.pdf 258c2ecf20Sopenharmony_ci */ 268c2ecf20Sopenharmony_cistatic const struct pt_regs_dwarfnum regdwarfnum_table[] = { 278c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(0), 288c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(1), 298c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(2), 308c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(3), 318c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(4), 328c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(5), 338c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(6), 348c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(7), 358c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(8), 368c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(9), 378c2ecf20Sopenharmony_ci GPR_DWARFNUM_NAME(10), 388c2ecf20Sopenharmony_ci REG_DWARFNUM_NAME("%fp", 11), 398c2ecf20Sopenharmony_ci REG_DWARFNUM_NAME("%ip", 12), 408c2ecf20Sopenharmony_ci REG_DWARFNUM_NAME("%sp", 13), 418c2ecf20Sopenharmony_ci REG_DWARFNUM_NAME("%lr", 14), 428c2ecf20Sopenharmony_ci REG_DWARFNUM_NAME("%pc", 15), 438c2ecf20Sopenharmony_ci REG_DWARFNUM_END, 448c2ecf20Sopenharmony_ci}; 458c2ecf20Sopenharmony_ci 468c2ecf20Sopenharmony_ci/** 478c2ecf20Sopenharmony_ci * get_arch_regstr() - lookup register name from it's DWARF register number 488c2ecf20Sopenharmony_ci * @n: the DWARF register number 498c2ecf20Sopenharmony_ci * 508c2ecf20Sopenharmony_ci * get_arch_regstr() returns the name of the register in struct 518c2ecf20Sopenharmony_ci * regdwarfnum_table from it's DWARF register number. If the register is not 528c2ecf20Sopenharmony_ci * found in the table, this returns NULL; 538c2ecf20Sopenharmony_ci */ 548c2ecf20Sopenharmony_ciconst char *get_arch_regstr(unsigned int n) 558c2ecf20Sopenharmony_ci{ 568c2ecf20Sopenharmony_ci const struct pt_regs_dwarfnum *roff; 578c2ecf20Sopenharmony_ci for (roff = regdwarfnum_table; roff->name != NULL; roff++) 588c2ecf20Sopenharmony_ci if (roff->dwarfnum == n) 598c2ecf20Sopenharmony_ci return roff->name; 608c2ecf20Sopenharmony_ci return NULL; 618c2ecf20Sopenharmony_ci} 62