pm_runtime.cocci starts with one rule that searches for a variety of functions calls, followed by various rules that report errors. Previously, the only connection between the first rule and the rest was to check that the first rule had matched somewhere. Change the rules to propagate a position from the first rule to the others, to make sure that the sites reported on are the same as the sites that were identified as having the relevant functions. Signed-off-by: Julia Lawall <Julia.Lawall@lip6.fr> Signed-off-by: Michal Marek <mmarek@suse.com>
		
			
				
	
	
		
			114 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /// Make sure pm_runtime_* calls does not use unnecessary IS_ERR_VALUE
 | |
| ///
 | |
| // Keywords: pm_runtime
 | |
| // Confidence: Medium
 | |
| // Copyright (C) 2013 Texas Instruments Incorporated - GPLv2.
 | |
| // URL: http://coccinelle.lip6.fr/
 | |
| // Options: --include-headers
 | |
| 
 | |
| virtual patch
 | |
| virtual context
 | |
| virtual org
 | |
| virtual report
 | |
| 
 | |
| //----------------------------------------------------------
 | |
| //  Detection
 | |
| //----------------------------------------------------------
 | |
| 
 | |
| @runtime_bad_err_handle exists@
 | |
| expression ret;
 | |
| position p;
 | |
| @@
 | |
| (
 | |
| ret@p = \(pm_runtime_idle\|
 | |
| 	pm_runtime_suspend\|
 | |
| 	pm_runtime_autosuspend\|
 | |
| 	pm_runtime_resume\|
 | |
| 	pm_request_idle\|
 | |
| 	pm_request_resume\|
 | |
| 	pm_request_autosuspend\|
 | |
| 	pm_runtime_get\|
 | |
| 	pm_runtime_get_sync\|
 | |
| 	pm_runtime_put\|
 | |
| 	pm_runtime_put_autosuspend\|
 | |
| 	pm_runtime_put_sync\|
 | |
| 	pm_runtime_put_sync_suspend\|
 | |
| 	pm_runtime_put_sync_autosuspend\|
 | |
| 	pm_runtime_set_active\|
 | |
| 	pm_schedule_suspend\|
 | |
| 	pm_runtime_barrier\|
 | |
| 	pm_generic_runtime_suspend\|
 | |
| 	pm_generic_runtime_resume\)(...);
 | |
| ...
 | |
| IS_ERR_VALUE(ret)
 | |
| ...
 | |
| )
 | |
| 
 | |
| //----------------------------------------------------------
 | |
| //  For context mode
 | |
| //----------------------------------------------------------
 | |
| 
 | |
| @depends on context@
 | |
| identifier pm_runtime_api;
 | |
| expression ret;
 | |
| position runtime_bad_err_handle.p;
 | |
| @@
 | |
| (
 | |
| ret@p = pm_runtime_api(...);
 | |
| ...
 | |
| * IS_ERR_VALUE(ret)
 | |
| ...
 | |
| )
 | |
| 
 | |
| //----------------------------------------------------------
 | |
| //  For patch mode
 | |
| //----------------------------------------------------------
 | |
| 
 | |
| @depends on patch@
 | |
| identifier pm_runtime_api;
 | |
| expression ret;
 | |
| position runtime_bad_err_handle.p;
 | |
| @@
 | |
| (
 | |
| ret@p = pm_runtime_api(...);
 | |
| ...
 | |
| - IS_ERR_VALUE(ret)
 | |
| + ret < 0
 | |
| ...
 | |
| )
 | |
| 
 | |
| //----------------------------------------------------------
 | |
| //  For org and report mode
 | |
| //----------------------------------------------------------
 | |
| 
 | |
| @r depends on (org || report) exists@
 | |
| position p1, p2;
 | |
| identifier pm_runtime_api;
 | |
| expression ret;
 | |
| position runtime_bad_err_handle.p;
 | |
| @@
 | |
| (
 | |
| ret@p = pm_runtime_api@p1(...);
 | |
| ...
 | |
| IS_ERR_VALUE@p2(ret)
 | |
| ...
 | |
| )
 | |
| 
 | |
| @script:python depends on org@
 | |
| p1 << r.p1;
 | |
| p2 << r.p2;
 | |
| pm_runtime_api << r.pm_runtime_api;
 | |
| @@
 | |
| 
 | |
| cocci.print_main(pm_runtime_api,p1)
 | |
| cocci.print_secs("IS_ERR_VALUE",p2)
 | |
| 
 | |
| @script:python depends on report@
 | |
| p1 << r.p1;
 | |
| p2 << r.p2;
 | |
| pm_runtime_api << r.pm_runtime_api;
 | |
| @@
 | |
| 
 | |
| msg = "%s returns < 0 as error. Unecessary IS_ERR_VALUE at line %s" % (pm_runtime_api, p2[0].line)
 | |
| coccilib.report.print_report(p1[0],msg)
 |