~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/scripts/coccinelle/api/simple_open.cocci

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /scripts/coccinelle/api/simple_open.cocci (Version linux-6.12-rc7) and /scripts/coccinelle/api/simple_open.cocci (Version linux-5.3.18)


  1 // SPDX-License-Identifier: GPL-2.0                 1 // SPDX-License-Identifier: GPL-2.0
  2 /// Remove an open coded simple_open() functio      2 /// Remove an open coded simple_open() function
  3 /// and replace file operations references to       3 /// and replace file operations references to the function
  4 /// with simple_open() instead.                     4 /// with simple_open() instead.
  5 ///                                                 5 ///
  6 // Confidence: High                                 6 // Confidence: High
  7 // Comments:                                        7 // Comments:
  8 // Options: --no-includes --include-headers         8 // Options: --no-includes --include-headers
  9                                                     9 
 10 virtual patch                                      10 virtual patch
 11 virtual report                                     11 virtual report
 12                                                    12 
 13 @ open depends on patch @                          13 @ open depends on patch @
 14 identifier open_f != simple_open;                  14 identifier open_f != simple_open;
 15 identifier i, f;                                   15 identifier i, f;
 16 @@                                                 16 @@
 17 -int open_f(struct inode *i, struct file *f)       17 -int open_f(struct inode *i, struct file *f)
 18 -{                                                 18 -{
 19 (                                                  19 (
 20 -if (i->i_private)                                 20 -if (i->i_private)
 21 -f->private_data = i->i_private;                   21 -f->private_data = i->i_private;
 22 |                                                  22 |
 23 -f->private_data = i->i_private;                   23 -f->private_data = i->i_private;
 24 )                                                  24 )
 25 -return 0;                                         25 -return 0;
 26 -}                                                 26 -}
 27                                                    27 
 28 @ has_open depends on open @                       28 @ has_open depends on open @
 29 identifier fops;                                   29 identifier fops;
 30 identifier open.open_f;                            30 identifier open.open_f;
 31 @@                                                 31 @@
 32 struct file_operations fops = {                    32 struct file_operations fops = {
 33 ...,                                               33 ...,
 34 -.open = open_f,                                   34 -.open = open_f,
 35 +.open = simple_open,                              35 +.open = simple_open,
 36 ...                                                36 ...
 37 };                                                 37 };
 38                                                    38 
 39 @ openr depends on report @                        39 @ openr depends on report @
 40 identifier open_f != simple_open;                  40 identifier open_f != simple_open;
 41 identifier i, f;                                   41 identifier i, f;
 42 position p;                                        42 position p;
 43 @@                                                 43 @@
 44 int open_f@p(struct inode *i, struct file *f)      44 int open_f@p(struct inode *i, struct file *f)
 45 {                                                  45 {
 46 (                                                  46 (
 47 if (i->i_private)                                  47 if (i->i_private)
 48 f->private_data = i->i_private;                    48 f->private_data = i->i_private;
 49 |                                                  49 |
 50 f->private_data = i->i_private;                    50 f->private_data = i->i_private;
 51 )                                                  51 )
 52 return 0;                                          52 return 0;
 53 }                                                  53 }
 54                                                    54 
 55 @ has_openr depends on openr @                     55 @ has_openr depends on openr @
 56 identifier fops;                                   56 identifier fops;
 57 identifier openr.open_f;                           57 identifier openr.open_f;
 58 position p;                                        58 position p;
 59 @@                                                 59 @@
 60 struct file_operations fops = {                    60 struct file_operations fops = {
 61 ...,                                               61 ...,
 62 .open = open_f@p,                                  62 .open = open_f@p,
 63 ...                                                63 ...
 64 };                                                 64 };
 65                                                    65 
 66 @script:python@                                    66 @script:python@
 67 pf << openr.p;                                     67 pf << openr.p;
 68 ps << has_openr.p;                                 68 ps << has_openr.p;
 69 @@                                                 69 @@
 70                                                    70 
 71 coccilib.report.print_report(pf[0],"WARNING op     71 coccilib.report.print_report(pf[0],"WARNING opportunity for simple_open, see also structure on line %s"%(ps[0].line))
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php