[PATCH] D11109: basic code generation for use-after-dtor
Naomi Musgrave
nmusgrave at google.com
Mon Jul 13 15:05:16 PDT 2015
nmusgrave updated this revision to Diff 29615.
nmusgrave marked 4 inline comments as done.
nmusgrave added a comment.
- refactored test for modularity, better flags
http://reviews.llvm.org/D11109
Files:
lib/CodeGen/CGClass.cpp
test/CodeGenCXX/sanitize-dtor-callback.cpp
Index: test/CodeGenCXX/sanitize-dtor-callback.cpp
===================================================================
--- /dev/null
+++ test/CodeGenCXX/sanitize-dtor-callback.cpp
@@ -0,0 +1,20 @@
+// Test -fsanitize-memory-use-after-dtor
+// RUN: %clang_cc1 -fsanitize=memory -fsanitize-memory-use-after-dtor -triple=x86_64-pc-linux -emit-llvm -o - %s | FileCheck %s
+// RUN: %clang_cc1 -fsanitize=memory -triple=x86_64-pc-linux -emit-llvm -o - %s | FileCheck %s -check-prefix=NO_DTOR_CHECK
+
+struct Simple {
+ int x;
+ ~Simple() {}
+};
+
+int main() {
+ Simple s;
+ s.~Simple();
+}
+// Simple internal member is poisoned by compiler-generated dtor
+// CHECK-LABEL: define linkonce_odr void @_ZN6SimpleD2Ev
+// CHECK: call void @__sanitizer_dtor_callback
+// CHECK: ret void
+
+// NO_DTOR_CHECK-NOT: call void @sanitizer_dtor_callback
+// NO_DTOR_CHECK: ret void
Index: lib/CodeGen/CGClass.cpp
===================================================================
--- lib/CodeGen/CGClass.cpp
+++ lib/CodeGen/CGClass.cpp
@@ -1448,6 +1448,29 @@
// Exit the try if applicable.
if (isTryBody)
ExitCXXTryStmt(*cast<CXXTryStmt>(Body), true);
+
+ // Insert memory-posioning instrumentation.
+ // Generates function call for handling object poisoning, passing in
+ // references to 'this' and its size as arguments.
+ if (CGM.getCodeGenOpts().SanitizeMemoryUseAfterDtor) {
+ const ASTRecordLayout &Layout =
+ getContext().getASTRecordLayout(Dtor->getParent());
+
+ llvm::Value *Args[2] = {
+ Builder.CreateBitCast(LoadCXXThis(), VoidPtrTy),
+ llvm::ConstantInt::get(CGM.SizeTy, Layout.getSize().getQuantity())
+ };
+ llvm::Type *ArgTypes[2] = {
+ VoidPtrTy,
+ SizeTy
+ };
+
+ llvm::FunctionType *FnType =
+ llvm::FunctionType::get(CGM.VoidTy, ArgTypes, false);
+ llvm::Value *Fn =
+ CGM.CreateRuntimeFunction(FnType, "__sanitizer_dtor_callback");
+ EmitNounwindRuntimeCall(Fn, Args);
+ }
}
void CodeGenFunction::emitImplicitAssignmentOperatorBody(FunctionArgList &Args) {
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D11109.29615.patch
Type: text/x-patch
Size: 2052 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20150713/433844fc/attachment.bin>
More information about the cfe-commits
mailing list