// RUN: %clang_analyze_cc1 -w -analyzer-checker=core,debug.ExprInspection \
// RUN: -analyzer-output=text -verify %s
externvoidclang_analyzer_eval(int);intOSAtomicCompareAndSwapPtrBarrier(void*,void*,void**);intOSAtomicCompareAndSwapPtrBarrier(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;}voidtestThatItActuallyWorks(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}}
}