-
Notifications
You must be signed in to change notification settings - Fork 11.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
After Linux kernel commit commit 200ed341b864 ("mips: Implement "current_stack_pointer"") We observe the following build error when compiling the Linux kernel targeting Mips: fatal error: error in backend: Invalid register name global variable Fixes: #54174 Link: ClangBuiltLinux/linux#1608 Reviewed By: atanasyan Differential Revision: https://reviews.llvm.org/D120926 (cherry picked from commit e0adc3b)
- Loading branch information
1 parent
09546e1
commit 0826716
Showing
4 changed files
with
70 additions
and
34 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
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 |
---|---|---|
@@ -1,18 +1,29 @@ | ||
; RUN: llc -mtriple=mips64 -relocation-model=static -mattr=+noabicalls -target-abi n32 < %s | FileCheck %s | ||
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py | ||
; RUN: llc -mtriple=mips64 -relocation-model=static -mattr=+noabicalls \ | ||
; RUN: -target-abi n32 < %s | FileCheck %s | ||
|
||
define i32* @get_gp() { | ||
entry: | ||
%0 = call i64 @llvm.read_register.i64(metadata !0) | ||
%1 = trunc i64 %0 to i32 | ||
%2 = inttoptr i32 %1 to i32* | ||
ret i32* %2 | ||
} | ||
declare i64 @llvm.read_register.i64(metadata) | ||
|
||
define i64 @get_gp() { | ||
; CHECK-LABEL: get_gp: | ||
; CHECK: sll $2, $gp, 0 | ||
; CHECK: # %bb.0: | ||
; CHECK-NEXT: jr $ra | ||
; CHECK-NEXT: move $2, $gp | ||
%1 = call i64 @llvm.read_register.i64(metadata !0) | ||
ret i64 %1 | ||
} | ||
|
||
declare i64 @llvm.read_register.i64(metadata) | ||
define i64 @get_sp() { | ||
; CHECK-LABEL: get_sp: | ||
; CHECK: # %bb.0: | ||
; CHECK-NEXT: jr $ra | ||
; CHECK-NEXT: move $2, $sp | ||
%1 = call i64 @llvm.read_register.i64(metadata !1) | ||
ret i64 %1 | ||
} | ||
|
||
!llvm.named.register.$28 = !{!0} | ||
!llvm.named.register.sp = !{!1} | ||
|
||
!0 = !{!"$28"} | ||
!1 = !{!"sp"} |
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 |
---|---|---|
@@ -1,17 +1,29 @@ | ||
; RUN: llc -mtriple=mips64 -relocation-model=static -mattr=+noabicalls < %s | FileCheck %s | ||
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py | ||
; RUN: llc -mtriple=mips64 -relocation-model=static -mattr=+noabicalls \ | ||
; RUN: < %s | FileCheck %s | ||
|
||
define i32* @get_gp() { | ||
entry: | ||
%0 = call i64 @llvm.read_register.i64(metadata !0) | ||
%1 = inttoptr i64 %0 to i32* | ||
ret i32* %1 | ||
} | ||
declare i64 @llvm.read_register.i64(metadata) | ||
|
||
define i64 @get_gp() { | ||
; CHECK-LABEL: get_gp: | ||
; CHECK: move $2, $gp | ||
; CHECK: # %bb.0: | ||
; CHECK-NEXT: jr $ra | ||
; CHECK-NEXT: move $2, $gp | ||
%1 = call i64 @llvm.read_register.i64(metadata !0) | ||
ret i64 %1 | ||
} | ||
|
||
declare i64 @llvm.read_register.i64(metadata) | ||
define i64 @get_sp() { | ||
; CHECK-LABEL: get_sp: | ||
; CHECK: # %bb.0: | ||
; CHECK-NEXT: jr $ra | ||
; CHECK-NEXT: move $2, $sp | ||
%1 = call i64 @llvm.read_register.i64(metadata !1) | ||
ret i64 %1 | ||
} | ||
|
||
!llvm.named.register.$28 = !{!0} | ||
!llvm.named.register.sp = !{!1} | ||
|
||
!0 = !{!"$28"} | ||
!1 = !{!"sp"} |
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 |
---|---|---|
@@ -1,17 +1,29 @@ | ||
; RUN: llc -mtriple=mips -relocation-model=static -mattr=+noabicalls < %s | FileCheck %s | ||
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py | ||
; RUN: llc -mtriple=mips -relocation-model=static -mattr=+noabicalls \ | ||
; RUN: < %s | FileCheck %s | ||
|
||
define i32* @get_gp() { | ||
entry: | ||
%0 = call i32 @llvm.read_register.i32(metadata !0) | ||
%1 = inttoptr i32 %0 to i32* | ||
ret i32* %1 | ||
} | ||
declare i32 @llvm.read_register.i32(metadata) | ||
|
||
define i32 @get_gp() { | ||
; CHECK-LABEL: get_gp: | ||
; CHECK: move $2, $gp | ||
; CHECK: # %bb.0: | ||
; CHECK-NEXT: jr $ra | ||
; CHECK-NEXT: move $2, $gp | ||
%1 = call i32 @llvm.read_register.i32(metadata !0) | ||
ret i32 %1 | ||
} | ||
|
||
declare i32 @llvm.read_register.i32(metadata) | ||
define i32 @get_sp() { | ||
; CHECK-LABEL: get_sp: | ||
; CHECK: # %bb.0: | ||
; CHECK-NEXT: jr $ra | ||
; CHECK-NEXT: move $2, $sp | ||
%1 = call i32 @llvm.read_register.i32(metadata !1) | ||
ret i32 %1 | ||
} | ||
|
||
!llvm.named.register.$28 = !{!0} | ||
!llvm.named.register.sp = !{!1} | ||
|
||
!0 = !{!"$28"} | ||
!1 = !{!"sp"} |