Em Wed, Jan 29, 2014 at 04:14:36PM +0200, Adrian Hunter escreveu:
> Kernel maps map memory addresses to file offsets.
> For symbol annotation, objdump needs the object VMA
> addresses.  For an unrelocated kernel, that is the
> same as the memory address.
> 
> The addresses passed to objdump for symbol annotation
> did not take into account kernel relocation.  This
> patch fixes that.

Question: To fix the problem reported by Linus, i.e. the very minimal
fix, we only need this patch, right?

Reading the other patches now.

- Arnaldo
 
> Signed-off-by: Adrian Hunter <adrian.hun...@intel.com>
> ---
>  tools/perf/util/map.c        | 5 +++--
>  tools/perf/util/map.h        | 1 +
>  tools/perf/util/symbol-elf.c | 2 ++
>  3 files changed, 6 insertions(+), 2 deletions(-)
> 
> diff --git a/tools/perf/util/map.c b/tools/perf/util/map.c
> index ee1dd68..b46f527 100644
> --- a/tools/perf/util/map.c
> +++ b/tools/perf/util/map.c
> @@ -39,6 +39,7 @@ void map__init(struct map *map, enum map_type type,
>       map->start    = start;
>       map->end      = end;
>       map->pgoff    = pgoff;
> +     map->reloc    = 0;
>       map->dso      = dso;
>       map->map_ip   = map__map_ip;
>       map->unmap_ip = map__unmap_ip;
> @@ -288,7 +289,7 @@ u64 map__rip_2objdump(struct map *map, u64 rip)
>       if (map->dso->rel)
>               return rip - map->pgoff;
>  
> -     return map->unmap_ip(map, rip);
> +     return map->unmap_ip(map, rip) - map->reloc;
>  }
>  
>  /**
> @@ -311,7 +312,7 @@ u64 map__objdump_2mem(struct map *map, u64 ip)
>       if (map->dso->rel)
>               return map->unmap_ip(map, ip + map->pgoff);
>  
> -     return ip;
> +     return ip + map->reloc;
>  }
>  
>  void map_groups__init(struct map_groups *mg)
> diff --git a/tools/perf/util/map.h b/tools/perf/util/map.h
> index 18068c6..257e513 100644
> --- a/tools/perf/util/map.h
> +++ b/tools/perf/util/map.h
> @@ -36,6 +36,7 @@ struct map {
>       bool                    erange_warned;
>       u32                     priv;
>       u64                     pgoff;
> +     u64                     reloc;
>       u32                     maj, min; /* only valid for MMAP2 record */
>       u64                     ino;      /* only valid for MMAP2 record */
>       u64                     ino_generation;/* only valid for MMAP2 record */
> diff --git a/tools/perf/util/symbol-elf.c b/tools/perf/util/symbol-elf.c
> index 7594567..8ce52da 100644
> --- a/tools/perf/util/symbol-elf.c
> +++ b/tools/perf/util/symbol-elf.c
> @@ -751,6 +751,8 @@ int dso__load_sym(struct dso *dso, struct map *map,
>                       if (strcmp(elf_name, kmap->ref_reloc_sym->name))
>                               continue;
>                       kmap->ref_reloc_sym->unrelocated_addr = sym.st_value;
> +                     map->reloc = kmap->ref_reloc_sym->addr -
> +                                  kmap->ref_reloc_sym->unrelocated_addr;
>                       break;
>               }
>       }
> -- 
> 1.7.11.7
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to