This is an archive of the discontinued LLVM Phabricator instance.

[mlir][LLVM-IR] Added support for global variable attributes
ClosedPublic

Authored by shraiysh on Apr 8 2022, 10:34 AM.

Details

Summary

This patch adds thread_local to llvm.mlir.global and adds translation for dso_local and addr_space to and from LLVM IR.

Diff Detail

Event Timeline

shraiysh created this revision.Apr 8 2022, 10:34 AM
Herald added a project: Restricted Project. · View Herald Transcript
shraiysh requested review of this revision.Apr 8 2022, 10:34 AM
rriddle added inline comments.Apr 8 2022, 11:31 AM
mlir/include/mlir/Dialect/LLVMIR/LLVMOps.td
1004

Can we just do thread_local? I don't see a big benefit in shrinking it.

Can you also add a test for the importing from LLVM IR?

shraiysh updated this revision to Diff 421828.Apr 10 2022, 9:31 PM

Added test for importing from LLVM IR.

mlir/include/mlir/Dialect/LLVMIR/LLVMOps.td
1004

It is a keyword in C++ and causes compilation issues with the generated builders. Is there a way to give a custom name of the argument to the autogenerated builder without changing the name of unit attribute in MLIR?

zero9178 added inline comments.
mlir/lib/Target/LLVMIR/ConvertFromLLVMIR.cpp
438 ↗(On Diff #421828)

I know that just like dsoLocal, this wasn't done previously, but this should set the address space from the global variable as well while we are at it, not default it to 0.

shraiysh updated this revision to Diff 421885.Apr 11 2022, 5:30 AM

Added address_space handling too.

shraiysh retitled this revision from [mlir][LLVM-IR] Added support for thread_local to [mlir][LLVM-IR] Added support for global variable attributes.Apr 11 2022, 5:31 AM
shraiysh edited the summary of this revision. (Show Details)
Mogball added inline comments.Apr 11 2022, 9:52 AM
mlir/lib/Dialect/LLVMIR/IR/LLVMDialect.cpp
1605 ↗(On Diff #421885)

These should be getThrLocalAttrName(result.name) (if LLVM Dialect has been switched to prefixed)

shraiysh added inline comments.Apr 12 2022, 2:04 AM
mlir/lib/Dialect/LLVMIR/IR/LLVMDialect.cpp
1605 ↗(On Diff #421885)

I don't think this is an autogenerated function. Also, it isn't clear to me what this function is supposed to do. There are some functions here. Are you referring to a similar function for "thr_local"? If yes, why the result.name argument? An example usage from the tree would be helpful.

mehdi_amini added inline comments.Apr 12 2022, 2:20 AM
mlir/include/mlir/Dialect/LLVMIR/LLVMOps.td
1004

We should fix ODS backend to handle the keyword, where does it cause an issue?

shraiysh added inline comments.Apr 12 2022, 2:49 AM
mlir/include/mlir/Dialect/LLVMIR/LLVMOps.td
1004

The argument name here (thread_local) is taken as-is while putting in builder declarations and definitions. This causes compilation error because thread_local is a C++ keyword too. A solution to this would be to convert all argument names to camel-case with the first letter capitalized before using them as builder arguments. Another solution would be to prefix/suffix them with something. Currently, the generated builder signature is -

build(..., bool thread_local, ...)
//                   ^ compilation error.
ftynse added inline comments.Apr 12 2022, 2:59 AM
mlir/include/mlir/Dialect/LLVMIR/LLVMOps.td
1004

How about $thread_local_ ? We already have precedent with $volatile_ in this dialect.

There is a switch that makes us generate accessors in camel case,getThreadLocal, but it works at the level of the dialect. We should switch it eventually, but it will create churn across the code base.

mlir/lib/Dialect/LLVMIR/IR/LLVMDialect.cpp
1605 ↗(On Diff #421885)

It is an autogenerated function, and I see similar functions for different attributes in build/tools/mlir/include/mlir/Dialect/LLVMIR/LLVMOps.h.inc. result.name is necessary to access the proper part of the storage in the registry for a yet unconstructed operation (once constructed, it will be possible to call the function without it because the OperationName can be obtained from an instance of Operation *).

We shouldn't be using magic strings in the code.

shraiysh updated this revision to Diff 422207.Apr 12 2022, 6:15 AM

Removed uses of magic strings.

Mogball accepted this revision.Apr 12 2022, 9:39 AM
This revision is now accepted and ready to land.Apr 12 2022, 9:39 AM
mehdi_amini added inline comments.Apr 12 2022, 2:51 PM
mlir/include/mlir/Dialect/LLVMIR/LLVMOps.td
1004

There is a switch that makes us generate accessors in camel case,getThreadLocal,

It is already the case for this dialect, we need to handle variable names as well apparently.

This revision was landed with ongoing or failed builds.Apr 12 2022, 8:01 PM
This revision was automatically updated to reflect the committed changes.