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 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110
|
// RUN: mlir-opt --pass-pipeline="builtin.module(test-lazy-loading)" %s -o %t | FileCheck %s
// RUN: mlir-opt --pass-pipeline="builtin.module(test-lazy-loading{bytecode-version=1})" %s -o %t | FileCheck %s --check-prefix=OLD-BYTECODE
func.func @op_with_passthrough_region_args() {
%0 = arith.constant 10 : index
// Ensure we can handle nested non-isolated/non-lazy regions.
"test.one_region_op"() ({
"test.consumer"(%0) : (index) -> ()
}) : () -> ()
test.isolated_region %0 {
"test.consumer"(%0) : (index) -> ()
}
%result:2 = "test.op"() : () -> (index, index)
test.isolated_region %result#1 {
"test.consumer"(%result#1) : (index) -> ()
}
test.isolated_regions {
"test.unknown_op"() : () -> ()
}, {
"test.unknown_op"() : () -> ()
}
// Ensure operations that aren't tagged as IsolatedFromAbove can
// still be lazy loaded if they don't have references to values
// defined above.
"test.one_region_op"() ({
"test.unknown_op"() : () -> ()
}) : () -> ()
// Similar test as above, but check that if one region has a reference
// to a value defined above, we don't lazy load the operation.
"test.two_region_op"() ({
"test.unknown_op"() : () -> ()
}, {
"test.consumer"(%0) : (index) -> ()
}) : () -> ()
return
}
// Before version 2, we can't support lazy loading.
// OLD-BYTECODE-NOT: Has 1 ops to materialize
// OLD-BYTECODE-NOT: Materializing
// OLD-BYTECODE: Has 0 ops to materialize
// CHECK: Has 1 ops to materialize
// CHECK: Before Materializing...
// CHECK: "builtin.module"() ({
// CHECK-NOT: func
// CHECK: Materializing...
// CHECK: "builtin.module"() ({
// CHECK: "func.func"() <{function_type = () -> (), sym_name = "op_with_passthrough_region_args"}> ({
// CHECK-NOT: arith
// CHECK: Has 1 ops to materialize
// CHECK: Before Materializing...
// CHECK: "func.func"() <{function_type = () -> (), sym_name = "op_with_passthrough_region_args"}> ({
// CHECK-NOT: arith
// CHECK: Materializing...
// CHECK: "func.func"() <{function_type = () -> (), sym_name = "op_with_passthrough_region_args"}> ({
// CHECK: arith
// CHECK: one_region_op
// CHECK: test.consumer
// CHECK: isolated_region
// CHECK-NOT: test.consumer
// CHECK: test.one_region_op
// CHECK-NOT: test.op
// CHECK: test.two_region_op
// CHECK: test.unknown_op
// CHECK: test.consumer
// CHECK: Has 4 ops to materialize
// CHECK: Before Materializing...
// CHECK: test.isolated_region
// CHECK-NOT: test.consumer
// CHECK: Materializing...
// CHECK: test.isolated_region
// CHECK: ^bb0(%arg0: index):
// CHECK: test.consumer
// CHECK: Has 3 ops to materialize
// CHECK: Before Materializing...
// CHECK: test.isolated_region
// CHECK-NOT: test.consumer
// CHECK: Materializing...
// CHECK: test.isolated_region
// CHECK: test.consumer
// CHECK: Has 2 ops to materialize
// CHECK: Before Materializing...
// CHECK: test.isolated_regions
// CHECK-NOT: test.unknown_op
// CHECK: Materializing...
// CHECK: test.isolated_regions
// CHECK: test.unknown_op
// CHECK: test.unknown_op
// CHECK: Has 1 ops to materialize
// CHECK: Before Materializing...
// CHECK: test.one_region_op
// CHECK-NOT: test.unknown_op
// CHECK: Materializing...
// CHECK: test.one_region_op
// CHECK: test.unknown_op
// CHECK: Has 0 ops to materialize
|