411 lines
		
	
	
	
		
			8.4 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			411 lines
		
	
	
	
		
			8.4 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0-only
 | |
| ///
 | |
| /// Use zeroing allocator rather than allocator followed by memset with 0
 | |
| ///
 | |
| /// This considers some simple cases that are common and easy to validate
 | |
| /// Note in particular that there are no ...s in the rule, so all of the
 | |
| /// matched code has to be contiguous
 | |
| ///
 | |
| // Confidence: High
 | |
| // Copyright: (C) 2009-2010 Julia Lawall, Nicolas Palix, DIKU.
 | |
| // Copyright: (C) 2009-2010 Gilles Muller, INRIA/LiP6.
 | |
| // Copyright: (C) 2017 Himanshu Jha
 | |
| // URL: http://coccinelle.lip6.fr/rules/kzalloc.html
 | |
| // Options: --no-includes --include-headers
 | |
| //
 | |
| // Keywords: kmalloc, kzalloc
 | |
| // Version min: < 2.6.12 kmalloc
 | |
| // Version min:   2.6.14 kzalloc
 | |
| //
 | |
| 
 | |
| virtual context
 | |
| virtual patch
 | |
| virtual org
 | |
| virtual report
 | |
| 
 | |
| //----------------------------------------------------------
 | |
| //  For context mode
 | |
| //----------------------------------------------------------
 | |
| 
 | |
| @depends on context@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1;
 | |
| statement S;
 | |
| @@
 | |
| 
 | |
| * x = (T)\(kmalloc(E1, ...)\|vmalloc(E1)\|dma_alloc_coherent(...,E1,...)\|
 | |
|   kmalloc_node(E1, ...)\|kmem_cache_alloc(...)\|kmem_alloc(E1, ...)\|
 | |
|   devm_kmalloc(...,E1,...)\|kvmalloc(E1, ...)\|kvmalloc_node(E1,...)\);
 | |
|   if ((x==NULL) || ...) S
 | |
| * memset((T2)x,0,E1);
 | |
| 
 | |
| //----------------------------------------------------------
 | |
| //  For patch mode
 | |
| //----------------------------------------------------------
 | |
| 
 | |
| @depends on patch@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1,E2,E3,E4;
 | |
| statement S;
 | |
| @@
 | |
| 
 | |
| (
 | |
| - x = kmalloc(E1,E2);
 | |
| + x = kzalloc(E1,E2);
 | |
| |
 | |
| - x = (T *)kmalloc(E1,E2);
 | |
| + x = kzalloc(E1,E2);
 | |
| |
 | |
| - x = (T)kmalloc(E1,E2);
 | |
| + x = (T)kzalloc(E1,E2);
 | |
| |
 | |
| - x = vmalloc(E1);
 | |
| + x = vzalloc(E1);
 | |
| |
 | |
| - x = (T *)vmalloc(E1);
 | |
| + x = vzalloc(E1);
 | |
| |
 | |
| - x = (T)vmalloc(E1);
 | |
| + x = (T)vzalloc(E1);
 | |
| |
 | |
| - x = kmalloc_node(E1,E2,E3);
 | |
| + x = kzalloc_node(E1,E2,E3);
 | |
| |
 | |
| - x = (T *)kmalloc_node(E1,E2,E3);
 | |
| + x = kzalloc_node(E1,E2,E3);
 | |
| |
 | |
| - x = (T)kmalloc_node(E1,E2,E3);
 | |
| + x = (T)kzalloc_node(E1,E2,E3);
 | |
| |
 | |
| - x = kmem_cache_alloc(E3,E4);
 | |
| + x = kmem_cache_zalloc(E3,E4);
 | |
| |
 | |
| - x = (T *)kmem_cache_alloc(E3,E4);
 | |
| + x = kmem_cache_zalloc(E3,E4);
 | |
| |
 | |
| - x = (T)kmem_cache_alloc(E3,E4);
 | |
| + x = (T)kmem_cache_zalloc(E3,E4);
 | |
| |
 | |
| - x = kmem_alloc(E1,E2);
 | |
| + x = kmem_zalloc(E1,E2);
 | |
| |
 | |
| - x = (T *)kmem_alloc(E1,E2);
 | |
| + x = kmem_zalloc(E1,E2);
 | |
| |
 | |
| - x = (T)kmem_alloc(E1,E2);
 | |
| + x = (T)kmem_zalloc(E1,E2);
 | |
| |
 | |
| - x = devm_kmalloc(E2,E1,E3);
 | |
| + x = devm_kzalloc(E2,E1,E3);
 | |
| |
 | |
| - x = (T *)devm_kmalloc(E2,E1,E3);
 | |
| + x = devm_kzalloc(E2,E1,E3);
 | |
| |
 | |
| - x = (T)devm_kmalloc(E2,E1,E3);
 | |
| + x = (T)devm_kzalloc(E2,E1,E3);
 | |
| |
 | |
| - x = kvmalloc(E1,E2);
 | |
| + x = kvzalloc(E1,E2);
 | |
| |
 | |
| - x = (T *)kvmalloc(E1,E2);
 | |
| + x = kvzalloc(E1,E2);
 | |
| |
 | |
| - x = (T)kvmalloc(E1,E2);
 | |
| + x = (T)kvzalloc(E1,E2);
 | |
| |
 | |
| - x = kvmalloc_node(E1,E2,E3);
 | |
| + x = kvzalloc_node(E1,E2,E3);
 | |
| |
 | |
| - x = (T *)kvmalloc_node(E1,E2,E3);
 | |
| + x = kvzalloc_node(E1,E2,E3);
 | |
| |
 | |
| - x = (T)kvmalloc_node(E1,E2,E3);
 | |
| + x = (T)kvzalloc_node(E1,E2,E3);
 | |
| )
 | |
|   if ((x==NULL) || ...) S
 | |
| - memset((T2)x,0,E1);
 | |
| 
 | |
| @depends on patch@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1,E2,E3,E4;
 | |
| statement S;
 | |
| @@
 | |
|   x = (T)dma_alloc_coherent(E1, E2, E3, E4);
 | |
|   if ((x==NULL) || ...) S
 | |
| - memset((T2)x, 0, E2);
 | |
| 
 | |
| //----------------------------------------------------------
 | |
| //  For org mode
 | |
| //----------------------------------------------------------
 | |
| 
 | |
| @r depends on org || report@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1,E2;
 | |
| statement S;
 | |
| position p;
 | |
| @@
 | |
| 
 | |
|  x = (T)kmalloc@p(E1,E2);
 | |
|  if ((x==NULL) || ...) S
 | |
|  memset((T2)x,0,E1);
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << r.p;
 | |
| x << r.x;
 | |
| @@
 | |
| 
 | |
| msg="%s" % (x)
 | |
| msg_safe=msg.replace("[","@(").replace("]",")")
 | |
| coccilib.org.print_todo(p[0], msg_safe)
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << r.p;
 | |
| x << r.x;
 | |
| @@
 | |
| 
 | |
| msg="WARNING: kzalloc should be used for %s, instead of kmalloc/memset" % (x)
 | |
| coccilib.report.print_report(p[0], msg)
 | |
| 
 | |
| //-----------------------------------------------------------------
 | |
| @r1 depends on org || report@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1;
 | |
| statement S;
 | |
| position p;
 | |
| @@
 | |
| 
 | |
|  x = (T)vmalloc@p(E1);
 | |
|  if ((x==NULL) || ...) S
 | |
|  memset((T2)x,0,E1);
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << r1.p;
 | |
| x << r1.x;
 | |
| @@
 | |
| 
 | |
| msg="%s" % (x)
 | |
| msg_safe=msg.replace("[","@(").replace("]",")")
 | |
| coccilib.org.print_todo(p[0], msg_safe)
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << r1.p;
 | |
| x << r1.x;
 | |
| @@
 | |
| 
 | |
| msg="WARNING: vzalloc should be used for %s, instead of vmalloc/memset" % (x)
 | |
| coccilib.report.print_report(p[0], msg)
 | |
| 
 | |
| //-----------------------------------------------------------------
 | |
| @r2 depends on org || report@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1,E2,E3,E4;
 | |
| statement S;
 | |
| position p;
 | |
| @@
 | |
| 
 | |
|  x = (T)dma_alloc_coherent@p(E1,E2,E3,E4);
 | |
|  if ((x==NULL) || ...) S
 | |
|  memset((T2)x,0,E2);
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << r2.p;
 | |
| x << r2.x;
 | |
| @@
 | |
| 
 | |
| msg="%s" % (x)
 | |
| msg_safe=msg.replace("[","@(").replace("]",")")
 | |
| coccilib.org.print_todo(p[0], msg_safe)
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << r2.p;
 | |
| x << r2.x;
 | |
| @@
 | |
| 
 | |
| msg="WARNING: dma_alloc_coherent used in %s already zeroes out memory, so memset is not needed" % (x)
 | |
| coccilib.report.print_report(p[0], msg)
 | |
| 
 | |
| //-----------------------------------------------------------------
 | |
| @r3 depends on org || report@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1,E2,E3;
 | |
| statement S;
 | |
| position p;
 | |
| @@
 | |
| 
 | |
|  x = (T)kmalloc_node@p(E1,E2,E3);
 | |
|  if ((x==NULL) || ...) S
 | |
|  memset((T2)x,0,E1);
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << r3.p;
 | |
| x << r3.x;
 | |
| @@
 | |
| 
 | |
| msg="%s" % (x)
 | |
| msg_safe=msg.replace("[","@(").replace("]",")")
 | |
| coccilib.org.print_todo(p[0], msg_safe)
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << r3.p;
 | |
| x << r3.x;
 | |
| @@
 | |
| 
 | |
| msg="WARNING: kzalloc_node should be used for %s, instead of kmalloc_node/memset" % (x)
 | |
| coccilib.report.print_report(p[0], msg)
 | |
| 
 | |
| //-----------------------------------------------------------------
 | |
| @r4 depends on org || report@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1,E2,E3;
 | |
| statement S;
 | |
| position p;
 | |
| @@
 | |
| 
 | |
|  x = (T)kmem_cache_alloc@p(E2,E3);
 | |
|  if ((x==NULL) || ...) S
 | |
|  memset((T2)x,0,E1);
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << r4.p;
 | |
| x << r4.x;
 | |
| @@
 | |
| 
 | |
| msg="%s" % (x)
 | |
| msg_safe=msg.replace("[","@(").replace("]",")")
 | |
| coccilib.org.print_todo(p[0], msg_safe)
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << r4.p;
 | |
| x << r4.x;
 | |
| @@
 | |
| 
 | |
| msg="WARNING: kmem_cache_zalloc should be used for %s, instead of kmem_cache_alloc/memset" % (x)
 | |
| coccilib.report.print_report(p[0], msg)
 | |
| 
 | |
| //-----------------------------------------------------------------
 | |
| @r5 depends on org || report@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1,E2;
 | |
| statement S;
 | |
| position p;
 | |
| @@
 | |
| 
 | |
|  x = (T)kmem_alloc@p(E1,E2);
 | |
|  if ((x==NULL) || ...) S
 | |
|  memset((T2)x,0,E1);
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << r5.p;
 | |
| x << r5.x;
 | |
| @@
 | |
| 
 | |
| msg="%s" % (x)
 | |
| msg_safe=msg.replace("[","@(").replace("]",")")
 | |
| coccilib.org.print_todo(p[0], msg_safe)
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << r5.p;
 | |
| x << r5.x;
 | |
| @@
 | |
| 
 | |
| msg="WARNING: kmem_zalloc should be used for %s, instead of kmem_alloc/memset" % (x)
 | |
| coccilib.report.print_report(p[0], msg)
 | |
| 
 | |
| //-----------------------------------------------------------------
 | |
| @r6 depends on org || report@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1,E2,E3;
 | |
| statement S;
 | |
| position p;
 | |
| @@
 | |
| 
 | |
|  x = (T)devm_kmalloc@p(E2,E1,E3);
 | |
|  if ((x==NULL) || ...) S
 | |
|  memset((T2)x,0,E1);
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << r6.p;
 | |
| x << r6.x;
 | |
| @@
 | |
| 
 | |
| msg="%s" % (x)
 | |
| msg_safe=msg.replace("[","@(").replace("]",")")
 | |
| coccilib.org.print_todo(p[0], msg_safe)
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << r6.p;
 | |
| x << r6.x;
 | |
| @@
 | |
| 
 | |
| msg="WARNING: devm_kzalloc should be used for %s, instead of devm_kmalloc/memset" % (x)
 | |
| coccilib.report.print_report(p[0], msg)
 | |
| 
 | |
| //-----------------------------------------------------------------
 | |
| @r7 depends on org || report@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1,E2;
 | |
| statement S;
 | |
| position p;
 | |
| @@
 | |
| 
 | |
|  x = (T)kvmalloc@p(E1,E2);
 | |
|  if ((x==NULL) || ...) S
 | |
|  memset((T2)x,0,E1);
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << r7.p;
 | |
| x << r7.x;
 | |
| @@
 | |
| 
 | |
| msg="%s" % (x)
 | |
| msg_safe=msg.replace("[","@(").replace("]",")")
 | |
| coccilib.org.print_todo(p[0], msg_safe)
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << r7.p;
 | |
| x << r7.x;
 | |
| @@
 | |
| 
 | |
| msg="WARNING: kvzalloc should be used for %s, instead of kvmalloc/memset" % (x)
 | |
| coccilib.report.print_report(p[0], msg)
 | |
| 
 | |
| //-----------------------------------------------------------------
 | |
| @r9 depends on org || report@
 | |
| type T, T2;
 | |
| expression x;
 | |
| expression E1,E2,E3;
 | |
| statement S;
 | |
| position p;
 | |
| @@
 | |
| 
 | |
|  x = (T)kvmalloc_node@p(E1,E2,E3);
 | |
|  if ((x==NULL) || ...) S
 | |
|  memset((T2)x,0,E1);
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << r9.p;
 | |
| x << r9.x;
 | |
| @@
 | |
| 
 | |
| msg="%s" % (x)
 | |
| msg_safe=msg.replace("[","@(").replace("]",")")
 | |
| coccilib.org.print_todo(p[0], msg_safe)
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << r9.p;
 | |
| x << r9.x;
 | |
| @@
 | |
| 
 | |
| msg="WARNING: kvzalloc_node should be used for %s, instead of kvmalloc_node/memset" % (x)
 | |
| coccilib.report.print_report(p[0], msg)
 |