mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-22 07:32:48 +00:00
dd0fb018a7
Remove the old IR ordering mechanism and switch to new one. Fix unit test failures. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@182704 91177308-0d34-0410-b5e6-96231b3b80d8
35 lines
960 B
LLVM
35 lines
960 B
LLVM
; RUN: llc -mtriple=aarch64-none-linux-gnu -verify-machineinstrs < %s | FileCheck %s
|
|
|
|
define float @test_sincos_f32(float %f) {
|
|
%sin = call float @sinf(float %f) readnone
|
|
%cos = call float @cosf(float %f) readnone
|
|
; CHECK: bl sinf
|
|
; CHECK: bl cosf
|
|
%val = fadd float %sin, %cos
|
|
ret float %val
|
|
}
|
|
|
|
define double @test_sincos_f64(double %f) {
|
|
%sin = call double @sin(double %f) readnone
|
|
%cos = call double @cos(double %f) readnone
|
|
%val = fadd double %sin, %cos
|
|
; CHECK: bl sin
|
|
; CHECK: bl cos
|
|
ret double %val
|
|
}
|
|
|
|
define fp128 @test_sincos_f128(fp128 %f) {
|
|
%sin = call fp128 @sinl(fp128 %f) readnone
|
|
%cos = call fp128 @cosl(fp128 %f) readnone
|
|
%val = fadd fp128 %sin, %cos
|
|
; CHECK: bl sinl
|
|
; CHECK: bl cosl
|
|
ret fp128 %val
|
|
}
|
|
|
|
declare float @sinf(float) readonly
|
|
declare double @sin(double) readonly
|
|
declare fp128 @sinl(fp128) readonly
|
|
declare float @cosf(float) readonly
|
|
declare double @cos(double) readonly
|
|
declare fp128 @cosl(fp128) readonly |