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

[SYCL] Change SPIR-V Enum token type from unsigned int to int for groups builtins #17445

Merged

Conversation

wenju-he
Copy link
Contributor

Motivation is the same as PR #17438, i.e. unifying SPIR-V builtin mangling to enhance SYCL AOT support for backend targets that bypass SPIR-V generation.

…ups builtins

Motivation is the same as PR intel#17438, i.e. unifying SPIR-V builtin
mangling to enhance SYCL AOT support for backend targets that bypass
SPIR-V generation.
@wenju-he wenju-he requested review from a team as code owners March 13, 2025 09:42
@wenju-he wenju-he requested a review from steffenlarsen March 13, 2025 09:42
Copy link
Contributor

@steffenlarsen steffenlarsen left a comment

Choose a reason for hiding this comment

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

Overall I'm alright with these changes, but we need to avoid the ABI break.

Copy link
Contributor

@Naghasan Naghasan left a comment

Choose a reason for hiding this comment

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

LGTM apart from the ABI break

Copy link
Contributor

@steffenlarsen steffenlarsen left a comment

Choose a reason for hiding this comment

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

👍

@wenju-he wenju-he requested a review from hvdijk March 18, 2025 04:32
@wenju-he
Copy link
Contributor Author

kindly ping @intel/dpcpp-cfe-reviewers for review

def : SPVBuiltin<name, [Event, UInt, PointerType<AGenTypeN, GlobalAS>, PointerType<ConstType<AGenTypeN>, LocalAS>, Size, Size, Event], Attr.Convergent>;
// TODO: Allow enum flags instead of Int ?
// TODO: We should enforce that the Int must be a literal.
def : SPVBuiltin<name,
Copy link
Contributor

Choose a reason for hiding this comment

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

Same as in #17438 (comment) , should we have a test checking that clang emits correct signature and mangling for the builtin in the IR?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

thanks @Fznamznon
done in bc42ed1

Copy link
Contributor

@frasercrmck frasercrmck left a comment

Choose a reason for hiding this comment

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

libclc LGTM

@wenju-he wenju-he requested a review from Fznamznon March 19, 2025 10:40
Copy link
Contributor

@Fznamznon Fznamznon left a comment

Choose a reason for hiding this comment

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

Thanks!

@hvdijk
Copy link
Contributor

hvdijk commented Mar 21, 2025

Heads up that there will be a trivially resolved conflict between this and #17570. I can wait a little bit for your PR to go in first, and then update mine, or I can get mine in first and then you can update, whichever you prefer so long as we don't both end up waiting on the other one to merge first. :)

@wenju-he
Copy link
Contributor Author

Thanks @hvdijk, either way is fine for me. :)

@intel/llvm-gatekeepers please merge, thanks.

@martygrant martygrant merged commit 19f3039 into intel:sycl Mar 24, 2025
44 of 46 checks passed
@wenju-he wenju-he deleted the group-builtin-spirv-token-unsigned-to-signed branch March 24, 2025 21:05
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.

7 participants