| // RUN: %clang_cc1 -analyze -analyzer-checker=core -analyzer-output=text -verify %s |
| // RUN: %clang_cc1 -analyze -analyzer-checker=core -analyzer-output=plist-multi-file %s -o - | FileCheck %s |
| |
| struct S { |
| int *x; |
| int y; |
| }; |
| |
| int *foo(); |
| |
| void inlined(struct S *s, int m) { |
| if (s->x) |
| //expected-note@-1{{Taking false branch}} |
| //expected-note@-2{{Assuming pointer value is null}} |
| |
| m++; |
| |
| } |
| void test(struct S syz, int *pp) { |
| int m = 0; |
| syz.x = foo(); |
| inlined(&syz, m); |
| // expected-note@-1{{Calling 'inlined'}} |
| // expected-note@-2{{Returning from 'inlined'}} |
| m += *syz.x; // expected-warning{{Dereference of null pointer (loaded from field 'x')}} |
| // expected-note@-1{{Dereference of null pointer (loaded from field 'x')}} |
| } |
| |
| //CHECK: <dict> |
| //CHECK: <key>files</key> |
| //CHECK: <array> |
| //CHECK: </array> |
| //CHECK: <key>diagnostics</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>path</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>kind</key><string>control</string> |
| //CHECK: <key>edges</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>start</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>20</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>20</integer> |
| //CHECK: <key>col</key><integer>5</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: <key>end</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>22</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>22</integer> |
| //CHECK: <key>col</key><integer>9</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>kind</key><string>event</string> |
| //CHECK: <key>location</key> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>22</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <key>ranges</key> |
| //CHECK: <array> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>22</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>22</integer> |
| //CHECK: <key>col</key><integer>18</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </array> |
| //CHECK: <key>depth</key><integer>0</integer> |
| //CHECK: <key>extended_message</key> |
| //CHECK: <string>Calling 'inlined'</string> |
| //CHECK: <key>message</key> |
| //CHECK: <string>Calling 'inlined'</string> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>kind</key><string>event</string> |
| //CHECK: <key>location</key> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>11</integer> |
| //CHECK: <key>col</key><integer>1</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <key>depth</key><integer>1</integer> |
| //CHECK: <key>extended_message</key> |
| //CHECK: <string>Entered call from 'test'</string> |
| //CHECK: <key>message</key> |
| //CHECK: <string>Entered call from 'test'</string> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>kind</key><string>control</string> |
| //CHECK: <key>edges</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>start</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>11</integer> |
| //CHECK: <key>col</key><integer>1</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>11</integer> |
| //CHECK: <key>col</key><integer>4</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: <key>end</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>12</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>12</integer> |
| //CHECK: <key>col</key><integer>4</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>kind</key><string>control</string> |
| //CHECK: <key>edges</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>start</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>12</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>12</integer> |
| //CHECK: <key>col</key><integer>4</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: <key>end</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>12</integer> |
| //CHECK: <key>col</key><integer>7</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>12</integer> |
| //CHECK: <key>col</key><integer>7</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>kind</key><string>event</string> |
| //CHECK: <key>location</key> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>12</integer> |
| //CHECK: <key>col</key><integer>7</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <key>ranges</key> |
| //CHECK: <array> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>12</integer> |
| //CHECK: <key>col</key><integer>7</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>12</integer> |
| //CHECK: <key>col</key><integer>10</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </array> |
| //CHECK: <key>depth</key><integer>1</integer> |
| //CHECK: <key>extended_message</key> |
| //CHECK: <string>Assuming pointer value is null</string> |
| //CHECK: <key>message</key> |
| //CHECK: <string>Assuming pointer value is null</string> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>kind</key><string>event</string> |
| //CHECK: <key>location</key> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>22</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <key>ranges</key> |
| //CHECK: <array> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>22</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>22</integer> |
| //CHECK: <key>col</key><integer>18</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </array> |
| //CHECK: <key>depth</key><integer>1</integer> |
| //CHECK: <key>extended_message</key> |
| //CHECK: <string>Returning from 'inlined'</string> |
| //CHECK: <key>message</key> |
| //CHECK: <string>Returning from 'inlined'</string> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>kind</key><string>control</string> |
| //CHECK: <key>edges</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>start</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>22</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>22</integer> |
| //CHECK: <key>col</key><integer>9</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: <key>end</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>25</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>25</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>kind</key><string>control</string> |
| //CHECK: <key>edges</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>start</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>25</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>25</integer> |
| //CHECK: <key>col</key><integer>3</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: <key>end</key> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>25</integer> |
| //CHECK: <key>col</key><integer>8</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>25</integer> |
| //CHECK: <key>col</key><integer>8</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>kind</key><string>event</string> |
| //CHECK: <key>location</key> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>25</integer> |
| //CHECK: <key>col</key><integer>8</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <key>ranges</key> |
| //CHECK: <array> |
| //CHECK: <array> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>25</integer> |
| //CHECK: <key>col</key><integer>13</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>25</integer> |
| //CHECK: <key>col</key><integer>13</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </array> |
| //CHECK: <key>depth</key><integer>0</integer> |
| //CHECK: <key>extended_message</key> |
| //CHECK: <string>Dereference of null pointer (loaded from field 'x')</string> |
| //CHECK: <key>message</key> |
| //CHECK: <string>Dereference of null pointer (loaded from field 'x')</string> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: <key>description</key><string>Dereference of null pointer (loaded from field 'x')</string> |
| //CHECK: <key>category</key><string>Logic error</string> |
| //CHECK: <key>type</key><string>Dereference of null pointer</string> |
| //CHECK: <key>issue_context_kind</key><string>function</string> |
| //CHECK: <key>issue_context</key><string>test</string> |
| //CHECK: <key>issue_hash</key><integer>6</integer> |
| //CHECK: <key>location</key> |
| //CHECK: <dict> |
| //CHECK: <key>line</key><integer>25</integer> |
| //CHECK: <key>col</key><integer>8</integer> |
| //CHECK: <key>file</key><integer>0</integer> |
| //CHECK: </dict> |
| //CHECK: </dict> |
| //CHECK: </array> |
| //CHECK: </dict> |
| //CHECK: </plist> |