mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 12:12:47 +01:00
d89c86a2d9
When using -ffixed-x18, the x18 (or w18) register can safely be used with the "global register variable" GCC extension, but the backend fails to recognize it. Patch by Roland McGrath. Differential Revision: https://reviews.llvm.org/D31793 llvm-svn: 299799
15 lines
440 B
LLVM
15 lines
440 B
LLVM
; RUN: not llc -mtriple=aarch64-fuchsia -o - %s 2>&1 | FileCheck %s --check-prefix=ERROR
|
|
; RUN: llc -mtriple=aarch64-fuchsia -mattr=+reserve-x18 -o - %s
|
|
|
|
define void @set_x18(i64 %x) {
|
|
entry:
|
|
; FIXME: Include an allocatable-specific error message
|
|
; ERROR: Invalid register name "x18".
|
|
tail call void @llvm.write_register.i64(metadata !0, i64 %x)
|
|
ret void
|
|
}
|
|
|
|
declare void @llvm.write_register.i64(metadata, i64) nounwind
|
|
|
|
!0 = !{!"x18"}
|