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

[CIR] Remove also the !cir.void return type from the textual IR #1249

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

keryell
Copy link
Collaborator

@keryell keryell commented Dec 19, 2024

This is the second phase of #1203, as the first phase has demonstrated that fixing the IR to avoid breaking an MLIR invariant can work.
Now, to avoid adding a new feature in the MLIR parser infrastructure, we change the way CIR IR textual representation is done by removing also !void or !cir.void in the function return types to just follow the normal way the other dialects work to represent function types.
See #1203 (comment) for more context.

@bcardosolopes
Copy link
Member

Hi @keryell, I missed this cause I usually don't go over draft PRs! Does this commit only reverts the original one or does it add anything else on top? I'm a bit confused by the description.

@bcardosolopes bcardosolopes marked this pull request as ready for review January 7, 2025 18:07
@keryell
Copy link
Collaborator Author

keryell commented Jan 8, 2025

I first reverted the original PR and I am still working on a good solution.
I got distracted by vacations 😄 and llvm/llvm-project#76337 since I am tweaking the CIR type .td file.

C/C++ functions returning void had an explicit !cir.void return type while not
having any returned value, which was breaking a lot of MLIR invariants when the
CIR dialect is used in a greater context, for example with the inliner.

Now, a C/C++ function returning void has no return type and no return values,
which does not break the MLIR invariant about the same number of return types
and returned values.

This change does not keeps the same parsing/pretty-printed syntax as before for
compatibility like in llvm#1203 because it
requires some new features from the MLIR parser infrastructure itself, which is
not great.

For now use a list of return types.
@keryell keryell force-pushed the ronan/remove-void-from-textual-IR branch from aa71766 to afde518 Compare January 8, 2025 17:25
@bcardosolopes
Copy link
Member

Can we have a PR that just reverts your previous solution? This might be easier to deal with next time we rebase. Another PR (or this one) can then reintroduce all the work without the MLIR bits?

@keryell
Copy link
Collaborator Author

keryell commented Jan 9, 2025

Can we have a PR that just reverts your previous solution? This might be easier to deal with next time we rebase. Another PR (or this one) can then reintroduce all the work without the MLIR bits?

Sure. I made #1276

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.

2 participants