linux-perf-users.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Namhyung Kim <namhyung@kernel.org>
To: Paran Lee <p4ranlee@gmail.com>
Cc: Peter Zijlstra <peterz@infradead.org>,
	Ingo Molnar <mingo@redhat.com>,
	 Arnaldo Carvalho de Melo <acme@kernel.org>,
	Mark Rutland <mark.rutland@arm.com>,
	 Alexander Shishkin <alexander.shishkin@linux.intel.com>,
	Jiri Olsa <jolsa@kernel.org>,  Ian Rogers <irogers@google.com>,
	Adrian Hunter <adrian.hunter@intel.com>,
	 Sean Christopherson <seanjc@google.com>,
	Li Dong <lidong@vivo.com>,
	 Paul Walmsley <paul.walmsley@sifive.com>,
	Palmer Dabbelt <palmer@dabbelt.com>,
	 Albert Ou <aou@eecs.berkeley.edu>,
	linux-perf-users@vger.kernel.org,
	 linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org,
	 shjy180909@gmail.com, austindh.kim@gmail.com,
	honggyu.kp@gmail.com,  tegongkang@gmail.com
Subject: Re: [PATCH] perf callchain: Support riscv cross-platform
Date: Wed, 22 Nov 2023 10:51:28 -0800	[thread overview]
Message-ID: <CAM9d7chhc3Guwh_PzxRM68zwSY-JHThgqkkKuEOsuFO8AVWmTw@mail.gmail.com> (raw)
In-Reply-To: <20231122155548.2449-1-p4ranlee@gmail.com>

Hi Paran,

On Wed, Nov 22, 2023 at 7:56 AM Paran Lee <p4ranlee@gmail.com> wrote:
>
> Support riscv cross platform callchain unwind.
> Tested on RISCV 64 Starfive VisionFive2 Board
> ------------
> $ uname -ra
> Linux starfive 5.15.0-starfive #
> 1 SMP Mon Dec 19 07:56:37 EST 2022 riscv64 GNU/Linux
> paran@starfive:~/linux-next$ cat /etc/os-release
> PRETTY_NAME="Debian GNU/Linux bookworm/sid"
> NAME="Debian GNU/Linux"
> ID=debian
> HOME_URL="https://www.debian.org/"
> SUPPORT_URL="https://www.debian.org/support"
> BUG_REPORT_URL="https://bugs.debian.org/"
> ------------
> paran@starfive:~/linux-next/tools/perf$
>  make  NO_AUXTRACE=1  NO_LIBTRACEEVENT=1 -j4
> Auto-detecting system features:
> ...                                   dwarf: [ on  ]
> ...                      dwarf_getlocations: [ on  ]
> ...                                   glibc: [ on  ]
> ...                                  libbfd: [ on  ]
> ...                          libbfd-buildid: [ on  ]
> ...                                  libcap: [ on  ]
> ...                                  libelf: [ on  ]
> ...                                 libnuma: [ on  ]
> ...                  numa_num_possible_cpus: [ on  ]
> ...                                 libperl: [ on  ]
> ...                               libpython: [ on  ]
> ...                               libcrypto: [ on  ]
> ...                               libunwind: [ on  ]
> ...                      libdw-dwarf-unwind: [ on  ]
> ...                                    zlib: [ on  ]
> ...                                    lzma: [ on  ]
> ...                               get_cpuid: [ OFF ]
> ...                                     bpf: [ on  ]
> ...                                  libaio: [ on  ]
> ...                                 libzstd: [ on  ]
> ...
> CC      arch/riscv/util/dwarf-regs.o
> CC      arch/riscv/util/unwind-libunwind.o
> ...
> LINK    perf
> ------------
> Signed-off-by: Paran Lee <p4ranlee@gmail.com>
> ---
>  tools/build/Makefile.feature                  |  2 +
>  tools/build/feature/Makefile                  |  8 ++++
>  tools/perf/Makefile.config                    | 18 +++++++++
>  tools/perf/arch/riscv/util/Build              |  1 +
>  tools/perf/arch/riscv/util/unwind-libunwind.c | 17 ++++++++
>  tools/perf/check-headers.sh                   |  3 ++
>  tools/perf/util/libunwind/riscv.c             | 40 +++++++++++++++++++
>  tools/perf/util/unwind-libunwind.c            |  5 +++
>  8 files changed, 94 insertions(+)
>  create mode 100644 tools/perf/arch/riscv/util/unwind-libunwind.c
>  create mode 100644 tools/perf/util/libunwind/riscv.c
>
> diff --git a/tools/build/Makefile.feature b/tools/build/Makefile.feature
> index 934e2777a2db..e4140dee1d70 100644
> --- a/tools/build/Makefile.feature
> +++ b/tools/build/Makefile.feature
> @@ -93,9 +93,11 @@ FEATURE_TESTS_EXTRA :=                  \
>           libunwind-x86_64               \
>           libunwind-arm                  \
>           libunwind-aarch64              \
> +         libunwind-riscv                \
>           libunwind-debug-frame          \
>           libunwind-debug-frame-arm      \
>           libunwind-debug-frame-aarch64  \
> +         libunwind-debug-frame-riscv    \
>           cxx                            \
>           llvm                           \
>           llvm-version                   \
> diff --git a/tools/build/feature/Makefile b/tools/build/feature/Makefile
> index dad79ede4e0a..e3218f98f824 100644
> --- a/tools/build/feature/Makefile
> +++ b/tools/build/feature/Makefile
> @@ -45,8 +45,10 @@ FILES=                                          \
>           test-libunwind-x86_64.bin              \
>           test-libunwind-arm.bin                 \
>           test-libunwind-aarch64.bin             \
> +                test-libunwind-riscv.bin               \
>           test-libunwind-debug-frame-arm.bin     \
>           test-libunwind-debug-frame-aarch64.bin \
> +                test-libunwind-debug-frame-riscv.bin   \

Whitespace damaged?  Also I think you need to add
the source files for the feature checks.

Thanks,
Namhyung


>           test-pthread-attr-setaffinity-np.bin   \
>           test-pthread-barrier.bin              \
>           test-stackprotector-all.bin            \
> @@ -189,12 +191,18 @@ $(OUTPUT)test-libunwind-arm.bin:
>  $(OUTPUT)test-libunwind-aarch64.bin:
>         $(BUILD) -lelf -lunwind-aarch64
>
> +$(OUTPUT)test-libunwind-riscv.bin:
> +       $(BUILD) -lelf -lunwind-riscv
> +
>  $(OUTPUT)test-libunwind-debug-frame-arm.bin:
>         $(BUILD) -lelf -lunwind-arm
>
>  $(OUTPUT)test-libunwind-debug-frame-aarch64.bin:
>         $(BUILD) -lelf -lunwind-aarch64
>
> +$(OUTPUT)test-libunwind-debug-frame-riscv.bin:
> +       $(BUILD) -lelf -lunwind-riscv
> +
>  $(OUTPUT)test-libaudit.bin:
>         $(BUILD) -laudit
>
> diff --git a/tools/perf/Makefile.config b/tools/perf/Makefile.config
> index b3e6ed10f40c..b72c1b886b28 100644
> --- a/tools/perf/Makefile.config
> +++ b/tools/perf/Makefile.config
> @@ -88,6 +88,8 @@ endif
>
>  ifeq ($(SRCARCH),riscv)
>    NO_PERF_REGS := 0
> +    CFLAGS += -I$(OUTPUT)arch/riscv/include/generated
> +    LIBUNWIND_LIBS = -lunwind -lunwind-riscv
>  endif
>
>  ifeq ($(SRCARCH),csky)
> @@ -147,6 +149,7 @@ FEATURE_CHECK_LDFLAGS-libunwind-debug-frame = $(LIBUNWIND_LDFLAGS) $(LIBUNWIND_L
>
>  FEATURE_CHECK_LDFLAGS-libunwind-arm += -lunwind -lunwind-arm
>  FEATURE_CHECK_LDFLAGS-libunwind-aarch64 += -lunwind -lunwind-aarch64
> +FEATURE_CHECK_LDFLAGS-libunwind-riscv += -lunwind -lunwind-riscv
>  FEATURE_CHECK_LDFLAGS-libunwind-x86 += -lunwind -llzma -lunwind-x86
>  FEATURE_CHECK_LDFLAGS-libunwind-x86_64 += -lunwind -llzma -lunwind-x86_64
>
> @@ -651,6 +654,21 @@ ifndef NO_LIBUNWIND
>      endif
>    endif
>
> +  $(call feature_check,libunwind-riscv)
> +  ifeq ($(feature-libunwind-riscv), 1)
> +    $(call detected,CONFIG_LIBUNWIND_RISCV)
> +    CFLAGS += -DHAVE_LIBUNWIND_RISCV_SUPPORT
> +    LDFLAGS += -lunwind-riscv
> +    EXTLIBS_LIBUNWIND += -lunwind-riscv
> +    have_libunwind = 1
> +    $(call feature_check,libunwind-debug-frame-riscv)
> +    ifneq ($(feature-libunwind-debug-frame-riscv), 1)
> +      msg := $(warning No debug_frame support found in libunwind-riscv);
> +      CFLAGS += -DNO_LIBUNWIND_DEBUG_FRAME_riscv
> +    endif
> +  endif
> +
> +
>    ifneq ($(feature-libunwind), 1)
>      msg := $(warning No libunwind found. Please install libunwind-dev[el] >= 1.1 and/or set LIBUNWIND_DIR);
>      NO_LOCAL_LIBUNWIND := 1
> diff --git a/tools/perf/arch/riscv/util/Build b/tools/perf/arch/riscv/util/Build
> index 603dbb5ae4dc..0f75e25ae638 100644
> --- a/tools/perf/arch/riscv/util/Build
> +++ b/tools/perf/arch/riscv/util/Build
> @@ -2,4 +2,5 @@ perf-y += perf_regs.o
>  perf-y += header.o
>
>  perf-$(CONFIG_DWARF) += dwarf-regs.o
> +perf-$(CONFIG_LOCAL_LIBUNWIND) += unwind-libunwind.o
>  perf-$(CONFIG_LIBDW_DWARF_UNWIND) += unwind-libdw.o
> diff --git a/tools/perf/arch/riscv/util/unwind-libunwind.c b/tools/perf/arch/riscv/util/unwind-libunwind.c
> new file mode 100644
> index 000000000000..e9d6c9c06f84
> --- /dev/null
> +++ b/tools/perf/arch/riscv/util/unwind-libunwind.c
> @@ -0,0 +1,17 @@
> +// SPDX-License-Identifier: GPL-2.0
> +#include <errno.h>
> +
> +#ifndef REMOTE_UNWIND_LIBUNWIND
> +#include <libunwind.h>
> +#include "perf_regs.h"
> +#include "../../../util/unwind.h"
> +#endif
> +#include "../../../util/debug.h"
> +
> +int LIBUNWIND__ARCH_REG_ID(int regnum)
> +{
> +       if (regnum < 0 || regnum >= PERF_REG_RISCV_MAX)
> +               return -EINVAL;
> +
> +       return regnum;
> +}
> diff --git a/tools/perf/check-headers.sh b/tools/perf/check-headers.sh
> index 66ba33dbcef2..3a774c9544c4 100755
> --- a/tools/perf/check-headers.sh
> +++ b/tools/perf/check-headers.sh
> @@ -48,6 +48,7 @@ FILES=(
>    "arch/loongarch/include/uapi/asm/perf_regs.h"
>    "arch/mips/include/uapi/asm/perf_regs.h"
>    "arch/powerpc/include/uapi/asm/perf_regs.h"
> +  "arch/riscv/include/uapi/asm/perf_regs.h"
>    "arch/s390/include/uapi/asm/perf_regs.h"
>    "arch/x86/include/uapi/asm/perf_regs.h"
>    "arch/x86/include/uapi/asm/kvm.h"
> @@ -67,6 +68,8 @@ FILES=(
>    "arch/mips/include/uapi/asm/errno.h"
>    "arch/parisc/include/uapi/asm/errno.h"
>    "arch/powerpc/include/uapi/asm/errno.h"
> +  "arch/riscv/include/uapi/asm/kvm.h"
> +  "arch/riscv/include/uapi/asm/unistd.h"
>    "arch/sparc/include/uapi/asm/errno.h"
>    "arch/x86/include/uapi/asm/errno.h"
>    "include/asm-generic/bitops/arch_hweight.h"
> diff --git a/tools/perf/util/libunwind/riscv.c b/tools/perf/util/libunwind/riscv.c
> new file mode 100644
> index 000000000000..c340c5609161
> --- /dev/null
> +++ b/tools/perf/util/libunwind/riscv.c
> @@ -0,0 +1,40 @@
> +// SPDX-License-Identifier: GPL-2.0
> +/*
> + * This file setups defines to compile arch specific binary from the
> + * generic one.
> + *
> + * The function 'LIBUNWIND__ARCH_REG_ID' name is set according to arch
> + * name and the definition of this function is included directly from
> + * 'arch/riscv/util/unwind-libunwind.c', to make sure that this function
> + * is defined no matter what arch the host is.
> + *
> + * Finally, the arch specific unwind methods are exported which will
> + * be assigned to each riscv thread.
> + */
> +
> +#define REMOTE_UNWIND_LIBUNWIND
> +
> +/* Define arch specific functions & regs for libunwind, should be
> + * defined before including "unwind.h"
> + */
> +#define LIBUNWIND__ARCH_REG_ID(regnum) libunwind__riscv_reg_id(regnum)
> +
> +#include "unwind.h"
> +#include "libunwind-riscv.h"
> +#define perf_event_riscv_regs perf_event_riscv64_regs
> +#include <../../../arch/riscv/include/uapi/asm/perf_regs.h>
> +#undef perf_event_riscv_regs
> +#include "../../arch/riscv/util/unwind-libunwind.c"
> +
> +/* NO_LIBUNWIND_DEBUG_FRAME is a feature flag for local libunwind,
> + * assign NO_LIBUNWIND_DEBUG_FRAME_RISCV64 to it for compiling riscv
> + * unwind methods.
> + */
> +#undef NO_LIBUNWIND_DEBUG_FRAME
> +#ifdef NO_LIBUNWIND_DEBUG_FRAME_RISCV
> +#define NO_LIBUNWIND_DEBUG_FRAME
> +#endif
> +#include "util/unwind-libunwind-local.c"
> +
> +struct unwind_libunwind_ops *
> +riscv_unwind_libunwind_ops = &_unwind_libunwind_ops;
> diff --git a/tools/perf/util/unwind-libunwind.c b/tools/perf/util/unwind-libunwind.c
> index 76cd63de80a8..52190f1eaf0d 100644
> --- a/tools/perf/util/unwind-libunwind.c
> +++ b/tools/perf/util/unwind-libunwind.c
> @@ -11,6 +11,7 @@
>  struct unwind_libunwind_ops __weak *local_unwind_libunwind_ops;
>  struct unwind_libunwind_ops __weak *x86_32_unwind_libunwind_ops;
>  struct unwind_libunwind_ops __weak *arm64_unwind_libunwind_ops;
> +struct unwind_libunwind_ops __weak *riscv_unwind_libunwind_ops;
>
>  static void unwind__register_ops(struct maps *maps, struct unwind_libunwind_ops *ops)
>  {
> @@ -54,6 +55,10 @@ int unwind__prepare_access(struct maps *maps, struct map *map, bool *initialized
>                 if (dso_type == DSO__TYPE_64BIT)
>                         ops = arm64_unwind_libunwind_ops;
>         }
> +       } else if (!strcmp(arch, "riscv64") || !strcmp(arch, "riscv")) {
> +               if (dso_type == DSO__TYPE_64BIT)
> +                       ops = riscv_unwind_libunwind_ops;
> +       }
>
>         if (!ops) {
>                 pr_warning_once("unwind: target platform=%s is not supported\n", arch);
> --
> 2.25.1
>

  reply	other threads:[~2023-11-22 18:51 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-11-22 15:55 [PATCH] perf callchain: Support riscv cross-platform Paran Lee
2023-11-22 18:51 ` Namhyung Kim [this message]
2023-11-24 11:47 ` kernel test robot

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=CAM9d7chhc3Guwh_PzxRM68zwSY-JHThgqkkKuEOsuFO8AVWmTw@mail.gmail.com \
    --to=namhyung@kernel.org \
    --cc=acme@kernel.org \
    --cc=adrian.hunter@intel.com \
    --cc=alexander.shishkin@linux.intel.com \
    --cc=aou@eecs.berkeley.edu \
    --cc=austindh.kim@gmail.com \
    --cc=honggyu.kp@gmail.com \
    --cc=irogers@google.com \
    --cc=jolsa@kernel.org \
    --cc=lidong@vivo.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-perf-users@vger.kernel.org \
    --cc=linux-riscv@lists.infradead.org \
    --cc=mark.rutland@arm.com \
    --cc=mingo@redhat.com \
    --cc=p4ranlee@gmail.com \
    --cc=palmer@dabbelt.com \
    --cc=paul.walmsley@sifive.com \
    --cc=peterz@infradead.org \
    --cc=seanjc@google.com \
    --cc=shjy180909@gmail.com \
    --cc=tegongkang@gmail.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).