mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-12 15:05:06 +00:00
53624a2df5
This patch is mostly just refactoring a bunch of copy-and-pasted code, but it also adds a check that the call instructions are readnone or readonly. That check was already present for sin, cos, sqrt, log2, and exp2 calls, but it was missing for the rest of the builtins being handled in this code. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@161282 91177308-0d34-0410-b5e6-96231b3b80d8
102 lines
1.8 KiB
LLVM
102 lines
1.8 KiB
LLVM
; RUN: llc < %s -march=arm -mattr=+vfp2 | FileCheck %s
|
|
|
|
define float @f1(float %a, float %b) {
|
|
;CHECK: f1:
|
|
;CHECK: vadd.f32
|
|
entry:
|
|
%tmp = fadd float %a, %b ; <float> [#uses=1]
|
|
ret float %tmp
|
|
}
|
|
|
|
define double @f2(double %a, double %b) {
|
|
;CHECK: f2:
|
|
;CHECK: vadd.f64
|
|
entry:
|
|
%tmp = fadd double %a, %b ; <double> [#uses=1]
|
|
ret double %tmp
|
|
}
|
|
|
|
define float @f3(float %a, float %b) {
|
|
;CHECK: f3:
|
|
;CHECK: vmul.f32
|
|
entry:
|
|
%tmp = fmul float %a, %b ; <float> [#uses=1]
|
|
ret float %tmp
|
|
}
|
|
|
|
define double @f4(double %a, double %b) {
|
|
;CHECK: f4:
|
|
;CHECK: vmul.f64
|
|
entry:
|
|
%tmp = fmul double %a, %b ; <double> [#uses=1]
|
|
ret double %tmp
|
|
}
|
|
|
|
define float @f5(float %a, float %b) {
|
|
;CHECK: f5:
|
|
;CHECK: vsub.f32
|
|
entry:
|
|
%tmp = fsub float %a, %b ; <float> [#uses=1]
|
|
ret float %tmp
|
|
}
|
|
|
|
define double @f6(double %a, double %b) {
|
|
;CHECK: f6:
|
|
;CHECK: vsub.f64
|
|
entry:
|
|
%tmp = fsub double %a, %b ; <double> [#uses=1]
|
|
ret double %tmp
|
|
}
|
|
|
|
define float @f7(float %a) {
|
|
;CHECK: f7:
|
|
;CHECK: eor
|
|
entry:
|
|
%tmp1 = fsub float -0.000000e+00, %a ; <float> [#uses=1]
|
|
ret float %tmp1
|
|
}
|
|
|
|
define double @f8(double %a) {
|
|
;CHECK: f8:
|
|
;CHECK: vneg.f64
|
|
entry:
|
|
%tmp1 = fsub double -0.000000e+00, %a ; <double> [#uses=1]
|
|
ret double %tmp1
|
|
}
|
|
|
|
define float @f9(float %a, float %b) {
|
|
;CHECK: f9:
|
|
;CHECK: vdiv.f32
|
|
entry:
|
|
%tmp1 = fdiv float %a, %b ; <float> [#uses=1]
|
|
ret float %tmp1
|
|
}
|
|
|
|
define double @f10(double %a, double %b) {
|
|
;CHECK: f10:
|
|
;CHECK: vdiv.f64
|
|
entry:
|
|
%tmp1 = fdiv double %a, %b ; <double> [#uses=1]
|
|
ret double %tmp1
|
|
}
|
|
|
|
define float @f11(float %a) {
|
|
;CHECK: f11:
|
|
;CHECK: bic
|
|
entry:
|
|
%tmp1 = call float @fabsf( float %a ) readnone ; <float> [#uses=1]
|
|
ret float %tmp1
|
|
}
|
|
|
|
declare float @fabsf(float)
|
|
|
|
define double @f12(double %a) {
|
|
;CHECK: f12:
|
|
;CHECK: vabs.f64
|
|
entry:
|
|
%tmp1 = call double @fabs( double %a ) readnone ; <double> [#uses=1]
|
|
ret double %tmp1
|
|
}
|
|
|
|
declare double @fabs(double)
|