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;
82d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines  buffer[1] = 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_new_right_oob.cc}}:[[@LINE-3]]
122d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines// CHECK: [[ADDR]] is located 0 bytes to the right of 1-byte region
132d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines// CHECK: allocated by thread T0 here:
14799172d60d32feb1acba1a6867f3a9c39a999e5cPirama Arumuga Nainar// CHECK:   {{#0 .* operator new}}
152d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines// CHECK:   {{#1 .* main .*operator_new_right_oob.cc}}:[[@LINE-8]]
162d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines  delete buffer;
172d1fdb26e458c4ddc04155c1d421bced3ba90cd0Stephen Hines}
18