 8ab596afb9
			
		
	
	
	8ab596afb9
	
	
	
		
			
			This patch hooks in the perf_regs and libunwind code for ARM64. The tools/perf/arch/arm64 is created; it contains the arch specific code for DWARF unwinding. Signed-off-by: Jean Pihet <jean.pihet@linaro.org> Acked-by: Will Deacon <will.deacon@arm.com> Link: http://lkml.kernel.org/r/1398688353-3737-1-git-send-email-jean.pihet@linaro.org Signed-off-by: Jiri Olsa <jolsa@kernel.org>
		
			
				
	
	
		
			80 lines
		
	
	
	
		
			2.1 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
	
		
			2.1 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Mapping of DWARF debug register numbers into register names.
 | |
|  *
 | |
|  * Copyright (C) 2010 Will Deacon, ARM Ltd.
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU General Public License version 2 as
 | |
|  * published by the Free Software Foundation.
 | |
|  */
 | |
| 
 | |
| #include <stddef.h>
 | |
| #include <dwarf-regs.h>
 | |
| 
 | |
| struct pt_regs_dwarfnum {
 | |
| 	const char *name;
 | |
| 	unsigned int dwarfnum;
 | |
| };
 | |
| 
 | |
| #define STR(s) #s
 | |
| #define REG_DWARFNUM_NAME(r, num) {.name = r, .dwarfnum = num}
 | |
| #define GPR_DWARFNUM_NAME(num) \
 | |
| 	{.name = STR(%x##num), .dwarfnum = num}
 | |
| #define REG_DWARFNUM_END {.name = NULL, .dwarfnum = 0}
 | |
| 
 | |
| /*
 | |
|  * Reference:
 | |
|  * http://infocenter.arm.com/help/topic/com.arm.doc.ihi0057b/IHI0057B_aadwarf64.pdf
 | |
|  */
 | |
| static const struct pt_regs_dwarfnum regdwarfnum_table[] = {
 | |
| 	GPR_DWARFNUM_NAME(0),
 | |
| 	GPR_DWARFNUM_NAME(1),
 | |
| 	GPR_DWARFNUM_NAME(2),
 | |
| 	GPR_DWARFNUM_NAME(3),
 | |
| 	GPR_DWARFNUM_NAME(4),
 | |
| 	GPR_DWARFNUM_NAME(5),
 | |
| 	GPR_DWARFNUM_NAME(6),
 | |
| 	GPR_DWARFNUM_NAME(7),
 | |
| 	GPR_DWARFNUM_NAME(8),
 | |
| 	GPR_DWARFNUM_NAME(9),
 | |
| 	GPR_DWARFNUM_NAME(10),
 | |
| 	GPR_DWARFNUM_NAME(11),
 | |
| 	GPR_DWARFNUM_NAME(12),
 | |
| 	GPR_DWARFNUM_NAME(13),
 | |
| 	GPR_DWARFNUM_NAME(14),
 | |
| 	GPR_DWARFNUM_NAME(15),
 | |
| 	GPR_DWARFNUM_NAME(16),
 | |
| 	GPR_DWARFNUM_NAME(17),
 | |
| 	GPR_DWARFNUM_NAME(18),
 | |
| 	GPR_DWARFNUM_NAME(19),
 | |
| 	GPR_DWARFNUM_NAME(20),
 | |
| 	GPR_DWARFNUM_NAME(21),
 | |
| 	GPR_DWARFNUM_NAME(22),
 | |
| 	GPR_DWARFNUM_NAME(23),
 | |
| 	GPR_DWARFNUM_NAME(24),
 | |
| 	GPR_DWARFNUM_NAME(25),
 | |
| 	GPR_DWARFNUM_NAME(26),
 | |
| 	GPR_DWARFNUM_NAME(27),
 | |
| 	GPR_DWARFNUM_NAME(28),
 | |
| 	GPR_DWARFNUM_NAME(29),
 | |
| 	REG_DWARFNUM_NAME("%lr", 30),
 | |
| 	REG_DWARFNUM_NAME("%sp", 31),
 | |
| 	REG_DWARFNUM_END,
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * get_arch_regstr() - lookup register name from it's DWARF register number
 | |
|  * @n:	the DWARF register number
 | |
|  *
 | |
|  * get_arch_regstr() returns the name of the register in struct
 | |
|  * regdwarfnum_table from it's DWARF register number. If the register is not
 | |
|  * found in the table, this returns NULL;
 | |
|  */
 | |
| const char *get_arch_regstr(unsigned int n)
 | |
| {
 | |
| 	const struct pt_regs_dwarfnum *roff;
 | |
| 	for (roff = regdwarfnum_table; roff->name != NULL; roff++)
 | |
| 		if (roff->dwarfnum == n)
 | |
| 			return roff->name;
 | |
| 	return NULL;
 | |
| }
 |