config root man

Current Path : /compat/linux/proc/self/root/usr/src/tools/test/testfloat/sparc64/

FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64
Upload File :
Current File : //compat/linux/proc/self/root/usr/src/tools/test/testfloat/sparc64/systfloat.S

/*-
 * Copyright (c) 2010 by Peter Jeremy <peterjeremy@acm.org>
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 * IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
 * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

/*
===============================================================================

This GNU assembler source file is part of TestFloat, Release 2a, a package
of programs for testing the correctness of floating-point arithmetic
complying to the IEC/IEEE Standard for Floating-Point.

Written by John R. Hauser.  More information is available through the Web
page `http://HTTP.CS.Berkeley.EDU/~jhauser/arithmetic/TestFloat.html'.

THIS SOFTWARE IS DISTRIBUTED AS IS, FOR FREE.  Although reasonable effort
has been made to avoid it, THIS SOFTWARE MAY CONTAIN FAULTS THAT WILL AT
TIMES RESULT IN INCORRECT BEHAVIOR.  USE OF THIS SOFTWARE IS RESTRICTED TO
PERSONS AND ORGANIZATIONS WHO CAN AND WILL TAKE FULL RESPONSIBILITY FOR ANY
AND ALL LOSSES, COSTS, OR OTHER PROBLEMS ARISING FROM ITS USE.

Derivative works are acceptable, even for commercial purposes, so long as
(1) they include prominent notice that the work is derivative, and (2) they
include prominent notice akin to these four paragraphs for those parts of
this code that are retained.

===============================================================================
*/

#include <machine/asm.h>
__FBSDID("$FreeBSD: release/9.1.0/tools/test/testfloat/sparc64/systfloat.S 207151 2010-04-24 12:11:41Z marius $");

	.text

/*
	.macro i2f32	src=%i0,dst=%f0
	st	\src,[%sp+2231]
	ld	[%sp+2231],\dst
	.endm

	.macro i2f64	src=%i0,dst=%f0
	stx	\src,[%sp+2231]
	ldd	[%sp+2231],\dst
	.endm

	.macro f2i32	src=%f0,dst=%i0
	st	\src,[%sp+2231]
	ld	[%sp+2231],\dst
	.endm

	.macro f2i64	src=%f0,dst=%i0
	std	\src,[%sp+2231]
	ldx	[%sp+2231],\dst
	.endm
*/
/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_int32_to_float32
syst_int32_to_float32:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	fitos	%f0,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_int32_to_float64
syst_int32_to_float64:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	fitod	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_int32_to_float128
syst_int32_to_float128:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	fitoq	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0
	std	%f2,[%sp+2231]
	ldx	[%sp+2231],%i1

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_int64_to_float32
syst_int64_to_float32:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	fxtos	%f0,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_int64_to_float64
syst_int64_to_float64:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	fxtod	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_int64_to_float128
syst_int64_to_float128:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	fxtoq	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0
	std	%f2,[%sp+2231]
	ldx	[%sp+2231],%i1

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_to_int32_round_to_zero
syst_float32_to_int32_round_to_zero:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	fstoi	%f0,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_to_int64_round_to_zero
syst_float32_to_int64_round_to_zero:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	fstox	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_to_float64
syst_float32_to_float64:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	fstod	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_to_float128
syst_float32_to_float128:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	fstoq	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0
	std	%f2,[%sp+2231]
	ldx	[%sp+2231],%i1

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_add
syst_float32_add:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	st	%i1,[%sp+2231]
	ld	[%sp+2231],%f1
	fadds	%f0,%f1,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_sub
syst_float32_sub:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	st	%i1,[%sp+2231]
	ld	[%sp+2231],%f1
	fsubs	%f0,%f1,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_mul
syst_float32_mul:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	st	%i1,[%sp+2231]
	ld	[%sp+2231],%f1
	fmuls	%f0,%f1,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_div
syst_float32_div:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	st	%i1,[%sp+2231]
	ld	[%sp+2231],%f1
	fdivs	%f0,%f1,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_sqrt
syst_float32_sqrt:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	fsqrts	%f0,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_eq
syst_float32_eq:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	st	%i1,[%sp+2231]
	ld	[%sp+2231],%f1
	fcmps	%fcc0,%f0,%f1
	mov	0,%i0
	move	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_le
syst_float32_le:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	st	%i1,[%sp+2231]
	ld	[%sp+2231],%f1
	fcmpes	%fcc0,%f0,%f1
	mov	0,%i0
	movle	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_lt
syst_float32_lt:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	st	%i1,[%sp+2231]
	ld	[%sp+2231],%f1
	fcmpes	%fcc0,%f0,%f1
	mov	0,%i0
	movl	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_eq_signaling
syst_float32_eq_signaling:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	st	%i1,[%sp+2231]
	ld	[%sp+2231],%f1
	fcmpes	%fcc0,%f0,%f1
	mov	0,%i0
	move	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_le_quiet
syst_float32_le_quiet:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	st	%i1,[%sp+2231]
	ld	[%sp+2231],%f1
	fcmps	%fcc0,%f0,%f1
	mov	0,%i0
	movle	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float32_lt_quiet
syst_float32_lt_quiet:
	save	%sp,-192,%sp

	st	%i0,[%sp+2231]
	ld	[%sp+2231],%f0
	st	%i1,[%sp+2231]
	ld	[%sp+2231],%f1
	fcmps	%fcc0,%f0,%f1
	mov	0,%i0
	movl	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_to_int32_round_to_zero
syst_float64_to_int32_round_to_zero:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	fdtoi	%f0,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_to_int64_round_to_zero
syst_float64_to_int64_round_to_zero:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	fdtox	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_to_float32
syst_float64_to_float32:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	fdtos	%f0,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_to_float128
syst_float64_to_float128:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	fdtoq	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0
	std	%f2,[%sp+2231]
	ldx	[%sp+2231],%i1

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_add
syst_float64_add:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	faddd	%f0,%f2,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_sub
syst_float64_sub:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fsubd	%f0,%f2,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_mul
syst_float64_mul:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fmuld	%f0,%f2,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_div
syst_float64_div:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fdivd	%f0,%f2,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_sqrt
syst_float64_sqrt:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	fsqrtd	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_eq
syst_float64_eq:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fcmpd	%fcc0,%f0,%f2
	mov	0,%i0
	move	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_le
syst_float64_le:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fcmped	%fcc0,%f0,%f2
	mov	0,%i0
	movle	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_lt
syst_float64_lt:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fcmped	%fcc0,%f0,%f2
	mov	0,%i0
	movl	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_eq_signaling
syst_float64_eq_signaling:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fcmped	%fcc0,%f0,%f2
	mov	0,%i0
	move	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_le_quiet
syst_float64_le_quiet:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fcmpd	%fcc0,%f0,%f2
	mov	0,%i0
	movle	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float64_lt_quiet
syst_float64_lt_quiet:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fcmpd	%fcc0,%f0,%f2
	mov	0,%i0
	movl	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_to_int32_round_to_zero
syst_float128_to_int32_round_to_zero:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fqtoi	%f0,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_to_int64_round_to_zero
syst_float128_to_int64_round_to_zero:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fqtox	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_to_float32
syst_float128_to_float32:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fqtos	%f0,%f0
	st	%f0,[%sp+2231]
	ld	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_to_float64
syst_float128_to_float64:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fqtod	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_add
syst_float128_add:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	stx	%i2,[%sp+2231]
	ldd	[%sp+2231],%f4
	stx	%i3,[%sp+2231]
	ldd	[%sp+2231],%f6
	faddq	%f0,%f4,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0
	std	%f2,[%sp+2231]
	ldx	[%sp+2231],%i1

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_sub
syst_float128_sub:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	stx	%i2,[%sp+2231]
	ldd	[%sp+2231],%f4
	stx	%i3,[%sp+2231]
	ldd	[%sp+2231],%f6
	fsubq	%f0,%f4,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0
	std	%f2,[%sp+2231]
	ldx	[%sp+2231],%i1

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_mul
syst_float128_mul:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	stx	%i2,[%sp+2231]
	ldd	[%sp+2231],%f4
	stx	%i3,[%sp+2231]
	ldd	[%sp+2231],%f6
	fmulq	%f0,%f4,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0
	std	%f2,[%sp+2231]
	ldx	[%sp+2231],%i1

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_div
syst_float128_div:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	stx	%i2,[%sp+2231]
	ldd	[%sp+2231],%f4
	stx	%i3,[%sp+2231]
	ldd	[%sp+2231],%f6
	fdivq	%f0,%f4,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0
	std	%f2,[%sp+2231]
	ldx	[%sp+2231],%i1

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_sqrt
syst_float128_sqrt:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	fsqrtq	%f0,%f0
	std	%f0,[%sp+2231]
	ldx	[%sp+2231],%i0
	std	%f2,[%sp+2231]
	ldx	[%sp+2231],%i1

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_eq
syst_float128_eq:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	stx	%i2,[%sp+2231]
	ldd	[%sp+2231],%f4
	stx	%i3,[%sp+2231]
	ldd	[%sp+2231],%f6
	fcmpq	%fcc0,%f0,%f4
	mov	0,%i0
	move	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_le
syst_float128_le:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	stx	%i2,[%sp+2231]
	ldd	[%sp+2231],%f4
	stx	%i3,[%sp+2231]
	ldd	[%sp+2231],%f6
	fcmpeq	%fcc0,%f0,%f4
	mov	0,%i0
	movle	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_lt
syst_float128_lt:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	stx	%i2,[%sp+2231]
	ldd	[%sp+2231],%f4
	stx	%i3,[%sp+2231]
	ldd	[%sp+2231],%f6
	fcmpeq	%fcc0,%f0,%f4
	mov	0,%i0
	movl	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_eq_signaling
syst_float128_eq_signaling:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	stx	%i2,[%sp+2231]
	ldd	[%sp+2231],%f4
	stx	%i3,[%sp+2231]
	ldd	[%sp+2231],%f6
	fcmpeq	%fcc0,%f0,%f4
	mov	0,%i0
	move	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_le_quiet
syst_float128_le_quiet:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	stx	%i2,[%sp+2231]
	ldd	[%sp+2231],%f4
	stx	%i3,[%sp+2231]
	ldd	[%sp+2231],%f6
	fcmpq	%fcc0,%f0,%f4
	mov	0,%i0
	movle	%fcc0,1,%i0

	ret
	restore

/*
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
*/
	.align	4
	.global	syst_float128_lt_quiet
syst_float128_lt_quiet:
	save	%sp,-192,%sp

	stx	%i0,[%sp+2231]
	ldd	[%sp+2231],%f0
	stx	%i1,[%sp+2231]
	ldd	[%sp+2231],%f2
	stx	%i2,[%sp+2231]
	ldd	[%sp+2231],%f4
	stx	%i3,[%sp+2231]
	ldd	[%sp+2231],%f6
	fcmpq	%fcc0,%f0,%f4
	mov	0,%i0
	movl	%fcc0,1,%i0

	ret
	restore

Man Man