diff options
Diffstat (limited to 'include/trace')
| -rw-r--r-- | include/trace/ftrace.h | 44 | ||||
| -rw-r--r-- | include/trace/syscall.h | 8 | 
2 files changed, 28 insertions, 24 deletions
| diff --git a/include/trace/ftrace.h b/include/trace/ftrace.h index 601ad7744247..ea6f9d4a20e9 100644 --- a/include/trace/ftrace.h +++ b/include/trace/ftrace.h @@ -401,18 +401,18 @@ static inline notrace int ftrace_get_offsets_##call(			\  #undef DEFINE_EVENT  #define DEFINE_EVENT(template, name, proto, args)			\  									\ -static void ftrace_profile_##name(proto);				\ +static void perf_trace_##name(proto);					\  									\  static notrace int							\ -ftrace_profile_enable_##name(struct ftrace_event_call *unused)		\ +perf_trace_enable_##name(struct ftrace_event_call *unused)		\  {									\ -	return register_trace_##name(ftrace_profile_##name);		\ +	return register_trace_##name(perf_trace_##name);		\  }									\  									\  static notrace void							\ -ftrace_profile_disable_##name(struct ftrace_event_call *unused)		\ +perf_trace_disable_##name(struct ftrace_event_call *unused)		\  {									\ -	unregister_trace_##name(ftrace_profile_##name);			\ +	unregister_trace_##name(perf_trace_##name);			\  }  #undef DEFINE_EVENT_PRINT @@ -507,12 +507,12 @@ ftrace_profile_disable_##name(struct ftrace_event_call *unused)		\  #ifdef CONFIG_PERF_EVENTS -#define _TRACE_PROFILE_INIT(call)					\ -	.profile_enable = ftrace_profile_enable_##call,			\ -	.profile_disable = ftrace_profile_disable_##call, +#define _TRACE_PERF_INIT(call)						\ +	.perf_event_enable = perf_trace_enable_##call,			\ +	.perf_event_disable = perf_trace_disable_##call,  #else -#define _TRACE_PROFILE_INIT(call) +#define _TRACE_PERF_INIT(call)  #endif /* CONFIG_PERF_EVENTS */  #undef __entry @@ -638,7 +638,7 @@ __attribute__((section("_ftrace_events"))) event_##call = {		\  	.unregfunc		= ftrace_raw_unreg_event_##call,	\  	.print_fmt		= print_fmt_##template,			\  	.define_fields		= ftrace_define_fields_##template,	\ -	_TRACE_PROFILE_INIT(call)					\ +	_TRACE_PERF_INIT(call)					\  }  #undef DEFINE_EVENT_PRINT @@ -657,18 +657,18 @@ __attribute__((section("_ftrace_events"))) event_##call = {		\  	.unregfunc		= ftrace_raw_unreg_event_##call,	\  	.print_fmt		= print_fmt_##call,			\  	.define_fields		= ftrace_define_fields_##template,	\ -	_TRACE_PROFILE_INIT(call)					\ +	_TRACE_PERF_INIT(call)					\  }  #include TRACE_INCLUDE(TRACE_INCLUDE_FILE)  /* - * Define the insertion callback to profile events + * Define the insertion callback to perf events   *   * The job is very similar to ftrace_raw_event_<call> except that we don't   * insert in the ring buffer but in a perf counter.   * - * static void ftrace_profile_<call>(proto) + * static void ftrace_perf_<call>(proto)   * {   *	struct ftrace_data_offsets_<call> __maybe_unused __data_offsets;   *	struct ftrace_event_call *event_call = &event_<call>; @@ -757,13 +757,14 @@ __attribute__((section("_ftrace_events"))) event_##call = {		\  #undef DECLARE_EVENT_CLASS  #define DECLARE_EVENT_CLASS(call, proto, args, tstruct, assign, print)	\  static notrace void							\ -ftrace_profile_templ_##call(struct ftrace_event_call *event_call,	\ +perf_trace_templ_##call(struct ftrace_event_call *event_call,		\  			    proto)					\  {									\  	struct ftrace_data_offsets_##call __maybe_unused __data_offsets;\  	struct ftrace_raw_##call *entry;				\  	u64 __addr = 0, __count = 1;					\  	unsigned long irq_flags;					\ +	struct pt_regs *__regs;						\  	int __entry_size;						\  	int __data_size;						\  	int rctx;							\ @@ -773,10 +774,10 @@ ftrace_profile_templ_##call(struct ftrace_event_call *event_call,	\  			     sizeof(u64));				\  	__entry_size -= sizeof(u32);					\  									\ -	if (WARN_ONCE(__entry_size > FTRACE_MAX_PROFILE_SIZE,		\ +	if (WARN_ONCE(__entry_size > PERF_MAX_TRACE_SIZE,		\  		      "profile buffer not large enough"))		\  		return;							\ -	entry = (struct ftrace_raw_##call *)ftrace_perf_buf_prepare(	\ +	entry = (struct ftrace_raw_##call *)perf_trace_buf_prepare(	\  		__entry_size, event_call->id, &rctx, &irq_flags);	\  	if (!entry)							\  		return;							\ @@ -784,17 +785,20 @@ ftrace_profile_templ_##call(struct ftrace_event_call *event_call,	\  									\  	{ assign; }							\  									\ -	ftrace_perf_buf_submit(entry, __entry_size, rctx, __addr,	\ -			       __count, irq_flags);			\ +	__regs = &__get_cpu_var(perf_trace_regs);			\ +	perf_fetch_caller_regs(__regs, 2);				\ +									\ +	perf_trace_buf_submit(entry, __entry_size, rctx, __addr,	\ +			       __count, irq_flags, __regs);		\  }  #undef DEFINE_EVENT  #define DEFINE_EVENT(template, call, proto, args)		\ -static notrace void ftrace_profile_##call(proto)		\ +static notrace void perf_trace_##call(proto)			\  {								\  	struct ftrace_event_call *event_call = &event_##call;	\  								\ -	ftrace_profile_templ_##template(event_call, args);	\ +	perf_trace_templ_##template(event_call, args);		\  }  #undef DEFINE_EVENT_PRINT diff --git a/include/trace/syscall.h b/include/trace/syscall.h index 0387100752f0..e5e5f48dbfb3 100644 --- a/include/trace/syscall.h +++ b/include/trace/syscall.h @@ -47,10 +47,10 @@ enum print_line_t print_syscall_exit(struct trace_iterator *iter, int flags);  #endif  #ifdef CONFIG_PERF_EVENTS -int prof_sysenter_enable(struct ftrace_event_call *call); -void prof_sysenter_disable(struct ftrace_event_call *call); -int prof_sysexit_enable(struct ftrace_event_call *call); -void prof_sysexit_disable(struct ftrace_event_call *call); +int perf_sysenter_enable(struct ftrace_event_call *call); +void perf_sysenter_disable(struct ftrace_event_call *call); +int perf_sysexit_enable(struct ftrace_event_call *call); +void perf_sysexit_disable(struct ftrace_event_call *call);  #endif  #endif /* _TRACE_SYSCALL_H */ | 
