1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-23 04:52:54 +02:00
llvm-mirror/test/CodeGen/AArch64/aarch64-named-reg-x18.ll
Petr Hosek d89c86a2d9 [AArch64] Allow global register asm("x18") or asm("w18") under -ffixed-x18
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
2017-04-07 20:41:58 +00:00

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"}