| 
									
										
										
										
											2005-06-21 17:14:34 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * lib/smp_processor_id.c | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * DEBUG_PREEMPT variant of smp_processor_id(). | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-11-16 21:29:17 -05:00
										 |  |  | #include <linux/export.h>
 | 
					
						
							| 
									
										
										
										
											2005-06-21 17:14:34 -07:00
										 |  |  | #include <linux/kallsyms.h>
 | 
					
						
							| 
									
										
										
										
											2005-10-30 15:03:48 -08:00
										 |  |  | #include <linux/sched.h>
 | 
					
						
							| 
									
										
										
										
											2005-06-21 17:14:34 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-12 21:20:41 +02:00
										 |  |  | notrace unsigned int debug_smp_processor_id(void) | 
					
						
							| 
									
										
										
										
											2005-06-21 17:14:34 -07:00
										 |  |  | { | 
					
						
							|  |  |  | 	unsigned long preempt_count = preempt_count(); | 
					
						
							|  |  |  | 	int this_cpu = raw_smp_processor_id(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (likely(preempt_count)) | 
					
						
							|  |  |  | 		goto out; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (irqs_disabled()) | 
					
						
							|  |  |  | 		goto out; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * Kernel threads bound to a single CPU can safely use | 
					
						
							|  |  |  | 	 * smp_processor_id(): | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2011-06-16 12:23:22 +02:00
										 |  |  | 	if (cpumask_equal(tsk_cpus_allowed(current), cpumask_of(this_cpu))) | 
					
						
							| 
									
										
										
										
											2005-06-21 17:14:34 -07:00
										 |  |  | 		goto out; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * It is valid to assume CPU-locality during early bootup: | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if (system_state != SYSTEM_RUNNING) | 
					
						
							|  |  |  | 		goto out; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * Avoid recursion: | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2008-05-12 21:20:44 +02:00
										 |  |  | 	preempt_disable_notrace(); | 
					
						
							| 
									
										
										
										
											2005-06-21 17:14:34 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!printk_ratelimit()) | 
					
						
							|  |  |  | 		goto out_enable; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-06 01:37:57 -08:00
										 |  |  | 	printk(KERN_ERR "BUG: using smp_processor_id() in preemptible [%08x] " | 
					
						
							|  |  |  | 			"code: %s/%d\n", | 
					
						
							|  |  |  | 			preempt_count() - 1, current->comm, current->pid); | 
					
						
							| 
									
										
										
										
											2005-06-21 17:14:34 -07:00
										 |  |  | 	print_symbol("caller is %s\n", (long)__builtin_return_address(0)); | 
					
						
							|  |  |  | 	dump_stack(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | out_enable: | 
					
						
							| 
									
										
										
										
											2008-05-12 21:20:44 +02:00
										 |  |  | 	preempt_enable_no_resched_notrace(); | 
					
						
							| 
									
										
										
										
											2005-06-21 17:14:34 -07:00
										 |  |  | out: | 
					
						
							|  |  |  | 	return this_cpu; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EXPORT_SYMBOL(debug_smp_processor_id); | 
					
						
							|  |  |  | 
 |