mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-11-04 02:11:25 +01:00 
			
		
		
		
	Add some useful static code analysis scripts for coccinelle copied from the Linux kernel v4.14-rc8: Warn on check against NULL before calling free. scripts/coccinelle/free/ifnullfree.cocci Detect superfluous NULL check for list iterator. scripts/coccinelle/iterators/itnull.cocci Check if list iterator is reassigned. scripts/coccinelle/iterators/list_entry_update.cocci Check if list iterator is used after loop. scripts/coccinelle/iterators/use_after_iter.cocci Find wrong argument of sizeof in allocation function: scripts/coccinelle/misc/badty.cocci Signed-off-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
		
			
				
	
	
		
			148 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			148 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
/// If list_for_each_entry, etc complete a traversal of the list, the iterator
 | 
						|
/// variable ends up pointing to an address at an offset from the list head,
 | 
						|
/// and not a meaningful structure.  Thus this value should not be used after
 | 
						|
/// the end of the iterator.
 | 
						|
//#False positives arise when there is a goto in the iterator and the
 | 
						|
//#reported reference is at the label of this goto.  Some flag tests
 | 
						|
//#may also cause a report to be a false positive.
 | 
						|
///
 | 
						|
// Confidence: Moderate
 | 
						|
// Copyright: (C) 2012 Julia Lawall, INRIA/LIP6.  GPLv2.
 | 
						|
// Copyright: (C) 2012 Gilles Muller, INRIA/LIP6.  GPLv2.
 | 
						|
// URL: http://coccinelle.lip6.fr/
 | 
						|
// Comments:
 | 
						|
// Options: --no-includes --include-headers
 | 
						|
 | 
						|
virtual context
 | 
						|
virtual org
 | 
						|
virtual report
 | 
						|
 | 
						|
@r exists@
 | 
						|
identifier c,member;
 | 
						|
expression E,x;
 | 
						|
iterator name list_for_each_entry;
 | 
						|
iterator name list_for_each_entry_reverse;
 | 
						|
iterator name list_for_each_entry_continue;
 | 
						|
iterator name list_for_each_entry_continue_reverse;
 | 
						|
iterator name list_for_each_entry_from;
 | 
						|
iterator name list_for_each_entry_safe;
 | 
						|
iterator name list_for_each_entry_safe_continue;
 | 
						|
iterator name list_for_each_entry_safe_from;
 | 
						|
iterator name list_for_each_entry_safe_reverse;
 | 
						|
iterator name hlist_for_each_entry;
 | 
						|
iterator name hlist_for_each_entry_continue;
 | 
						|
iterator name hlist_for_each_entry_from;
 | 
						|
iterator name hlist_for_each_entry_safe;
 | 
						|
statement S;
 | 
						|
position p1,p2;
 | 
						|
@@
 | 
						|
 | 
						|
(
 | 
						|
list_for_each_entry@p1(c,...,member) { ... when != break;
 | 
						|
                                 when forall
 | 
						|
                                 when strict
 | 
						|
}
 | 
						|
|
 | 
						|
list_for_each_entry_reverse@p1(c,...,member) { ... when != break;
 | 
						|
                                 when forall
 | 
						|
                                 when strict
 | 
						|
}
 | 
						|
|
 | 
						|
list_for_each_entry_continue@p1(c,...,member) { ... when != break;
 | 
						|
                                 when forall
 | 
						|
                                 when strict
 | 
						|
}
 | 
						|
|
 | 
						|
list_for_each_entry_continue_reverse@p1(c,...,member) { ... when != break;
 | 
						|
                                 when forall
 | 
						|
                                 when strict
 | 
						|
}
 | 
						|
|
 | 
						|
list_for_each_entry_from@p1(c,...,member) { ... when != break;
 | 
						|
                                 when forall
 | 
						|
                                 when strict
 | 
						|
}
 | 
						|
|
 | 
						|
list_for_each_entry_safe@p1(c,...,member) { ... when != break;
 | 
						|
                                 when forall
 | 
						|
                                 when strict
 | 
						|
}
 | 
						|
|
 | 
						|
list_for_each_entry_safe_continue@p1(c,...,member) { ... when != break;
 | 
						|
                                 when forall
 | 
						|
                                 when strict
 | 
						|
}
 | 
						|
|
 | 
						|
list_for_each_entry_safe_from@p1(c,...,member) { ... when != break;
 | 
						|
                                 when forall
 | 
						|
                                 when strict
 | 
						|
}
 | 
						|
|
 | 
						|
list_for_each_entry_safe_reverse@p1(c,...,member) { ... when != break;
 | 
						|
                                 when forall
 | 
						|
                                 when strict
 | 
						|
}
 | 
						|
)
 | 
						|
...
 | 
						|
(
 | 
						|
list_for_each_entry(c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_reverse(c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_continue(c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_continue_reverse(c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_from(c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_safe(c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_safe(x,c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_safe_continue(c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_safe_continue(x,c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_safe_from(c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_safe_from(x,c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_safe_reverse(c,...) S
 | 
						|
|
 | 
						|
list_for_each_entry_safe_reverse(x,c,...) S
 | 
						|
|
 | 
						|
hlist_for_each_entry(c,...) S
 | 
						|
|
 | 
						|
hlist_for_each_entry_continue(c,...) S
 | 
						|
|
 | 
						|
hlist_for_each_entry_from(c,...) S
 | 
						|
|
 | 
						|
hlist_for_each_entry_safe(c,...) S
 | 
						|
|
 | 
						|
list_remove_head(x,c,...)
 | 
						|
|
 | 
						|
sizeof(<+...c...+>)
 | 
						|
|
 | 
						|
 &c->member
 | 
						|
|
 | 
						|
c = E
 | 
						|
|
 | 
						|
*c@p2
 | 
						|
)
 | 
						|
 | 
						|
@script:python depends on org@
 | 
						|
p1 << r.p1;
 | 
						|
p2 << r.p2;
 | 
						|
@@
 | 
						|
 | 
						|
cocci.print_main("invalid iterator index reference",p2)
 | 
						|
cocci.print_secs("iterator",p1)
 | 
						|
 | 
						|
@script:python depends on report@
 | 
						|
p1 << r.p1;
 | 
						|
p2 << r.p2;
 | 
						|
@@
 | 
						|
 | 
						|
msg = "ERROR: invalid reference to the index variable of the iterator on line %s" % (p1[0].line)
 | 
						|
coccilib.report.print_report(p2[0], msg)
 |