mirror of
				https://github.com/linuxkit/linuxkit.git
				synced 2025-10-31 23:30:47 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			86 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 5d8962ddabfd1dc4f1df9651e9e8932d36b5f1ef Mon Sep 17 00:00:00 2001
 | |
| From: Thomas Gleixner <tglx@linutronix.de>
 | |
| Date: Sun, 17 Jul 2011 21:56:42 +0200
 | |
| Subject: [PATCH 230/414] trace: Add migrate-disabled counter to tracing output
 | |
| 
 | |
| Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
 | |
| ---
 | |
|  include/linux/trace_events.h | 2 ++
 | |
|  kernel/trace/trace.c         | 9 ++++++---
 | |
|  kernel/trace/trace_events.c  | 2 ++
 | |
|  kernel/trace/trace_output.c  | 5 +++++
 | |
|  4 files changed, 15 insertions(+), 3 deletions(-)
 | |
| 
 | |
| diff --git a/include/linux/trace_events.h b/include/linux/trace_events.h
 | |
| index aefc80f2909b..ffd595ab5008 100644
 | |
| --- a/include/linux/trace_events.h
 | |
| +++ b/include/linux/trace_events.h
 | |
| @@ -62,6 +62,8 @@ struct trace_entry {
 | |
|  	unsigned char		flags;
 | |
|  	unsigned char		preempt_count;
 | |
|  	int			pid;
 | |
| +	unsigned short		migrate_disable;
 | |
| +	unsigned short		padding;
 | |
|  };
 | |
|  
 | |
|  #define TRACE_EVENT_TYPE_MAX						\
 | |
| diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c
 | |
| index 7f779b99501b..5796c41319c8 100644
 | |
| --- a/kernel/trace/trace.c
 | |
| +++ b/kernel/trace/trace.c
 | |
| @@ -2141,6 +2141,8 @@ tracing_generic_entry_update(struct trace_entry *entry, unsigned long flags,
 | |
|  		((pc & SOFTIRQ_OFFSET) ? TRACE_FLAG_SOFTIRQ : 0) |
 | |
|  		(tif_need_resched() ? TRACE_FLAG_NEED_RESCHED : 0) |
 | |
|  		(test_preempt_need_resched() ? TRACE_FLAG_PREEMPT_RESCHED : 0);
 | |
| +
 | |
| +	entry->migrate_disable = (tsk) ? __migrate_disabled(tsk) & 0xFF : 0;
 | |
|  }
 | |
|  EXPORT_SYMBOL_GPL(tracing_generic_entry_update);
 | |
|  
 | |
| @@ -3344,9 +3346,10 @@ static void print_lat_help_header(struct seq_file *m)
 | |
|  		    "#                | / _----=> need-resched    \n"
 | |
|  		    "#                || / _---=> hardirq/softirq \n"
 | |
|  		    "#                ||| / _--=> preempt-depth   \n"
 | |
| -		    "#                |||| /     delay            \n"
 | |
| -		    "#  cmd     pid   ||||| time  |   caller      \n"
 | |
| -		    "#     \\   /      |||||  \\    |   /         \n");
 | |
| +		    "#                |||| / _--=> migrate-disable\n"
 | |
| +		    "#                ||||| /     delay           \n"
 | |
| +		    "#  cmd     pid   |||||| time  |   caller     \n"
 | |
| +		    "#     \\   /      |||||  \\   |   /          \n");
 | |
|  }
 | |
|  
 | |
|  static void print_event_info(struct trace_buffer *buf, struct seq_file *m)
 | |
| diff --git a/kernel/trace/trace_events.c b/kernel/trace/trace_events.c
 | |
| index 1b87157edbff..9ba230a4052f 100644
 | |
| --- a/kernel/trace/trace_events.c
 | |
| +++ b/kernel/trace/trace_events.c
 | |
| @@ -187,6 +187,8 @@ static int trace_define_common_fields(void)
 | |
|  	__common_field(unsigned char, flags);
 | |
|  	__common_field(unsigned char, preempt_count);
 | |
|  	__common_field(int, pid);
 | |
| +	__common_field(unsigned short, migrate_disable);
 | |
| +	__common_field(unsigned short, padding);
 | |
|  
 | |
|  	return ret;
 | |
|  }
 | |
| diff --git a/kernel/trace/trace_output.c b/kernel/trace/trace_output.c
 | |
| index c738e764e2a5..2bccb364a483 100644
 | |
| --- a/kernel/trace/trace_output.c
 | |
| +++ b/kernel/trace/trace_output.c
 | |
| @@ -493,6 +493,11 @@ int trace_print_lat_fmt(struct trace_seq *s, struct trace_entry *entry)
 | |
|  	else
 | |
|  		trace_seq_putc(s, '.');
 | |
|  
 | |
| +	if (entry->migrate_disable)
 | |
| +		trace_seq_printf(s, "%x", entry->migrate_disable);
 | |
| +	else
 | |
| +		trace_seq_putc(s, '.');
 | |
| +
 | |
|  	return !trace_seq_has_overflowed(s);
 | |
|  }
 | |
|  
 | |
| -- 
 | |
| 2.17.0
 | |
| 
 |