diff --git a/mlir/include/mlir/Dialect/LLVMIR/LLVMIntrinsicOps.td b/mlir/include/mlir/Dialect/LLVMIR/LLVMIntrinsicOps.td --- a/mlir/include/mlir/Dialect/LLVMIR/LLVMIntrinsicOps.td +++ b/mlir/include/mlir/Dialect/LLVMIR/LLVMIntrinsicOps.td @@ -312,6 +312,11 @@ let assemblyFormat = "$val `,` $expected `,` $prob attr-dict `:` type($val)"; } +def LLVM_ThreadlocalAddress : LLVM_OneResultIntrOp<"threadlocal.address", [], + [0], [Pure]> { + let arguments = (ins LLVM_AnyPointer:$global); +} + // // Coroutine intrinsics. // diff --git a/mlir/test/Target/LLVMIR/Import/intrinsic.ll b/mlir/test/Target/LLVMIR/Import/intrinsic.ll --- a/mlir/test/Target/LLVMIR/Import/intrinsic.ll +++ b/mlir/test/Target/LLVMIR/Import/intrinsic.ll @@ -547,6 +547,13 @@ ret void } +; CHECK-LABEL: llvm.func @threadlocal_test +define void @threadlocal_test(ptr %0) { + ; CHECK: "llvm.intr.threadlocal.address"(%{{.*}}) : (!llvm.ptr) -> !llvm.ptr + %local = call ptr @llvm.threadlocal.address.p0(ptr %0) + ret void +} + ; CHECK-LABEL: llvm.func @coro_id define void @coro_id(i32 %0, ptr %1) { ; CHECK: llvm.intr.coro.id %{{.*}}, %{{.*}}, %{{.*}}, %{{.*}} : (i32, !llvm.ptr, !llvm.ptr, !llvm.ptr) -> !llvm.token @@ -869,6 +876,7 @@ declare i1 @llvm.is.constant.i32(i32) declare i32 @llvm.expect.i32(i32, i32) declare i16 @llvm.expect.with.probability.i16(i16, i16, double immarg) +declare nonnull ptr @llvm.threadlocal.address.p0(ptr nonnull) declare token @llvm.coro.id(i32, ptr readnone, ptr nocapture readonly, ptr) declare ptr @llvm.coro.begin(token, ptr writeonly) declare i64 @llvm.coro.size.i64() diff --git a/mlir/test/Target/LLVMIR/llvmir-intrinsics.mlir b/mlir/test/Target/LLVMIR/llvmir-intrinsics.mlir --- a/mlir/test/Target/LLVMIR/llvmir-intrinsics.mlir +++ b/mlir/test/Target/LLVMIR/llvmir-intrinsics.mlir @@ -489,6 +489,13 @@ llvm.return } +// CHECK-LABEL: @threadlocal_test +llvm.func @threadlocal_test(%arg0 : !llvm.ptr) { + // CHECK: call ptr @llvm.threadlocal.address.p0(ptr %{{.*}}) + "llvm.intr.threadlocal.address"(%arg0) : (!llvm.ptr) -> !llvm.ptr + llvm.return +} + // CHECK-LABEL: @sadd_sat_test llvm.func @sadd_sat_test(%arg0: i32, %arg1: i32, %arg2: vector<8xi32>, %arg3: vector<8xi32>) { // CHECK: call i32 @llvm.sadd.sat.i32 @@ -906,6 +913,7 @@ // CHECK-DAG: declare i1 @llvm.is.constant.i32(i32) // CHECK-DAG: declare i32 @llvm.expect.i32(i32, i32) // CHECK-DAG: declare i16 @llvm.expect.with.probability.i16(i16, i16, double immarg) +// CHECK-DAG: declare nonnull ptr @llvm.threadlocal.address.p0(ptr nonnull) // CHECK-DAG: declare token @llvm.coro.id(i32, ptr readnone, ptr nocapture readonly, ptr) // CHECK-DAG: declare ptr @llvm.coro.begin(token, ptr writeonly) // CHECK-DAG: declare i64 @llvm.coro.size.i64()