|
|
6daba0 |
From 72317b333b85eed483ad00bcd4f40944019a7c13 Mon Sep 17 00:00:00 2001
|
|
|
6daba0 |
From: "xtkoba+ruby@gmail.com" <xtkoba+ruby@gmail.com>
|
|
|
6daba0 |
Date: Fri, 13 Aug 2021 13:45:53 +0000
|
|
|
6daba0 |
Subject: [PATCH] Ignore `DW_FORM_ref_addr` [Bug #17052]
|
|
|
6daba0 |
|
|
|
6daba0 |
Ignore `DW_FORM_ref_addr` form and other forms that are not supposed
|
|
|
6daba0 |
to be used currently.
|
|
|
6daba0 |
---
|
|
|
6daba0 |
addr2line.c | 23 ++++++++++++++++++++---
|
|
|
6daba0 |
1 file changed, 20 insertions(+), 3 deletions(-)
|
|
|
6daba0 |
|
|
|
6daba0 |
diff --git a/addr2line.c b/addr2line.c
|
|
|
6daba0 |
index fed1a8da84e5..92c6da5e3bea 100644
|
|
|
6daba0 |
--- a/addr2line.c
|
|
|
6daba0 |
+++ b/addr2line.c
|
|
|
6daba0 |
@@ -1593,14 +1593,31 @@ di_read_cu(DebugInfoReader *reader)
|
|
|
6daba0 |
}
|
|
|
6daba0 |
|
|
|
6daba0 |
static void
|
|
|
6daba0 |
-read_abstract_origin(DebugInfoReader *reader, uint64_t abstract_origin, line_info_t *line)
|
|
|
6daba0 |
+read_abstract_origin(DebugInfoReader *reader, uint64_t form, uint64_t abstract_origin, line_info_t *line)
|
|
|
6daba0 |
{
|
|
|
6daba0 |
char *p = reader->p;
|
|
|
6daba0 |
char *q = reader->q;
|
|
|
6daba0 |
int level = reader->level;
|
|
|
6daba0 |
DIE die;
|
|
|
6daba0 |
|
|
|
6daba0 |
- reader->p = reader->current_cu + abstract_origin;
|
|
|
6daba0 |
+ switch (form) {
|
|
|
6daba0 |
+ case DW_FORM_ref1:
|
|
|
6daba0 |
+ case DW_FORM_ref2:
|
|
|
6daba0 |
+ case DW_FORM_ref4:
|
|
|
6daba0 |
+ case DW_FORM_ref8:
|
|
|
6daba0 |
+ case DW_FORM_ref_udata:
|
|
|
6daba0 |
+ reader->p = reader->current_cu + abstract_origin;
|
|
|
6daba0 |
+ break;
|
|
|
6daba0 |
+ case DW_FORM_ref_addr:
|
|
|
6daba0 |
+ goto finish; /* not supported yet */
|
|
|
6daba0 |
+ case DW_FORM_ref_sig8:
|
|
|
6daba0 |
+ goto finish; /* not supported yet */
|
|
|
6daba0 |
+ case DW_FORM_ref_sup4:
|
|
|
6daba0 |
+ case DW_FORM_ref_sup8:
|
|
|
6daba0 |
+ goto finish; /* not supported yet */
|
|
|
6daba0 |
+ default:
|
|
|
6daba0 |
+ goto finish;
|
|
|
6daba0 |
+ }
|
|
|
6daba0 |
if (!di_read_die(reader, &die)) goto finish;
|
|
|
6daba0 |
|
|
|
6daba0 |
/* enumerate abbrev */
|
|
|
6daba0 |
@@ -1665,7 +1682,7 @@ debug_info_read(DebugInfoReader *reader, int num_traces, void **traces,
|
|
|
6daba0 |
/* 1 or 3 */
|
|
|
6daba0 |
break; /* goto skip_die; */
|
|
|
6daba0 |
case DW_AT_abstract_origin:
|
|
|
6daba0 |
- read_abstract_origin(reader, v.as.uint64, &line);
|
|
|
6daba0 |
+ read_abstract_origin(reader, v.form, v.as.uint64, &line);
|
|
|
6daba0 |
break; /* goto skip_die; */
|
|
|
6daba0 |
}
|
|
|
6daba0 |
}
|