mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 20:51:52 +01:00
8a9a382ab2
This patch implements the infrastructure to use named register constructs in programs that need access to specific registers (bare metal, kernels, etc). So far, only the stack pointer is supported as a technology preview, but as it is, the intrinsic can already support all non-allocatable registers from any architecture. llvm-svn: 208104
14 lines
389 B
LLVM
14 lines
389 B
LLVM
; RUN: not llc < %s -mtriple=arm-apple-darwin 2>&1 | FileCheck %s
|
|
; RUN: not llc < %s -mtriple=arm-linux-gnueabi 2>&1 | FileCheck %s
|
|
|
|
define i32 @get_stack() nounwind {
|
|
entry:
|
|
; CHECK: Invalid register name global variable
|
|
%sp = call i32 @llvm.read_register.i32(metadata !0)
|
|
ret i32 %sp
|
|
}
|
|
|
|
declare i32 @llvm.read_register.i32(metadata) nounwind
|
|
|
|
!0 = metadata !{metadata !"notareg\00"}
|