================ @@ -1,11 +1,27 @@ // RUN: %clang_analyze_cc1 -triple amdgcn-unknown-unknown \ -// RUN: -analyzer-checker=core -verify %s +// RUN: -Wno-incompatible-library-redeclaration \ +// RUN: -analyzer-checker=core,unix.cstring.BadSizeArg -verify %s // expected-no-diagnostics // // By default, pointers are 64-bits. +#define ADDRESS_SPACE_64BITS __attribute__((address_space(0))) #define ADDRESS_SPACE_32BITS __attribute__((address_space(3))) int test(ADDRESS_SPACE_32BITS int *p, ADDRESS_SPACE_32BITS void *q) { return p == q; // no-crash } + +// Make sure that the cstring checker handles non-default address spaces +ADDRESS_SPACE_64BITS void * +memcpy(ADDRESS_SPACE_64BITS void *, + ADDRESS_SPACE_32BITS const void *, + long unsigned int); + +ADDRESS_SPACE_64BITS struct { + char m[16]; +} n; + +void avoid_cstring_checker_crash(ADDRESS_SPACE_32BITS char *p) { + memcpy(&n.m[0], p, 4); // no-crash +} ---------------- nuudlman wrote:
Done https://github.com/llvm/llvm-project/pull/153498 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits