mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-25 13:45:34 +00:00
ed541fe200
Summary: The -mcpu=mips16 option caused the Integrated Assembler to crash because it couldn't figure out the architecture revision number to write to the .MIPS.abiflags section. This CPU definition has been removed because, like microMIPS, MIPS16 is an ASE to a base architecture. Reviewers: vkalintiris Subscribers: rkotler, llvm-commits, dsanders Differential Revision: http://reviews.llvm.org/D13656 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@250407 91177308-0d34-0410-b5e6-96231b3b80d8
115 lines
5.3 KiB
LLVM
115 lines
5.3 KiB
LLVM
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -mattr=+soft-float -mips16-hard-float -relocation-model=static < %s | FileCheck %s -check-prefix=__call_stub_fp___fixunsdfsi
|
|
|
|
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -mattr=+soft-float -mips16-hard-float -relocation-model=static < %s | FileCheck %s -check-prefix=__call_stub_fp___floatdidf
|
|
|
|
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -mattr=+soft-float -mips16-hard-float -relocation-model=static < %s | FileCheck %s -check-prefix=__call_stub_fp___floatdisf
|
|
|
|
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -mattr=+soft-float -mips16-hard-float -relocation-model=static < %s | FileCheck %s -check-prefix=__call_stub_fp___floatundidf
|
|
|
|
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -mattr=+soft-float -mips16-hard-float -relocation-model=static < %s | FileCheck %s -check-prefix=__call_stub_fp___fixsfdi
|
|
|
|
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -mattr=+soft-float -mips16-hard-float -relocation-model=static < %s | FileCheck %s -check-prefix=__call_stub_fp___fixunsdfdi
|
|
|
|
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -mattr=+soft-float -mips16-hard-float -relocation-model=static < %s | FileCheck %s -check-prefix=__call_stub_fp___fixdfdi
|
|
|
|
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -mattr=+soft-float -mips16-hard-float -relocation-model=static < %s | FileCheck %s -check-prefix=__call_stub_fp___fixunssfsi
|
|
|
|
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -mattr=+soft-float -mips16-hard-float -relocation-model=static < %s | FileCheck %s -check-prefix=__call_stub_fp___fixunssfdi
|
|
|
|
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -mattr=+soft-float -mips16-hard-float -relocation-model=static < %s | FileCheck %s -check-prefix=__call_stub_fp___floatundisf
|
|
|
|
@ll1 = global i64 0, align 8
|
|
@ll2 = global i64 0, align 8
|
|
@ll3 = global i64 0, align 8
|
|
@l1 = global i32 0, align 4
|
|
@l2 = global i32 0, align 4
|
|
@l3 = global i32 0, align 4
|
|
@ull1 = global i64 0, align 8
|
|
@ull2 = global i64 0, align 8
|
|
@ull3 = global i64 0, align 8
|
|
@ul1 = global i32 0, align 4
|
|
@ul2 = global i32 0, align 4
|
|
@ul3 = global i32 0, align 4
|
|
@d1 = global double 0.000000e+00, align 8
|
|
@d2 = global double 0.000000e+00, align 8
|
|
@d3 = global double 0.000000e+00, align 8
|
|
@d4 = global double 0.000000e+00, align 8
|
|
@f1 = global float 0.000000e+00, align 4
|
|
@f2 = global float 0.000000e+00, align 4
|
|
@f3 = global float 0.000000e+00, align 4
|
|
@f4 = global float 0.000000e+00, align 4
|
|
|
|
; Function Attrs: nounwind
|
|
define void @_Z3foov() #0 {
|
|
entry:
|
|
%0 = load double, double* @d1, align 8
|
|
%conv = fptosi double %0 to i64
|
|
store i64 %conv, i64* @ll1, align 8
|
|
%1 = load double, double* @d2, align 8
|
|
%conv1 = fptoui double %1 to i64
|
|
store i64 %conv1, i64* @ull1, align 8
|
|
%2 = load float, float* @f1, align 4
|
|
%conv2 = fptosi float %2 to i64
|
|
store i64 %conv2, i64* @ll2, align 8
|
|
%3 = load float, float* @f2, align 4
|
|
%conv3 = fptoui float %3 to i64
|
|
store i64 %conv3, i64* @ull2, align 8
|
|
%4 = load double, double* @d3, align 8
|
|
%conv4 = fptosi double %4 to i32
|
|
store i32 %conv4, i32* @l1, align 4
|
|
%5 = load double, double* @d4, align 8
|
|
%conv5 = fptoui double %5 to i32
|
|
store i32 %conv5, i32* @ul1, align 4
|
|
%6 = load float, float* @f3, align 4
|
|
%conv6 = fptosi float %6 to i32
|
|
store i32 %conv6, i32* @l2, align 4
|
|
%7 = load float, float* @f4, align 4
|
|
%conv7 = fptoui float %7 to i32
|
|
store i32 %conv7, i32* @ul2, align 4
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: nounwind
|
|
define void @_Z3goov() #0 {
|
|
entry:
|
|
%0 = load i64, i64* @ll1, align 8
|
|
%conv = sitofp i64 %0 to double
|
|
store double %conv, double* @d1, align 8
|
|
%1 = load i64, i64* @ull1, align 8
|
|
%conv1 = uitofp i64 %1 to double
|
|
store double %conv1, double* @d2, align 8
|
|
%2 = load i64, i64* @ll2, align 8
|
|
%conv2 = sitofp i64 %2 to float
|
|
store float %conv2, float* @f1, align 4
|
|
%3 = load i64, i64* @ull2, align 8
|
|
%conv3 = uitofp i64 %3 to float
|
|
store float %conv3, float* @f2, align 4
|
|
%4 = load i32, i32* @l1, align 4
|
|
%conv4 = sitofp i32 %4 to double
|
|
store double %conv4, double* @d3, align 8
|
|
%5 = load i32, i32* @ul1, align 4
|
|
%conv5 = uitofp i32 %5 to double
|
|
store double %conv5, double* @d4, align 8
|
|
%6 = load i32, i32* @l2, align 4
|
|
%conv6 = sitofp i32 %6 to float
|
|
store float %conv6, float* @f3, align 4
|
|
%7 = load i32, i32* @ul2, align 4
|
|
%conv7 = uitofp i32 %7 to float
|
|
store float %conv7, float* @f4, align 4
|
|
ret void
|
|
}
|
|
|
|
attributes #0 = { nounwind "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }
|
|
|
|
; __call_stub_fp___fixunsdfsi: __call_stub_fp___fixunsdfsi:
|
|
; __call_stub_fp___floatdidf: __call_stub_fp___floatdidf:
|
|
; __call_stub_fp___floatdisf: __call_stub_fp___floatdisf:
|
|
; __call_stub_fp___floatundidf: __call_stub_fp___floatundidf:
|
|
; __call_stub_fp___fixsfdi: __call_stub_fp___fixsfdi:
|
|
; __call_stub_fp___fixunsdfdi: __call_stub_fp___fixunsdfdi:
|
|
; __call_stub_fp___fixdfdi: __call_stub_fp___fixdfdi:
|
|
; __call_stub_fp___fixunssfsi: __call_stub_fp___fixunssfsi:
|
|
; __call_stub_fp___fixunssfdi: __call_stub_fp___fixunssfdi:
|
|
; __call_stub_fp___floatundisf: __call_stub_fp___floatundisf:
|
|
|