[llvm] r191325 - Verify that we don't optimize null return checks to the nothrow_t version of operator new.
Benjamin Kramer
benny.kra at googlemail.com
Tue Sep 24 11:37:49 PDT 2013
Author: d0k
Date: Tue Sep 24 13:37:49 2013
New Revision: 191325
URL: http://llvm.org/viewvc/llvm-project?rev=191325&view=rev
Log:
Verify that we don't optimize null return checks to the nothrow_t version of operator new.
Modified:
llvm/trunk/test/Transforms/InstSimplify/call.ll
Modified: llvm/trunk/test/Transforms/InstSimplify/call.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstSimplify/call.ll?rev=191325&r1=191324&r2=191325&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/InstSimplify/call.ll (original)
+++ llvm/trunk/test/Transforms/InstSimplify/call.ll Tue Sep 24 13:37:49 2013
@@ -122,6 +122,29 @@ cast.end:
declare noalias i8* @_Znwm(i64)
+%"struct.std::nothrow_t" = type { i8 }
+ at _ZSt7nothrow = external global %"struct.std::nothrow_t"
+
+define i8* @operator_new_nothrow_t() {
+entry:
+ %call = tail call noalias i8* @_ZnamRKSt9nothrow_t(i64 8, %"struct.std::nothrow_t"* @_ZSt7nothrow)
+ %cmp = icmp eq i8* %call, null
+ br i1 %cmp, label %cast.end, label %cast.notnull
+
+cast.notnull: ; preds = %entry
+ %add.ptr = getelementptr inbounds i8* %call, i64 4
+ br label %cast.end
+
+cast.end: ; preds = %cast.notnull, %entry
+ %cast.result = phi i8* [ %add.ptr, %cast.notnull ], [ null, %entry ]
+ ret i8* %cast.result
+
+; CHECK-LABEL: @operator_new_nothrow_t
+; CHECK: br i1 %cmp, label %cast.end, label %cast.notnull
+}
+
+declare i8* @_ZnamRKSt9nothrow_t(i64, %"struct.std::nothrow_t"*) nounwind
+
define i8* @malloc_can_return_null() {
entry:
%call = tail call noalias i8* @malloc(i64 8)
More information about the llvm-commits
mailing list