GCC 15 Adds Option For Arm Guarded Control Stack "GCS" Code Generation
- Reference: 0001505956
- News link: https://www.phoronix.com/news/GCC-15-Arm-GCS-Code-Generation
- Source link:
Arm introduced Guarded Control Stack with their 2022 CPU extensions and is a means of helping mitigate against some return object programming (ROP) attacks. As explained in the [3]Arm documentation :
"A GCS is a protected region of virtual address space allocated by software. When the processor executes a Branch with Link instruction, such as BL, the return address is pushed onto the GCS as well as being written into the Link Register (LR). On a procedure return, the latest stored return address is popped from the GCS. The processor either compares the popped value with the LR, or uses the popped value directly...To prevent accidental or malicious changes to the GCS, a new Stage 1 permission is introduced. This permission allows reads by software, but restricts writes to either GCSPUSH instructions or as a side-effect of executing a BL."
With the latest GCC patches merged on Thursday, there is now a "-mbranch-protection=gcs" option supported. This enables Arm Guarded Control Stack compatible code generation. This branch protection option is the same one that can also be set to Branch Target Identification "BTI" for earlier Arm processors.
The -mbranch-protection=gcs option is introduced via [4]this commit while related Arm GCS patches were also merged on Thursday and will all be part of the upcoming GCC 15.1 release.
[1] https://www.phoronix.com/search/GCC+15
[2] https://www.phoronix.com/news/GCC-15-Stage-1-Ends-November
[3] https://community.arm.com/arm-community-blogs/b/architectures-and-processors-blog/posts/arm-a-profile-architecture-2022
[4] https://gcc.gnu.org/git/?p=gcc.git;a=commitdiff;h=56ded80b96b0f65327694912a6affbfc75e4e30d
phoronix