1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
// RUN: %target-sil-opt -enable-sil-verify-all %s -allocbox-to-stack -enable-lexical-lifetimes | %FileCheck %s
sil_stage raw
import Builtin
struct Int {
var _value: Builtin.Int64
}
struct Bool {
var _value: Builtin.Int1
}
protocol Error {}
// CHECK-LABEL: sil [ossa] @promote_nonlexical
// CHECK: alloc_stack $
// CHECK-NOT: alloc_box
// CHECK-NOT: destroy_value
// CHECK: return
// CHECK-LABEL: } // end sil function 'promote_nonlexical'
sil [ossa] @promote_nonlexical : $@convention(thin) (Int) -> Int {
bb0(%0 : $Int):
%1 = alloc_box ${ var Int }
%1a = project_box %1 : ${ var Int }, 0
store %0 to [trivial] %1a : $*Int
%3 = load [trivial] %1a : $*Int
destroy_value %1 : ${ var Int }
return %3 : $Int
}
// CHECK-LABEL: sil [ossa] @promote_lexical
// CHECK: alloc_stack [lexical]
// CHECK-NOT: alloc_box
// CHECK-NOT: destroy_value
// CHECK: return
// CHECK-LABEL: } // end sil function 'promote_lexical'
sil [ossa] @promote_lexical : $@convention(thin) (Int) -> Int {
bb0(%0 : $Int):
%1 = alloc_box ${ var Int }
%b = begin_borrow [lexical] %1 : ${ var Int }
%1a = project_box %b : ${ var Int }, 0
store %0 to [trivial] %1a : $*Int
%3 = load [trivial] %1a : $*Int
end_borrow %b : ${ var Int }
destroy_value %1 : ${ var Int }
return %3 : $Int
}
// CHECK-LABEL: sil [ossa] @keep_dead_end : {{.*}} {
// CHECK: [[STACK:%[^,]+]] = alloc_stack
// CHECK: cond_br undef, [[DIE:bb[0-9]+]]
// CHECK: [[DIE]]:
// CHECK-NEXT: unreachable
// CHECK-LABEL: } // end sil function 'keep_dead_end'
sil [ossa] @keep_dead_end : $@convention(thin) () -> () {
bb0:
%b = alloc_box ${ var Int }
cond_br undef, die, exit
die:
dealloc_box [dead_end] %b : ${ var Int }
unreachable
exit:
dealloc_box %b : ${ var Int }
%retval = tuple ()
return %retval : $()
}
|