mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-26 05:51:29 +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)
 |