2009-09-25 00:02:18 +08:00
|
|
|
#ifndef __PERF_CACHE_H
|
|
|
|
#define __PERF_CACHE_H
|
2009-04-20 21:00:56 +08:00
|
|
|
|
2010-03-12 07:12:44 +08:00
|
|
|
#include <stdbool.h>
|
2009-04-20 21:00:56 +08:00
|
|
|
#include "util.h"
|
|
|
|
#include "strbuf.h"
|
2009-07-01 18:37:06 +08:00
|
|
|
#include "../perf.h"
|
2009-04-20 21:00:56 +08:00
|
|
|
|
2009-10-13 16:18:16 +08:00
|
|
|
#define CMD_EXEC_PATH "--exec-path"
|
|
|
|
#define CMD_PERF_DIR "--perf-dir="
|
|
|
|
#define CMD_WORK_TREE "--work-tree="
|
|
|
|
#define CMD_DEBUGFS_DIR "--debugfs-dir="
|
|
|
|
|
2009-04-20 21:00:56 +08:00
|
|
|
#define PERF_DIR_ENVIRONMENT "PERF_DIR"
|
|
|
|
#define PERF_WORK_TREE_ENVIRONMENT "PERF_WORK_TREE"
|
|
|
|
#define EXEC_PATH_ENVIRONMENT "PERF_EXEC_PATH"
|
2010-05-19 05:29:23 +08:00
|
|
|
#define DEFAULT_PERF_DIR_ENVIRONMENT ".perf"
|
2009-07-22 02:16:29 +08:00
|
|
|
#define PERF_DEBUGFS_ENVIRONMENT "PERF_DEBUGFS_DIR"
|
2009-04-20 21:00:56 +08:00
|
|
|
|
|
|
|
typedef int (*config_fn_t)(const char *, const char *, void *);
|
|
|
|
extern int perf_default_config(const char *, const char *, void *);
|
|
|
|
extern int perf_config(config_fn_t fn, void *);
|
|
|
|
extern int perf_config_int(const char *, const char *);
|
|
|
|
extern int perf_config_bool(const char *, const char *);
|
|
|
|
extern int config_error_nonbool(const char *);
|
perf buildid: add perfconfig option to specify buildid cache dir
This patch adds the ability to specify an alternate directory to store the
buildid cache (buildids, copy of binaries). By default, it is hardcoded to
$HOME/.debug. This directory contains immutable data. The layout of the
directory is such that no conflicts in filenames are possible. A modification
in a file, yields a different buildid and thus a different location in the
subdir hierarchy.
You may want to put the buildid cache elsewhere because of disk space
limitation or simply to share the cache between users. It is also useful for
remote collect vs. local analysis of profiles.
This patch adds a new config option to the perfconfig file. Under the tag
'buildid', there is a dir option. For instance, if you have:
$ cat /etc/perfconfig
[buildid]
dir = /var/cache/perf-buildid
All buildids and binaries are be saved in the directory specified. The perf
record, buildid-list, buildid-cache, report, annotate, and archive commands
will it to pull information out.
The option can be set in the system-wide perfconfig file or in the
$HOME/.perfconfig file.
Cc: David S. Miller <davem@davemloft.net>
Cc: Frédéric Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Cc: Tom Zanussi <tzanussi@gmail.com>
LKML-Reference: <4c055fb7.df0ce30a.5f0d.ffffae52@mx.google.com>
Signed-off-by: Stephane Eranian <eranian@google.com>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2010-06-02 03:25:01 +08:00
|
|
|
extern const char *perf_config_dirname(const char *, const char *);
|
2009-04-20 21:00:56 +08:00
|
|
|
|
|
|
|
/* pager.c */
|
|
|
|
extern void setup_pager(void);
|
|
|
|
extern const char *pager_program;
|
|
|
|
extern int pager_in_use(void);
|
|
|
|
extern int pager_use_color;
|
|
|
|
|
perf tui: Allow disabling the TUI on a per command basis in ~/.perfconfig
Using the same scheme as for git's/perf's pager setup, i.e. if one
doesn't want to, on a newt enabled perf binary, to disable the TUI for
'perf report', its just a matter of doing:
[root@doppio linux-2.6-tip]# printf "[tui]\n\nreport = off\n" >
/root/.perfconfig
[root@doppio linux-2.6-tip]# cat /root/.perfconfig
[tui]
report = off
[root@doppio linux-2.6-tip]#
System wide settings are also possible, by editing /etc/perfconfig, etc,
i.e. the git machinery for config files applies to perf as well, so when
in doubt where to put your settings, consult the git documentation, if
it fails, please let us know.
Suggested-by: Ingo Molnar <mingo@elte.hu>
Discussed-with: Stephane Eranian <eranian@google.com>
Cc: Frédéric Weisbecker <fweisbec@gmail.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Stephane Eranian <eranian@google.com>
Cc: Tom Zanussi <tzanussi@gmail.com>
LKML-Reference: <new-submission>
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2010-05-21 09:01:10 +08:00
|
|
|
extern int use_browser;
|
2010-03-12 07:12:44 +08:00
|
|
|
|
|
|
|
#ifdef NO_NEWT_SUPPORT
|
2011-02-01 04:08:39 +08:00
|
|
|
static inline void setup_browser(bool fallback_to_pager)
|
2010-03-12 07:12:44 +08:00
|
|
|
{
|
2011-02-01 04:08:39 +08:00
|
|
|
if (fallback_to_pager)
|
|
|
|
setup_pager();
|
2010-03-12 07:12:44 +08:00
|
|
|
}
|
2010-03-23 00:10:25 +08:00
|
|
|
static inline void exit_browser(bool wait_for_ok __used) {}
|
2010-03-12 07:12:44 +08:00
|
|
|
#else
|
2011-02-01 04:08:39 +08:00
|
|
|
void setup_browser(bool fallback_to_pager);
|
2010-03-23 00:10:25 +08:00
|
|
|
void exit_browser(bool wait_for_ok);
|
2010-03-12 07:12:44 +08:00
|
|
|
#endif
|
|
|
|
|
2012-03-20 02:13:29 +08:00
|
|
|
#ifdef NO_GTK2_SUPPORT
|
|
|
|
static inline void perf_gtk_setup_browser(int argc __used, const char *argv[] __used, bool fallback_to_pager)
|
|
|
|
{
|
|
|
|
if (fallback_to_pager)
|
|
|
|
setup_pager();
|
|
|
|
}
|
|
|
|
static inline void perf_gtk_exit_browser(bool wait_for_ok __used) {}
|
|
|
|
#else
|
|
|
|
void perf_gtk_setup_browser(int argc, const char *argv[], bool fallback_to_pager);
|
|
|
|
void perf_gtk_exit_browser(bool wait_for_ok);
|
|
|
|
#endif
|
|
|
|
|
2009-04-20 21:00:56 +08:00
|
|
|
char *alias_lookup(const char *alias);
|
|
|
|
int split_cmdline(char *cmdline, const char ***argv);
|
|
|
|
|
|
|
|
#define alloc_nr(x) (((x)+16)*3/2)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Realloc the buffer pointed at by variable 'x' so that it can hold
|
|
|
|
* at least 'nr' entries; the number of entries currently allocated
|
|
|
|
* is 'alloc', using the standard growing factor alloc_nr() macro.
|
|
|
|
*
|
|
|
|
* DO NOT USE any expression with side-effect for 'x' or 'alloc'.
|
|
|
|
*/
|
|
|
|
#define ALLOC_GROW(x, nr, alloc) \
|
|
|
|
do { \
|
|
|
|
if ((nr) > alloc) { \
|
|
|
|
if (alloc_nr(alloc) < (nr)) \
|
|
|
|
alloc = (nr); \
|
|
|
|
else \
|
|
|
|
alloc = alloc_nr(alloc); \
|
|
|
|
x = xrealloc((x), alloc * sizeof(*(x))); \
|
|
|
|
} \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
|
|
|
|
static inline int is_absolute_path(const char *path)
|
|
|
|
{
|
|
|
|
return path[0] == '/';
|
|
|
|
}
|
2009-04-20 21:22:22 +08:00
|
|
|
|
|
|
|
const char *make_nonrelative_path(const char *path);
|
|
|
|
char *strip_path_suffix(const char *path, const char *suffix);
|
|
|
|
|
|
|
|
extern char *mkpath(const char *fmt, ...) __attribute__((format (printf, 1, 2)));
|
|
|
|
extern char *perf_path(const char *fmt, ...) __attribute__((format (printf, 1, 2)));
|
|
|
|
|
|
|
|
extern char *perf_pathdup(const char *fmt, ...)
|
|
|
|
__attribute__((format (printf, 1, 2)));
|
|
|
|
|
2010-08-21 08:38:20 +08:00
|
|
|
#ifdef NO_STRLCPY
|
2009-04-20 21:22:22 +08:00
|
|
|
extern size_t strlcpy(char *dest, const char *src, size_t size);
|
2010-08-21 08:38:20 +08:00
|
|
|
#endif
|
2009-04-20 21:22:22 +08:00
|
|
|
|
2009-09-25 00:02:18 +08:00
|
|
|
#endif /* __PERF_CACHE_H */
|