forked from OSchip/llvm-project
30 lines
1.1 KiB
C
30 lines
1.1 KiB
C
// RUN: %clang_analyze_cc1 -w -analyzer-checker=core,debug.ExprInspection \
|
|
// RUN: -analyzer-output=text -verify %s
|
|
|
|
extern void clang_analyzer_eval(int);
|
|
|
|
int OSAtomicCompareAndSwapPtrBarrier(void *, void *, void **);
|
|
int OSAtomicCompareAndSwapPtrBarrier(void *, void *, void **) {
|
|
// There is some body in the actual header,
|
|
// but we should trust our BodyFarm instead.
|
|
}
|
|
|
|
int *invalidSLocOnRedecl(void) {
|
|
// 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) {
|
|
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}}
|
|
}
|