-
Notifications
You must be signed in to change notification settings - Fork 745
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[llvm][ARM][AArch64] Add attributes to synthetic functions. (#83153)
Module flags represent the original intention. Depends on #82819 Reland as it was but reland needed as dependent patch relanded.
- Loading branch information
1 parent
e464684
commit 4dcd9d2
Showing
3 changed files
with
95 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
33 changes: 33 additions & 0 deletions
33
llvm/test/Instrumentation/AddressSanitizer/module-flags-aarch64.ll
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
;; Verify that the synthetic functions inherit their flags from the corresponding | ||
;; BTE and return address signing module flags. | ||
; RUN: opt < %s -passes=asan -S | FileCheck %s | ||
; REQUIRES: aarch64-registered-target | ||
|
||
target triple = "aarch64-unknown-linux-gnu" | ||
|
||
@g = dso_local global i32 0, align 4 | ||
|
||
define i32 @test_load() sanitize_address { | ||
entry: | ||
%tmp = load i32, ptr @g, align 4 | ||
ret i32 %tmp | ||
} | ||
|
||
!llvm.module.flags = !{!0, !1} | ||
|
||
;; Due to -fasynchronous-unwind-tables. | ||
!0 = !{i32 7, !"uwtable", i32 2} | ||
|
||
;; Due to -fno-omit-frame-pointer. | ||
!1 = !{i32 7, !"frame-pointer", i32 2} | ||
|
||
!llvm.module.flags = !{!2, !3, !4} | ||
|
||
!2 = !{i32 8, !"branch-target-enforcement", i32 1} | ||
!3 = !{i32 8, !"sign-return-address", i32 1} | ||
!4 = !{i32 8, !"sign-return-address-all", i32 0} | ||
|
||
;; Set the uwtable attribute on ctor/dtor. | ||
; CHECK: define internal void @asan.module_ctor() #[[#ATTR:]] | ||
; CHECK: define internal void @asan.module_dtor() #[[#ATTR]] | ||
; CHECK: attributes #[[#ATTR]] = { nounwind uwtable "branch-target-enforcement" "frame-pointer"="all" "sign-return-address"="non-leaf" "sign-return-address-key"="a_key" } |
33 changes: 33 additions & 0 deletions
33
llvm/test/Instrumentation/MemorySanitizer/AArch64/module-flags-aarch64.ll
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
;; Verify that the synthetic functions inherit their flags from the corresponding | ||
;; BTE and return address signing module flags. | ||
; RUN: opt < %s -passes=asan -S | FileCheck %s | ||
; REQUIRES: aarch64-registered-target | ||
|
||
target triple = "aarch64-unknown-linux-gnu" | ||
|
||
@g = dso_local global i32 0, align 4 | ||
|
||
define i32 @test_load() sanitize_memory { | ||
entry: | ||
%tmp = load i32, ptr @g, align 4 | ||
ret i32 %tmp | ||
} | ||
|
||
!llvm.module.flags = !{!0, !1} | ||
|
||
;; Due to -fasynchronous-unwind-tables. | ||
!0 = !{i32 7, !"uwtable", i32 2} | ||
|
||
;; Due to -fno-omit-frame-pointer. | ||
!1 = !{i32 7, !"frame-pointer", i32 2} | ||
|
||
!llvm.module.flags = !{!2, !3, !4} | ||
|
||
!2 = !{i32 8, !"branch-target-enforcement", i32 1} | ||
!3 = !{i32 8, !"sign-return-address", i32 1} | ||
!4 = !{i32 8, !"sign-return-address-all", i32 0} | ||
|
||
;; Set the uwtable attribute on ctor/dtor. | ||
; CHECK: define internal void @asan.module_ctor() #[[#ATTR:]] | ||
; CHECK: define internal void @asan.module_dtor() #[[#ATTR]] | ||
; CHECK: attributes #[[#ATTR]] = { nounwind uwtable "branch-target-enforcement" "frame-pointer"="all" "sign-return-address"="non-leaf" "sign-return-address-key"="a_key" } |