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

[AArch64] Lower ptrauth.sign of constant as PtrAuthGlobalAddress. #133788

Draft
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

ahmedbougacha
Copy link
Member

This lets us guarantee the emission of one of our hardened constant signed pointer materialization sequences, rather than emitting the sign intrinsic as a naked sign, and exposing the raw pointer.

Do that in the builder to help guarantee that through the backend.

At the IR level, there aren't great ways to enforce that the constant operand to the intrinsic stays there, but we might be able to do that by generalizing immarg to be applicable to callsites rather than just Intrinsic definitions. That's all theoretical either way, and there's rarely a good reason to hoist a constant op from an intrinsic anyway.

This is pretty tolerant of weird discriminators, which should cover the interesting cases.

This lets us guarantee the emission of one of our hardened constant
signed pointer materialization sequences, rather than emitting the
sign intrinsic as a naked sign, and exposing the raw pointer.

Do that in the builder to help guarantee that through the backend.

At the IR level, there aren't great ways to enforce that the constant
operand to the intrinsic stays there, but we might be able to do that
by generalizing immarg to be applicable to callsites rather than just
Intrinsic definitions.  That's all theoretical either way, and there's
rarely a good reason to hoist a constant op from an intrinsic anyway.

This is pretty tolerant of weird discriminators, which should cover the
interesting cases.
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.

1 participant