Linux Audio

Check our new training course

Linux BSP development engineering services

Need help to port Linux and bootloaders to your hardware?
Loading...
v3.15
  1/*
  2 * Post mortem Dwarf CFI based unwinding on top of regs and stack dumps.
  3 *
  4 * Lots of this code have been borrowed or heavily inspired from parts of
  5 * the libunwind 0.99 code which are (amongst other contributors I may have
  6 * forgotten):
  7 *
  8 * Copyright (C) 2002-2007 Hewlett-Packard Co
  9 *	Contributed by David Mosberger-Tang <davidm@hpl.hp.com>
 10 *
 11 * And the bugs have been added by:
 12 *
 13 * Copyright (C) 2010, Frederic Weisbecker <fweisbec@gmail.com>
 14 * Copyright (C) 2012, Jiri Olsa <jolsa@redhat.com>
 15 *
 16 */
 17
 18#include <elf.h>
 19#include <gelf.h>
 20#include <fcntl.h>
 21#include <string.h>
 22#include <unistd.h>
 23#include <sys/mman.h>
 24#include <linux/list.h>
 25#include <libunwind.h>
 26#include <libunwind-ptrace.h>
 
 27#include "thread.h"
 28#include "session.h"
 29#include "perf_regs.h"
 30#include "unwind.h"
 31#include "symbol.h"
 32#include "util.h"
 
 33
 34extern int
 35UNW_OBJ(dwarf_search_unwind_table) (unw_addr_space_t as,
 36				    unw_word_t ip,
 37				    unw_dyn_info_t *di,
 38				    unw_proc_info_t *pi,
 39				    int need_unwind_info, void *arg);
 40
 41#define dwarf_search_unwind_table UNW_OBJ(dwarf_search_unwind_table)
 42
 43extern int
 44UNW_OBJ(dwarf_find_debug_frame) (int found, unw_dyn_info_t *di_debug,
 45				 unw_word_t ip,
 46				 unw_word_t segbase,
 47				 const char *obj_name, unw_word_t start,
 48				 unw_word_t end);
 49
 50#define dwarf_find_debug_frame UNW_OBJ(dwarf_find_debug_frame)
 51
 52#define DW_EH_PE_FORMAT_MASK	0x0f	/* format of the encoded value */
 53#define DW_EH_PE_APPL_MASK	0x70	/* how the value is to be applied */
 54
 55/* Pointer-encoding formats: */
 56#define DW_EH_PE_omit		0xff
 57#define DW_EH_PE_ptr		0x00	/* pointer-sized unsigned value */
 58#define DW_EH_PE_udata4		0x03	/* unsigned 32-bit value */
 59#define DW_EH_PE_udata8		0x04	/* unsigned 64-bit value */
 60#define DW_EH_PE_sdata4		0x0b	/* signed 32-bit value */
 61#define DW_EH_PE_sdata8		0x0c	/* signed 64-bit value */
 62
 63/* Pointer-encoding application: */
 64#define DW_EH_PE_absptr		0x00	/* absolute value */
 65#define DW_EH_PE_pcrel		0x10	/* rel. to addr. of encoded value */
 66
 67/*
 68 * The following are not documented by LSB v1.3, yet they are used by
 69 * GCC, presumably they aren't documented by LSB since they aren't
 70 * used on Linux:
 71 */
 72#define DW_EH_PE_funcrel	0x40	/* start-of-procedure-relative */
 73#define DW_EH_PE_aligned	0x50	/* aligned pointer */
 74
 75/* Flags intentionaly not handled, since they're not needed:
 76 * #define DW_EH_PE_indirect      0x80
 77 * #define DW_EH_PE_uleb128       0x01
 78 * #define DW_EH_PE_udata2        0x02
 79 * #define DW_EH_PE_sleb128       0x09
 80 * #define DW_EH_PE_sdata2        0x0a
 81 * #define DW_EH_PE_textrel       0x20
 82 * #define DW_EH_PE_datarel       0x30
 83 */
 84
 85struct unwind_info {
 86	struct perf_sample	*sample;
 87	struct machine		*machine;
 88	struct thread		*thread;
 89};
 90
 91#define dw_read(ptr, type, end) ({	\
 92	type *__p = (type *) ptr;	\
 93	type  __v;			\
 94	if ((__p + 1) > (type *) end)	\
 95		return -EINVAL;		\
 96	__v = *__p++;			\
 97	ptr = (typeof(ptr)) __p;	\
 98	__v;				\
 99	})
100
101static int __dw_read_encoded_value(u8 **p, u8 *end, u64 *val,
102				   u8 encoding)
103{
104	u8 *cur = *p;
105	*val = 0;
106
107	switch (encoding) {
108	case DW_EH_PE_omit:
109		*val = 0;
110		goto out;
111	case DW_EH_PE_ptr:
112		*val = dw_read(cur, unsigned long, end);
113		goto out;
114	default:
115		break;
116	}
117
118	switch (encoding & DW_EH_PE_APPL_MASK) {
119	case DW_EH_PE_absptr:
120		break;
121	case DW_EH_PE_pcrel:
122		*val = (unsigned long) cur;
123		break;
124	default:
125		return -EINVAL;
126	}
127
128	if ((encoding & 0x07) == 0x00)
129		encoding |= DW_EH_PE_udata4;
130
131	switch (encoding & DW_EH_PE_FORMAT_MASK) {
132	case DW_EH_PE_sdata4:
133		*val += dw_read(cur, s32, end);
134		break;
135	case DW_EH_PE_udata4:
136		*val += dw_read(cur, u32, end);
137		break;
138	case DW_EH_PE_sdata8:
139		*val += dw_read(cur, s64, end);
140		break;
141	case DW_EH_PE_udata8:
142		*val += dw_read(cur, u64, end);
143		break;
144	default:
145		return -EINVAL;
146	}
147
148 out:
149	*p = cur;
150	return 0;
151}
152
153#define dw_read_encoded_value(ptr, end, enc) ({			\
154	u64 __v;						\
155	if (__dw_read_encoded_value(&ptr, end, &__v, enc)) {	\
156		return -EINVAL;                                 \
157	}                                                       \
158	__v;                                                    \
159	})
160
161static u64 elf_section_offset(int fd, const char *name)
162{
163	Elf *elf;
164	GElf_Ehdr ehdr;
165	GElf_Shdr shdr;
166	u64 offset = 0;
167
168	elf = elf_begin(fd, PERF_ELF_C_READ_MMAP, NULL);
169	if (elf == NULL)
170		return 0;
171
172	do {
173		if (gelf_getehdr(elf, &ehdr) == NULL)
174			break;
175
176		if (!elf_section_by_name(elf, &ehdr, &shdr, name, NULL))
177			break;
178
179		offset = shdr.sh_offset;
180	} while (0);
181
182	elf_end(elf);
183	return offset;
184}
185
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
186struct table_entry {
187	u32 start_ip_offset;
188	u32 fde_offset;
189};
190
191struct eh_frame_hdr {
192	unsigned char version;
193	unsigned char eh_frame_ptr_enc;
194	unsigned char fde_count_enc;
195	unsigned char table_enc;
196
197	/*
198	 * The rest of the header is variable-length and consists of the
199	 * following members:
200	 *
201	 *	encoded_t eh_frame_ptr;
202	 *	encoded_t fde_count;
203	 */
204
205	/* A single encoded pointer should not be more than 8 bytes. */
206	u64 enc[2];
207
208	/*
209	 * struct {
210	 *    encoded_t start_ip;
211	 *    encoded_t fde_addr;
212	 * } binary_search_table[fde_count];
213	 */
214	char data[0];
215} __packed;
216
217static int unwind_spec_ehframe(struct dso *dso, struct machine *machine,
218			       u64 offset, u64 *table_data, u64 *segbase,
219			       u64 *fde_count)
220{
221	struct eh_frame_hdr hdr;
222	u8 *enc = (u8 *) &hdr.enc;
223	u8 *end = (u8 *) &hdr.data;
224	ssize_t r;
225
226	r = dso__data_read_offset(dso, machine, offset,
227				  (u8 *) &hdr, sizeof(hdr));
228	if (r != sizeof(hdr))
229		return -EINVAL;
230
231	/* We dont need eh_frame_ptr, just skip it. */
232	dw_read_encoded_value(enc, end, hdr.eh_frame_ptr_enc);
233
234	*fde_count  = dw_read_encoded_value(enc, end, hdr.fde_count_enc);
235	*segbase    = offset;
236	*table_data = (enc - (u8 *) &hdr) + offset;
237	return 0;
238}
239
240static int read_unwind_spec_eh_frame(struct dso *dso, struct machine *machine,
241				     u64 *table_data, u64 *segbase,
242				     u64 *fde_count)
243{
244	int ret = -EINVAL, fd;
245	u64 offset;
246
247	fd = dso__data_fd(dso, machine);
248	if (fd < 0)
249		return -EINVAL;
250
251	/* Check the .eh_frame section for unwinding info */
252	offset = elf_section_offset(fd, ".eh_frame_hdr");
253	close(fd);
 
 
 
254
255	if (offset)
256		ret = unwind_spec_ehframe(dso, machine, offset,
257					  table_data, segbase,
258					  fde_count);
259
260	return ret;
261}
262
263#ifndef NO_LIBUNWIND_DEBUG_FRAME
264static int read_unwind_spec_debug_frame(struct dso *dso,
265					struct machine *machine, u64 *offset)
266{
267	int fd = dso__data_fd(dso, machine);
 
268
269	if (fd < 0)
270		return -EINVAL;
 
 
271
272	/* Check the .debug_frame section for unwinding info */
273	*offset = elf_section_offset(fd, ".debug_frame");
274	close(fd);
 
 
275
 
276	if (*offset)
277		return 0;
278
279	return -EINVAL;
280}
281#endif
282
283static struct map *find_map(unw_word_t ip, struct unwind_info *ui)
284{
285	struct addr_location al;
286
287	thread__find_addr_map(ui->thread, ui->machine, PERF_RECORD_MISC_USER,
288			      MAP__FUNCTION, ip, &al);
 
 
 
 
 
 
 
 
 
289	return al.map;
290}
291
292static int
293find_proc_info(unw_addr_space_t as, unw_word_t ip, unw_proc_info_t *pi,
294	       int need_unwind_info, void *arg)
295{
296	struct unwind_info *ui = arg;
297	struct map *map;
298	unw_dyn_info_t di;
299	u64 table_data, segbase, fde_count;
 
300
301	map = find_map(ip, ui);
302	if (!map || !map->dso)
303		return -EINVAL;
304
305	pr_debug("unwind: find_proc_info dso %s\n", map->dso->name);
306
307	/* Check the .eh_frame section for unwinding info */
308	if (!read_unwind_spec_eh_frame(map->dso, ui->machine,
309				       &table_data, &segbase, &fde_count)) {
310		memset(&di, 0, sizeof(di));
311		di.format   = UNW_INFO_FORMAT_REMOTE_TABLE;
312		di.start_ip = map->start;
313		di.end_ip   = map->end;
314		di.u.rti.segbase    = map->start + segbase;
315		di.u.rti.table_data = map->start + table_data;
316		di.u.rti.table_len  = fde_count * sizeof(struct table_entry)
317				      / sizeof(unw_word_t);
318		return dwarf_search_unwind_table(as, ip, &di, pi,
319						 need_unwind_info, arg);
320	}
321
322#ifndef NO_LIBUNWIND_DEBUG_FRAME
323	/* Check the .debug_frame section for unwinding info */
324	if (!read_unwind_spec_debug_frame(map->dso, ui->machine, &segbase)) {
 
 
 
 
 
 
 
 
 
 
 
325		memset(&di, 0, sizeof(di));
326		if (dwarf_find_debug_frame(0, &di, ip, 0, map->dso->name,
327					   map->start, map->end))
328			return dwarf_search_unwind_table(as, ip, &di, pi,
329							 need_unwind_info, arg);
330	}
331#endif
332
333	return -EINVAL;
334}
335
336static int access_fpreg(unw_addr_space_t __maybe_unused as,
337			unw_regnum_t __maybe_unused num,
338			unw_fpreg_t __maybe_unused *val,
339			int __maybe_unused __write,
340			void __maybe_unused *arg)
341{
342	pr_err("unwind: access_fpreg unsupported\n");
343	return -UNW_EINVAL;
344}
345
346static int get_dyn_info_list_addr(unw_addr_space_t __maybe_unused as,
347				  unw_word_t __maybe_unused *dil_addr,
348				  void __maybe_unused *arg)
349{
350	return -UNW_ENOINFO;
351}
352
353static int resume(unw_addr_space_t __maybe_unused as,
354		  unw_cursor_t __maybe_unused *cu,
355		  void __maybe_unused *arg)
356{
357	pr_err("unwind: resume unsupported\n");
358	return -UNW_EINVAL;
359}
360
361static int
362get_proc_name(unw_addr_space_t __maybe_unused as,
363	      unw_word_t __maybe_unused addr,
364		char __maybe_unused *bufp, size_t __maybe_unused buf_len,
365		unw_word_t __maybe_unused *offp, void __maybe_unused *arg)
366{
367	pr_err("unwind: get_proc_name unsupported\n");
368	return -UNW_EINVAL;
369}
370
371static int access_dso_mem(struct unwind_info *ui, unw_word_t addr,
372			  unw_word_t *data)
373{
374	struct addr_location al;
375	ssize_t size;
376
377	thread__find_addr_map(ui->thread, ui->machine, PERF_RECORD_MISC_USER,
378			      MAP__FUNCTION, addr, &al);
379	if (!al.map) {
380		pr_debug("unwind: no map for %lx\n", (unsigned long)addr);
381		return -1;
382	}
383
384	if (!al.map->dso)
385		return -1;
386
387	size = dso__data_read_addr(al.map->dso, al.map, ui->machine,
388				   addr, (u8 *) data, sizeof(*data));
389
390	return !(size == sizeof(*data));
391}
392
393static int access_mem(unw_addr_space_t __maybe_unused as,
394		      unw_word_t addr, unw_word_t *valp,
395		      int __write, void *arg)
396{
397	struct unwind_info *ui = arg;
398	struct stack_dump *stack = &ui->sample->user_stack;
399	u64 start, end;
400	int offset;
401	int ret;
402
403	/* Don't support write, probably not needed. */
404	if (__write || !stack || !ui->sample->user_regs.regs) {
405		*valp = 0;
406		return 0;
407	}
408
409	ret = perf_reg_value(&start, &ui->sample->user_regs, PERF_REG_SP);
410	if (ret)
411		return ret;
412
413	end = start + stack->size;
414
415	/* Check overflow. */
416	if (addr + sizeof(unw_word_t) < addr)
417		return -EINVAL;
418
419	if (addr < start || addr + sizeof(unw_word_t) >= end) {
420		ret = access_dso_mem(ui, addr, valp);
421		if (ret) {
422			pr_debug("unwind: access_mem %p not inside range"
423				 " 0x%" PRIx64 "-0x%" PRIx64 "\n",
424				 (void *) addr, start, end);
425			*valp = 0;
426			return ret;
427		}
428		return 0;
429	}
430
431	offset = addr - start;
432	*valp  = *(unw_word_t *)&stack->data[offset];
433	pr_debug("unwind: access_mem addr %p val %lx, offset %d\n",
434		 (void *) addr, (unsigned long)*valp, offset);
435	return 0;
436}
437
438static int access_reg(unw_addr_space_t __maybe_unused as,
439		      unw_regnum_t regnum, unw_word_t *valp,
440		      int __write, void *arg)
441{
442	struct unwind_info *ui = arg;
443	int id, ret;
444	u64 val;
445
446	/* Don't support write, I suspect we don't need it. */
447	if (__write) {
448		pr_err("unwind: access_reg w %d\n", regnum);
449		return 0;
450	}
451
452	if (!ui->sample->user_regs.regs) {
453		*valp = 0;
454		return 0;
455	}
456
457	id = libunwind__arch_reg_id(regnum);
458	if (id < 0)
459		return -EINVAL;
460
461	ret = perf_reg_value(&val, &ui->sample->user_regs, id);
462	if (ret) {
463		pr_err("unwind: can't read reg %d\n", regnum);
464		return ret;
465	}
466
467	*valp = (unw_word_t) val;
468	pr_debug("unwind: reg %d, val %lx\n", regnum, (unsigned long)*valp);
469	return 0;
470}
471
472static void put_unwind_info(unw_addr_space_t __maybe_unused as,
473			    unw_proc_info_t *pi __maybe_unused,
474			    void *arg __maybe_unused)
475{
476	pr_debug("unwind: put_unwind_info called\n");
477}
478
479static int entry(u64 ip, struct thread *thread, struct machine *machine,
480		 unwind_entry_cb_t cb, void *arg)
481{
482	struct unwind_entry e;
483	struct addr_location al;
484
485	thread__find_addr_location(thread, machine,
486				   PERF_RECORD_MISC_USER,
487				   MAP__FUNCTION, ip, &al);
488
489	e.ip = ip;
490	e.map = al.map;
491	e.sym = al.sym;
492
493	pr_debug("unwind: %s:ip = 0x%" PRIx64 " (0x%" PRIx64 ")\n",
494		 al.sym ? al.sym->name : "''",
495		 ip,
496		 al.map ? al.map->map_ip(al.map, ip) : (u64) 0);
497
498	return cb(&e, arg);
499}
500
501static void display_error(int err)
502{
503	switch (err) {
504	case UNW_EINVAL:
505		pr_err("unwind: Only supports local.\n");
506		break;
507	case UNW_EUNSPEC:
508		pr_err("unwind: Unspecified error.\n");
509		break;
510	case UNW_EBADREG:
511		pr_err("unwind: Register unavailable.\n");
512		break;
513	default:
514		break;
515	}
516}
517
518static unw_accessors_t accessors = {
519	.find_proc_info		= find_proc_info,
520	.put_unwind_info	= put_unwind_info,
521	.get_dyn_info_list_addr	= get_dyn_info_list_addr,
522	.access_mem		= access_mem,
523	.access_reg		= access_reg,
524	.access_fpreg		= access_fpreg,
525	.resume			= resume,
526	.get_proc_name		= get_proc_name,
527};
528
529static int get_entries(struct unwind_info *ui, unwind_entry_cb_t cb,
530		       void *arg, int max_stack)
531{
532	unw_addr_space_t addr_space;
533	unw_cursor_t c;
534	int ret;
 
535
536	addr_space = unw_create_addr_space(&accessors, 0);
537	if (!addr_space) {
538		pr_err("unwind: Can't create unwind address space.\n");
539		return -ENOMEM;
540	}
541
542	ret = unw_init_remote(&c, addr_space, ui);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
543	if (ret)
544		display_error(ret);
545
546	while (!ret && (unw_step(&c) > 0) && max_stack--) {
547		unw_word_t ip;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
548
549		unw_get_reg(&c, UNW_REG_IP, &ip);
550		ret = ip ? entry(ip, ui->thread, ui->machine, cb, arg) : 0;
 
 
 
 
 
 
 
 
 
 
551	}
552
553	unw_destroy_addr_space(addr_space);
554	return ret;
555}
556
557int unwind__get_entries(unwind_entry_cb_t cb, void *arg,
558			struct machine *machine, struct thread *thread,
559			struct perf_sample *data, int max_stack)
560{
561	u64 ip;
562	struct unwind_info ui = {
563		.sample       = data,
564		.thread       = thread,
565		.machine      = machine,
566	};
567	int ret;
568
569	if (!data->user_regs.regs)
570		return -EINVAL;
571
572	ret = perf_reg_value(&ip, &data->user_regs, PERF_REG_IP);
573	if (ret)
574		return ret;
575
576	ret = entry(ip, thread, machine, cb, arg);
577	if (ret)
578		return -ENOMEM;
579
580	return --max_stack > 0 ? get_entries(&ui, cb, arg, max_stack) : 0;
581}
v4.6
  1/*
  2 * Post mortem Dwarf CFI based unwinding on top of regs and stack dumps.
  3 *
  4 * Lots of this code have been borrowed or heavily inspired from parts of
  5 * the libunwind 0.99 code which are (amongst other contributors I may have
  6 * forgotten):
  7 *
  8 * Copyright (C) 2002-2007 Hewlett-Packard Co
  9 *	Contributed by David Mosberger-Tang <davidm@hpl.hp.com>
 10 *
 11 * And the bugs have been added by:
 12 *
 13 * Copyright (C) 2010, Frederic Weisbecker <fweisbec@gmail.com>
 14 * Copyright (C) 2012, Jiri Olsa <jolsa@redhat.com>
 15 *
 16 */
 17
 18#include <elf.h>
 19#include <gelf.h>
 20#include <fcntl.h>
 21#include <string.h>
 22#include <unistd.h>
 23#include <sys/mman.h>
 24#include <linux/list.h>
 25#include <libunwind.h>
 26#include <libunwind-ptrace.h>
 27#include "callchain.h"
 28#include "thread.h"
 29#include "session.h"
 30#include "perf_regs.h"
 31#include "unwind.h"
 32#include "symbol.h"
 33#include "util.h"
 34#include "debug.h"
 35
 36extern int
 37UNW_OBJ(dwarf_search_unwind_table) (unw_addr_space_t as,
 38				    unw_word_t ip,
 39				    unw_dyn_info_t *di,
 40				    unw_proc_info_t *pi,
 41				    int need_unwind_info, void *arg);
 42
 43#define dwarf_search_unwind_table UNW_OBJ(dwarf_search_unwind_table)
 44
 45extern int
 46UNW_OBJ(dwarf_find_debug_frame) (int found, unw_dyn_info_t *di_debug,
 47				 unw_word_t ip,
 48				 unw_word_t segbase,
 49				 const char *obj_name, unw_word_t start,
 50				 unw_word_t end);
 51
 52#define dwarf_find_debug_frame UNW_OBJ(dwarf_find_debug_frame)
 53
 54#define DW_EH_PE_FORMAT_MASK	0x0f	/* format of the encoded value */
 55#define DW_EH_PE_APPL_MASK	0x70	/* how the value is to be applied */
 56
 57/* Pointer-encoding formats: */
 58#define DW_EH_PE_omit		0xff
 59#define DW_EH_PE_ptr		0x00	/* pointer-sized unsigned value */
 60#define DW_EH_PE_udata4		0x03	/* unsigned 32-bit value */
 61#define DW_EH_PE_udata8		0x04	/* unsigned 64-bit value */
 62#define DW_EH_PE_sdata4		0x0b	/* signed 32-bit value */
 63#define DW_EH_PE_sdata8		0x0c	/* signed 64-bit value */
 64
 65/* Pointer-encoding application: */
 66#define DW_EH_PE_absptr		0x00	/* absolute value */
 67#define DW_EH_PE_pcrel		0x10	/* rel. to addr. of encoded value */
 68
 69/*
 70 * The following are not documented by LSB v1.3, yet they are used by
 71 * GCC, presumably they aren't documented by LSB since they aren't
 72 * used on Linux:
 73 */
 74#define DW_EH_PE_funcrel	0x40	/* start-of-procedure-relative */
 75#define DW_EH_PE_aligned	0x50	/* aligned pointer */
 76
 77/* Flags intentionaly not handled, since they're not needed:
 78 * #define DW_EH_PE_indirect      0x80
 79 * #define DW_EH_PE_uleb128       0x01
 80 * #define DW_EH_PE_udata2        0x02
 81 * #define DW_EH_PE_sleb128       0x09
 82 * #define DW_EH_PE_sdata2        0x0a
 83 * #define DW_EH_PE_textrel       0x20
 84 * #define DW_EH_PE_datarel       0x30
 85 */
 86
 87struct unwind_info {
 88	struct perf_sample	*sample;
 89	struct machine		*machine;
 90	struct thread		*thread;
 91};
 92
 93#define dw_read(ptr, type, end) ({	\
 94	type *__p = (type *) ptr;	\
 95	type  __v;			\
 96	if ((__p + 1) > (type *) end)	\
 97		return -EINVAL;		\
 98	__v = *__p++;			\
 99	ptr = (typeof(ptr)) __p;	\
100	__v;				\
101	})
102
103static int __dw_read_encoded_value(u8 **p, u8 *end, u64 *val,
104				   u8 encoding)
105{
106	u8 *cur = *p;
107	*val = 0;
108
109	switch (encoding) {
110	case DW_EH_PE_omit:
111		*val = 0;
112		goto out;
113	case DW_EH_PE_ptr:
114		*val = dw_read(cur, unsigned long, end);
115		goto out;
116	default:
117		break;
118	}
119
120	switch (encoding & DW_EH_PE_APPL_MASK) {
121	case DW_EH_PE_absptr:
122		break;
123	case DW_EH_PE_pcrel:
124		*val = (unsigned long) cur;
125		break;
126	default:
127		return -EINVAL;
128	}
129
130	if ((encoding & 0x07) == 0x00)
131		encoding |= DW_EH_PE_udata4;
132
133	switch (encoding & DW_EH_PE_FORMAT_MASK) {
134	case DW_EH_PE_sdata4:
135		*val += dw_read(cur, s32, end);
136		break;
137	case DW_EH_PE_udata4:
138		*val += dw_read(cur, u32, end);
139		break;
140	case DW_EH_PE_sdata8:
141		*val += dw_read(cur, s64, end);
142		break;
143	case DW_EH_PE_udata8:
144		*val += dw_read(cur, u64, end);
145		break;
146	default:
147		return -EINVAL;
148	}
149
150 out:
151	*p = cur;
152	return 0;
153}
154
155#define dw_read_encoded_value(ptr, end, enc) ({			\
156	u64 __v;						\
157	if (__dw_read_encoded_value(&ptr, end, &__v, enc)) {	\
158		return -EINVAL;                                 \
159	}                                                       \
160	__v;                                                    \
161	})
162
163static u64 elf_section_offset(int fd, const char *name)
164{
165	Elf *elf;
166	GElf_Ehdr ehdr;
167	GElf_Shdr shdr;
168	u64 offset = 0;
169
170	elf = elf_begin(fd, PERF_ELF_C_READ_MMAP, NULL);
171	if (elf == NULL)
172		return 0;
173
174	do {
175		if (gelf_getehdr(elf, &ehdr) == NULL)
176			break;
177
178		if (!elf_section_by_name(elf, &ehdr, &shdr, name, NULL))
179			break;
180
181		offset = shdr.sh_offset;
182	} while (0);
183
184	elf_end(elf);
185	return offset;
186}
187
188#ifndef NO_LIBUNWIND_DEBUG_FRAME
189static int elf_is_exec(int fd, const char *name)
190{
191	Elf *elf;
192	GElf_Ehdr ehdr;
193	int retval = 0;
194
195	elf = elf_begin(fd, PERF_ELF_C_READ_MMAP, NULL);
196	if (elf == NULL)
197		return 0;
198	if (gelf_getehdr(elf, &ehdr) == NULL)
199		goto out;
200
201	retval = (ehdr.e_type == ET_EXEC);
202
203out:
204	elf_end(elf);
205	pr_debug("unwind: elf_is_exec(%s): %d\n", name, retval);
206	return retval;
207}
208#endif
209
210struct table_entry {
211	u32 start_ip_offset;
212	u32 fde_offset;
213};
214
215struct eh_frame_hdr {
216	unsigned char version;
217	unsigned char eh_frame_ptr_enc;
218	unsigned char fde_count_enc;
219	unsigned char table_enc;
220
221	/*
222	 * The rest of the header is variable-length and consists of the
223	 * following members:
224	 *
225	 *	encoded_t eh_frame_ptr;
226	 *	encoded_t fde_count;
227	 */
228
229	/* A single encoded pointer should not be more than 8 bytes. */
230	u64 enc[2];
231
232	/*
233	 * struct {
234	 *    encoded_t start_ip;
235	 *    encoded_t fde_addr;
236	 * } binary_search_table[fde_count];
237	 */
238	char data[0];
239} __packed;
240
241static int unwind_spec_ehframe(struct dso *dso, struct machine *machine,
242			       u64 offset, u64 *table_data, u64 *segbase,
243			       u64 *fde_count)
244{
245	struct eh_frame_hdr hdr;
246	u8 *enc = (u8 *) &hdr.enc;
247	u8 *end = (u8 *) &hdr.data;
248	ssize_t r;
249
250	r = dso__data_read_offset(dso, machine, offset,
251				  (u8 *) &hdr, sizeof(hdr));
252	if (r != sizeof(hdr))
253		return -EINVAL;
254
255	/* We dont need eh_frame_ptr, just skip it. */
256	dw_read_encoded_value(enc, end, hdr.eh_frame_ptr_enc);
257
258	*fde_count  = dw_read_encoded_value(enc, end, hdr.fde_count_enc);
259	*segbase    = offset;
260	*table_data = (enc - (u8 *) &hdr) + offset;
261	return 0;
262}
263
264static int read_unwind_spec_eh_frame(struct dso *dso, struct machine *machine,
265				     u64 *table_data, u64 *segbase,
266				     u64 *fde_count)
267{
268	int ret = -EINVAL, fd;
269	u64 offset = dso->data.eh_frame_hdr_offset;
270
271	if (offset == 0) {
272		fd = dso__data_get_fd(dso, machine);
273		if (fd < 0)
274			return -EINVAL;
275
276		/* Check the .eh_frame section for unwinding info */
277		offset = elf_section_offset(fd, ".eh_frame_hdr");
278		dso->data.eh_frame_hdr_offset = offset;
279		dso__data_put_fd(dso);
280	}
281
282	if (offset)
283		ret = unwind_spec_ehframe(dso, machine, offset,
284					  table_data, segbase,
285					  fde_count);
286
287	return ret;
288}
289
290#ifndef NO_LIBUNWIND_DEBUG_FRAME
291static int read_unwind_spec_debug_frame(struct dso *dso,
292					struct machine *machine, u64 *offset)
293{
294	int fd;
295	u64 ofs = dso->data.debug_frame_offset;
296
297	if (ofs == 0) {
298		fd = dso__data_get_fd(dso, machine);
299		if (fd < 0)
300			return -EINVAL;
301
302		/* Check the .debug_frame section for unwinding info */
303		ofs = elf_section_offset(fd, ".debug_frame");
304		dso->data.debug_frame_offset = ofs;
305		dso__data_put_fd(dso);
306	}
307
308	*offset = ofs;
309	if (*offset)
310		return 0;
311
312	return -EINVAL;
313}
314#endif
315
316static struct map *find_map(unw_word_t ip, struct unwind_info *ui)
317{
318	struct addr_location al;
319
320	thread__find_addr_map(ui->thread, PERF_RECORD_MISC_USER,
321			      MAP__FUNCTION, ip, &al);
322	if (!al.map) {
323		/*
324		 * We've seen cases (softice) where DWARF unwinder went
325		 * through non executable mmaps, which we need to lookup
326		 * in MAP__VARIABLE tree.
327		 */
328		thread__find_addr_map(ui->thread, PERF_RECORD_MISC_USER,
329				      MAP__VARIABLE, ip, &al);
330	}
331	return al.map;
332}
333
334static int
335find_proc_info(unw_addr_space_t as, unw_word_t ip, unw_proc_info_t *pi,
336	       int need_unwind_info, void *arg)
337{
338	struct unwind_info *ui = arg;
339	struct map *map;
340	unw_dyn_info_t di;
341	u64 table_data, segbase, fde_count;
342	int ret = -EINVAL;
343
344	map = find_map(ip, ui);
345	if (!map || !map->dso)
346		return -EINVAL;
347
348	pr_debug("unwind: find_proc_info dso %s\n", map->dso->name);
349
350	/* Check the .eh_frame section for unwinding info */
351	if (!read_unwind_spec_eh_frame(map->dso, ui->machine,
352				       &table_data, &segbase, &fde_count)) {
353		memset(&di, 0, sizeof(di));
354		di.format   = UNW_INFO_FORMAT_REMOTE_TABLE;
355		di.start_ip = map->start;
356		di.end_ip   = map->end;
357		di.u.rti.segbase    = map->start + segbase;
358		di.u.rti.table_data = map->start + table_data;
359		di.u.rti.table_len  = fde_count * sizeof(struct table_entry)
360				      / sizeof(unw_word_t);
361		ret = dwarf_search_unwind_table(as, ip, &di, pi,
362						need_unwind_info, arg);
363	}
364
365#ifndef NO_LIBUNWIND_DEBUG_FRAME
366	/* Check the .debug_frame section for unwinding info */
367	if (ret < 0 &&
368	    !read_unwind_spec_debug_frame(map->dso, ui->machine, &segbase)) {
369		int fd = dso__data_get_fd(map->dso, ui->machine);
370		int is_exec = elf_is_exec(fd, map->dso->name);
371		unw_word_t base = is_exec ? 0 : map->start;
372		const char *symfile;
373
374		if (fd >= 0)
375			dso__data_put_fd(map->dso);
376
377		symfile = map->dso->symsrc_filename ?: map->dso->name;
378
379		memset(&di, 0, sizeof(di));
380		if (dwarf_find_debug_frame(0, &di, ip, base, symfile,
381					   map->start, map->end))
382			return dwarf_search_unwind_table(as, ip, &di, pi,
383							 need_unwind_info, arg);
384	}
385#endif
386
387	return ret;
388}
389
390static int access_fpreg(unw_addr_space_t __maybe_unused as,
391			unw_regnum_t __maybe_unused num,
392			unw_fpreg_t __maybe_unused *val,
393			int __maybe_unused __write,
394			void __maybe_unused *arg)
395{
396	pr_err("unwind: access_fpreg unsupported\n");
397	return -UNW_EINVAL;
398}
399
400static int get_dyn_info_list_addr(unw_addr_space_t __maybe_unused as,
401				  unw_word_t __maybe_unused *dil_addr,
402				  void __maybe_unused *arg)
403{
404	return -UNW_ENOINFO;
405}
406
407static int resume(unw_addr_space_t __maybe_unused as,
408		  unw_cursor_t __maybe_unused *cu,
409		  void __maybe_unused *arg)
410{
411	pr_err("unwind: resume unsupported\n");
412	return -UNW_EINVAL;
413}
414
415static int
416get_proc_name(unw_addr_space_t __maybe_unused as,
417	      unw_word_t __maybe_unused addr,
418		char __maybe_unused *bufp, size_t __maybe_unused buf_len,
419		unw_word_t __maybe_unused *offp, void __maybe_unused *arg)
420{
421	pr_err("unwind: get_proc_name unsupported\n");
422	return -UNW_EINVAL;
423}
424
425static int access_dso_mem(struct unwind_info *ui, unw_word_t addr,
426			  unw_word_t *data)
427{
428	struct map *map;
429	ssize_t size;
430
431	map = find_map(addr, ui);
432	if (!map) {
 
433		pr_debug("unwind: no map for %lx\n", (unsigned long)addr);
434		return -1;
435	}
436
437	if (!map->dso)
438		return -1;
439
440	size = dso__data_read_addr(map->dso, map, ui->machine,
441				   addr, (u8 *) data, sizeof(*data));
442
443	return !(size == sizeof(*data));
444}
445
446static int access_mem(unw_addr_space_t __maybe_unused as,
447		      unw_word_t addr, unw_word_t *valp,
448		      int __write, void *arg)
449{
450	struct unwind_info *ui = arg;
451	struct stack_dump *stack = &ui->sample->user_stack;
452	u64 start, end;
453	int offset;
454	int ret;
455
456	/* Don't support write, probably not needed. */
457	if (__write || !stack || !ui->sample->user_regs.regs) {
458		*valp = 0;
459		return 0;
460	}
461
462	ret = perf_reg_value(&start, &ui->sample->user_regs, PERF_REG_SP);
463	if (ret)
464		return ret;
465
466	end = start + stack->size;
467
468	/* Check overflow. */
469	if (addr + sizeof(unw_word_t) < addr)
470		return -EINVAL;
471
472	if (addr < start || addr + sizeof(unw_word_t) >= end) {
473		ret = access_dso_mem(ui, addr, valp);
474		if (ret) {
475			pr_debug("unwind: access_mem %p not inside range"
476				 " 0x%" PRIx64 "-0x%" PRIx64 "\n",
477				 (void *) (uintptr_t) addr, start, end);
478			*valp = 0;
479			return ret;
480		}
481		return 0;
482	}
483
484	offset = addr - start;
485	*valp  = *(unw_word_t *)&stack->data[offset];
486	pr_debug("unwind: access_mem addr %p val %lx, offset %d\n",
487		 (void *) (uintptr_t) addr, (unsigned long)*valp, offset);
488	return 0;
489}
490
491static int access_reg(unw_addr_space_t __maybe_unused as,
492		      unw_regnum_t regnum, unw_word_t *valp,
493		      int __write, void *arg)
494{
495	struct unwind_info *ui = arg;
496	int id, ret;
497	u64 val;
498
499	/* Don't support write, I suspect we don't need it. */
500	if (__write) {
501		pr_err("unwind: access_reg w %d\n", regnum);
502		return 0;
503	}
504
505	if (!ui->sample->user_regs.regs) {
506		*valp = 0;
507		return 0;
508	}
509
510	id = libunwind__arch_reg_id(regnum);
511	if (id < 0)
512		return -EINVAL;
513
514	ret = perf_reg_value(&val, &ui->sample->user_regs, id);
515	if (ret) {
516		pr_err("unwind: can't read reg %d\n", regnum);
517		return ret;
518	}
519
520	*valp = (unw_word_t) val;
521	pr_debug("unwind: reg %d, val %lx\n", regnum, (unsigned long)*valp);
522	return 0;
523}
524
525static void put_unwind_info(unw_addr_space_t __maybe_unused as,
526			    unw_proc_info_t *pi __maybe_unused,
527			    void *arg __maybe_unused)
528{
529	pr_debug("unwind: put_unwind_info called\n");
530}
531
532static int entry(u64 ip, struct thread *thread,
533		 unwind_entry_cb_t cb, void *arg)
534{
535	struct unwind_entry e;
536	struct addr_location al;
537
538	thread__find_addr_location(thread, PERF_RECORD_MISC_USER,
 
539				   MAP__FUNCTION, ip, &al);
540
541	e.ip = ip;
542	e.map = al.map;
543	e.sym = al.sym;
544
545	pr_debug("unwind: %s:ip = 0x%" PRIx64 " (0x%" PRIx64 ")\n",
546		 al.sym ? al.sym->name : "''",
547		 ip,
548		 al.map ? al.map->map_ip(al.map, ip) : (u64) 0);
549
550	return cb(&e, arg);
551}
552
553static void display_error(int err)
554{
555	switch (err) {
556	case UNW_EINVAL:
557		pr_err("unwind: Only supports local.\n");
558		break;
559	case UNW_EUNSPEC:
560		pr_err("unwind: Unspecified error.\n");
561		break;
562	case UNW_EBADREG:
563		pr_err("unwind: Register unavailable.\n");
564		break;
565	default:
566		break;
567	}
568}
569
570static unw_accessors_t accessors = {
571	.find_proc_info		= find_proc_info,
572	.put_unwind_info	= put_unwind_info,
573	.get_dyn_info_list_addr	= get_dyn_info_list_addr,
574	.access_mem		= access_mem,
575	.access_reg		= access_reg,
576	.access_fpreg		= access_fpreg,
577	.resume			= resume,
578	.get_proc_name		= get_proc_name,
579};
580
581int unwind__prepare_access(struct thread *thread)
 
582{
583	unw_addr_space_t addr_space;
584
585	if (callchain_param.record_mode != CALLCHAIN_DWARF)
586		return 0;
587
588	addr_space = unw_create_addr_space(&accessors, 0);
589	if (!addr_space) {
590		pr_err("unwind: Can't create unwind address space.\n");
591		return -ENOMEM;
592	}
593
594	unw_set_caching_policy(addr_space, UNW_CACHE_GLOBAL);
595	thread__set_priv(thread, addr_space);
596
597	return 0;
598}
599
600void unwind__flush_access(struct thread *thread)
601{
602	unw_addr_space_t addr_space;
603
604	if (callchain_param.record_mode != CALLCHAIN_DWARF)
605		return;
606
607	addr_space = thread__priv(thread);
608	unw_flush_cache(addr_space, 0, 0);
609}
610
611void unwind__finish_access(struct thread *thread)
612{
613	unw_addr_space_t addr_space;
614
615	if (callchain_param.record_mode != CALLCHAIN_DWARF)
616		return;
617
618	addr_space = thread__priv(thread);
619	unw_destroy_addr_space(addr_space);
620}
621
622static int get_entries(struct unwind_info *ui, unwind_entry_cb_t cb,
623		       void *arg, int max_stack)
624{
625	u64 val;
626	unw_word_t ips[max_stack];
627	unw_addr_space_t addr_space;
628	unw_cursor_t c;
629	int ret, i = 0;
630
631	ret = perf_reg_value(&val, &ui->sample->user_regs, PERF_REG_IP);
632	if (ret)
633		return ret;
634
635	ips[i++] = (unw_word_t) val;
636
637	/*
638	 * If we need more than one entry, do the DWARF
639	 * unwind itself.
640	 */
641	if (max_stack - 1 > 0) {
642		addr_space = thread__priv(ui->thread);
643		if (addr_space == NULL)
644			return -1;
645
646		ret = unw_init_remote(&c, addr_space, ui);
647		if (ret)
648			display_error(ret);
649
650		while (!ret && (unw_step(&c) > 0) && i < max_stack) {
651			unw_get_reg(&c, UNW_REG_IP, &ips[i]);
652			++i;
653		}
654
655		max_stack = i;
656	}
657
658	/*
659	 * Display what we got based on the order setup.
660	 */
661	for (i = 0; i < max_stack && !ret; i++) {
662		int j = i;
663
664		if (callchain_param.order == ORDER_CALLER)
665			j = max_stack - i - 1;
666		ret = ips[j] ? entry(ips[j], ui->thread, cb, arg) : 0;
667	}
668
 
669	return ret;
670}
671
672int unwind__get_entries(unwind_entry_cb_t cb, void *arg,
673			struct thread *thread,
674			struct perf_sample *data, int max_stack)
675{
 
676	struct unwind_info ui = {
677		.sample       = data,
678		.thread       = thread,
679		.machine      = thread->mg->machine,
680	};
 
681
682	if (!data->user_regs.regs)
683		return -EINVAL;
684
685	if (max_stack <= 0)
686		return -EINVAL;
 
 
 
 
 
687
688	return get_entries(&ui, cb, arg, max_stack);
689}