of: MSI: Simplify irqdomain lookup
[linux/fpc-iii.git] / scripts / coccinelle / iterators / use_after_iter.cocci
blobf085f5968c5238d631d6239c9d2a92a1b85fcd91
1 /// If list_for_each_entry, etc complete a traversal of the list, the iterator
2 /// variable ends up pointing to an address at an offset from the list head,
3 /// and not a meaningful structure.  Thus this value should not be used after
4 /// the end of the iterator.
5 //#False positives arise when there is a goto in the iterator and the
6 //#reported reference is at the label of this goto.  Some flag tests
7 //#may also cause a report to be a false positive.
8 ///
9 // Confidence: Moderate
10 // Copyright: (C) 2012 Julia Lawall, INRIA/LIP6.  GPLv2.
11 // Copyright: (C) 2012 Gilles Muller, INRIA/LIP6.  GPLv2.
12 // URL: http://coccinelle.lip6.fr/
13 // Comments:
14 // Options: --no-includes --include-headers
16 virtual context
17 virtual org
18 virtual report
20 @r exists@
21 identifier c,member;
22 expression E,x;
23 iterator name list_for_each_entry;
24 iterator name list_for_each_entry_reverse;
25 iterator name list_for_each_entry_continue;
26 iterator name list_for_each_entry_continue_reverse;
27 iterator name list_for_each_entry_from;
28 iterator name list_for_each_entry_safe;
29 iterator name list_for_each_entry_safe_continue;
30 iterator name list_for_each_entry_safe_from;
31 iterator name list_for_each_entry_safe_reverse;
32 iterator name hlist_for_each_entry;
33 iterator name hlist_for_each_entry_continue;
34 iterator name hlist_for_each_entry_from;
35 iterator name hlist_for_each_entry_safe;
36 statement S;
37 position p1,p2;
41 list_for_each_entry@p1(c,...,member) { ... when != break;
42                                  when forall
43                                  when strict
46 list_for_each_entry_reverse@p1(c,...,member) { ... when != break;
47                                  when forall
48                                  when strict
51 list_for_each_entry_continue@p1(c,...,member) { ... when != break;
52                                  when forall
53                                  when strict
56 list_for_each_entry_continue_reverse@p1(c,...,member) { ... when != break;
57                                  when forall
58                                  when strict
61 list_for_each_entry_from@p1(c,...,member) { ... when != break;
62                                  when forall
63                                  when strict
66 list_for_each_entry_safe@p1(c,...,member) { ... when != break;
67                                  when forall
68                                  when strict
71 list_for_each_entry_safe_continue@p1(c,...,member) { ... when != break;
72                                  when forall
73                                  when strict
76 list_for_each_entry_safe_from@p1(c,...,member) { ... when != break;
77                                  when forall
78                                  when strict
81 list_for_each_entry_safe_reverse@p1(c,...,member) { ... when != break;
82                                  when forall
83                                  when strict
86 ...
88 list_for_each_entry(c,...) S
90 list_for_each_entry_reverse(c,...) S
92 list_for_each_entry_continue(c,...) S
94 list_for_each_entry_continue_reverse(c,...) S
96 list_for_each_entry_from(c,...) S
98 list_for_each_entry_safe(c,...) S
100 list_for_each_entry_safe(x,c,...) S
102 list_for_each_entry_safe_continue(c,...) S
104 list_for_each_entry_safe_continue(x,c,...) S
106 list_for_each_entry_safe_from(c,...) S
108 list_for_each_entry_safe_from(x,c,...) S
110 list_for_each_entry_safe_reverse(c,...) S
112 list_for_each_entry_safe_reverse(x,c,...) S
114 hlist_for_each_entry(c,...) S
116 hlist_for_each_entry_continue(c,...) S
118 hlist_for_each_entry_from(c,...) S
120 hlist_for_each_entry_safe(c,...) S
122 list_remove_head(x,c,...)
124 sizeof(<+...c...+>)
126 &c->member
128 c = E
130 *c@p2
133 @script:python depends on org@
134 p1 << r.p1;
135 p2 << r.p2;
138 cocci.print_main("invalid iterator index reference",p2)
139 cocci.print_secs("iterator",p1)
141 @script:python depends on report@
142 p1 << r.p1;
143 p2 << r.p2;
146 msg = "ERROR: invalid reference to the index variable of the iterator on line %s" % (p1[0].line)
147 coccilib.report.print_report(p2[0], msg)