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 *);
|
|
|
|
|
|
|
|
/* 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
|
|
|
|
static inline void setup_browser(void)
|
|
|
|
{
|
|
|
|
setup_pager();
|
|
|
|
}
|
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
|
|
|
|
void setup_browser(void);
|
2010-03-23 00:10:25 +08:00
|
|
|
void exit_browser(bool wait_for_ok);
|
2010-03-12 07:12:44 +08:00
|
|
|
#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)));
|
|
|
|
|
|
|
|
extern size_t strlcpy(char *dest, const char *src, size_t size);
|
|
|
|
|
2009-09-25 00:02:18 +08:00
|
|
|
#endif /* __PERF_CACHE_H */
|