From: Sukadev Bhattiprolu <sukadev@linux.vnet.ibm.com> To: mingo@redhat.com, ak@linux.intel.com, Michael Ellerman <mpe@ellerman.id.au>, Jiri Olsa <jolsa@redhat.com>, Arnaldo Carvalho de Melo <acme@kernel.org> Cc: peterz@infradead.org, namhyung@kernel.org, linuxppc-dev@lists.ozlabs.org, <linux-kernel@vger.kernel.org> Subject: [PATCH v9 11/11] perf-download: Download the events json file Date: Mon, 13 Apr 2015 23:41:04 -0700 [thread overview] Message-ID: <1428993665-2133-12-git-send-email-sukadev@linux.vnet.ibm.com> (raw) In-Reply-To: <1428993665-2133-1-git-send-email-sukadev@linux.vnet.ibm.com> Add a downloader to automatically download the right files from a download site. This is implemented as a script calling curl, similar to perf archive. The perf driver automatically calls the right binary. The downloader is extensible, but currently only implements an Intel and Powerpc event download. It would be straightforward to add support for other architectures. For now, there could be slight variations in how individual architectures organize the JSON files. Eg. Powerpc has a simple mapping from its PVR to cpu family eg power8's events file, which x86 uses, CPU vendor, family model to locate the specific file to download. The downloaded event files are put into ~/.cache/pmu-events, where the builtin event parser in util/* can find them automatically. Signed-off-by: Andi Kleen <ak@linux.intel.com> Link: http://lkml.kernel.org/n/1405123165-22666-8-git-send-email-andi@firstfloor.org Signed-off-by: Jiri Olsa <jolsa@kernel.org> Signed-off-by: Sukadev Bhattiprolu <sukadev@linux.vnet.ibm.com> Changelog[v9] (by Sukadev Bhattiprolu) Add the perf-download script back into patchset. Set default download location to the tools/perf/pmu-events/ directory in Linus's tree. Include code to parse/download powerpc JSON files. Remove Acked-by: Namhyung Kim since this patch has major changes --- tools/perf/Documentation/perf-download.txt | 31 +++++ tools/perf/Documentation/perf-list.txt | 12 +- tools/perf/Makefile.perf | 5 +- tools/perf/perf-download.sh | 171 ++++++++++++++++++++++++++++ 4 files changed, 217 insertions(+), 2 deletions(-) create mode 100644 tools/perf/Documentation/perf-download.txt create mode 100755 tools/perf/perf-download.sh diff --git a/tools/perf/Documentation/perf-download.txt b/tools/perf/Documentation/perf-download.txt new file mode 100644 index 0000000..9e5b28e --- /dev/null +++ b/tools/perf/Documentation/perf-download.txt @@ -0,0 +1,31 @@ +perf-download(1) +=============== + +NAME +---- +perf-download - Download event files for current CPU. + +SYNOPSIS +-------- +[verse] +'perf download' [vendor-family-model] + +DESCRIPTION +----------- +This command automatically downloads the event list for the current CPU and +stores them in $XDG_CACHE_HOME/pmu-events (or $HOME/.cache/pmu-events). +The other tools automatically look for them there. The CPU can be also +specified at the command line. + +The downloading is done using http through wget, which needs +to be installed. When behind a firewall the proxies +may also need to be set up using "export https_proxy=...." + +The user should regularly call this to download updated event lists +for the current CPU. + +Note the downloaded files are stored per user, so if perf is +used as both normal user and with sudo the event files may +also need to be moved to root's home directory with +sudo mkdir /root/.cache ; sud cp -r ~/.cache/pmu-events /root/.cache +after downloading. diff --git a/tools/perf/Documentation/perf-list.txt b/tools/perf/Documentation/perf-list.txt index 7479efe..98637e8 100644 --- a/tools/perf/Documentation/perf-list.txt +++ b/tools/perf/Documentation/perf-list.txt @@ -66,6 +66,16 @@ Sampling). Examples to use IBS: perf record -a -e r076:p ... # same as -e cpu-cycles:p perf record -a -e r0C1:p ... # use ibs op counting micro-ops +PER CPU EVENT LISTS +------------------- + +For some CPUs (particularly modern Intel CPUs) "perf download" can +download additional CPU specific event definitions, which then +become visible in perf list and available in the other perf tools. + +This obsoletes the raw event description method described below +for most cases. + RAW HARDWARE EVENT DESCRIPTOR ----------------------------- Even when an event is not available in a symbolic form within perf right now, @@ -141,6 +151,6 @@ types specified. SEE ALSO -------- linkperf:perf-stat[1], linkperf:perf-top[1], -linkperf:perf-record[1], +linkperf:perf-record[1], linkperf:perf-download[1], http://www.intel.com/Assets/PDF/manual/253669.pdf[Intel® 64 and IA-32 Architectures Software Developer's Manual Volume 3B: System Programming Guide], http://support.amd.com/us/Processor_TechDocs/24593_APM_v2.pdf[AMD64 Architecture Programmer’s Manual Volume 2: System Programming] diff --git a/tools/perf/Makefile.perf b/tools/perf/Makefile.perf index d9c03c4..9f955b1 100644 --- a/tools/perf/Makefile.perf +++ b/tools/perf/Makefile.perf @@ -136,6 +136,7 @@ SCRIPT_SH = SCRIPT_SH += perf-archive.sh SCRIPT_SH += perf-with-kcore.sh +SCRIPT_SH += perf-download.sh grep-libs = $(filter -l%,$(1)) strip-libs = $(filter-out -l%,$(1)) @@ -946,6 +947,8 @@ endif $(INSTALL) $(OUTPUT)perf-archive -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)' $(call QUIET_INSTALL, perf-with-kcore) \ $(INSTALL) $(OUTPUT)perf-with-kcore -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)' + $(call QUIET_INSTALL, perf-download) \ + $(INSTALL) $(OUTPUT)perf-download -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)' ifndef NO_LIBPERL $(call QUIET_INSTALL, perl-scripts) \ $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl/Perf-Trace-Util/lib/Perf/Trace'; \ @@ -991,7 +994,7 @@ config-clean: @$(MAKE) -C config/feature-checks clean >/dev/null clean: $(LIBTRACEEVENT)-clean $(LIBAPIKFS)-clean config-clean - $(call QUIET_CLEAN, core-objs) $(RM) $(LIB_OBJS) $(BUILTIN_OBJS) $(LIB_FILE) $(OUTPUT)perf-archive $(OUTPUT)perf-with-kcore $(OUTPUT)perf.o $(LANG_BINDINGS) $(GTK_OBJS) + $(call QUIET_CLEAN, core-objs) $(RM) $(LIB_OBJS) $(BUILTIN_OBJS) $(LIB_FILE) $(OUTPUT)perf-archive $(OUTPUT)perf-with-kcore $(OUTPUT)perf-download $(OUTPUT)perf.o $(LANG_BINDINGS) $(GTK_OBJS) $(call QUIET_CLEAN, core-progs) $(RM) $(ALL_PROGRAMS) perf perf-read-vdso32 perf-read-vdsox32 $(call QUIET_CLEAN, core-gen) $(RM) *.spec *.pyc *.pyo */*.pyc */*.pyo $(OUTPUT)common-cmds.h TAGS tags cscope* $(OUTPUT)PERF-VERSION-FILE $(OUTPUT)PERF-CFLAGS $(OUTPUT)PERF-FEATURES $(OUTPUT)util/*-bison* $(OUTPUT)util/*-flex* $(QUIET_SUBDIR0)Documentation $(QUIET_SUBDIR1) clean diff --git a/tools/perf/perf-download.sh b/tools/perf/perf-download.sh new file mode 100755 index 0000000..79922c5 --- /dev/null +++ b/tools/perf/perf-download.sh @@ -0,0 +1,171 @@ +#!/bin/bash +# +# Download event files for current cpu for perf +# + +set -e + +CURLOPT=${CURLOPT:- --max-time 5 --progress-bar} +MAPFILE=${MAPFILE:-mapfile.csv} +GKO=https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/plain/; +CACHEDIR=${XDG_CACHE_HOME:-~/.cache} + +ARCH=""; +CPUREV=""; +VENDOR=""; +VFM=""; + +init_arch() +{ + arch=`uname -m | sed -r 's/(x86.*|i.*86)/x86/' \ + | sed -r 's/ppc.*/powerpc/'`; + + if [ "x$arch" == "xpowerpc" -o "x$arch" == "xx86" ]; then + ARCH=$arch; + else + echo "Unknown architecture/CPU $arch" + exit 1; + fi +} + +init_cpu_revision() +{ + if [ "x$ARCH" == "xpowerpc" ]; then + CPUREV=`grep revision /proc/cpuinfo | tail -1 | + awk '{ gsub(/\)/, "", $6); printf("%s%s", $5, $6); }'` + fi +} + +init_vendor_family_model() +{ + if [ "x$ARCH" != "xx86" ]; then + return; + fi + + VFM=$(awk ' + /^vendor/ { V=$3 } + /^model/ && $2 == ":" { M=$3 } + /^cpu family/ { F = $4 } + END { printf("%s-%s-%X", V, F, M) }' \ + /proc/cpuinfo) + + VENDOR=$(echo $VFM | ( IFS=- read v f m ; echo $v) ) +} + +init_defaults() +{ + # Not all architectures need all these + init_arch; + init_cpu_revision; + init_vendor_family_model; +} + +download_x86_files() +{ + case "$VENDOR" in + + GenuineIntel) + echo "Downloading readme.txt" + curl $CURLOPT $URLBASE/readme.txt -o readme.txt + if [ ! -f "readme.txt" ]; then + echo "Couldn't download $URLBASE/readme.txt, continuing" + fi + + ;; + + # Add more CPU vendors here + + *) + echo "Unsupported CPU vendor $V" + exit 1 + ;; + esac + + echo "Downloading models file" + curl $CURLOPT $URLBASE/$MAPFILE -o $MAPFILE + + if [ ! -f $MAPFILE ]; then + echo "Could not download $URLBASE/$MAPFILE" + exit 1; + fi + + events_file=`mktemp`; + echo "Downloading events file" + awk -v urlbase=$URLBASE -v cpu="$VFM" -F, \ + '$1 == cpu && $4 == "core" { \ + print "url = \"" urlbase $3 "\""; \ + exit 0 }' \ + $MAPFILE > $events_file + + if [ -s $events_file ] ; then + curl $CURLOPT -K $events_file -o $VFM-core.json + else + echo "CPU $VFM not found" + fi + + #rm -f $events_file +} + +download_powerpc_files() +{ + # + # Mapfile for Power looks like this: + # + # 004d0100,core,power8.json + # + # where first column is the PVR, and last column is the + # name of the events file for the CPU family. Download + # the events file and create a symlink to it: + # + # 004d0100-core.json -> power8.json + # + echo "Downloading models file, $MAPFILE" + curl $CURLOPT ${URLBASE}/$MAPFILE -o $MAPFILE + + if [ ! -f $MAPFILE ]; then + echo "Could not download $URLBASE/$MAPFILE" + exit 1; + fi + + target=`awk -v cpu="$CPUREV" -F, \ + '$1 == cpu && $2 == "core" { print $3 }' $MAPFILE` + + cpurev=${CPUREV}-core.json + rm -f $cpurev; + + echo "Downloading events file for CPU/Rev '$cpurev'" + curl $CURLOPT ${URLBASE}/$target -o $target + ln -s $target $cpurev +} +# +# Main +# +if ! type curl > /dev/null ; then + echo "please install curl" + exit 1 +fi + +if [ "$1" == "" ] ; then + init_defaults; +else + ARCH=$1; + CPUREV=$2; + VENDOR=$3; +fi; + +URLBASE=${URLBASE:-${GKO}/tools/perf/pmu-events/arch/${ARCH}/}; + +[ ! -d $CACHEDIR/pmu-events ] && mkdir -p $CACHEDIR/pmu-events +cd $CACHEDIR/pmu-events + +case $ARCH in + +x86) + download_x86_files + ;; + +powerpc) + + download_powerpc_files + ;; +esac -- 1.7.9.5
WARNING: multiple messages have this Message-ID (diff)
From: Sukadev Bhattiprolu <sukadev@linux.vnet.ibm.com> To: mingo@redhat.com, ak@linux.intel.com, Michael Ellerman <mpe@ellerman.id.au>, Jiri Olsa <jolsa@redhat.com>, Arnaldo Carvalho de Melo <acme@kernel.org> Cc: peterz@infradead.org, namhyung@kernel.org, linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org Subject: [PATCH v9 11/11] perf-download: Download the events json file Date: Mon, 13 Apr 2015 23:41:04 -0700 [thread overview] Message-ID: <1428993665-2133-12-git-send-email-sukadev@linux.vnet.ibm.com> (raw) In-Reply-To: <1428993665-2133-1-git-send-email-sukadev@linux.vnet.ibm.com> Add a downloader to automatically download the right files from a download site. This is implemented as a script calling curl, similar to perf archive. The perf driver automatically calls the right binary. The downloader is extensible, but currently only implements an Intel and Powerpc event download. It would be straightforward to add support for other architectures. For now, there could be slight variations in how individual architectures organize the JSON files. Eg. Powerpc has a simple mapping from its PVR to cpu family eg power8's events file, which x86 uses, CPU vendor, family model to locate the specific file to download. The downloaded event files are put into ~/.cache/pmu-events, where the builtin event parser in util/* can find them automatically. Signed-off-by: Andi Kleen <ak@linux.intel.com> Link: http://lkml.kernel.org/n/1405123165-22666-8-git-send-email-andi@firstfloor.org Signed-off-by: Jiri Olsa <jolsa@kernel.org> Signed-off-by: Sukadev Bhattiprolu <sukadev@linux.vnet.ibm.com> Changelog[v9] (by Sukadev Bhattiprolu) Add the perf-download script back into patchset. Set default download location to the tools/perf/pmu-events/ directory in Linus's tree. Include code to parse/download powerpc JSON files. Remove Acked-by: Namhyung Kim since this patch has major changes --- tools/perf/Documentation/perf-download.txt | 31 +++++ tools/perf/Documentation/perf-list.txt | 12 +- tools/perf/Makefile.perf | 5 +- tools/perf/perf-download.sh | 171 ++++++++++++++++++++++++++++ 4 files changed, 217 insertions(+), 2 deletions(-) create mode 100644 tools/perf/Documentation/perf-download.txt create mode 100755 tools/perf/perf-download.sh diff --git a/tools/perf/Documentation/perf-download.txt b/tools/perf/Documentation/perf-download.txt new file mode 100644 index 0000000..9e5b28e --- /dev/null +++ b/tools/perf/Documentation/perf-download.txt @@ -0,0 +1,31 @@ +perf-download(1) +=============== + +NAME +---- +perf-download - Download event files for current CPU. + +SYNOPSIS +-------- +[verse] +'perf download' [vendor-family-model] + +DESCRIPTION +----------- +This command automatically downloads the event list for the current CPU and +stores them in $XDG_CACHE_HOME/pmu-events (or $HOME/.cache/pmu-events). +The other tools automatically look for them there. The CPU can be also +specified at the command line. + +The downloading is done using http through wget, which needs +to be installed. When behind a firewall the proxies +may also need to be set up using "export https_proxy=...." + +The user should regularly call this to download updated event lists +for the current CPU. + +Note the downloaded files are stored per user, so if perf is +used as both normal user and with sudo the event files may +also need to be moved to root's home directory with +sudo mkdir /root/.cache ; sud cp -r ~/.cache/pmu-events /root/.cache +after downloading. diff --git a/tools/perf/Documentation/perf-list.txt b/tools/perf/Documentation/perf-list.txt index 7479efe..98637e8 100644 --- a/tools/perf/Documentation/perf-list.txt +++ b/tools/perf/Documentation/perf-list.txt @@ -66,6 +66,16 @@ Sampling). Examples to use IBS: perf record -a -e r076:p ... # same as -e cpu-cycles:p perf record -a -e r0C1:p ... # use ibs op counting micro-ops +PER CPU EVENT LISTS +------------------- + +For some CPUs (particularly modern Intel CPUs) "perf download" can +download additional CPU specific event definitions, which then +become visible in perf list and available in the other perf tools. + +This obsoletes the raw event description method described below +for most cases. + RAW HARDWARE EVENT DESCRIPTOR ----------------------------- Even when an event is not available in a symbolic form within perf right now, @@ -141,6 +151,6 @@ types specified. SEE ALSO -------- linkperf:perf-stat[1], linkperf:perf-top[1], -linkperf:perf-record[1], +linkperf:perf-record[1], linkperf:perf-download[1], http://www.intel.com/Assets/PDF/manual/253669.pdf[Intel® 64 and IA-32 Architectures Software Developer's Manual Volume 3B: System Programming Guide], http://support.amd.com/us/Processor_TechDocs/24593_APM_v2.pdf[AMD64 Architecture Programmer’s Manual Volume 2: System Programming] diff --git a/tools/perf/Makefile.perf b/tools/perf/Makefile.perf index d9c03c4..9f955b1 100644 --- a/tools/perf/Makefile.perf +++ b/tools/perf/Makefile.perf @@ -136,6 +136,7 @@ SCRIPT_SH = SCRIPT_SH += perf-archive.sh SCRIPT_SH += perf-with-kcore.sh +SCRIPT_SH += perf-download.sh grep-libs = $(filter -l%,$(1)) strip-libs = $(filter-out -l%,$(1)) @@ -946,6 +947,8 @@ endif $(INSTALL) $(OUTPUT)perf-archive -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)' $(call QUIET_INSTALL, perf-with-kcore) \ $(INSTALL) $(OUTPUT)perf-with-kcore -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)' + $(call QUIET_INSTALL, perf-download) \ + $(INSTALL) $(OUTPUT)perf-download -t '$(DESTDIR_SQ)$(perfexec_instdir_SQ)' ifndef NO_LIBPERL $(call QUIET_INSTALL, perl-scripts) \ $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/scripts/perl/Perf-Trace-Util/lib/Perf/Trace'; \ @@ -991,7 +994,7 @@ config-clean: @$(MAKE) -C config/feature-checks clean >/dev/null clean: $(LIBTRACEEVENT)-clean $(LIBAPIKFS)-clean config-clean - $(call QUIET_CLEAN, core-objs) $(RM) $(LIB_OBJS) $(BUILTIN_OBJS) $(LIB_FILE) $(OUTPUT)perf-archive $(OUTPUT)perf-with-kcore $(OUTPUT)perf.o $(LANG_BINDINGS) $(GTK_OBJS) + $(call QUIET_CLEAN, core-objs) $(RM) $(LIB_OBJS) $(BUILTIN_OBJS) $(LIB_FILE) $(OUTPUT)perf-archive $(OUTPUT)perf-with-kcore $(OUTPUT)perf-download $(OUTPUT)perf.o $(LANG_BINDINGS) $(GTK_OBJS) $(call QUIET_CLEAN, core-progs) $(RM) $(ALL_PROGRAMS) perf perf-read-vdso32 perf-read-vdsox32 $(call QUIET_CLEAN, core-gen) $(RM) *.spec *.pyc *.pyo */*.pyc */*.pyo $(OUTPUT)common-cmds.h TAGS tags cscope* $(OUTPUT)PERF-VERSION-FILE $(OUTPUT)PERF-CFLAGS $(OUTPUT)PERF-FEATURES $(OUTPUT)util/*-bison* $(OUTPUT)util/*-flex* $(QUIET_SUBDIR0)Documentation $(QUIET_SUBDIR1) clean diff --git a/tools/perf/perf-download.sh b/tools/perf/perf-download.sh new file mode 100755 index 0000000..79922c5 --- /dev/null +++ b/tools/perf/perf-download.sh @@ -0,0 +1,171 @@ +#!/bin/bash +# +# Download event files for current cpu for perf +# + +set -e + +CURLOPT=${CURLOPT:- --max-time 5 --progress-bar} +MAPFILE=${MAPFILE:-mapfile.csv} +GKO=https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/plain/; +CACHEDIR=${XDG_CACHE_HOME:-~/.cache} + +ARCH=""; +CPUREV=""; +VENDOR=""; +VFM=""; + +init_arch() +{ + arch=`uname -m | sed -r 's/(x86.*|i.*86)/x86/' \ + | sed -r 's/ppc.*/powerpc/'`; + + if [ "x$arch" == "xpowerpc" -o "x$arch" == "xx86" ]; then + ARCH=$arch; + else + echo "Unknown architecture/CPU $arch" + exit 1; + fi +} + +init_cpu_revision() +{ + if [ "x$ARCH" == "xpowerpc" ]; then + CPUREV=`grep revision /proc/cpuinfo | tail -1 | + awk '{ gsub(/\)/, "", $6); printf("%s%s", $5, $6); }'` + fi +} + +init_vendor_family_model() +{ + if [ "x$ARCH" != "xx86" ]; then + return; + fi + + VFM=$(awk ' + /^vendor/ { V=$3 } + /^model/ && $2 == ":" { M=$3 } + /^cpu family/ { F = $4 } + END { printf("%s-%s-%X", V, F, M) }' \ + /proc/cpuinfo) + + VENDOR=$(echo $VFM | ( IFS=- read v f m ; echo $v) ) +} + +init_defaults() +{ + # Not all architectures need all these + init_arch; + init_cpu_revision; + init_vendor_family_model; +} + +download_x86_files() +{ + case "$VENDOR" in + + GenuineIntel) + echo "Downloading readme.txt" + curl $CURLOPT $URLBASE/readme.txt -o readme.txt + if [ ! -f "readme.txt" ]; then + echo "Couldn't download $URLBASE/readme.txt, continuing" + fi + + ;; + + # Add more CPU vendors here + + *) + echo "Unsupported CPU vendor $V" + exit 1 + ;; + esac + + echo "Downloading models file" + curl $CURLOPT $URLBASE/$MAPFILE -o $MAPFILE + + if [ ! -f $MAPFILE ]; then + echo "Could not download $URLBASE/$MAPFILE" + exit 1; + fi + + events_file=`mktemp`; + echo "Downloading events file" + awk -v urlbase=$URLBASE -v cpu="$VFM" -F, \ + '$1 == cpu && $4 == "core" { \ + print "url = \"" urlbase $3 "\""; \ + exit 0 }' \ + $MAPFILE > $events_file + + if [ -s $events_file ] ; then + curl $CURLOPT -K $events_file -o $VFM-core.json + else + echo "CPU $VFM not found" + fi + + #rm -f $events_file +} + +download_powerpc_files() +{ + # + # Mapfile for Power looks like this: + # + # 004d0100,core,power8.json + # + # where first column is the PVR, and last column is the + # name of the events file for the CPU family. Download + # the events file and create a symlink to it: + # + # 004d0100-core.json -> power8.json + # + echo "Downloading models file, $MAPFILE" + curl $CURLOPT ${URLBASE}/$MAPFILE -o $MAPFILE + + if [ ! -f $MAPFILE ]; then + echo "Could not download $URLBASE/$MAPFILE" + exit 1; + fi + + target=`awk -v cpu="$CPUREV" -F, \ + '$1 == cpu && $2 == "core" { print $3 }' $MAPFILE` + + cpurev=${CPUREV}-core.json + rm -f $cpurev; + + echo "Downloading events file for CPU/Rev '$cpurev'" + curl $CURLOPT ${URLBASE}/$target -o $target + ln -s $target $cpurev +} +# +# Main +# +if ! type curl > /dev/null ; then + echo "please install curl" + exit 1 +fi + +if [ "$1" == "" ] ; then + init_defaults; +else + ARCH=$1; + CPUREV=$2; + VENDOR=$3; +fi; + +URLBASE=${URLBASE:-${GKO}/tools/perf/pmu-events/arch/${ARCH}/}; + +[ ! -d $CACHEDIR/pmu-events ] && mkdir -p $CACHEDIR/pmu-events +cd $CACHEDIR/pmu-events + +case $ARCH in + +x86) + download_x86_files + ;; + +powerpc) + + download_powerpc_files + ;; +esac -- 1.7.9.5
next prev parent reply other threads:[~2015-04-14 6:42 UTC|newest] Thread overview: 50+ messages / expand[flat|nested] mbox.gz Atom feed top 2015-04-14 6:40 [PATCH v9 00/11] Add support for JSON event files Sukadev Bhattiprolu 2015-04-14 6:40 ` Sukadev Bhattiprolu 2015-04-14 6:40 ` [PATCH v9 01/11] perf, tools: Add jsmn `jasmine' JSON parser Sukadev Bhattiprolu 2015-04-14 6:40 ` Sukadev Bhattiprolu 2015-04-14 6:40 ` [PATCH v9 02/11] perf, tools: Add support for text descriptions of events and alias add Sukadev Bhattiprolu 2015-04-14 6:40 ` Sukadev Bhattiprolu 2015-04-14 6:40 ` [PATCH v9 03/11] perf, tools, list: Update perf list to output descriptions Sukadev Bhattiprolu 2015-04-14 6:40 ` Sukadev Bhattiprolu 2015-04-14 6:40 ` [PATCH v9 04/11] perf, tools: Add support for reading JSON event files Sukadev Bhattiprolu 2015-04-14 6:40 ` Sukadev Bhattiprolu 2015-04-14 6:40 ` [PATCH v9 05/11] perf, tools: Automatically look for event file name for cpu Sukadev Bhattiprolu 2015-04-14 6:40 ` Sukadev Bhattiprolu 2015-04-14 6:40 ` [PATCH v9 06/11] powerpc/perf: Implement get_cpu_str() Sukadev Bhattiprolu 2015-04-14 6:40 ` Sukadev Bhattiprolu 2015-04-14 6:41 ` [PATCH v9 07/11] perf, tools: Query terminal width and use in perf list Sukadev Bhattiprolu 2015-04-14 6:41 ` Sukadev Bhattiprolu 2015-04-14 6:41 ` [PATCH v9 08/11] perf, tools: Add a new pmu interface to iterate over all events Sukadev Bhattiprolu 2015-04-14 6:41 ` Sukadev Bhattiprolu 2015-04-14 6:41 ` [PATCH v9 09/11] perf, tools, test: Add test case for alias and JSON parsing Sukadev Bhattiprolu 2015-04-14 6:41 ` Sukadev Bhattiprolu 2015-04-14 6:41 ` [PATCH v9 10/11] perf, tools: Add a --no-desc flag to perf list Sukadev Bhattiprolu 2015-04-14 6:41 ` Sukadev Bhattiprolu 2015-04-14 6:41 ` Sukadev Bhattiprolu [this message] 2015-04-14 6:41 ` [PATCH v9 11/11] perf-download: Download the events json file Sukadev Bhattiprolu 2015-04-14 8:55 ` 'perf upgrade' (was: Re: [PATCH v9 00/11] Add support for JSON event files.) Ingo Molnar 2015-04-14 8:55 ` Ingo Molnar 2015-04-14 11:21 ` Michael Ellerman 2015-04-14 11:21 ` Michael Ellerman 2015-04-14 12:58 ` Ingo Molnar 2015-04-14 12:58 ` Ingo Molnar 2015-04-14 18:03 ` Sukadev Bhattiprolu 2015-04-14 18:03 ` Sukadev Bhattiprolu 2015-04-14 22:53 ` Michael Ellerman 2015-04-14 22:53 ` Michael Ellerman 2015-04-15 9:25 ` Ingo Molnar 2015-04-15 9:25 ` Ingo Molnar 2015-04-15 19:17 ` Andi Kleen 2015-04-15 19:17 ` Andi Kleen 2015-04-15 20:50 ` Sukadev Bhattiprolu 2015-04-15 20:50 ` Sukadev Bhattiprolu 2015-04-17 15:31 ` Jiri Olsa 2015-04-17 15:31 ` Jiri Olsa 2015-04-17 20:09 ` Andi Kleen 2015-04-17 20:09 ` Andi Kleen 2015-04-18 13:05 ` Jiri Olsa 2015-04-18 13:05 ` Jiri Olsa 2015-04-18 13:12 ` Jiri Olsa 2015-04-18 13:12 ` Jiri Olsa 2015-04-14 20:16 ` Andi Kleen 2015-04-14 20:16 ` Andi Kleen
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=1428993665-2133-12-git-send-email-sukadev@linux.vnet.ibm.com \ --to=sukadev@linux.vnet.ibm.com \ --cc=acme@kernel.org \ --cc=ak@linux.intel.com \ --cc=jolsa@redhat.com \ --cc=linux-kernel@vger.kernel.org \ --cc=linuxppc-dev@lists.ozlabs.org \ --cc=mingo@redhat.com \ --cc=mpe@ellerman.id.au \ --cc=namhyung@kernel.org \ --cc=peterz@infradead.org \ /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: linkBe 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.