mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-25 21:29:32 +00:00 
			
		
		
		
	 da485e0cb1
			
		
	
	
		da485e0cb1
		
	
	
	
	
		
			
			For now include/trace/boot.h doesn't need to include necessary headers for its functions and structures because the files that include it already do it. But boot.h could be needed as well for further uses on other files. So, this patch adds the necessary headers for future purposes... Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
		
			
				
	
	
		
			61 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _LINUX_TRACE_BOOT_H
 | |
| #define _LINUX_TRACE_BOOT_H
 | |
| 
 | |
| #include <linux/module.h>
 | |
| #include <linux/kallsyms.h>
 | |
| #include <linux/init.h>
 | |
| 
 | |
| /*
 | |
|  * Structure which defines the trace of an initcall
 | |
|  * while it is called.
 | |
|  * You don't have to fill the func field since it is
 | |
|  * only used internally by the tracer.
 | |
|  */
 | |
| struct boot_trace_call {
 | |
| 	pid_t			caller;
 | |
| 	char			func[KSYM_SYMBOL_LEN];
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * Structure which defines the trace of an initcall
 | |
|  * while it returns.
 | |
|  */
 | |
| struct boot_trace_ret {
 | |
| 	char			func[KSYM_SYMBOL_LEN];
 | |
| 	int				result;
 | |
| 	unsigned long long	duration;		/* nsecs */
 | |
| };
 | |
| 
 | |
| #ifdef CONFIG_BOOT_TRACER
 | |
| /* Append the traces on the ring-buffer */
 | |
| extern void trace_boot_call(struct boot_trace_call *bt, initcall_t fn);
 | |
| extern void trace_boot_ret(struct boot_trace_ret *bt, initcall_t fn);
 | |
| 
 | |
| /* Tells the tracer that smp_pre_initcall is finished.
 | |
|  * So we can start the tracing
 | |
|  */
 | |
| extern void start_boot_trace(void);
 | |
| 
 | |
| /* Resume the tracing of other necessary events
 | |
|  * such as sched switches
 | |
|  */
 | |
| extern void enable_boot_trace(void);
 | |
| 
 | |
| /* Suspend this tracing. Actually, only sched_switches tracing have
 | |
|  * to be suspended. Initcalls doesn't need it.)
 | |
|  */
 | |
| extern void disable_boot_trace(void);
 | |
| #else
 | |
| static inline
 | |
| void trace_boot_call(struct boot_trace_call *bt, initcall_t fn) { }
 | |
| 
 | |
| static inline
 | |
| void trace_boot_ret(struct boot_trace_ret *bt, initcall_t fn) { }
 | |
| 
 | |
| static inline void start_boot_trace(void) { }
 | |
| static inline void enable_boot_trace(void) { }
 | |
| static inline void disable_boot_trace(void) { }
 | |
| #endif /* CONFIG_BOOT_TRACER */
 | |
| 
 | |
| #endif /* __LINUX_TRACE_BOOT_H */
 |