From: Adrian Hunter <adrian.hunter@intel.com>
To: Hekuang <hekuang@huawei.com>,
peterz@infradead.org, mingo@redhat.com, acme@kernel.org,
alexander.shishkin@linux.intel.com, jolsa@redhat.com,
wangnan0@huawei.com, jpoimboe@redhat.com, ak@linux.intel.com,
eranian@google.com, namhyung@kernel.org,
sukadev@linux.vnet.ibm.com, masami.hiramatsu.pt@hitachi.com,
tumanova@linux.vnet.ibm.com, kan.liang@intel.com,
penberg@kernel.org, dsahern@gmail.com
Cc: linux-kernel@vger.kernel.org
Subject: Re: [PATCH v2 5/9] perf tools: Add methods to test dso is 64-bit or 32-bit
Date: Tue, 10 May 2016 13:34:50 +0300 [thread overview]
Message-ID: <5731B94A.3070402@intel.com> (raw)
In-Reply-To: <5731AEBB.8060200@huawei.com>
On 10/05/16 12:49, Hekuang wrote:
> hi
>
> 在 2016/5/10 16:08, Adrian Hunter 写道:
>> On 10/05/16 10:40, He Kuang wrote:
>>> 32-bit programs can be run on 64-bit machines, so we should choose
>>> unwind methods according to 'thread->map' instead of the host
>>> architecture.
>>>
>>> This patch adds methods to test whether a dso is 64-bit or 32-bit by
>>> the class info in elf.
>> What about using dso->is_64_bit set by dso__load_sym() ?
>
> I've noticed this variable, but it's value is not as its name said:
>
> util/dso.c: 1067 dso->is_64_bit = (sizeof(void *) == 8);
That is just initialization i.e. before we know what it is we assume it is
the same as the host.
>
> This is only related to the host architecture.
>
> A closer one is 'is_64_bit' in 'struct symsrc', but the value is assigned
> after dso
> loaded. So I think we should provide individual methods to get that value.
Are you saying you don't load dsos? Or that is_64_bit is set incorrectly?
>
> Thanks.
>
>>
>>> Signed-off-by: He Kuang <hekuang@huawei.com>
>>> ---
>>> tools/perf/util/symbol-elf.c | 16 +++++++++++++++
>>> tools/perf/util/symbol.c | 49
>>> ++++++++++++++++++++++++++++++++++++++++++++
>>> tools/perf/util/symbol.h | 2 ++
>>> 3 files changed, 67 insertions(+)
>>>
>>> diff --git a/tools/perf/util/symbol-elf.c b/tools/perf/util/symbol-elf.c
>>> index 3f9d679..9f290b9 100644
>>> --- a/tools/perf/util/symbol-elf.c
>>> +++ b/tools/perf/util/symbol-elf.c
>>> @@ -636,6 +636,22 @@ bool __weak elf__needs_adjust_symbols(GElf_Ehdr ehdr)
>>> return ehdr.e_type == ET_EXEC || ehdr.e_type == ET_REL;
>>> }
>>> +int elf_is_64_bit(char *name)
>>> +{
>>> + Elf *elf;
>>> + int fd;
>>> +
>>> + fd = open(name, O_RDONLY);
>>> + if (fd < 0)
>>> + return -1;
>>> +
>>> + elf = elf_begin(fd, PERF_ELF_C_READ_MMAP, NULL);
>>> + if (elf == NULL)
>>> + return -1;
>>> +
>>> + return (gelf_getclass(elf) == ELFCLASS64);
>>> +}
>>> +
>>> int symsrc__init(struct symsrc *ss, struct dso *dso, const char *name,
>>> enum dso_binary_type type)
>>> {
>>> diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c
>>> index 4630751..592bf8c 100644
>>> --- a/tools/perf/util/symbol.c
>>> +++ b/tools/perf/util/symbol.c
>>> @@ -1395,6 +1395,55 @@ static bool dso__is_compatible_symtab_type(struct
>>> dso *dso, bool kmod,
>>> }
>>> }
>>> +int dso_is_64_bit(struct dso *dso, struct map *map)
>>> +{
>>> + char *name;
>>> + u_int i;
>>> + bool kmod;
>>> + char *root_dir = (char *) "";
>>> + struct machine *machine;
>>> +
>>> + if (map->groups && map->groups->machine)
>>> + machine = map->groups->machine;
>>> + else
>>> + machine = NULL;
>>> +
>>> + if (machine)
>>> + root_dir = machine->root_dir;
>>> +
>>> + name = malloc(PATH_MAX);
>>> + if (!name)
>>> + return -1;
>>> +
>>> + kmod = dso->symtab_type == DSO_BINARY_TYPE__SYSTEM_PATH_KMODULE ||
>>> + dso->symtab_type == DSO_BINARY_TYPE__SYSTEM_PATH_KMODULE_COMP ||
>>> + dso->symtab_type == DSO_BINARY_TYPE__GUEST_KMODULE ||
>>> + dso->symtab_type == DSO_BINARY_TYPE__GUEST_KMODULE_COMP;
>>> +
>>> + /*
>>> + * Iterate over candidate debug images.
>>> + * Keep track of "interesting" ones (those which have a symtab, dynsym,
>>> + * and/or opd section) for processing.
>>> + */
>>> + for (i = 0; i < DSO_BINARY_TYPE__SYMTAB_CNT; i++) {
>>> + enum dso_binary_type symtab_type = binary_type_symtab[i];
>>> +
>>> + if (!dso__is_compatible_symtab_type(dso, kmod, symtab_type))
>>> + continue;
>>> +
>>> + if (dso__read_binary_type_filename(dso, symtab_type,
>>> + root_dir, name, PATH_MAX))
>>> + continue;
>>> +
>>> + if (!is_regular_file(name))
>>> + continue;
>>> +
>>> + return elf_is_64_bit(name);
>>> + }
>>> +
>>> + return -1;
>>> +}
>>> +
>>> int dso__load(struct dso *dso, struct map *map, symbol_filter_t filter)
>>> {
>>> char *name;
>>> diff --git a/tools/perf/util/symbol.h b/tools/perf/util/symbol.h
>>> index 4e6910e..d33fbf4 100644
>>> --- a/tools/perf/util/symbol.h
>>> +++ b/tools/perf/util/symbol.h
>>> @@ -308,6 +308,8 @@ int setup_list(struct strlist **list, const char
>>> *list_str,
>>> const char *list_name);
>>> int setup_intlist(struct intlist **list, const char *list_str,
>>> const char *list_name);
>>> +int elf_is_64_bit(char *name);
>>> +int dso_is_64_bit(struct dso *dso, struct map *map);
>>> #ifdef HAVE_LIBELF_SUPPORT
>>> bool elf__needs_adjust_symbols(GElf_Ehdr ehdr);
>>>
>>
>
>
>
next prev parent reply other threads:[~2016-05-10 10:38 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-05-10 7:40 [PATCH v2 0/9] Add support for remote unwind He Kuang
2016-05-10 7:40 ` [PATCH v2 1/9] perf tools: Omit DWARF judgement when recording dwarf callchain He Kuang
2016-05-10 13:45 ` Arnaldo Carvalho de Melo
2016-05-10 7:40 ` [PATCH v2 2/9] perf script: Add options for custom vdso path He Kuang
2016-05-10 13:44 ` Arnaldo Carvalho de Melo
2016-05-11 1:33 ` Hekuang
2016-05-10 7:40 ` [PATCH v2 3/9] perf build: Add build-test for libunwind cross-platforms support He Kuang
2016-05-11 11:52 ` Jiri Olsa
2016-05-11 13:24 ` Arnaldo Carvalho de Melo
2016-05-12 10:23 ` [tip:perf/core] " tip-bot for He Kuang
2016-05-10 7:40 ` [PATCH v2 4/9] perf build: Add build-test for debug-frame on arm/arm64 He Kuang
2016-05-11 11:58 ` Jiri Olsa
2016-05-11 13:24 ` Arnaldo Carvalho de Melo
2016-05-12 10:24 ` [tip:perf/core] " tip-bot for He Kuang
2016-05-10 7:40 ` [PATCH v2 5/9] perf tools: Add methods to test dso is 64-bit or 32-bit He Kuang
2016-05-10 8:08 ` Adrian Hunter
2016-05-10 9:49 ` Hekuang
2016-05-10 10:34 ` Adrian Hunter [this message]
2016-05-10 11:38 ` Hekuang
2016-05-10 11:59 ` Adrian Hunter
2016-05-10 12:29 ` Hekuang
2016-05-10 7:40 ` [PATCH v2 6/9] perf tools: Promote proper messages for cross-platform unwind He Kuang
2016-05-10 7:40 ` [PATCH v2 7/9] perf callchain: Add support " He Kuang
2016-05-10 7:40 ` [PATCH v2 8/9] perf callchain: Support x86 target platform He Kuang
2016-05-10 7:40 ` [PATCH v2 9/9] perf callchain: Support aarch64 cross-platform He Kuang
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=5731B94A.3070402@intel.com \
--to=adrian.hunter@intel.com \
--cc=acme@kernel.org \
--cc=ak@linux.intel.com \
--cc=alexander.shishkin@linux.intel.com \
--cc=dsahern@gmail.com \
--cc=eranian@google.com \
--cc=hekuang@huawei.com \
--cc=jolsa@redhat.com \
--cc=jpoimboe@redhat.com \
--cc=kan.liang@intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=masami.hiramatsu.pt@hitachi.com \
--cc=mingo@redhat.com \
--cc=namhyung@kernel.org \
--cc=penberg@kernel.org \
--cc=peterz@infradead.org \
--cc=sukadev@linux.vnet.ibm.com \
--cc=tumanova@linux.vnet.ibm.com \
--cc=wangnan0@huawei.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.