Index: cfe/trunk/lib/Driver/ToolChains/WebAssembly.h =================================================================== --- cfe/trunk/lib/Driver/ToolChains/WebAssembly.h +++ cfe/trunk/lib/Driver/ToolChains/WebAssembly.h @@ -66,6 +66,7 @@ llvm::opt::ArgStringList &CC1Args) const override; void AddCXXStdlibLibArgs(const llvm::opt::ArgList &Args, llvm::opt::ArgStringList &CmdArgs) const override; + SanitizerMask getSupportedSanitizers() const override; const char *getDefaultLinker() const override { return "wasm-ld"; } Index: cfe/trunk/lib/Driver/ToolChains/WebAssembly.cpp =================================================================== --- cfe/trunk/lib/Driver/ToolChains/WebAssembly.cpp +++ cfe/trunk/lib/Driver/ToolChains/WebAssembly.cpp @@ -208,6 +208,14 @@ } } +SanitizerMask WebAssembly::getSupportedSanitizers() const { + SanitizerMask Res = ToolChain::getSupportedSanitizers(); + if (getTriple().isOSEmscripten()) { + Res |= SanitizerKind::Vptr; + } + return Res; +} + Tool *WebAssembly::buildLinker() const { return new tools::wasm::Linker(*this); } Index: cfe/trunk/test/CodeGenCXX/wasm-sanitize-vptr.cpp =================================================================== --- cfe/trunk/test/CodeGenCXX/wasm-sanitize-vptr.cpp +++ cfe/trunk/test/CodeGenCXX/wasm-sanitize-vptr.cpp @@ -0,0 +1,20 @@ +// RUN: %clang_cc1 -std=c++11 -fsanitize=vptr -emit-llvm %s -o - -triple wasm32-unknown-emscripten | FileCheck %s + +struct S { + virtual ~S() {} + int a; +}; + +struct T : S { + int b; +}; + +// CHECK-LABEL: @_Z15bad_static_castv +void bad_static_cast() { + S s; + // CHECK: br i1 %[[NONNULL:.*]], label %[[CONT:.*]], label %[[MISS:.*]], !prof + // CHECK: [[MISS]]: + // CHECK: call void @__ubsan_handle_dynamic_type_cache_miss_abort + // CHECK: [[CONT]]: + T &r = static_cast(s); +}