perf/urgent fixes:
. perf probe: Fix segfault due to testing the wrong pointer for NULL, from Ananth N Mavinakayanahalli. . libtraceevent: Remove hard coded include to /usr/local/include in Makefile, which causes cross builds to include host header files, fix from Jack Mitchell. . perf record: Use the right target interface for synthesizing threads when --cpu/-C option is used, fix from Jiri Olsa. . Check if -DFORTIFY_SOURCE=2 is allowed, as gcc 4.7.2 defines it and then the build is broken when it is redefined in perf, fix from Marcin Slusarz. . Fix build with NO_NEWT=1, that can happen explicitely or when the newt-devel package is not installed, from Michael Ellerman. . perf/POWER7: Create a sysfs format entry for Power7 events, missing patch from a patchseries already merged, from Sukadev Bhattiprolu. . Fix LIBNUMA build with glibc 2.12 and older, from Vinson Lee. Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com> -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.14 (GNU/Linux) iQIcBAABAgAGBQJRQblOAAoJENZQFvNTUqpAop0P+wT/5oWqaMU1WgHpP4OTn8dU 6FkOf9+9IvncOLvE32Kg+hcnLsf9pQWnOxpZgmIxq53d0GI51eNyGPrpedAb89ep aa1/C5TUoX18tPiVYB5jahM+f8cw1gZX0CGzdJSpMJF3a0qiXTPAawUnoVJOpPYr lPaAmR8sxvm+HwlyBTQM4FFNY36O7inPQxg/gvoW8348Ml9bl63Bh3GytHCOOGLf cNgceQu8NpvAG0kqWUFhlZVyYHW4ruD7q+3VUY8ZNltYuA+LAy1Z0FHC8SxJM3B2 CSKNqRaO8NJ/9eqQ9hg1CHeZVqyNLx58Y0yByGf5LiMUd6DMN7KoQzZEtekEt+L5 baijxKlFoIX/tneIt2droWIvxzyahhKwUTXbrcaDRPIPw4KqWvy/5+KN+S939yPs TnuDai6y+yxPXZMPxLCCharXVGwDWP9HiW7nq25ZLmFILWMUbL42Apb4ErMsEoik CRO6ALB9bFn1GkTWPCEMGGmnDGudQSRRwOlgoMEt6XdL5RALv/lgX4HMWfSQ1Wpz 0GzXRDSokXwAu2QIp2QoqsNspvH/1f4WUjiHiwwDSoontujbJ7/hrqdXYjMuS8cU lh0I8p/JpLdvEnCF4vwQo2YozWZEvPtlrYNVx+PqPB1RsNow0WCepHeg/urfxHC3 qVO/30jASFDpYLyl7h2N =aN1j -----END PGP SIGNATURE----- Merge tag 'perf-urgent-for-mingo' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux into perf/urgent Pull perf/urgent fixes from Arnaldo Carvalho de Melo: . perf probe: Fix segfault due to testing the wrong pointer for NULL, from Ananth N Mavinakayanahalli. . libtraceevent: Remove hard coded include to /usr/local/include in Makefile, which causes cross builds to include host header files, fix from Jack Mitchell. . perf record: Use the right target interface for synthesizing threads when --cpu/-C option is used, fix from Jiri Olsa. . Check if -DFORTIFY_SOURCE=2 is allowed, as gcc 4.7.2 defines it and then the build is broken when it is redefined in perf, fix from Marcin Slusarz. . Fix build with NO_NEWT=1, that can happen explicitely or when the newt-devel package is not installed, from Michael Ellerman. . perf/POWER7: Create a sysfs format entry for Power7 events, missing patch from a patchseries already merged, from Sukadev Bhattiprolu. . Fix LIBNUMA build with glibc 2.12 and older, from Vinson Lee. Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com> Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
commit
a0bf225db7
7 changed files with 53 additions and 7 deletions
|
@ -420,7 +420,20 @@ static struct attribute_group power7_pmu_events_group = {
|
||||||
.attrs = power7_events_attr,
|
.attrs = power7_events_attr,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
PMU_FORMAT_ATTR(event, "config:0-19");
|
||||||
|
|
||||||
|
static struct attribute *power7_pmu_format_attr[] = {
|
||||||
|
&format_attr_event.attr,
|
||||||
|
NULL,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct attribute_group power7_pmu_format_group = {
|
||||||
|
.name = "format",
|
||||||
|
.attrs = power7_pmu_format_attr,
|
||||||
|
};
|
||||||
|
|
||||||
static const struct attribute_group *power7_pmu_attr_groups[] = {
|
static const struct attribute_group *power7_pmu_attr_groups[] = {
|
||||||
|
&power7_pmu_format_group,
|
||||||
&power7_pmu_events_group,
|
&power7_pmu_events_group,
|
||||||
NULL,
|
NULL,
|
||||||
};
|
};
|
||||||
|
|
|
@ -122,7 +122,7 @@ export Q VERBOSE
|
||||||
|
|
||||||
EVENT_PARSE_VERSION = $(EP_VERSION).$(EP_PATCHLEVEL).$(EP_EXTRAVERSION)
|
EVENT_PARSE_VERSION = $(EP_VERSION).$(EP_PATCHLEVEL).$(EP_EXTRAVERSION)
|
||||||
|
|
||||||
INCLUDES = -I. -I/usr/local/include $(CONFIG_INCLUDES)
|
INCLUDES = -I. $(CONFIG_INCLUDES)
|
||||||
|
|
||||||
# Set compile option CFLAGS if not set elsewhere
|
# Set compile option CFLAGS if not set elsewhere
|
||||||
CFLAGS ?= -g -Wall
|
CFLAGS ?= -g -Wall
|
||||||
|
|
|
@ -95,7 +95,7 @@ ifeq ("$(origin DEBUG)", "command line")
|
||||||
PERF_DEBUG = $(DEBUG)
|
PERF_DEBUG = $(DEBUG)
|
||||||
endif
|
endif
|
||||||
ifndef PERF_DEBUG
|
ifndef PERF_DEBUG
|
||||||
CFLAGS_OPTIMIZE = -O6 -D_FORTIFY_SOURCE=2
|
CFLAGS_OPTIMIZE = -O6
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifdef PARSER_DEBUG
|
ifdef PARSER_DEBUG
|
||||||
|
@ -180,6 +180,12 @@ ifeq ($(call try-cc,$(SOURCE_HELLO),$(CFLAGS) -Werror -Wvolatile-register-var,-W
|
||||||
CFLAGS := $(CFLAGS) -Wvolatile-register-var
|
CFLAGS := $(CFLAGS) -Wvolatile-register-var
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifndef PERF_DEBUG
|
||||||
|
ifeq ($(call try-cc,$(SOURCE_HELLO),$(CFLAGS) -D_FORTIFY_SOURCE=2,-D_FORTIFY_SOURCE=2),y)
|
||||||
|
CFLAGS := $(CFLAGS) -D_FORTIFY_SOURCE=2
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
### --- END CONFIGURATION SECTION ---
|
### --- END CONFIGURATION SECTION ---
|
||||||
|
|
||||||
ifeq ($(srctree),)
|
ifeq ($(srctree),)
|
||||||
|
|
|
@ -1,6 +1,30 @@
|
||||||
#ifndef BENCH_H
|
#ifndef BENCH_H
|
||||||
#define BENCH_H
|
#define BENCH_H
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The madvise transparent hugepage constants were added in glibc
|
||||||
|
* 2.13. For compatibility with older versions of glibc, define these
|
||||||
|
* tokens if they are not already defined.
|
||||||
|
*
|
||||||
|
* PA-RISC uses different madvise values from other architectures and
|
||||||
|
* needs to be special-cased.
|
||||||
|
*/
|
||||||
|
#ifdef __hppa__
|
||||||
|
# ifndef MADV_HUGEPAGE
|
||||||
|
# define MADV_HUGEPAGE 67
|
||||||
|
# endif
|
||||||
|
# ifndef MADV_NOHUGEPAGE
|
||||||
|
# define MADV_NOHUGEPAGE 68
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
# ifndef MADV_HUGEPAGE
|
||||||
|
# define MADV_HUGEPAGE 14
|
||||||
|
# endif
|
||||||
|
# ifndef MADV_NOHUGEPAGE
|
||||||
|
# define MADV_NOHUGEPAGE 15
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
extern int bench_numa(int argc, const char **argv, const char *prefix);
|
extern int bench_numa(int argc, const char **argv, const char *prefix);
|
||||||
extern int bench_sched_messaging(int argc, const char **argv, const char *prefix);
|
extern int bench_sched_messaging(int argc, const char **argv, const char *prefix);
|
||||||
extern int bench_sched_pipe(int argc, const char **argv, const char *prefix);
|
extern int bench_sched_pipe(int argc, const char **argv, const char *prefix);
|
||||||
|
|
|
@ -573,13 +573,15 @@ static int __cmd_record(struct perf_record *rec, int argc, const char **argv)
|
||||||
perf_event__synthesize_guest_os, tool);
|
perf_event__synthesize_guest_os, tool);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!opts->target.system_wide)
|
if (perf_target__has_task(&opts->target))
|
||||||
err = perf_event__synthesize_thread_map(tool, evsel_list->threads,
|
err = perf_event__synthesize_thread_map(tool, evsel_list->threads,
|
||||||
process_synthesized_event,
|
process_synthesized_event,
|
||||||
machine);
|
machine);
|
||||||
else
|
else if (perf_target__has_cpu(&opts->target))
|
||||||
err = perf_event__synthesize_threads(tool, process_synthesized_event,
|
err = perf_event__synthesize_threads(tool, process_synthesized_event,
|
||||||
machine);
|
machine);
|
||||||
|
else /* command specified */
|
||||||
|
err = 0;
|
||||||
|
|
||||||
if (err != 0)
|
if (err != 0)
|
||||||
goto out_delete_session;
|
goto out_delete_session;
|
||||||
|
|
|
@ -208,8 +208,9 @@ static inline int script_browse(const char *script_opt __maybe_unused)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define K_LEFT -1
|
#define K_LEFT -1000
|
||||||
#define K_RIGHT -2
|
#define K_RIGHT -2000
|
||||||
|
#define K_SWITCH_INPUT_DATA -3000
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef GTK2_SUPPORT
|
#ifdef GTK2_SUPPORT
|
||||||
|
|
|
@ -143,7 +143,7 @@ struct strlist *strlist__new(bool dupstr, const char *list)
|
||||||
slist->rblist.node_delete = strlist__node_delete;
|
slist->rblist.node_delete = strlist__node_delete;
|
||||||
|
|
||||||
slist->dupstr = dupstr;
|
slist->dupstr = dupstr;
|
||||||
if (slist && strlist__parse_list(slist, list) != 0)
|
if (list && strlist__parse_list(slist, list) != 0)
|
||||||
goto out_error;
|
goto out_error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue