mirror of
				https://github.com/torvalds/linux.git
				synced 2025-10-31 08:38:45 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			119 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
	
		
			2.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0-only
 | |
| /// Use memdup_user rather than duplicating its implementation
 | |
| /// This is a little bit restricted to reduce false positives
 | |
| ///
 | |
| // Confidence: High
 | |
| // Copyright: (C) 2010-2012 Nicolas Palix.
 | |
| // Copyright: (C) 2010-2012 Julia Lawall, INRIA/LIP6.
 | |
| // Copyright: (C) 2010-2012 Gilles Muller, INRIA/LiP6.
 | |
| // URL: https://coccinelle.gitlabpages.inria.fr/website
 | |
| // Comments:
 | |
| // Options: --no-includes --include-headers
 | |
| 
 | |
| virtual patch
 | |
| virtual context
 | |
| virtual org
 | |
| virtual report
 | |
| 
 | |
| @initialize:python@
 | |
| @@
 | |
| filter = frozenset(['memdup_user', 'vmemdup_user'])
 | |
| 
 | |
| def relevant(p):
 | |
|     return not (filter & {el.current_element for el in p})
 | |
| 
 | |
| @depends on patch@
 | |
| expression from,to,size;
 | |
| identifier l1,l2;
 | |
| position p : script:python() { relevant(p) };
 | |
| @@
 | |
| 
 | |
| -  to = \(kmalloc@p\|kzalloc@p\)
 | |
| -		(size,\(GFP_KERNEL\|GFP_USER\|
 | |
| -		      \(GFP_KERNEL\|GFP_USER\)|__GFP_NOWARN\));
 | |
| +  to = memdup_user(from,size);
 | |
|    if (
 | |
| -      to==NULL
 | |
| +      IS_ERR(to)
 | |
|                  || ...) {
 | |
|    <+... when != goto l1;
 | |
| -  -ENOMEM
 | |
| +  PTR_ERR(to)
 | |
|    ...+>
 | |
|    }
 | |
| -  if (copy_from_user(to, from, size) != 0) {
 | |
| -    <+... when != goto l2;
 | |
| -    -EFAULT
 | |
| -    ...+>
 | |
| -  }
 | |
| 
 | |
| @depends on patch@
 | |
| expression from,to,size;
 | |
| identifier l1,l2;
 | |
| position p : script:python() { relevant(p) };
 | |
| @@
 | |
| 
 | |
| -  to = \(kvmalloc@p\|kvzalloc@p\)(size,\(GFP_KERNEL\|GFP_USER\));
 | |
| +  to = vmemdup_user(from,size);
 | |
|    if (
 | |
| -      to==NULL
 | |
| +      IS_ERR(to)
 | |
|                  || ...) {
 | |
|    <+... when != goto l1;
 | |
| -  -ENOMEM
 | |
| +  PTR_ERR(to)
 | |
|    ...+>
 | |
|    }
 | |
| -  if (copy_from_user(to, from, size) != 0) {
 | |
| -    <+... when != goto l2;
 | |
| -    -EFAULT
 | |
| -    ...+>
 | |
| -  }
 | |
| 
 | |
| @r depends on !patch@
 | |
| expression from,to,size;
 | |
| position p : script:python() { relevant(p) };
 | |
| statement S1,S2;
 | |
| @@
 | |
| 
 | |
| *  to = \(kmalloc@p\|kzalloc@p\)
 | |
| 		(size,\(GFP_KERNEL\|GFP_USER\|
 | |
| 		      \(GFP_KERNEL\|GFP_USER\)|__GFP_NOWARN\));
 | |
|    if (to==NULL || ...) S1
 | |
|    if (copy_from_user(to, from, size) != 0)
 | |
|    S2
 | |
| 
 | |
| @rv depends on !patch@
 | |
| expression from,to,size;
 | |
| position p : script:python() { relevant(p) };
 | |
| statement S1,S2;
 | |
| @@
 | |
| 
 | |
| *  to = \(kvmalloc@p\|kvzalloc@p\)(size,\(GFP_KERNEL\|GFP_USER\));
 | |
|    if (to==NULL || ...) S1
 | |
|    if (copy_from_user(to, from, size) != 0)
 | |
|    S2
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << r.p;
 | |
| @@
 | |
| 
 | |
| coccilib.org.print_todo(p[0], "WARNING opportunity for memdup_user")
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << r.p;
 | |
| @@
 | |
| 
 | |
| coccilib.report.print_report(p[0], "WARNING opportunity for memdup_user")
 | |
| 
 | |
| @script:python depends on org@
 | |
| p << rv.p;
 | |
| @@
 | |
| 
 | |
| coccilib.org.print_todo(p[0], "WARNING opportunity for vmemdup_user")
 | |
| 
 | |
| @script:python depends on report@
 | |
| p << rv.p;
 | |
| @@
 | |
| 
 | |
| coccilib.report.print_report(p[0], "WARNING opportunity for vmemdup_user")
 | 
