llvm-6502/test/CodeGen/MBlaze/fpu.ll
Wesley Peck 13a949071c Major update of the MicroBlaze backend. The new features are:
1. A delay slot filler that searches for valid instructions
       to fill the delay slot with. Previously NOPs would always
       be inserted into delay slots.
    2. Support for MC based instruction printer added.
    3. Support for MC based machine code generation and ELF
       file generation. ELF file generation does not yet
       completely work as much of the ELF support infrastructure
       is still x86/x86-64 specific.
    4. General clean up of the MBlaze backend code. Much of the
       tablegen code has been cleanup and simplified.

Bug Fixes:
    1. Removed duplicate periods from subtarget feature descriptions.
    2. Many of the instructions had bad machine code information
       in the tablegen files. Much of this has been fixed.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@116986 91177308-0d34-0410-b5e6-96231b3b80d8
2010-10-21 03:09:55 +00:00

67 lines
1.5 KiB
LLVM

; Ensure that floating point operations are lowered to function calls when the
; FPU is not available in the hardware and that function calls are not used
; when the FPU is available in the hardware.
;
; RUN: llc < %s -march=mblaze | FileCheck -check-prefix=FUN %s
; RUN: llc < %s -march=mblaze -mattr=+fpu | FileCheck -check-prefix=FPU %s
define float @test_add(float %a, float %b) {
; FUN: test_add:
; FPU: test_add:
%tmp.1 = fadd float %a, %b
; FUN: brlid
; FPU-NOT: brlid
ret float %tmp.1
; FUN: rtsd
; FPU: rtsd
; FUN-NOT: fadd
; FPU-NEXT: fadd
}
define float @test_sub(float %a, float %b) {
; FUN: test_sub:
; FPU: test_sub:
%tmp.1 = fsub float %a, %b
; FUN: brlid
; FPU-NOT: brlid
ret float %tmp.1
; FUN: rtsd
; FPU: rtsd
; FUN-NOT: frsub
; FPU-NEXT: frsub
}
define float @test_mul(float %a, float %b) {
; FUN: test_mul:
; FPU: test_mul:
%tmp.1 = fmul float %a, %b
; FUN: brlid
; FPU-NOT: brlid
ret float %tmp.1
; FUN: rtsd
; FPU: rtsd
; FUN-NOT: fmul
; FPU-NEXT: fmul
}
define float @test_div(float %a, float %b) {
; FUN: test_div:
; FPU: test_div:
%tmp.1 = fdiv float %a, %b
; FUN: brlid
; FPU-NOT: brlid
ret float %tmp.1
; FUN: rtsd
; FPU: rtsd
; FUN-NOT: fdiv
; FPU-NEXT: fdiv
}