Skip to content

Conversation

dkolsen-pgi
Copy link
Collaborator

Change the assembly format for cir::FuncType from

!cir.func<!returnType (!argType)>

to

!cir.func<(!argType) -> !returnType>

This change (1) is easier to parse because it doesn't require lookahead, (2) is consistent with the format of ClangIR FuncOp assembly, and (3) is consistent with function types in other MLIR dialects.

Change all the tests to use or to expect the new format for function types.

The contents and the semantics of cir::FuncType are unchanged. Only the assembly format is being changed. Functions that return void in C or C++ are still represented in MLIR as having no return type.

Most of the changes are in parseFuncType and printFuncType and the functions they call in CIRTypes.cpp.

A FuncType::verify function was added to check that an explicit return type is not cir::VoidType.

FuncType::isVoid() was renamed to FuncType::hasVoidReturn()

Some comments for FuncType were improved.

An llvm_unreachable was added to StructType::getKindAsStr to suppress a compiler warning and to catch a memory error that corrupts the RecordKind field. (This was a drive-by fix and has nothing to do with the rest of this change.)

Change the assembly format for `cir::FuncType` from
```
!cir.func<!returnType (!argType)>
```
to
```
!cir.func<(!argType) -> !returnType>
```

This change (1) is easier to parse because it doesn't require lookahead,
(2) is consistent with the format of ClangIR `FuncOp` assembly, and
(3) is consistent with function types in other MLIR dialects.

Change all the tests to use or to expect the new format for function
types.

The contents and the semantics of `cir::FuncType` are unchanged.  Only
the assembly format is being changed.  Functions that return `void` in C
or C++ are still represented in MLIR as having no return type.

Most of the changes are in `parseFuncType` and `printFuncType` and the
functions they call in `CIRTypes.cpp`.

A `FuncType::verify` function was added to check that an explicit return
type is not `cir::VoidType`.

`FuncType::isVoid()` was renamed to `FuncType::hasVoidReturn()`

Some comments for `FuncType` were improved.

An `llvm_unreachable` was added to `StructType::getKindAsStr` to
suppress a compiler warning and to catch a memory error that corrupts
the `RecordKind` field.  (This was a drive-by fix and has nothing to do
with the rest of this change.)
@dkolsen-pgi
Copy link
Collaborator Author

I considered renaming FuncType::getReturnType and FuncType::getReturnTypes so that the difference between them was more clear. But I struggled to find the right names. So instead I just made the documentation for those functions more clear.

Copy link
Collaborator

@andykaylor andykaylor left a comment

Choose a reason for hiding this comment

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

lgtm

Copy link
Member

@bcardosolopes bcardosolopes left a comment

Choose a reason for hiding this comment

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

LGTM pending one nit

@bcardosolopes bcardosolopes merged commit af9a39d into llvm:main Feb 24, 2025
6 checks passed
Copy link
Collaborator

@keryell keryell left a comment

Choose a reason for hiding this comment

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

Thanks!


/// Returns whether the function returns void.
bool isVoid() const;
/// Does the fuction type return nothing?
Copy link
Collaborator

Choose a reason for hiding this comment

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

s/fuction/function/ for the next PR.

lanza pushed a commit that referenced this pull request Mar 18, 2025
Change the assembly format for `cir::FuncType` from
```
!cir.func<!returnType (!argType)>
```
to
```
!cir.func<(!argType) -> !returnType>
```

This change (1) is easier to parse because it doesn't require lookahead,
(2) is consistent with the format of ClangIR `FuncOp` assembly, and (3)
is consistent with function types in other MLIR dialects.

Change all the tests to use or to expect the new format for function
types.

The contents and the semantics of `cir::FuncType` are unchanged. Only
the assembly format is being changed. Functions that return `void` in C
or C++ are still represented in MLIR as having no return type.

Most of the changes are in `parseFuncType` and `printFuncType` and the
functions they call in `CIRTypes.cpp`.

A `FuncType::verify` function was added to check that an explicit return
type is not `cir::VoidType`.

`FuncType::isVoid()` was renamed to `FuncType::hasVoidReturn()`

Some comments for `FuncType` were improved.

An `llvm_unreachable` was added to `StructType::getKindAsStr` to
suppress a compiler warning and to catch a memory error that corrupts
the `RecordKind` field. (This was a drive-by fix and has nothing to do
with the rest of this change.)
terapines-osc-cir pushed a commit to Terapines/clangir that referenced this pull request Sep 2, 2025
Change the assembly format for `cir::FuncType` from
```
!cir.func<!returnType (!argType)>
```
to
```
!cir.func<(!argType) -> !returnType>
```

This change (1) is easier to parse because it doesn't require lookahead,
(2) is consistent with the format of ClangIR `FuncOp` assembly, and (3)
is consistent with function types in other MLIR dialects.

Change all the tests to use or to expect the new format for function
types.

The contents and the semantics of `cir::FuncType` are unchanged. Only
the assembly format is being changed. Functions that return `void` in C
or C++ are still represented in MLIR as having no return type.

Most of the changes are in `parseFuncType` and `printFuncType` and the
functions they call in `CIRTypes.cpp`.

A `FuncType::verify` function was added to check that an explicit return
type is not `cir::VoidType`.

`FuncType::isVoid()` was renamed to `FuncType::hasVoidReturn()`

Some comments for `FuncType` were improved.

An `llvm_unreachable` was added to `StructType::getKindAsStr` to
suppress a compiler warning and to catch a memory error that corrupts
the `RecordKind` field. (This was a drive-by fix and has nothing to do
with the rest of this change.)
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