16a211c5814e25d6745a5058cc0e499e5235d3821Stephen Hines// RUN: %clang_cl_asan -O0 %s -Fe%t 22d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines// RUN: not %run %t 2>&1 | FileCheck %s 32d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines 42d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines#include <windows.h> 52d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines 62d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hinesint main() { 72d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines char *buffer = new char[42]; 82d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines buffer[42] = 42; 92d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines// CHECK: AddressSanitizer: heap-buffer-overflow on address [[ADDR:0x[0-9a-f]+]] 102d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines// CHECK: WRITE of size 1 at [[ADDR]] thread T0 112d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines// CHECK: {{#0 .* main .*operator_array_new_right_oob.cc}}:[[@LINE-3]] 122d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines// CHECK: [[ADDR]] is located 0 bytes to the right of 42-byte region 132d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines// CHECK: allocated by thread T0 here: 146d1862363c88c183b0ed7740fca876342cf0474bStephen Hines// FIXME: The 'operator new' frame should have []. 156d1862363c88c183b0ed7740fca876342cf0474bStephen Hines// CHECK: {{#0 .* operator new}} 166d1862363c88c183b0ed7740fca876342cf0474bStephen Hines// CHECK: {{#1 .* main .*operator_array_new_right_oob.cc}}:[[@LINE-9]] 172d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines delete [] buffer; 182d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines} 19