This script detects cases where ARRAY_SIZE can be used such as where there is a division of sizeof the array by the sizeof its first element or by any indexed element or the element type. It replaces the division of the two sizeofs by ARRAY_SIZE. Signed-off-by: Himangi Saraogi <himangi774@gmail.com> Acked-by: Julia Lawall <julia.lawall@lip6.fr> Signed-off-by: Michal Marek <mmarek@suse.cz>
		
			
				
	
	
		
			87 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
/// Use ARRAY_SIZE instead of dividing sizeof array with sizeof an element
 | 
						|
///
 | 
						|
//# This makes an effort to find cases where ARRAY_SIZE can be used such as
 | 
						|
//# where there is a division of sizeof the array by the sizeof its first
 | 
						|
//# element or by any indexed element or the element type. It replaces the
 | 
						|
//# division of the two sizeofs by ARRAY_SIZE.
 | 
						|
//
 | 
						|
// Confidence: High
 | 
						|
// Copyright: (C) 2014 Himangi Saraogi.  GPLv2.
 | 
						|
// Comments:
 | 
						|
// Options: --no-includes --include-headers
 | 
						|
 | 
						|
virtual patch
 | 
						|
virtual context
 | 
						|
virtual org
 | 
						|
virtual report
 | 
						|
 | 
						|
@i@
 | 
						|
@@
 | 
						|
 | 
						|
#include <linux/kernel.h>
 | 
						|
 | 
						|
//----------------------------------------------------------
 | 
						|
//  For context mode
 | 
						|
//----------------------------------------------------------
 | 
						|
 | 
						|
@depends on i&&context@
 | 
						|
type T;
 | 
						|
T[] E;
 | 
						|
@@
 | 
						|
(
 | 
						|
* (sizeof(E)/sizeof(*E))
 | 
						|
|
 | 
						|
* (sizeof(E)/sizeof(E[...]))
 | 
						|
|
 | 
						|
* (sizeof(E)/sizeof(T))
 | 
						|
)
 | 
						|
 | 
						|
//----------------------------------------------------------
 | 
						|
//  For patch mode
 | 
						|
//----------------------------------------------------------
 | 
						|
 | 
						|
@depends on i&&patch@
 | 
						|
type T;
 | 
						|
T[] E;
 | 
						|
@@
 | 
						|
(
 | 
						|
- (sizeof(E)/sizeof(*E))
 | 
						|
+ ARRAY_SIZE(E)
 | 
						|
|
 | 
						|
- (sizeof(E)/sizeof(E[...]))
 | 
						|
+ ARRAY_SIZE(E)
 | 
						|
|
 | 
						|
- (sizeof(E)/sizeof(T))
 | 
						|
+ ARRAY_SIZE(E)
 | 
						|
)
 | 
						|
 | 
						|
//----------------------------------------------------------
 | 
						|
//  For org and report mode
 | 
						|
//----------------------------------------------------------
 | 
						|
 | 
						|
@r@
 | 
						|
type T;
 | 
						|
T[] E;
 | 
						|
position p;
 | 
						|
@@
 | 
						|
(
 | 
						|
 (sizeof(E)@p /sizeof(*E))
 | 
						|
|
 | 
						|
 (sizeof(E)@p /sizeof(E[...]))
 | 
						|
|
 | 
						|
 (sizeof(E)@p /sizeof(T))
 | 
						|
)
 | 
						|
 | 
						|
@script:python depends on i&&org@
 | 
						|
p << r.p;
 | 
						|
@@
 | 
						|
 | 
						|
coccilib.org.print_todo(p[0], "WARNING should use ARRAY_SIZE")
 | 
						|
 | 
						|
@script:python depends on i&&report@
 | 
						|
p << r.p;
 | 
						|
@@
 | 
						|
 | 
						|
msg="WARNING: Use ARRAY_SIZE"
 | 
						|
coccilib.report.print_report(p[0], msg)
 | 
						|
 |