blob: 5f578a382a668e9e0ba11cfc2210603cb6442f54 [file] [edit]
// RUN: mlir-opt %s -split-input-file --verify-roundtrip | FileCheck %s
llvm.func internal @callee() -> !llvm.ptr attributes {dso_local} {
%0 = llvm.mlir.zero : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
llvm.mlir.alias external @foo_alias : !llvm.ptr {
%0 = llvm.mlir.addressof @callee : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
llvm.mlir.alias external @_ZTV1D : !llvm.struct<(array<3 x ptr>)> {
%0 = llvm.mlir.addressof @callee : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
// CHECK: llvm.mlir.alias external @foo_alias : !llvm.ptr {
// CHECK: %[[ADDR:.*]] = llvm.mlir.addressof @callee : !llvm.ptr
// CHECK: llvm.return %[[ADDR]] : !llvm.ptr
// CHECK: }
// CHECK: llvm.mlir.alias external @_ZTV1D : !llvm.struct<(array<3 x ptr>)> {
// CHECK: %[[ADDR:.*]] = llvm.mlir.addressof @callee : !llvm.ptr
// CHECK: llvm.return %[[ADDR]] : !llvm.ptr
// CHECK: }
// -----
llvm.mlir.global weak_odr @zed(42 : i32) : i32
llvm.mlir.alias weak_odr @foo : i32 {
%0 = llvm.mlir.addressof @zed : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
llvm.mlir.alias weak_odr @foo2 : i16 {
%0 = llvm.mlir.addressof @zed : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
// CHECK: llvm.mlir.alias weak_odr @foo : i32 {
// CHECK: %[[ADDR:.*]] = llvm.mlir.addressof @zed : !llvm.ptr
// CHECK: llvm.return %[[ADDR]] : !llvm.ptr
// CHECK: }
// CHECK: llvm.mlir.alias weak_odr @foo2 : i16 {
// CHECK: %[[ADDR:.*]] = llvm.mlir.addressof @zed : !llvm.ptr
// CHECK: llvm.return %[[ADDR]] : !llvm.ptr
// CHECK: }
// -----
llvm.mlir.global private constant @glob.private(dense<0> : tensor<32xi32>) : !llvm.array<32 x i32>
llvm.mlir.alias linkonce_odr hidden @glob {dso_local} : !llvm.array<32 x i32> {
%0 = llvm.mlir.constant(1234 : i64) : i64
%1 = llvm.mlir.addressof @glob.private : !llvm.ptr
%2 = llvm.ptrtoint %1 : !llvm.ptr to i64
%3 = llvm.add %2, %0 : i64
%4 = llvm.inttoptr %3 : i64 to !llvm.ptr
llvm.return %4 : !llvm.ptr
}
// CHECK: llvm.mlir.global private constant @glob.private(dense<0> : tensor<32xi32>)
// CHECK: llvm.mlir.alias linkonce_odr hidden @glob {dso_local} : !llvm.array<32 x i32> {
// CHECK: %[[CST:.*]] = llvm.mlir.constant(1234 : i64) : i64
// CHECK: %[[ADDR:.*]] = llvm.mlir.addressof @glob.private : !llvm.ptr
// CHECK: %[[INTADDR:.*]] = llvm.ptrtoint %[[ADDR]] : !llvm.ptr to i64
// CHECK: %[[BACKTOPTR:.*]] = llvm.add %[[INTADDR]], %[[CST]] : i64
// CHECK: %[[RET_ADDR:.*]] = llvm.inttoptr %[[BACKTOPTR]] : i64 to !llvm.ptr
// CHECK: llvm.return %[[RET_ADDR]] : !llvm.ptr
// CHECK: }
// -----
llvm.mlir.global external @v1(0 : i32) : i32
llvm.mlir.alias external @a3 : i32 {
%0 = llvm.mlir.addressof @v1 : !llvm.ptr
%1 = llvm.addrspacecast %0 : !llvm.ptr to !llvm.ptr<2>
llvm.return %1 : !llvm.ptr<2>
}
// CHECK: llvm.mlir.alias external @a3 : i32 {
// CHECK: %[[ADDR:.*]] = llvm.mlir.addressof @v1 : !llvm.ptr
// CHECK: %1 = llvm.addrspacecast %[[ADDR]] : !llvm.ptr to !llvm.ptr<2>
// CHECK: llvm.return %1 : !llvm.ptr<2>
// CHECK: }
// -----
llvm.mlir.global private @g1(0 : i32) {dso_local} : i32
llvm.mlir.alias private @a1 {dso_local} : i32 {
%0 = llvm.mlir.addressof @g1 : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
llvm.mlir.global internal constant @g2() : !llvm.ptr {
%0 = llvm.mlir.addressof @a1 : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
llvm.mlir.alias private @a2 {dso_local} : !llvm.ptr {
%0 = llvm.mlir.addressof @a1 : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
llvm.mlir.global internal constant @g3() : !llvm.ptr {
%0 = llvm.mlir.addressof @a2 : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
// CHECK: llvm.mlir.alias private @a1 {dso_local} : i32 {
// CHECK: %[[ADDR:.*]] = llvm.mlir.addressof @g1 : !llvm.ptr
// CHECK: llvm.return %[[ADDR]] : !llvm.ptr
// CHECK: }
// CHECK: llvm.mlir.global internal constant @g2()
// CHECK: %[[ADDR:.*]] = llvm.mlir.addressof @a1 : !llvm.ptr
// CHECK: llvm.return %[[ADDR]] : !llvm.ptr
// CHECK: }
// CHECK: llvm.mlir.alias private @a2 {dso_local} : !llvm.ptr {
// CHECK: %[[ADDR:.*]] = llvm.mlir.addressof @a1 : !llvm.ptr
// CHECK: llvm.return %[[ADDR]] : !llvm.ptr
// CHECK: }
// CHECK: llvm.mlir.global internal constant @g3()
// CHECK: %[[ADDR:.*]] = llvm.mlir.addressof @a2 : !llvm.ptr
// CHECK: llvm.return %[[ADDR]] : !llvm.ptr
// CHECK: }
// -----
llvm.mlir.global private @g30(0 : i32) {dso_local} : i32
llvm.mlir.alias private thread_local unnamed_addr @a30 {dso_local} : i32 {
%0 = llvm.mlir.addressof @g30 : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
// CHECK: llvm.mlir.alias private thread_local unnamed_addr @a30 {dso_local} : i32 {
// CHECK: %0 = llvm.mlir.addressof @g30 : !llvm.ptr
// CHECK: llvm.return %0 : !llvm.ptr
// CHECK: }
// -----
// Test that llvm.call and llvm.invoke can use an alias as the callee.
llvm.func @aliased_func() {
llvm.return
}
llvm.mlir.alias external @func_alias {addr_space = 0 : i32} : !llvm.ptr {
%0 = llvm.mlir.addressof @aliased_func : !llvm.ptr
llvm.return %0 : !llvm.ptr
}
llvm.func @caller() {
llvm.call @func_alias() : () -> ()
llvm.return
}
// CHECK-LABEL: llvm.func @caller()
// CHECK: llvm.call @func_alias() : () -> ()