|  | /* SPDX-License-Identifier: GPL-2.0 */ | 
|  | #ifndef _LINUX_TRACE_H | 
|  | #define _LINUX_TRACE_H | 
|  |  | 
|  | #ifdef CONFIG_TRACING | 
|  |  | 
|  | #define TRACE_EXPORT_FUNCTION	BIT(0) | 
|  | #define TRACE_EXPORT_EVENT	BIT(1) | 
|  | #define TRACE_EXPORT_MARKER	BIT(2) | 
|  |  | 
|  | /* | 
|  | * The trace export - an export of Ftrace output. The trace_export | 
|  | * can process traces and export them to a registered destination as | 
|  | * an addition to the current only output of Ftrace - i.e. ring buffer. | 
|  | * | 
|  | * If you want traces to be sent to some other place rather than ring | 
|  | * buffer only, just need to register a new trace_export and implement | 
|  | * its own .write() function for writing traces to the storage. | 
|  | * | 
|  | * next		- pointer to the next trace_export | 
|  | * write	- copy traces which have been delt with ->commit() to | 
|  | *		  the destination | 
|  | * flags	- which ftrace to be exported | 
|  | */ | 
|  | struct trace_export { | 
|  | struct trace_export __rcu	*next; | 
|  | void (*write)(struct trace_export *, const void *, unsigned int); | 
|  | int flags; | 
|  | }; | 
|  |  | 
|  | int register_ftrace_export(struct trace_export *export); | 
|  | int unregister_ftrace_export(struct trace_export *export); | 
|  |  | 
|  | struct trace_array; | 
|  |  | 
|  | void trace_printk_init_buffers(void); | 
|  | int trace_array_printk(struct trace_array *tr, unsigned long ip, | 
|  | const char *fmt, ...); | 
|  | int trace_array_init_printk(struct trace_array *tr); | 
|  | void trace_array_put(struct trace_array *tr); | 
|  | struct trace_array *trace_array_get_by_name(const char *name); | 
|  | int trace_array_destroy(struct trace_array *tr); | 
|  | #endif	/* CONFIG_TRACING */ | 
|  |  | 
|  | #endif	/* _LINUX_TRACE_H */ |