| 
									
										
										
										
											2010-10-24 23:37:31 +02:00
										 |  |  | /// Find nested lock+irqsave functions that use the same flags variables | 
					
						
							|  |  |  | /// | 
					
						
							|  |  |  | // Confidence: High | 
					
						
							| 
									
										
										
										
											2012-01-14 23:41:54 +01:00
										 |  |  | // Copyright: (C) 2010-2012 Nicolas Palix.  GPLv2. | 
					
						
							|  |  |  | // Copyright: (C) 2010-2012 Julia Lawall, INRIA/LIP6.  GPLv2. | 
					
						
							|  |  |  | // Copyright: (C) 2010-2012 Gilles Muller, INRIA/LiP6.  GPLv2. | 
					
						
							| 
									
										
										
										
											2010-10-24 23:37:31 +02:00
										 |  |  | // URL: http://coccinelle.lip6.fr/ | 
					
						
							|  |  |  | // Comments: | 
					
						
							|  |  |  | // Options: -no_includes -include_headers | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | virtual context | 
					
						
							|  |  |  | virtual org | 
					
						
							|  |  |  | virtual report | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-14 23:41:54 +01:00
										 |  |  | @r exists@ | 
					
						
							| 
									
										
										
										
											2010-10-24 23:37:31 +02:00
										 |  |  | expression lock1,lock2,flags; | 
					
						
							|  |  |  | position p1,p2; | 
					
						
							|  |  |  | @@ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ( | 
					
						
							|  |  |  | spin_lock_irqsave@p1(lock1,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | read_lock_irqsave@p1(lock1,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | write_lock_irqsave@p1(lock1,flags) | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | ... when != flags | 
					
						
							|  |  |  | ( | 
					
						
							|  |  |  | spin_lock_irqsave(lock1,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | read_lock_irqsave(lock1,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | write_lock_irqsave(lock1,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | spin_lock_irqsave@p2(lock2,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | read_lock_irqsave@p2(lock2,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | write_lock_irqsave@p2(lock2,flags) | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-14 23:41:54 +01:00
										 |  |  | @d exists@ | 
					
						
							| 
									
										
										
										
											2010-10-24 23:37:31 +02:00
										 |  |  | expression f <= r.flags; | 
					
						
							|  |  |  | expression lock1,lock2,flags; | 
					
						
							|  |  |  | position r.p1, r.p2; | 
					
						
							|  |  |  | @@ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ( | 
					
						
							|  |  |  | *spin_lock_irqsave@p1(lock1,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | *read_lock_irqsave@p1(lock1,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | *write_lock_irqsave@p1(lock1,flags) | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | ... when != f | 
					
						
							|  |  |  | ( | 
					
						
							|  |  |  | *spin_lock_irqsave@p2(lock2,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | *read_lock_irqsave@p2(lock2,flags) | 
					
						
							|  |  |  | | | 
					
						
							|  |  |  | *write_lock_irqsave@p2(lock2,flags) | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // ---------------------------------------------------------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @script:python depends on d && org@ | 
					
						
							|  |  |  | p1 << r.p1; | 
					
						
							|  |  |  | p2 << r.p2; | 
					
						
							|  |  |  | @@ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | cocci.print_main("original lock",p1) | 
					
						
							|  |  |  | cocci.print_secs("nested lock+irqsave that reuses flags",p2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @script:python depends on d && report@ | 
					
						
							|  |  |  | p1 << r.p1; | 
					
						
							|  |  |  | p2 << r.p2; | 
					
						
							|  |  |  | @@ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-14 23:41:54 +01:00
										 |  |  | msg="ERROR: nested lock+irqsave that reuses flags from line %s." % (p1[0].line) | 
					
						
							| 
									
										
										
										
											2010-10-24 23:37:31 +02:00
										 |  |  | coccilib.report.print_report(p2[0], msg) |