From: Hekuang <hekuang@huawei.com>
To: Arnaldo Carvalho de Melo <acme@kernel.org>, Jiri Olsa <jolsa@redhat.com>
Cc: <peterz@infradead.org>, <mingo@redhat.com>,
<alexander.shishkin@linux.intel.com>, <wangnan0@huawei.com>,
<jpoimboe@redhat.com>, <ak@linux.intel.com>, <eranian@google.com>,
<namhyung@kernel.org>, <adrian.hunter@intel.com>,
<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>,
<linux-kernel@vger.kernel.org>
Subject: Re: [PATCH v9 00/14] Add support for remote unwind
Date: Wed, 8 Jun 2016 15:33:22 +0800 [thread overview]
Message-ID: <5757CA42.4040703@huawei.com> (raw)
In-Reply-To: <20160607194426.GF11589@kernel.org>
hi
在 2016/6/8 3:44, Arnaldo Carvalho de Melo 写道:
> Em Fri, Jun 03, 2016 at 09:06:29AM +0200, Jiri Olsa escreveu:
>> On Fri, Jun 03, 2016 at 03:33:09AM +0000, He Kuang wrote:
>>
>> SNIP
>>
>>> For using remote libunwind libraries, reference this:
>>> http://thread.gmane.org/gmane.linux.kernel/2224430
>>>
>>> and now we can use LIBUNWIND_DIR to specific custom dirctories
>>> containing libunwind libs.
>>>
>>> Acked-by: Jiri Olsa <jolsa@kernel.org> for most patches except:
>>>
>>> v9:
>>> - Change function unwind__register_ops() to static.
>>> - Move up unwind__prepare_access() in thread__insert_map() and save
>>> map_groups__remove() call.
>>> - Enclose multiple line if/else into braces.
>>> - Fix miss modified function declaration for unwind__prepare_access()
>>> in patch 10.
>> for patchset:
>>
>> Acked-by: Jiri Olsa <jolsa@kernel.org>
> Ok, I'm applying it, after fixing 'perf test unwind', 'perf top --call-graph dwarf'
> and 'perf trace --call-graph dwarf', but I have one question, is the
> scenario where we collect on a x86_64 machine and want to do analysis on
> a ARM64 or x86-32 machine supported? This should be the odd case now,
Yes, it's supported.
But I never tested this before, so I just compiled libunwind for
aarch64, and tested unwinding i686 perf.data on aarch64. Then I
found another issue I've considered but missed at some version of
this patch series.
In util/unwind-libunwind-local.c, PERF_REG_SP/IP is used, but
those macros are assigned to the host platform, we should
redefine them in the wrapper file, for example in
"util/libunwind/x86_32.c".
After fixing this problem, i686 perf.data can be parsed on
aarch64 machine. Since you've already applied the v9 patches,
should I send patches based on the lastest tree as bug fixes or
just update v9 patches?
Thank you.
Here is the modified part:
diff --git a/tools/perf/util/libunwind/arm64.c
b/tools/perf/util/libunwind/arm64.c
index 4fb5395..8a5c2fc 100644
--- a/tools/perf/util/libunwind/arm64.c
+++ b/tools/perf/util/libunwind/arm64.c
@@ -29,6 +29,11 @@
#ifdef NO_LIBUNWIND_DEBUG_FRAME_AARCH64
#define NO_LIBUNWIND_DEBUG_FRAME
#endif
+
+#undef PERF_REG_IP
+#undef PERF_REG_SP
+#define PERF_REG_IP PERF_REG_ARM64_PC
+#define PERF_REG_SP PERF_REG_ARM64_SP
#include "util/unwind-libunwind-local.c"
struct unwind_libunwind_ops *
diff --git a/tools/perf/util/libunwind/x86_32.c
b/tools/perf/util/libunwind/x86_32.c
index d98c17e..de21a39 100644
--- a/tools/perf/util/libunwind/x86_32.c
+++ b/tools/perf/util/libunwind/x86_32.c
@@ -31,6 +31,11 @@
#ifndef NO_LIBUNWIND_DEBUG_FRAME
#define NO_LIBUNWIND_DEBUG_FRAME
#endif
+
+#undef PERF_REG_IP
+#undef PERF_REG_SP
+#define PERF_REG_IP PERF_REG_X86_IP
+#define PERF_REG_SP PERF_REG_X86_SP
#include "util/unwind-libunwind-local.c"
struct unwind_libunwind_ops *
> but from a quick look I couldn't see this as being supported, is that
> true or I was just lazy not to have tried this?
>
> - Arnaldo
prev parent reply other threads:[~2016-06-08 7:35 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-06-03 3:33 [PATCH v9 00/14] Add support for remote unwind He Kuang
2016-06-03 3:33 ` [PATCH v9 01/14] perf tools: Use LIBUNWIND_DIR for remote libunwind feature check He Kuang
2016-06-08 8:45 ` [tip:perf/core] perf unwind: " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 02/14] perf tools: Decouple thread->address_space on libunwind He Kuang
2016-06-08 8:46 ` [tip:perf/core] perf unwind: " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 03/14] perf tools: Introducing struct unwind_libunwind_ops for local unwind He Kuang
2016-06-08 8:46 ` [tip:perf/core] perf unwind: Introduce 'struct unwind_libunwind_ops' " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 04/14] perf tools: Move unwind__prepare_access from thread_new into thread__insert_map He Kuang
2016-06-08 8:47 ` [tip:perf/core] perf unwind: " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 05/14] perf tools: Don't mix LIBUNWIND_LIBS into LIBUNWIND_LDFLAGS He Kuang
2016-06-08 8:47 ` [tip:perf/core] perf unwind: " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 06/14] perf tools: Separate local/remote libunwind config He Kuang
2016-06-08 8:47 ` [tip:perf/core] perf unwind: " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 07/14] perf tools: Rename unwind-libunwind.c to unwind-libunwind-local.c He Kuang
2016-06-08 8:48 ` [tip:perf/core] perf unwind: " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 08/14] perf tools: Extract common API out of unwind-libunwind-local.c He Kuang
2016-06-08 8:48 ` [tip:perf/core] " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 09/14] perf tools: Export normalize_arch() function He Kuang
2016-06-08 8:49 ` [tip:perf/core] " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 10/14] perf tools: Check the target platform before assigning unwind methods He Kuang
2016-06-04 5:36 ` [PATCH v9 10/14 UPDATE] " He Kuang
2016-06-07 18:06 ` Arnaldo Carvalho de Melo
2016-06-08 8:49 ` [tip:perf/core] perf unwind: " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 11/14] perf tools: Change fixed name of libunwind__arch_reg_id to macro He Kuang
2016-06-08 8:50 ` [tip:perf/core] perf unwind: " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 12/14] perf tools: Introduce flag to separate local/remote unwind compilation He Kuang
2016-06-08 8:50 ` [tip:perf/core] perf unwind: " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 13/14] perf callchain: Support x86 target platform He Kuang
2016-06-08 8:51 ` [tip:perf/core] " tip-bot for He Kuang
2016-06-03 3:33 ` [PATCH v9 14/14] perf callchain: Support aarch64 cross-platform He Kuang
2016-06-08 8:51 ` [tip:perf/core] " tip-bot for He Kuang
2016-06-03 7:06 ` [PATCH v9 00/14] Add support for remote unwind Jiri Olsa
2016-06-03 19:42 ` Arnaldo Carvalho de Melo
2016-06-03 21:06 ` Arnaldo Carvalho de Melo
2016-06-03 21:09 ` Arnaldo Carvalho de Melo
2016-06-04 5:39 ` Hekuang
2016-06-07 15:12 ` Arnaldo Carvalho de Melo
2016-06-07 15:14 ` Arnaldo Carvalho de Melo
2016-06-07 19:44 ` Arnaldo Carvalho de Melo
2016-06-08 7:33 ` Hekuang [this message]
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=5757CA42.4040703@huawei.com \
--to=hekuang@huawei.com \
--cc=acme@kernel.org \
--cc=adrian.hunter@intel.com \
--cc=ak@linux.intel.com \
--cc=alexander.shishkin@linux.intel.com \
--cc=dsahern@gmail.com \
--cc=eranian@google.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.