mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:32:44 +01:00
59f9149f4e
The MemorySSA-based implementation has been enabled without issue for a while now, so keeping the old implementation around doesn't seem useful anymore. This drops the MemDep-based implementation. Differential Revision: https://reviews.llvm.org/D97877
24 lines
1.1 KiB
LLVM
24 lines
1.1 KiB
LLVM
; RUN: opt -dse -S < %s | FileCheck %s
|
|
|
|
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
|
|
target triple = "x86_64-apple-darwin"
|
|
|
|
%"class.std::auto_ptr" = type { i32* }
|
|
|
|
; CHECK-LABEL: @_Z3foov(
|
|
define void @_Z3foov(%"class.std::auto_ptr"* noalias nocapture sret(%"class.std::auto_ptr") %agg.result) uwtable ssp {
|
|
_ZNSt8auto_ptrIiED1Ev.exit:
|
|
%temp.lvalue = alloca %"class.std::auto_ptr", align 8
|
|
call void @_Z3barv(%"class.std::auto_ptr"* sret(%"class.std::auto_ptr") %temp.lvalue)
|
|
%_M_ptr.i.i = getelementptr inbounds %"class.std::auto_ptr", %"class.std::auto_ptr"* %temp.lvalue, i64 0, i32 0
|
|
%tmp.i.i = load i32*, i32** %_M_ptr.i.i, align 8
|
|
; CHECK-NOT: store i32* null
|
|
store i32* null, i32** %_M_ptr.i.i, align 8
|
|
%_M_ptr.i.i4 = getelementptr inbounds %"class.std::auto_ptr", %"class.std::auto_ptr"* %agg.result, i64 0, i32 0
|
|
store i32* %tmp.i.i, i32** %_M_ptr.i.i4, align 8
|
|
; CHECK: ret void
|
|
ret void
|
|
}
|
|
|
|
declare void @_Z3barv(%"class.std::auto_ptr"* sret(%"class.std::auto_ptr"))
|