| // RUN: %clang_analyze_cc1 -w -analyzer-checker=core,debug.ExprInspection \ |
| // RUN: -analyzer-output=text -verify %s |
| |
| int OSAtomicCompareAndSwapPtrBarrier(*, *, **); |
| int OSAtomicCompareAndSwapPtrBarrier() { |
| // There is some body in the actual header, |
| // but we should trust our BodyFarm instead. |
| } |
| |
| int *invalidSLocOnRedecl() { |
| // Was crashing when trying to throw a report about returning an uninitialized |
| // value to the caller. FIXME: We should probably still throw that report, |
| // something like "The "compare" part of CompareAndSwap depends on an |
| // undefined value". |
| int *b; |
| OSAtomicCompareAndSwapPtrBarrier(0, 0, &b); // no-crash |
| return b; |
| } |
| |
| void testThatItActuallyWorks() { |
| void *x = 0; |
| int res = OSAtomicCompareAndSwapPtrBarrier(0, &x, &x); |
| clang_analyzer_eval(res); // expected-warning{{TRUE}} |
| // expected-note@-1{{TRUE}} |
| clang_analyzer_eval(x == &x); // expected-warning{{TRUE}} |
| // expected-note@-1{{TRUE}} |
| } |