Alexey Samsonov | 00cd273 | 2014-01-21 11:58:33 +0000 | [diff] [blame] | 1 | // RUN: %clang_asan -O2 %s -o %t |
Reid Kleckner | 7a21138 | 2016-03-11 19:11:15 +0000 | [diff] [blame] | 2 | // RUN: %env_asan_opts=check_printf=1 not %run %t 2>&1 | FileCheck --check-prefix=CHECK-ON %s |
| 3 | // RUN: not %run %t 2>&1 | FileCheck --check-prefix=CHECK-ON %s |
Alexey Samsonov | 00cd273 | 2014-01-21 11:58:33 +0000 | [diff] [blame] | 4 | |
Peter Collingbourne | 7b17c9d | 2018-04-20 19:07:35 +0000 | [diff] [blame] | 5 | // FIXME: sprintf is not intercepted on Windows yet. But this test can |
| 6 | // pass if sprintf calls memmove, which is intercepted, so we can't XFAIL it. |
Petr Hosek | eb46c95 | 2018-08-09 02:16:18 +0000 | [diff] [blame] | 7 | // UNSUPPORTED: windows-msvc |
Timur Iskhodzhanov | 7f29181 | 2014-05-28 13:06:14 +0000 | [diff] [blame] | 8 | |
Alexey Samsonov | 00cd273 | 2014-01-21 11:58:33 +0000 | [diff] [blame] | 9 | #include <stdio.h> |
| 10 | int main() { |
| 11 | volatile char c = '0'; |
| 12 | volatile int x = 12; |
| 13 | volatile float f = 1.239; |
| 14 | volatile char s[] = "34"; |
| 15 | volatile char buf[2]; |
Reid Kleckner | 60e53cd | 2016-03-11 21:07:48 +0000 | [diff] [blame] | 16 | fputs("before sprintf\n", stderr); |
Alexey Samsonov | 00cd273 | 2014-01-21 11:58:33 +0000 | [diff] [blame] | 17 | sprintf((char *)buf, "%c %d %.3f %s\n", c, x, f, s); |
Reid Kleckner | 60e53cd | 2016-03-11 21:07:48 +0000 | [diff] [blame] | 18 | fputs("after sprintf", stderr); |
| 19 | fputs((const char *)buf, stderr); |
Alexey Samsonov | 00cd273 | 2014-01-21 11:58:33 +0000 | [diff] [blame] | 20 | return 0; |
| 21 | // Check that size of output buffer is sanitized. |
Reid Kleckner | 7a21138 | 2016-03-11 19:11:15 +0000 | [diff] [blame] | 22 | // CHECK-ON: before sprintf |
| 23 | // CHECK-ON-NOT: after sprintf |
Alexey Samsonov | 00cd273 | 2014-01-21 11:58:33 +0000 | [diff] [blame] | 24 | // CHECK-ON: stack-buffer-overflow |
| 25 | // CHECK-ON-NOT: 0 12 1.239 34 |
Alexey Samsonov | 00cd273 | 2014-01-21 11:58:33 +0000 | [diff] [blame] | 26 | } |