| #ifndef __PERF_SESSION_H | 
 | #define __PERF_SESSION_H | 
 |  | 
 | #include "hist.h" | 
 | #include "event.h" | 
 | #include "header.h" | 
 | #include "symbol.h" | 
 | #include "thread.h" | 
 | #include <linux/rbtree.h> | 
 | #include "../../../include/linux/perf_event.h" | 
 |  | 
 | struct sample_queue; | 
 | struct ip_callchain; | 
 | struct thread; | 
 |  | 
 | struct ordered_samples { | 
 | 	u64			last_flush; | 
 | 	u64			next_flush; | 
 | 	u64			max_timestamp; | 
 | 	struct list_head	samples; | 
 | 	struct list_head	sample_cache; | 
 | 	struct list_head	to_free; | 
 | 	struct sample_queue	*sample_buffer; | 
 | 	struct sample_queue	*last_sample; | 
 | 	int			sample_buffer_idx; | 
 | }; | 
 |  | 
 | struct perf_session { | 
 | 	struct perf_header	header; | 
 | 	unsigned long		size; | 
 | 	unsigned long		mmap_window; | 
 | 	struct rb_root		threads; | 
 | 	struct list_head	dead_threads; | 
 | 	struct thread		*last_match; | 
 | 	struct machine		host_machine; | 
 | 	struct rb_root		machines; | 
 | 	struct perf_evlist	*evlist; | 
 | 	/* | 
 | 	 * FIXME: Need to split this up further, we need global | 
 | 	 *	  stats + per event stats. 'perf diff' also needs | 
 | 	 *	  to properly support multiple events in a single | 
 | 	 *	  perf.data file. | 
 | 	 */ | 
 | 	struct hists		hists; | 
 | 	u64			sample_type; | 
 | 	int			fd; | 
 | 	bool			fd_pipe; | 
 | 	bool			repipe; | 
 | 	bool			sample_id_all; | 
 | 	u16			id_hdr_size; | 
 | 	int			cwdlen; | 
 | 	char			*cwd; | 
 | 	struct ordered_samples	ordered_samples; | 
 | 	struct callchain_cursor	callchain_cursor; | 
 | 	char			filename[0]; | 
 | }; | 
 |  | 
 | struct perf_evsel; | 
 | struct perf_event_ops; | 
 |  | 
 | typedef int (*event_sample)(union perf_event *event, struct perf_sample *sample, | 
 | 			    struct perf_evsel *evsel, struct perf_session *session); | 
 | typedef int (*event_op)(union perf_event *self, struct perf_sample *sample, | 
 | 			struct perf_session *session); | 
 | typedef int (*event_synth_op)(union perf_event *self, | 
 | 			      struct perf_session *session); | 
 | typedef int (*event_op2)(union perf_event *self, struct perf_session *session, | 
 | 			 struct perf_event_ops *ops); | 
 |  | 
 | struct perf_event_ops { | 
 | 	event_sample	sample; | 
 | 	event_op	mmap, | 
 | 			comm, | 
 | 			fork, | 
 | 			exit, | 
 | 			lost, | 
 | 			read, | 
 | 			throttle, | 
 | 			unthrottle; | 
 | 	event_synth_op	attr, | 
 | 			event_type, | 
 | 			tracing_data, | 
 | 			build_id; | 
 | 	event_op2	finished_round; | 
 | 	bool		ordered_samples; | 
 | 	bool		ordering_requires_timestamps; | 
 | }; | 
 |  | 
 | struct perf_session *perf_session__new(const char *filename, int mode, | 
 | 				       bool force, bool repipe, | 
 | 				       struct perf_event_ops *ops); | 
 | 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); | 
 |  | 
 | int 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_session__set_kallsyms_ref_reloc_sym(struct map **maps, | 
 | 					     const char *symbol_name, | 
 | 					     u64 addr); | 
 |  | 
 | void mem_bswap_64(void *src, int byte_size); | 
 |  | 
 | int perf_session__create_kernel_maps(struct perf_session *self); | 
 |  | 
 | void perf_session__update_sample_type(struct perf_session *self); | 
 | void perf_session__remove_thread(struct perf_session *self, struct thread *th); | 
 |  | 
 | static inline | 
 | struct machine *perf_session__find_host_machine(struct perf_session *self) | 
 | { | 
 | 	return &self->host_machine; | 
 | } | 
 |  | 
 | static inline | 
 | struct machine *perf_session__find_machine(struct perf_session *self, pid_t pid) | 
 | { | 
 | 	if (pid == HOST_KERNEL_ID) | 
 | 		return &self->host_machine; | 
 | 	return machines__find(&self->machines, pid); | 
 | } | 
 |  | 
 | static inline | 
 | struct machine *perf_session__findnew_machine(struct perf_session *self, pid_t pid) | 
 | { | 
 | 	if (pid == HOST_KERNEL_ID) | 
 | 		return &self->host_machine; | 
 | 	return machines__findnew(&self->machines, pid); | 
 | } | 
 |  | 
 | static inline | 
 | void perf_session__process_machines(struct perf_session *self, | 
 | 				    machine__process_t process) | 
 | { | 
 | 	process(&self->host_machine, self); | 
 | 	return machines__process(&self->machines, process, self); | 
 | } | 
 |  | 
 | size_t perf_session__fprintf_dsos(struct perf_session *self, FILE *fp); | 
 |  | 
 | size_t perf_session__fprintf_dsos_buildid(struct perf_session *self, | 
 | 					  FILE *fp, bool with_hits); | 
 |  | 
 | size_t perf_session__fprintf_nr_events(struct perf_session *session, FILE *fp); | 
 |  | 
 | static inline int perf_session__parse_sample(struct perf_session *session, | 
 | 					     const union perf_event *event, | 
 | 					     struct perf_sample *sample) | 
 | { | 
 | 	return perf_event__parse_sample(event, session->sample_type, | 
 | 					session->sample_id_all, sample); | 
 | } | 
 |  | 
 | void perf_session__print_symbols(union perf_event *event, | 
 | 				 struct perf_sample *sample, | 
 | 				 struct perf_session *session); | 
 |  | 
 | #endif /* __PERF_SESSION_H */ |