The previous patches added the use of print_fmt string and changes the trace_define_field() function to also create the fields and format output for the event format files. text data bss dec hex filename 5857201 1355780 9336808 16549789 fc879d vmlinux 5884589 1351684 9337896 16574169 fce6d9 vmlinux-orig The above shows the size of the vmlinux after this patch set compared to the vmlinux-orig which is before the patch set. This saves us 27k on text, 1k on bss and adds just 4k of data. The total savings of 24k in size. Signed-off-by: Lai Jiangshan <laijs@cn.fujitsu.com> LKML-Reference: <4B273D4D.40604@cn.fujitsu.com> Acked-by: Masami Hiramatsu <mhiramat@redhat.com> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
57 lines
1.8 KiB
C
57 lines
1.8 KiB
C
#ifndef _TRACE_SYSCALL_H
|
|
#define _TRACE_SYSCALL_H
|
|
|
|
#include <linux/tracepoint.h>
|
|
#include <linux/unistd.h>
|
|
#include <linux/ftrace_event.h>
|
|
|
|
#include <asm/ptrace.h>
|
|
|
|
|
|
/*
|
|
* A syscall entry in the ftrace syscalls array.
|
|
*
|
|
* @name: name of the syscall
|
|
* @syscall_nr: number of the syscall
|
|
* @nb_args: number of parameters it takes
|
|
* @types: list of types as strings
|
|
* @args: list of args as strings (args[i] matches types[i])
|
|
* @enter_event: associated syscall_enter trace event
|
|
* @exit_event: associated syscall_exit trace event
|
|
*/
|
|
struct syscall_metadata {
|
|
const char *name;
|
|
int syscall_nr;
|
|
int nb_args;
|
|
const char **types;
|
|
const char **args;
|
|
|
|
struct ftrace_event_call *enter_event;
|
|
struct ftrace_event_call *exit_event;
|
|
};
|
|
|
|
#ifdef CONFIG_FTRACE_SYSCALLS
|
|
extern unsigned long arch_syscall_addr(int nr);
|
|
extern int init_syscall_trace(struct ftrace_event_call *call);
|
|
|
|
extern int syscall_enter_define_fields(struct ftrace_event_call *call);
|
|
extern int syscall_exit_define_fields(struct ftrace_event_call *call);
|
|
extern int reg_event_syscall_enter(struct ftrace_event_call *call);
|
|
extern void unreg_event_syscall_enter(struct ftrace_event_call *call);
|
|
extern int reg_event_syscall_exit(struct ftrace_event_call *call);
|
|
extern void unreg_event_syscall_exit(struct ftrace_event_call *call);
|
|
extern int
|
|
ftrace_format_syscall(struct ftrace_event_call *call, struct trace_seq *s);
|
|
enum print_line_t print_syscall_enter(struct trace_iterator *iter, int flags);
|
|
enum print_line_t print_syscall_exit(struct trace_iterator *iter, int flags);
|
|
#endif
|
|
#ifdef CONFIG_EVENT_PROFILE
|
|
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);
|
|
|
|
#endif
|
|
|
|
#endif /* _TRACE_SYSCALL_H */
|