blob: 2df74b67a31a23c4d6c1c7b9ca4d5bd80839b3df [file] [log] [blame]
Alexey Samsonov00cd2732014-01-21 11:58:33 +00001// RUN: %clang_asan -O2 %s -o %t
Filipe Cabecinhas91244922015-06-15 20:43:42 +00002// RUN: env ASAN_OPTIONS=$ASAN_OPTIONS:check_printf=1 %run %t 2>&1 | FileCheck %s
3// RUN: env ASAN_OPTIONS=$ASAN_OPTIONS:check_printf=0 %run %t 2>&1 | FileCheck %s
Greg Fitzgeraldb8aae542014-04-30 21:34:17 +00004// RUN: %run %t 2>&1 | FileCheck %s
Alexey Samsonov00cd2732014-01-21 11:58:33 +00005
6#include <stdio.h>
Timur Iskhodzhanov7f291812014-05-28 13:06:14 +00007#if defined(_WIN32)
8# define snprintf _snprintf
9#endif
10
Alexey Samsonov00cd2732014-01-21 11:58:33 +000011int main() {
12 volatile char c = '0';
13 volatile int x = 12;
14 volatile float f = 1.239;
15 volatile char s[] = "34";
Alexey Samsonov00cd2732014-01-21 11:58:33 +000016 // Check that printf works fine under Asan.
Alexey Samsonov1d028b82014-01-23 15:09:38 +000017 printf("%c %d %.3f %s\n", c, x, f, s);
Alexey Samsonov00cd2732014-01-21 11:58:33 +000018 // CHECK: 0 12 1.239 34
Alexey Samsonov1d028b82014-01-23 15:09:38 +000019 // Check that snprintf works fine under Asan.
20 char buf[4];
21 snprintf(buf, 1000, "qwe");
22 printf("%s\n", buf);
23 // CHECK: qwe
24 return 0;
Alexey Samsonov00cd2732014-01-21 11:58:33 +000025}