mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
1703a71495
short form. Constant islands will expand them if they are out of range. Since there is not direct object emitter at this time, it does not have any material affect because the assembler sorts this out. But we need to know for the actual constant island work. We track the difference by putting # 16 inst in the comments. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@194766 91177308-0d34-0410-b5e6-96231b3b80d8
22 lines
808 B
LLVM
22 lines
808 B
LLVM
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mcpu=mips16 -soft-float -mips16-hard-float -relocation-model=pic -mips16-constant-islands < %s | FileCheck %s -check-prefix=cond-b-short
|
|
|
|
@i = global i32 1, align 4
|
|
@j = global i32 2, align 4
|
|
@k = common global i32 0, align 4
|
|
|
|
; Function Attrs: nounwind optsize
|
|
define void @t() #0 {
|
|
entry:
|
|
%0 = load i32* @i, align 4
|
|
%1 = load i32* @j, align 4
|
|
%cmp = icmp ne i32 %0, %1
|
|
%cond = select i1 %cmp, i32 1, i32 2
|
|
store i32 %cond, i32* @k, align 4
|
|
; cond-b-short: btnez $BB0_{{[0-9]+}} # 16 bit inst
|
|
ret void
|
|
}
|
|
|
|
attributes #0 = { nounwind optsize "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="true" }
|
|
|
|
|