Skip to content

[AArch64] Add overflow check for R_AARCH64_ADR_PREL_PG_HI21#1330

Draft
Shankar Easwaran (quic-seaswara) wants to merge 1 commit into
mainfrom
R_AARCH64_ADR_PREL_PG_HI21_overflow
Draft

[AArch64] Add overflow check for R_AARCH64_ADR_PREL_PG_HI21#1330
Shankar Easwaran (quic-seaswara) wants to merge 1 commit into
mainfrom
R_AARCH64_ADR_PREL_PG_HI21_overflow

Conversation

@quic-seaswara

Copy link
Copy Markdown
Contributor

The ADRP instruction encodes (PG(S+A) - PG(P)) >> 12 in a 21-bit signed immediate field. Add a signed 21-bit range check for R_AARCH64_ADR_PREL_PG_HI21; the _NC (no-check) variant intentionally skips the check.

Add a lit test that verifies a link within range succeeds and a link that overflows the 21-bit field is caught with an overflow diagnostic.

The ADRP instruction encodes (PG(S+A) - PG(P)) >> 12 in a 21-bit signed
immediate field. Add a signed 21-bit range check for R_AARCH64_ADR_PREL_PG_HI21;
the _NC (no-check) variant intentionally skips the check.

Add a lit test that verifies a link within range succeeds and a link
that overflows the 21-bit field is caught with an overflow diagnostic.

Fixes #1329

Signed-off-by: Shankar Easwaran <seaswara@qti.qualcomm.com>
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