mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
47 lines
1.4 KiB
LLVM
47 lines
1.4 KiB
LLVM
|
; RUN: llc < %s -mtriple=i386-pc-linux -mcpu=corei7 -relocation-model=static | FileCheck --check-prefix=X86 %s
|
||
|
; RUN: llc < %s -mtriple=x86_64-pc-linux -mcpu=corei7 | FileCheck --check-prefix=X64 %s
|
||
|
|
||
|
@buf = internal global [5 x i8*] zeroinitializer
|
||
|
|
||
|
declare i8* @llvm.frameaddress(i32) nounwind readnone
|
||
|
|
||
|
declare i8* @llvm.stacksave() nounwind
|
||
|
|
||
|
declare i32 @llvm.eh.sjlj.setjmp(i8*) nounwind
|
||
|
|
||
|
declare void @llvm.eh.sjlj.longjmp(i8*) nounwind
|
||
|
|
||
|
define i32 @sj0() nounwind {
|
||
|
%fp = tail call i8* @llvm.frameaddress(i32 0)
|
||
|
store i8* %fp, i8** getelementptr inbounds ([5 x i8*]* @buf, i64 0, i64 0), align 16
|
||
|
%sp = tail call i8* @llvm.stacksave()
|
||
|
store i8* %sp, i8** getelementptr inbounds ([5 x i8*]* @buf, i64 0, i64 2), align 16
|
||
|
%r = tail call i32 @llvm.eh.sjlj.setjmp(i8* bitcast ([5 x i8*]* @buf to i8*))
|
||
|
ret i32 %r
|
||
|
; X86: sj0
|
||
|
; x86: movl %ebp, buf
|
||
|
; x86: movl ${{.*LBB.*}}, buf+4
|
||
|
; X86: movl %esp, buf+8
|
||
|
; X86: ret
|
||
|
; X64: sj0
|
||
|
; x64: movq %rbp, buf(%rip)
|
||
|
; x64: movq ${{.*LBB.*}}, buf+8(%rip)
|
||
|
; X64: movq %rsp, buf+16(%rip)
|
||
|
; X64: ret
|
||
|
}
|
||
|
|
||
|
define void @lj0() nounwind {
|
||
|
tail call void @llvm.eh.sjlj.longjmp(i8* bitcast ([5 x i8*]* @buf to i8*))
|
||
|
unreachable
|
||
|
; X86: lj0
|
||
|
; X86: movl buf, %ebp
|
||
|
; X86: movl buf+4, %[[REG32:.*]]
|
||
|
; X86: movl buf+8, %esp
|
||
|
; X86: jmpl *%[[REG32]]
|
||
|
; X64: lj0
|
||
|
; X64: movq buf(%rip), %rbp
|
||
|
; X64: movq buf+8(%rip), %[[REG64:.*]]
|
||
|
; X64: movq buf+16(%rip), %rsp
|
||
|
; X64: jmpq *%[[REG64]]
|
||
|
}
|