// RUN: mlir-translate -mlir-to-llvmir -split-input-file %s | FileCheck %s llvm.func @foo(%arg0: !llvm.ptr) #alias_scope_domain = #llvm.alias_scope_domain, description = "The domain"> #alias_scope1 = #llvm.alias_scope, domain = #alias_scope_domain, description = "The first scope"> #alias_scope2 = #llvm.alias_scope, domain = #alias_scope_domain> #alias_scope3 = #llvm.alias_scope, domain = #alias_scope_domain> // CHECK-LABEL: @alias_scopes llvm.func @alias_scopes(%arg1 : !llvm.ptr) { %0 = llvm.mlir.constant(0 : i32) : i32 // CHECK: call void @llvm.experimental.noalias.scope.decl(metadata ![[SCOPES1:[0-9]+]]) llvm.intr.experimental.noalias.scope.decl #alias_scope1 // CHECK: store {{.*}}, !alias.scope ![[SCOPES1]], !noalias ![[SCOPES23:[0-9]+]] llvm.store %0, %arg1 {alias_scopes = [#alias_scope1], noalias_scopes = [#alias_scope2, #alias_scope3]} : i32, !llvm.ptr // CHECK: load {{.*}}, !alias.scope ![[SCOPES2:[0-9]+]], !noalias ![[SCOPES13:[0-9]+]] %1 = llvm.load %arg1 {alias_scopes = [#alias_scope2], noalias_scopes = [#alias_scope1, #alias_scope3]} : !llvm.ptr -> i32 // CHECK: atomicrmw {{.*}}, !alias.scope ![[SCOPES3:[0-9]+]], !noalias ![[SCOPES12:[0-9]+]] %2 = llvm.atomicrmw add %arg1, %0 monotonic {alias_scopes = [#alias_scope3], noalias_scopes = [#alias_scope1, #alias_scope2]} : !llvm.ptr, i32 // CHECK: cmpxchg {{.*}}, !alias.scope ![[SCOPES3]] %3 = llvm.cmpxchg %arg1, %1, %2 acq_rel monotonic {alias_scopes = [#alias_scope3]} : !llvm.ptr, i32 %5 = llvm.mlir.constant(42 : i8) : i8 // CHECK: llvm.memcpy{{.*}}, !alias.scope ![[SCOPES3]] "llvm.intr.memcpy"(%arg1, %arg1, %0) <{isVolatile = false}> {alias_scopes = [#alias_scope3]} : (!llvm.ptr, !llvm.ptr, i32) -> () // CHECK: llvm.memset{{.*}}, !noalias ![[SCOPES3]] "llvm.intr.memset"(%arg1, %5, %0) <{isVolatile = false}> {noalias_scopes = [#alias_scope3]} : (!llvm.ptr, i8, i32) -> () // CHECK: call void @foo({{.*}} !alias.scope ![[SCOPES3]] llvm.call @foo(%arg1) {alias_scopes = [#alias_scope3]} : (!llvm.ptr) -> () // CHECK: call void @foo({{.*}} !noalias ![[SCOPES3]] llvm.call @foo(%arg1) {noalias_scopes = [#alias_scope3]} : (!llvm.ptr) -> () llvm.return } // Check the intrinsic declarations. // CHECK-DAG: declare void @llvm.experimental.noalias.scope.decl(metadata) // CHECK-DAG: declare void @llvm.memcpy.p0.p0.i32(ptr noalias nocapture writeonly, ptr noalias nocapture readonly, i32, i1 immarg) // CHECK-DAG: declare void @llvm.memset.p0.i32(ptr nocapture writeonly, i8, i32, i1 immarg) // Check the translated metadata. // CHECK-DAG: ![[DOMAIN:[0-9]+]] = distinct !{![[DOMAIN]], !"The domain"} // CHECK-DAG: ![[SCOPE1:[0-9]+]] = distinct !{![[SCOPE1]], ![[DOMAIN]], !"The first scope"} // CHECK-DAG: ![[SCOPE2:[0-9]+]] = distinct !{![[SCOPE2]], ![[DOMAIN]]} // CHECK-DAG: ![[SCOPE3:[0-9]+]] = distinct !{![[SCOPE3]], ![[DOMAIN]]} // CHECK-DAG: ![[SCOPES1]] = !{![[SCOPE1]]} // CHECK-DAG: ![[SCOPES2]] = !{![[SCOPE2]]} // CHECK-DAG: ![[SCOPES3]] = !{![[SCOPE3]]} // CHECK-DAG: ![[SCOPES12]] = !{![[SCOPE1]], ![[SCOPE2]]} // CHECK-DAG: ![[SCOPES13]] = !{![[SCOPE1]], ![[SCOPE3]]} // CHECK-DAG: ![[SCOPES23]] = !{![[SCOPE2]], ![[SCOPE3]]} // ----- // This test verifies the noalias scope intrinsice can be translated in // isolation. It is the only operation using alias scopes attributes without // implementing AliasAnalysisOpInterface. #alias_scope_domain = #llvm.alias_scope_domain, description = "The domain"> #alias_scope1 = #llvm.alias_scope, domain = #alias_scope_domain> // CHECK-LABEL: @noalias_intr_only llvm.func @noalias_intr_only(%arg1 : !llvm.ptr) { %0 = llvm.mlir.constant(0 : i32) : i32 // CHECK: call void @llvm.experimental.noalias.scope.decl(metadata ![[SCOPES1:[0-9]+]]) llvm.intr.experimental.noalias.scope.decl #alias_scope1 llvm.return } // Check the translated metadata. // CHECK-DAG: ![[DOMAIN:[0-9]+]] = distinct !{![[DOMAIN]], !"The domain"} // CHECK-DAG: ![[SCOPE1:[0-9]+]] = distinct !{![[SCOPE1]], ![[DOMAIN]]} // CHECK-DAG: ![[SCOPES1]] = !{![[SCOPE1]]}