mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-06 20:32:19 +00:00
8ffc5ca532
loading immediate into register is cheap, so take advantage of remat. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@233666 91177308-0d34-0410-b5e6-96231b3b80d8
29 lines
582 B
LLVM
29 lines
582 B
LLVM
; RUN: llc < %s -march=bpf | FileCheck %s
|
|
|
|
define i32 @test0(i32 %X) {
|
|
%tmp.1 = add i32 %X, 1
|
|
ret i32 %tmp.1
|
|
; CHECK-LABEL: test0:
|
|
; CHECK: addi r1, 1
|
|
}
|
|
|
|
; CHECK-LABEL: store_imm:
|
|
; CHECK: stw 0(r1), r{{[03]}}
|
|
; CHECK: stw 4(r2), r{{[03]}}
|
|
define i32 @store_imm(i32* %a, i32* %b) {
|
|
entry:
|
|
store i32 0, i32* %a, align 4
|
|
%0 = getelementptr inbounds i32, i32* %b, i32 1
|
|
store i32 0, i32* %0, align 4
|
|
ret i32 0
|
|
}
|
|
|
|
@G = external global i8
|
|
define zeroext i8 @loadG() {
|
|
%tmp = load i8, i8* @G
|
|
ret i8 %tmp
|
|
; CHECK-LABEL: loadG:
|
|
; CHECK: ld_64 r1
|
|
; CHECK: ldb r0, 0(r1)
|
|
}
|