blob: dee00a5c96b7bb0aa05677e7a4d61c957767ef25 [file] [log] [blame]
Alexey Samsonov00cd2732014-01-21 11:58:33 +00001// RUN: %clang_asan -O2 %s -o %t
Timur Iskhodzhanovd67df362014-05-26 13:44:57 +00002// RUN: env ASAN_OPTIONS=check_printf=1 %run %t 2>&1 | FileCheck %s
3// RUN: env 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>
7int main() {
8 volatile char c = '0';
9 volatile int x = 12;
10 volatile float f = 1.239;
11 volatile char s[] = "34";
Alexey Samsonov00cd2732014-01-21 11:58:33 +000012 // Check that printf works fine under Asan.
Alexey Samsonov1d028b82014-01-23 15:09:38 +000013 printf("%c %d %.3f %s\n", c, x, f, s);
Alexey Samsonov00cd2732014-01-21 11:58:33 +000014 // CHECK: 0 12 1.239 34
Alexey Samsonov1d028b82014-01-23 15:09:38 +000015 // Check that snprintf works fine under Asan.
16 char buf[4];
17 snprintf(buf, 1000, "qwe");
18 printf("%s\n", buf);
19 // CHECK: qwe
20 return 0;
Alexey Samsonov00cd2732014-01-21 11:58:33 +000021}