llvm-project/clang/test/Analysis/OSAtomic_mac.c
Aaron Ballman 1c2558021c Use functions with prototypes when appropriate; NFC
A significant number of our tests in C accidentally use functions
without prototypes. This patch converts the function signatures to have
a prototype for the situations where the test is not specific to K&R C
declarations. e.g.,

  void func();

becomes

  void func(void);

This is the final batch of tests being updated to add prototypes,
hopefully.
2022-02-24 15:30:13 -05:00

28 lines
1.0 KiB
C

// RUN: %clang_analyze_cc1 -w -analyzer-checker=core,debug.ExprInspection \
// RUN: -analyzer-output=text -verify %s
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}}
}