Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

jl-generators.cpp changes #447

Draft
wants to merge 11 commits into
base: main
Choose a base branch
from

Conversation

glou-nes
Copy link
Contributor

@glou-nes glou-nes commented Jan 1, 2025

@jumerckx, sorry for the formatting.

I try to implement features in JuliaLLVM/TableGen.jl#1 in C++
I implement several ideas :

  • renaming result_ to result
  • apply the typing defining in args, for instance: result_layouts=nothing::Union{Attribute, Nothing} doesn't constraint result_layouts so change to : result_layouts::Union{Attribute, Nothing} =nothing
  • create Julia enum for EnumAttr : using Attr parsing (MLIR doesn't expose methods in C to easily construct arbitrary attribute) and discriminant.
  • typing Attribute and use Julia type for easy ones (Int, Float, Vector).
  • more complex Attributes ("struct" layout) such as conv

@jumerckx
Copy link
Collaborator

jumerckx commented Jan 1, 2025

This is super cool!!!

sorry for the formatting.

My bad, the file should've been properly formatted in the first place 😅.

I've done a quick review and this is clearly a strict improvement over what we had.
I imagine the next step would be to update dialect calls throughout the project? If you want I can try help out with that.

@glou-nes
Copy link
Contributor Author

glou-nes commented Jan 1, 2025

This is super cool!!!

sorry for the formatting.

My bad, the file should've been properly formatted in the first place 😅.

I've done a quick review and this is clearly a strict improvement over what we had. I imagine the next step would be to update dialect calls throughout the project? If you want I can try help out with that.

@jumerckx I think so, an other interesting part can be to handle "struct" attr, the C part is not exposed for all dialect, so using parse can be doable here. I try to get rid of parsing and build attribute directly from data with not much success (anyway parse is probably not the heaviest operation atm), Do you have experience with attribute internals? I don't know if we want to do all the attribute change directly or doing enum/simple one firstly and "struct" one after. Do you have ideas here?

@jumerckx
Copy link
Collaborator

jumerckx commented Jan 3, 2025

I try to get rid of parsing and build attribute directly from data with not much success (anyway parse is probably not the heaviest operation atm)

When I wrote the original generator, I asked around on the MLIR discord and the conclusion was that this was impossible using the C API.
I agree using parse seems the way to go for now, the struct stuff looks very cool already!

@glou-nes
Copy link
Contributor Author

glou-nes commented Jan 3, 2025

I try to get rid of parsing and build attribute directly from data with not much success (anyway parse is probably not the heaviest operation atm)

When I wrote the original generator, I asked around on the MLIR discord and the conclusion was that this was impossible using the C API. I agree using parse seems the way to go for now, the struct stuff looks very cool already!

Thank for the confirmation, my idea was to add a C API in ReactantExtra to manually create custom attributes. The parsing work for almost all attributes: the few ones left are not specialized and here a generic IR.Attribute must be provided.

@jumerckx
Copy link
Collaborator

jumerckx commented Jan 3, 2025

The parsing work for almost all attributes:

Would a custom CAPI extension help with this? I imagine not but might be misunderstanding.

What happens with attribute values that don't have a corresponding Julia type that can be used in the struct? Does it fallback to ::String fields in the struct then, or is this a case where a generic IR.Attribute has to be provided?

@glou-nes
Copy link
Contributor Author

glou-nes commented Jan 3, 2025

The parsing work for almost all attributes:

Would a custom CAPI extension help with this? I imagine not but might be misunderstanding.

What happens with attribute values that don't have a corresponding Julia type that can be used in the struct? Does it fallback to ::String fields in the struct then, or is this a case where a generic IR.Attribute has to be provided?

generic IR.Attribute in this case, an example of that with VHLO_DictionaryAttrV1 and the Parameter : ArrayRefParameter<"std::pair<mlir::Attribute, mlir::Attribute>"> . I suppose it's better to get the generic option, because that kind of parameters have probably custom/complex parsing logic.

{"bool", "Bool"},
{"unsigned", "Int"},
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this should be UInt

@glou-nes
Copy link
Contributor Author

glou-nes commented Jan 9, 2025

@jumerckx I think I have a clean version of this here, the logic is much more sane now; this get support for almost all attributes (AffineMapAttr is an exception but I don't know exactly how to add support to it). Do you think these changes are good enough / need more features? Next is probably to get all the testbench running.

@jumerckx
Copy link
Collaborator

jumerckx commented Jan 9, 2025

Do you think these changes are good enough / need more features?

For sure, maybe others have more specific wishes but this is huge already.

Next is probably to get all the testbench running.

Let me know if/where I can make myself useful by helping out!

MLIR.jl is currently being neglected a bit, but in due time we could upstream these bindings to there as well? (or maybe split out and move to Tablegen.jl) @mofeing probably has thoughts on this as well.

@glou-nes
Copy link
Contributor Author

glou-nes commented Jan 9, 2025

Let me know if/where I can make myself useful by helping out!

Sure, I want to get basic.jl testbench running firstly, If you want you can check to see if the generation is good with the new Dialects, I haven't check them at all.

@mofeing
Copy link
Collaborator

mofeing commented Jan 9, 2025

MLIR.jl is currently being neglected a bit, but in due time we could upstream these bindings to there as well? (or maybe split out and move to Tablegen.jl) @mofeing probably has thoughts on this as well.

yeah, it could be great if we could upstream things slowly.

although it's not a priority so no problem if you don't have the time.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants