You've already forked linux-apfs
mirror of
https://github.com/linux-apfs/linux-apfs.git
synced 2026-05-01 15:00:59 -07:00
2e33af0295
Move the defined fields from the event to the class structure.
Since the fields of the event are defined by the class they belong
to, it makes sense to have the class hold the information instead
of the individual events. The events of the same class would just
hold duplicate information.
After this change the size of the kernel dropped another 3K:
text data bss dec hex filename
4913961 1088356 861512 6863829 68bbd5 vmlinux.orig
4900252 1057412 861512 6819176 680d68 vmlinux.regs
4900375 1053380 861512 6815267 67fe23 vmlinux.fields
Although the text increased, this was mainly due to the C files
having to adapt to the change. This is a constant increase, where
new tracepoints will not increase the Text. But the big drop is
in the data size (as well as needed allocations to hold the fields).
This will give even more savings as more tracepoints are created.
Note, if just TRACE_EVENT()s are used and not DECLARE_EVENT_CLASS()
with several DEFINE_EVENT()s, then the savings will be lost. But
we are pushing developers to consolidate events with DEFINE_EVENT()
so this should not be an issue.
The kprobes define a unique class to every new event, but are dynamic
so it should not be a issue.
The syscalls however have a single class but the fields for the individual
events are different. The syscalls use a metadata to define the
fields. I moved the fields list from the event to the metadata and
added a "get_fields()" function to the class. This function is used
to find the fields. For normal events and kprobes, get_fields() just
returns a pointer to the fields list_head in the class. For syscall
events, it returns the fields list_head in the metadata for the event.
v2: Fixed the syscall fields. The syscall metadata needs a list
of fields for both enter and exit.
Acked-by: Frederic Weisbecker <fweisbec@gmail.com>
Acked-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Acked-by: Masami Hiramatsu <mhiramat@redhat.com>
Cc: Tom Zanussi <tzanussi@gmail.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
57 lines
1.7 KiB
C
57 lines
1.7 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 list_head enter_fields;
|
|
struct list_head exit_fields;
|
|
|
|
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 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_PERF_EVENTS
|
|
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 */
|