// Test strict_string_checks option in strstr function // RUN: %clang_asan %s -o %t && %run %t 2>&1 // Newer versions of Android's strstr() uses memchr() internally, which actually // does trigger a heap-buffer-overflow (as it tries to find the // null-terminator). The same applies to FreeBSD. // UNSUPPORTED: android, freebsd // RUN: %env_asan_opts=strict_string_checks=false %run %t 2>&1 // RUN: %env_asan_opts=strict_string_checks=true not %run %t 2>&1 | FileCheck %s #include #include #include int main(int argc, char **argv) { size_t size = 100; char fill = 'o'; char *s1 = (char*)malloc(size); char *s2 = (char*)malloc(size); memset(s1, fill, size); memset(s2, fill, size); s2[size - 1]='\0'; char* r = strstr(s1, s2); // CHECK: {{.*ERROR: AddressSanitizer: heap-buffer-overflow on address}} // CHECK: READ of size {{101|100}} assert(r == s1); free(s1); free(s2); return 0; }