! ! Copyright 2005 Sun Microsystems, Inc. All rights reserved. ! Use is subject to license terms. ! ! CDDL HEADER START ! ! The contents of this file are subject to the terms of the ! Common Development and Distribution License, Version 1.0 only ! (the "License"). You may not use this file except in compliance ! with the License. ! ! You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE ! or http://www.opensolaris.org/os/licensing. ! See the License for the specific language governing permissions ! and limitations under the License. ! ! When distributing Covered Code, include this CDDL HEADER in each ! file and include the License file at usr/src/OPENSOLARIS.LICENSE. ! If applicable, add the following below this CDDL HEADER, with the ! fields enclosed by brackets "[]" replaced with your own identifying ! information: Portions Copyright [yyyy] [name of copyright owner] ! ! CDDL HEADER END ! ! ! .ident "%Z%%M% %I% %E% SMI" ! ! This file contains inline templates for the internal routines used ! by the quad precision emulation code for SPARC. It should be used ! in preference to __quad.s whenever possible. .inline __quad_getfsrp,1 st %fsr,[%o0] .end .inline __quad_setfsrp,1 ld [%o0],%fsr .end .inline __quad_dp_sqrt,1 ldd [%o0],%f0 fsqrtd %f0,%f0 .end .inline __quad_faddq,3 ldd [%o0],%f0 ldd [%o0+8],%f2 ldd [%o1],%f4 ldd [%o1+8],%f6 faddq %f0,%f4,%f8 std %f8,[%o2] std %f10,[%o2+8] .end .inline __quad_fsubq,3 ldd [%o0],%f0 ldd [%o0+8],%f2 ldd [%o1],%f4 ldd [%o1+8],%f6 fsubq %f0,%f4,%f8 std %f8,[%o2] std %f10,[%o2+8] .end .inline __quad_fmulq,3 ldd [%o0],%f0 ldd [%o0+8],%f2 ldd [%o1],%f4 ldd [%o1+8],%f6 fmulq %f0,%f4,%f8 std %f8,[%o2] std %f10,[%o2+8] .end .inline __quad_fdivq,3 ldd [%o0],%f0 ldd [%o0+8],%f2 ldd [%o1],%f4 ldd [%o1+8],%f6 fdivq %f0,%f4,%f8 std %f8,[%o2] std %f10,[%o2+8] .end .inline __quad_fsqrtq,2 ldd [%o0],%f0 ldd [%o0+8],%f2 fsqrtq %f0,%f4 std %f4,[%o1] std %f6,[%o1+8] .end .inline __quad_fcmpq,3 ldd [%o0],%f0 ldd [%o0+8],%f2 ldd [%o1],%f4 ldd [%o1+8],%f6 .volatile fcmpq %f0,%f4 st %fsr,[%o2] .nonvolatile .end .inline __quad_fcmpeq,3 ldd [%o0],%f0 ldd [%o0+8],%f2 ldd [%o1],%f4 ldd [%o1+8],%f6 .volatile fcmpeq %f0,%f4 st %fsr,[%o2] .nonvolatile .end .inline __quad_fstoq,2 ld [%o0],%f0 fstoq %f0,%f4 std %f4,[%o1] std %f6,[%o1+8] .end .inline __quad_fdtoq,2 ldd [%o0],%f0 fdtoq %f0,%f4 std %f4,[%o1] std %f6,[%o1+8] .end .inline __quad_fqtoi,2 ldd [%o0],%f0 ldd [%o0+8],%f2 fqtoi %f0,%f4 st %f4,[%o1] .end .inline __quad_fqtos,2 ldd [%o0],%f0 ldd [%o0+8],%f2 fqtos %f0,%f4 st %f4,[%o1] .end .inline __quad_fqtod,2 ldd [%o0],%f0 ldd [%o0+8],%f2 fqtod %f0,%f4 std %f4,[%o1] .end ! only used in V9 code .inline __quad_fqtox,2 ldd [%o0],%f0 ldd [%o0+8],%f2 fqtox %f0,%f4 std %f4,[%o1] .end