diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-05-22 18:18:55 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-05-22 18:18:55 -0700 | 
| commit | 2ff2b289a695807e291e1ed9f639d8a3ba5f4254 (patch) | |
| tree | e4b7f44e5cc1582ba2be8aeba221f4841f4c86a6 /tools/lib/traceevent/parse-utils.c | |
| parent | 88d6ae8dc33af12fe1c7941b1fae2767374046fd (diff) | |
| parent | 73787190d04a34e6da745da893b3ae8bedde418f (diff) | |
Merge branch 'perf-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull perf changes from Ingo Molnar:
 "Lots of changes:
   - (much) improved assembly annotation support in perf report, with
     jump visualization, searching, navigation, visual output
     improvements and more.
    - kernel support for AMD IBS PMU hardware features.  Notably 'perf
      record -e cycles:p' and 'perf top -e cycles:p' should work without
      skid now, like PEBS does on the Intel side, because it takes
      advantage of IBS transparently.
    - the libtracevents library: it is the first step towards unifying
      tracing tooling and perf, and it also gives a tracing library for
      external tools like powertop to rely on.
    - infrastructure: various improvements and refactoring of the UI
      modules and related code
    - infrastructure: cleanup and simplification of the profiling
      targets code (--uid, --pid, --tid, --cpu, --all-cpus, etc.)
    - tons of robustness fixes all around
    - various ftrace updates: speedups, cleanups, robustness
      improvements.
    - typing 'make' in tools/ will now give you a menu of projects to
      build and a short help text to explain what each does.
    - ... and lots of other changes I forgot to list.
  The perf record make bzImage + perf report regression you reported
  should be fixed."
* 'perf-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (166 commits)
  tracing: Remove kernel_lock annotations
  tracing: Fix initial buffer_size_kb state
  ring-buffer: Merge separate resize loops
  perf evsel: Create events initially disabled -- again
  perf tools: Split term type into value type and term type
  perf hists: Fix callchain ip printf format
  perf target: Add uses_mmap field
  ftrace: Remove selecting FRAME_POINTER with FUNCTION_TRACER
  ftrace/x86: Have x86 ftrace use the ftrace_modify_all_code()
  ftrace: Make ftrace_modify_all_code() global for archs to use
  ftrace: Return record ip addr for ftrace_location()
  ftrace: Consolidate ftrace_location() and ftrace_text_reserved()
  ftrace: Speed up search by skipping pages by address
  ftrace: Remove extra helper functions
  ftrace: Sort all function addresses, not just per page
  tracing: change CPU ring buffer state from tracing_cpumask
  tracing: Check return value of tracing_dentry_percpu()
  ring-buffer: Reset head page before running self test
  ring-buffer: Add integrity check at end of iter read
  ring-buffer: Make addition of pages in ring buffer atomic
  ...
Diffstat (limited to 'tools/lib/traceevent/parse-utils.c')
| -rw-r--r-- | tools/lib/traceevent/parse-utils.c | 110 | 
1 files changed, 110 insertions, 0 deletions
| diff --git a/tools/lib/traceevent/parse-utils.c b/tools/lib/traceevent/parse-utils.c new file mode 100644 index 00000000000..f023a133abb --- /dev/null +++ b/tools/lib/traceevent/parse-utils.c @@ -0,0 +1,110 @@ +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <stdarg.h> +#include <errno.h> + +#define __weak __attribute__((weak)) + +void __vdie(const char *fmt, va_list ap) +{ +	int ret = errno; + +	if (errno) +		perror("trace-cmd"); +	else +		ret = -1; + +	fprintf(stderr, "  "); +	vfprintf(stderr, fmt, ap); + +	fprintf(stderr, "\n"); +	exit(ret); +} + +void __die(const char *fmt, ...) +{ +	va_list ap; + +	va_start(ap, fmt); +	__vdie(fmt, ap); +	va_end(ap); +} + +void __weak die(const char *fmt, ...) +{ +	va_list ap; + +	va_start(ap, fmt); +	__vdie(fmt, ap); +	va_end(ap); +} + +void __vwarning(const char *fmt, va_list ap) +{ +	if (errno) +		perror("trace-cmd"); +	errno = 0; + +	fprintf(stderr, "  "); +	vfprintf(stderr, fmt, ap); + +	fprintf(stderr, "\n"); +} + +void __warning(const char *fmt, ...) +{ +	va_list ap; + +	va_start(ap, fmt); +	__vwarning(fmt, ap); +	va_end(ap); +} + +void __weak warning(const char *fmt, ...) +{ +	va_list ap; + +	va_start(ap, fmt); +	__vwarning(fmt, ap); +	va_end(ap); +} + +void __vpr_stat(const char *fmt, va_list ap) +{ +	vprintf(fmt, ap); +	printf("\n"); +} + +void __pr_stat(const char *fmt, ...) +{ +	va_list ap; + +	va_start(ap, fmt); +	__vpr_stat(fmt, ap); +	va_end(ap); +} + +void __weak vpr_stat(const char *fmt, va_list ap) +{ +	__vpr_stat(fmt, ap); +} + +void __weak pr_stat(const char *fmt, ...) +{ +	va_list ap; + +	va_start(ap, fmt); +	__vpr_stat(fmt, ap); +	va_end(ap); +} + +void __weak *malloc_or_die(unsigned int size) +{ +	void *data; + +	data = malloc(size); +	if (!data) +		die("malloc"); +	return data; +} | 
