|
|
@@ -269,13 +269,14 @@ static int read_unwind_spec_eh_frame(struct dso *dso, struct machine *machine,
|
|
|
u64 offset = dso->data.eh_frame_hdr_offset;
|
|
|
|
|
|
if (offset == 0) {
|
|
|
- fd = dso__data_fd(dso, machine);
|
|
|
+ fd = dso__data_get_fd(dso, machine);
|
|
|
if (fd < 0)
|
|
|
return -EINVAL;
|
|
|
|
|
|
/* Check the .eh_frame section for unwinding info */
|
|
|
offset = elf_section_offset(fd, ".eh_frame_hdr");
|
|
|
dso->data.eh_frame_hdr_offset = offset;
|
|
|
+ dso__data_put_fd(dso);
|
|
|
}
|
|
|
|
|
|
if (offset)
|
|
|
@@ -294,13 +295,14 @@ static int read_unwind_spec_debug_frame(struct dso *dso,
|
|
|
u64 ofs = dso->data.debug_frame_offset;
|
|
|
|
|
|
if (ofs == 0) {
|
|
|
- fd = dso__data_fd(dso, machine);
|
|
|
+ fd = dso__data_get_fd(dso, machine);
|
|
|
if (fd < 0)
|
|
|
return -EINVAL;
|
|
|
|
|
|
/* Check the .debug_frame section for unwinding info */
|
|
|
ofs = elf_section_offset(fd, ".debug_frame");
|
|
|
dso->data.debug_frame_offset = ofs;
|
|
|
+ dso__data_put_fd(dso);
|
|
|
}
|
|
|
|
|
|
*offset = ofs;
|
|
|
@@ -353,10 +355,13 @@ find_proc_info(unw_addr_space_t as, unw_word_t ip, unw_proc_info_t *pi,
|
|
|
#ifndef NO_LIBUNWIND_DEBUG_FRAME
|
|
|
/* Check the .debug_frame section for unwinding info */
|
|
|
if (!read_unwind_spec_debug_frame(map->dso, ui->machine, &segbase)) {
|
|
|
- int fd = dso__data_fd(map->dso, ui->machine);
|
|
|
+ int fd = dso__data_get_fd(map->dso, ui->machine);
|
|
|
int is_exec = elf_is_exec(fd, map->dso->name);
|
|
|
unw_word_t base = is_exec ? 0 : map->start;
|
|
|
|
|
|
+ if (fd >= 0)
|
|
|
+ dso__data_put_fd(dso);
|
|
|
+
|
|
|
memset(&di, 0, sizeof(di));
|
|
|
if (dwarf_find_debug_frame(0, &di, ip, base, map->dso->name,
|
|
|
map->start, map->end))
|