#include <sys/asm_linkage.h>
ENTRY_NP(__quad_getfsrp)
retl
st %fsr,[%o0]
SET_SIZE(__quad_getfsrp)
ENTRY_NP(__quad_setfsrp)
retl
ld [%o0],%fsr
SET_SIZE(__quad_setfsrp)
ENTRY_NP(__quad_dp_sqrt)
ldd [%o0],%f0
fsqrtd %f0,%f0
retl
nop
SET_SIZE(__quad_dp_sqrt)
ENTRY_NP(__quad_faddq)
ldd [%o0],%f0
ldd [%o0+8],%f2
ldd [%o1],%f4
ldd [%o1+8],%f6
faddq %f0,%f4,%f8
std %f8,[%o2]
retl
std %f10,[%o2+8]
SET_SIZE(__quad_faddq)
ENTRY_NP(__quad_fsubq)
ldd [%o0],%f0
ldd [%o0+8],%f2
ldd [%o1],%f4
ldd [%o1+8],%f6
fsubq %f0,%f4,%f8
std %f8,[%o2]
retl
std %f10,[%o2+8]
SET_SIZE(__quad_fsubq)
ENTRY_NP(__quad_fmulq)
ldd [%o0],%f0
ldd [%o0+8],%f2
ldd [%o1],%f4
ldd [%o1+8],%f6
fmulq %f0,%f4,%f8
std %f8,[%o2]
retl
std %f10,[%o2+8]
SET_SIZE(__quad_fmulq)
ENTRY_NP(__quad_fdivq)
ldd [%o0],%f0
ldd [%o0+8],%f2
ldd [%o1],%f4
ldd [%o1+8],%f6
fdivq %f0,%f4,%f8
std %f8,[%o2]
retl
std %f10,[%o2+8]
SET_SIZE(__quad_fdivq)
ENTRY_NP(__quad_fsqrtq)
ldd [%o0],%f0
ldd [%o0+8],%f2
fsqrtq %f0,%f4
std %f4,[%o1]
retl
std %f6,[%o1+8]
SET_SIZE(__quad_fsqrtq)
ENTRY_NP(__quad_fcmpq)
ldd [%o0],%f0
ldd [%o0+8],%f2
ldd [%o1],%f4
ldd [%o1+8],%f6
fcmpq %f0,%f4
retl
st %fsr,[%o2]
SET_SIZE(__quad_fcmpq)
ENTRY_NP(__quad_fcmpeq)
ldd [%o0],%f0
ldd [%o0+8],%f2
ldd [%o1],%f4
ldd [%o1+8],%f6
fcmpeq %f0,%f4
retl
st %fsr,[%o2]
SET_SIZE(__quad_fcmpeq)
ENTRY_NP(__quad_fstoq)
ld [%o0],%f0
fstoq %f0,%f4
std %f4,[%o1]
retl
std %f6,[%o1+8]
SET_SIZE(__quad_fstoq)
ENTRY_NP(__quad_fdtoq)
ldd [%o0],%f0
fdtoq %f0,%f4
std %f4,[%o1]
retl
std %f6,[%o1+8]
SET_SIZE(__quad_fdtoq)
ENTRY_NP(__quad_fqtoi)
ldd [%o0],%f0
ldd [%o0+8],%f2
fqtoi %f0,%f4
retl
st %f4,[%o1]
SET_SIZE(__quad_fqtoi)
ENTRY_NP(__quad_fqtos)
ldd [%o0],%f0
ldd [%o0+8],%f2
fqtos %f0,%f4
retl
st %f4,[%o1]
SET_SIZE(__quad_fqtos)
ENTRY_NP(__quad_fqtod)
ldd [%o0],%f0
ldd [%o0+8],%f2
fqtod %f0,%f4
retl
std %f4,[%o1]
SET_SIZE(__quad_fqtod)
#if defined(__sparcv9)
ENTRY_NP(__quad_fqtox)
ldd [%o0],%f0
ldd [%o0+8],%f2
fqtox %f0,%f4
retl
std %f4,[%o1]
SET_SIZE(__quad_fqtox)
#endif