mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-18 10:31:57 +00:00
6693d0de3e
For PPC targets, FastISel does not take the sign extension information into account when selecting return instructions whose operands are constants. A consequence of this is that the return of boolean values is not correct. This patch fixes the problem by evaluating the sign extension information also for constants, forwarding this information to PPCMaterializeInt which takes this information to drive the sign extension during the materialization. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@217993 91177308-0d34-0410-b5e6-96231b3b80d8
175 lines
3.0 KiB
LLVM
175 lines
3.0 KiB
LLVM
; RUN: llc < %s -O0 -verify-machineinstrs -fast-isel-abort -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 | FileCheck %s --check-prefix=ELF64
|
|
|
|
define zeroext i1 @rettrue() nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: rettrue
|
|
; ELF64: li 3, 1
|
|
; ELF64: blr
|
|
ret i1 true
|
|
}
|
|
|
|
define zeroext i1 @retfalse() nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: retfalse
|
|
; ELF64: li 3, 0
|
|
; ELF64: blr
|
|
ret i1 false
|
|
}
|
|
|
|
define signext i1 @retstrue() nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: retstrue
|
|
; ELF64: li 3, -1
|
|
; ELF64: blr
|
|
ret i1 true
|
|
}
|
|
|
|
define signext i1 @retsfalse() nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: retsfalse
|
|
; ELF64: li 3, 0
|
|
; ELF64: blr
|
|
ret i1 false
|
|
}
|
|
|
|
define signext i8 @ret2(i8 signext %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret2
|
|
; ELF64: extsb
|
|
; ELF64: blr
|
|
ret i8 %a
|
|
}
|
|
|
|
define zeroext i8 @ret3(i8 signext %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret3
|
|
; ELF64: rldicl {{[0-9]+}}, {{[0-9]+}}, 0, 56
|
|
; ELF64: blr
|
|
ret i8 %a
|
|
}
|
|
|
|
define signext i16 @ret4(i16 signext %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret4
|
|
; ELF64: extsh
|
|
; ELF64: blr
|
|
ret i16 %a
|
|
}
|
|
|
|
define zeroext i16 @ret5(i16 signext %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret5
|
|
; ELF64: rldicl {{[0-9]+}}, {{[0-9]+}}, 0, 48
|
|
; ELF64: blr
|
|
ret i16 %a
|
|
}
|
|
|
|
define i16 @ret6(i16 %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret6
|
|
; ELF64: rldicl {{[0-9]+}}, {{[0-9]+}}, 0, 48
|
|
; ELF64: blr
|
|
ret i16 %a
|
|
}
|
|
|
|
define signext i32 @ret7(i32 signext %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret7
|
|
; ELF64: extsw
|
|
; ELF64: blr
|
|
ret i32 %a
|
|
}
|
|
|
|
define zeroext i32 @ret8(i32 signext %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret8
|
|
; ELF64: rldicl {{[0-9]+}}, {{[0-9]+}}, 0, 32
|
|
; ELF64: blr
|
|
ret i32 %a
|
|
}
|
|
|
|
define i32 @ret9(i32 %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret9
|
|
; ELF64: rldicl {{[0-9]+}}, {{[0-9]+}}, 0, 32
|
|
; ELF64: blr
|
|
ret i32 %a
|
|
}
|
|
|
|
define i64 @ret10(i64 %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret10
|
|
; ELF64-NOT: exts
|
|
; ELF64-NOT: rldicl
|
|
; ELF64: blr
|
|
ret i64 %a
|
|
}
|
|
|
|
define float @ret11(float %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret11
|
|
; ELF64: blr
|
|
ret float %a
|
|
}
|
|
|
|
define double @ret12(double %a) nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret12
|
|
; ELF64: blr
|
|
ret double %a
|
|
}
|
|
|
|
define i8 @ret13() nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret13
|
|
; ELF64: li
|
|
; ELF64: blr
|
|
ret i8 15;
|
|
}
|
|
|
|
define i16 @ret14() nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret14
|
|
; ELF64: li
|
|
; ELF64: blr
|
|
ret i16 -225;
|
|
}
|
|
|
|
define i32 @ret15() nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret15
|
|
; ELF64: lis
|
|
; ELF64: ori
|
|
; ELF64: blr
|
|
ret i32 278135;
|
|
}
|
|
|
|
define i64 @ret16() nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret16
|
|
; ELF64: li
|
|
; ELF64: sldi
|
|
; ELF64: oris
|
|
; ELF64: ori
|
|
; ELF64: blr
|
|
ret i64 27813515225;
|
|
}
|
|
|
|
define float @ret17() nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret17
|
|
; ELF64: addis
|
|
; ELF64: lfs
|
|
; ELF64: blr
|
|
ret float 2.5;
|
|
}
|
|
|
|
define double @ret18() nounwind uwtable ssp {
|
|
entry:
|
|
; ELF64-LABEL: ret18
|
|
; ELF64: addis
|
|
; ELF64: lfd
|
|
; ELF64: blr
|
|
ret double 2.5e-33;
|
|
}
|