f9224c5c94
Newt has widespread availability and provides a rather simple API as can be seen by the size of this patch. The work needed to support it will benefit other frontends too. In this initial patch it just checks if the output is a tty, if not it falls back to the previous behaviour, also if newt-devel/libnewt-dev is not installed the previous behaviour is maintaned. Pressing enter on a symbol will annotate it, ESC in the annotation window will return to the report symbol list. More work will be done to remove the special casing in color_fprintf, stop using fmemopen/FILE in the printing of hist_entries, etc. Also the annotation doesn't need to be done via spawning "perf annotate" and then browsing its output, we can do better by calling directly the builtin-annotate.c functions, that would then be moved to tools/perf/util/annotate.c and shared with perf top, etc But lets go by baby steps, this patch already improves perf usability by allowing to quickly do annotations on symbols from the report screen and provides a first experimentation with libnewt/TUI integration of tools. Tested on RHEL5 and Fedora12 X86_64 and on Debian PARISC64 to browse a perf.data file collected on a Fedora12 x86_64 box. Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Avi Kivity <avi@redhat.com> Cc: Frédéric Weisbecker <fweisbec@gmail.com> Cc: Mike Galbraith <efault@gmx.de> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Paul Mackerras <paulus@samba.org> LKML-Reference: <1268349164-5822-5-git-send-email-acme@infradead.org> Signed-off-by: Ingo Molnar <mingo@elte.hu>
99 lines
2.6 KiB
C
99 lines
2.6 KiB
C
#ifndef __PERF_SESSION_H
|
|
#define __PERF_SESSION_H
|
|
|
|
#include "event.h"
|
|
#include "header.h"
|
|
#include "symbol.h"
|
|
#include "thread.h"
|
|
#include <linux/rbtree.h>
|
|
#include "../../../include/linux/perf_event.h"
|
|
|
|
struct ip_callchain;
|
|
struct thread;
|
|
|
|
struct perf_session {
|
|
struct perf_header header;
|
|
unsigned long size;
|
|
unsigned long mmap_window;
|
|
struct map_groups kmaps;
|
|
struct rb_root threads;
|
|
struct thread *last_match;
|
|
struct map *vmlinux_maps[MAP__NR_TYPES];
|
|
struct events_stats events_stats;
|
|
struct rb_root stats_by_id;
|
|
unsigned long event_total[PERF_RECORD_MAX];
|
|
unsigned long unknown_events;
|
|
struct rb_root hists;
|
|
u64 sample_type;
|
|
struct ref_reloc_sym ref_reloc_sym;
|
|
int fd;
|
|
int cwdlen;
|
|
char *cwd;
|
|
char filename[0];
|
|
};
|
|
|
|
typedef int (*event_op)(event_t *self, struct perf_session *session);
|
|
|
|
struct perf_event_ops {
|
|
event_op sample,
|
|
mmap,
|
|
comm,
|
|
fork,
|
|
exit,
|
|
lost,
|
|
read,
|
|
throttle,
|
|
unthrottle;
|
|
};
|
|
|
|
struct perf_session *perf_session__new(const char *filename, int mode, bool force);
|
|
void perf_session__delete(struct perf_session *self);
|
|
|
|
void perf_event_header__bswap(struct perf_event_header *self);
|
|
|
|
int __perf_session__process_events(struct perf_session *self,
|
|
u64 data_offset, u64 data_size, u64 size,
|
|
struct perf_event_ops *ops);
|
|
int perf_session__process_events(struct perf_session *self,
|
|
struct perf_event_ops *event_ops);
|
|
|
|
struct symbol **perf_session__resolve_callchain(struct perf_session *self,
|
|
struct thread *thread,
|
|
struct ip_callchain *chain,
|
|
struct symbol **parent);
|
|
|
|
bool perf_session__has_traces(struct perf_session *self, const char *msg);
|
|
|
|
int perf_header__read_build_ids(struct perf_header *self, int input,
|
|
u64 offset, u64 file_size);
|
|
|
|
int perf_session__set_kallsyms_ref_reloc_sym(struct perf_session *self,
|
|
const char *symbol_name,
|
|
u64 addr);
|
|
|
|
void mem_bswap_64(void *src, int byte_size);
|
|
|
|
static inline int __perf_session__create_kernel_maps(struct perf_session *self,
|
|
struct dso *kernel)
|
|
{
|
|
return __map_groups__create_kernel_maps(&self->kmaps,
|
|
self->vmlinux_maps, kernel);
|
|
}
|
|
|
|
static inline struct map *
|
|
perf_session__new_module_map(struct perf_session *self,
|
|
u64 start, const char *filename)
|
|
{
|
|
return map_groups__new_module(&self->kmaps, start, filename);
|
|
}
|
|
|
|
#ifdef NO_NEWT_SUPPORT
|
|
static inline void perf_session__browse_hists(struct rb_root *hists __used,
|
|
u64 session_total __used,
|
|
const char *helpline __used) {}
|
|
#else
|
|
void perf_session__browse_hists(struct rb_root *hists, u64 session_total,
|
|
const char *helpline);
|
|
#endif
|
|
#endif /* __PERF_SESSION_H */
|