43 lines
1.4 KiB
MLIR
43 lines
1.4 KiB
MLIR
|
// RUN: mlir-translate -test-to-llvmir -split-input-file %s | FileCheck %s
|
||
|
|
||
|
module {
|
||
|
"test.symbol"() <{sym_name = "foo"}> : () -> ()
|
||
|
}
|
||
|
|
||
|
// CHECK-NOT: @sym_from_attr
|
||
|
// CHECK: @foo = external global i32
|
||
|
// CHECK-NOT: @sym_from_attr
|
||
|
|
||
|
// -----
|
||
|
|
||
|
// Make sure that the module attribute is processed before its body, so that the
|
||
|
// `test.symbol` that is created as a result of the `test.discardable_mod_attr`
|
||
|
// attribute is later picked up and translated to LLVM IR.
|
||
|
module attributes {test.discardable_mod_attr = true} {}
|
||
|
|
||
|
// CHECK: @sym_from_attr = external global i32
|
||
|
|
||
|
// -----
|
||
|
|
||
|
// CHECK-LABEL: @dialect_attr_translation
|
||
|
llvm.func @dialect_attr_translation() {
|
||
|
// CHECK: ret void, !annotation ![[MD_ID:.+]]
|
||
|
llvm.return {test.add_annotation}
|
||
|
}
|
||
|
// CHECK: ![[MD_ID]] = !{!"annotation_from_test"}
|
||
|
|
||
|
// -----
|
||
|
|
||
|
// CHECK-LABEL: @dialect_attr_translation_multi
|
||
|
llvm.func @dialect_attr_translation_multi(%a: i64, %b: i64, %c: i64) -> i64 {
|
||
|
// CHECK: add {{.*}}, !annotation ![[MD_ID_ADD:.+]]
|
||
|
// CHECK: mul {{.*}}, !annotation ![[MD_ID_MUL:.+]]
|
||
|
// CHECK: ret {{.*}}, !annotation ![[MD_ID_RET:.+]]
|
||
|
%ab = llvm.add %a, %b {test.add_annotation = "add"} : i64
|
||
|
%r = llvm.mul %ab, %c {test.add_annotation = "mul"} : i64
|
||
|
llvm.return {test.add_annotation = "ret"} %r : i64
|
||
|
}
|
||
|
// CHECK-DAG: ![[MD_ID_ADD]] = !{!"annotation_from_test: add"}
|
||
|
// CHECK-DAG: ![[MD_ID_MUL]] = !{!"annotation_from_test: mul"}
|
||
|
// CHECK-DAG: ![[MD_ID_RET]] = !{!"annotation_from_test: ret"}
|