[llvm] [mlir] [mlir][EmitC] Add MathToEmitC pass for math function lowering to EmitC (PR #113799)
Tomer Solomon via llvm-commits
llvm-commits at lists.llvm.org
Tue Nov 5 23:41:31 PST 2024
================
@@ -62,4 +62,13 @@ def EmitC_OpaqueAttr : EmitC_Attr<"Opaque", "opaque"> {
def EmitC_OpaqueOrTypedAttr : AnyAttrOf<[EmitC_OpaqueAttr, TypedAttrInterface]>;
+def MathToEmitCLanguageTarget : I32EnumAttr<"MathToEmitCLanguageTarget",
+ "Specifies the language target for generating callees.", [
+ I32EnumAttrCase<"C", 0, "Use C-style function names">,
+ I32EnumAttrCase<"CPP", 1, "Use C++-style function names">
+ ]> {
+ let cppNamespace = "::mlir::emitc";
+}
----------------
recursion-man wrote:
@marbre, thanks for the input.
I noticed that **ConvertSPIRVToLLVMPass** relies on a custom Option for **ClientAPI** defined in **SPIRVBase.td**, which is similar to what I’m aiming for here. Additionally, **include/mlir/Dialect/ArmSME/Transforms/Passes.td** defines attributes directly in its passes file but includes **mlir/IR/EnumAttr.td**, going beyond the usual **Conversion/Passes.td** convention to include only **mlir/Pass/PassBase.td**.
At this point, defining the attribute in **EmitCBase.td** or **EmitCAttributes.td** seems like the only alternative I can think of. What are your thoughts?
I also agree with your point on keeping this PR focused without adding too much at once. Further ideas we discussed can be part of future work.
https://github.com/llvm/llvm-project/pull/113799
More information about the llvm-commits
mailing list