blob: d7b35e462f61e9dbb18809a4e917040e430a4b12 [file] [log] [blame]
// RUN: mlir-opt %s --pass-pipeline="builtin.module(test-transform-dialect-interpreter{transform-library-paths=%p%{fs-sep}include%{fs-sep}test-interpreter-library/definitions-self-contained.mlir})" \
// RUN: --verify-diagnostics --split-input-file | FileCheck %s
// RUN: mlir-opt %s --pass-pipeline="builtin.module(test-transform-dialect-interpreter{transform-library-paths=%p%{fs-sep}include%{fs-sep}test-interpreter-library/definitions-self-contained.mlir}, test-transform-dialect-interpreter)" \
// RUN: --verify-diagnostics --split-input-file | FileCheck %s
// The definition of the @print_message named sequence is provided in another
// file. It will be included because of the pass option. Subsequent application
// of the same pass works but only without the library file (since the first
// application loads external symbols and loading them again woul make them
// clash).
// Note that the same diagnostic produced twice at the same location only
// needs to be matched once.
// expected-remark @below {{message}}
// expected-remark @below {{unannotated}}
// expected-remark @below {{internal colliding (without suffix)}}
// expected-remark @below {{internal colliding_0}}
// expected-remark @below {{internal colliding_1}}
// expected-remark @below {{internal colliding_3}}
// expected-remark @below {{internal colliding_4}}
// expected-remark @below {{internal colliding_5}}
module attributes {transform.with_named_sequence} {
// CHECK-DAG: transform.named_sequence @print_message(
// CHECK-DAG: transform.include @private_helper
transform.named_sequence private @print_message(!transform.any_op {transform.readonly})
// These ops collide with ops from the other module before or after renaming.
transform.named_sequence private @colliding(%arg0: !transform.any_op {transform.readonly}) {
transform.debug.emit_remark_at %arg0, "internal colliding (without suffix)" : !transform.any_op
transform.yield
}
transform.named_sequence private @colliding_0(%arg0: !transform.any_op {transform.readonly}) {
transform.debug.emit_remark_at %arg0, "internal colliding_0" : !transform.any_op
transform.yield
}
transform.named_sequence private @colliding_1(%arg0: !transform.any_op {transform.readonly}) {
transform.debug.emit_remark_at %arg0, "internal colliding_1" : !transform.any_op
transform.yield
}
transform.named_sequence private @colliding_3(%arg0: !transform.any_op {transform.readonly}) {
transform.debug.emit_remark_at %arg0, "internal colliding_3" : !transform.any_op
transform.yield
}
// This symbol is public and thus can't be renamed.
// CHECK-DAG: transform.named_sequence @colliding_4(
transform.named_sequence @colliding_4(%arg0: !transform.any_op {transform.readonly}) {
transform.debug.emit_remark_at %arg0, "internal colliding_4" : !transform.any_op
transform.yield
}
transform.named_sequence private @colliding_5(%arg0: !transform.any_op {transform.readonly}) {
transform.debug.emit_remark_at %arg0, "internal colliding_5" : !transform.any_op
transform.yield
}
// CHECK-DAG: transform.named_sequence @unannotated(
// CHECK-DAG: transform.debug.emit_remark_at %{{.*}}, "unannotated"
transform.named_sequence @unannotated(!transform.any_op {transform.readonly})
transform.sequence failures(propagate) {
^bb0(%arg0: !transform.any_op):
include @print_message failures(propagate) (%arg0) : (!transform.any_op) -> ()
include @unannotated failures(propagate) (%arg0) : (!transform.any_op) -> ()
include @colliding failures(propagate) (%arg0) : (!transform.any_op) -> ()
include @colliding_0 failures(propagate) (%arg0) : (!transform.any_op) -> ()
include @colliding_1 failures(propagate) (%arg0) : (!transform.any_op) -> ()
include @colliding_3 failures(propagate) (%arg0) : (!transform.any_op) -> ()
include @colliding_4 failures(propagate) (%arg0) : (!transform.any_op) -> ()
include @colliding_5 failures(propagate) (%arg0) : (!transform.any_op) -> ()
}
}