1 1.10 matt /* $NetBSD: floatdisf.c,v 1.10 2013/02/03 01:48:53 matt Exp $ */ 2 1.3 cgd 3 1.1 mycroft /*- 4 1.1 mycroft * Copyright (c) 1992, 1993 5 1.1 mycroft * The Regents of the University of California. All rights reserved. 6 1.1 mycroft * 7 1.1 mycroft * This software was developed by the Computer Systems Engineering group 8 1.1 mycroft * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and 9 1.1 mycroft * contributed to Berkeley. 10 1.1 mycroft * 11 1.1 mycroft * Redistribution and use in source and binary forms, with or without 12 1.1 mycroft * modification, are permitted provided that the following conditions 13 1.1 mycroft * are met: 14 1.1 mycroft * 1. Redistributions of source code must retain the above copyright 15 1.1 mycroft * notice, this list of conditions and the following disclaimer. 16 1.1 mycroft * 2. Redistributions in binary form must reproduce the above copyright 17 1.1 mycroft * notice, this list of conditions and the following disclaimer in the 18 1.1 mycroft * documentation and/or other materials provided with the distribution. 19 1.6 agc * 3. Neither the name of the University nor the names of its contributors 20 1.1 mycroft * may be used to endorse or promote products derived from this software 21 1.1 mycroft * without specific prior written permission. 22 1.1 mycroft * 23 1.1 mycroft * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 24 1.1 mycroft * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 25 1.1 mycroft * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 26 1.1 mycroft * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 27 1.1 mycroft * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 28 1.1 mycroft * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 29 1.1 mycroft * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 30 1.1 mycroft * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 31 1.1 mycroft * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 32 1.1 mycroft * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 33 1.1 mycroft * SUCH DAMAGE. 34 1.1 mycroft */ 35 1.1 mycroft 36 1.4 christos #include <sys/cdefs.h> 37 1.1 mycroft #if defined(LIBC_SCCS) && !defined(lint) 38 1.3 cgd #if 0 39 1.3 cgd static char sccsid[] = "@(#)floatdisf.c 8.1 (Berkeley) 6/4/93"; 40 1.3 cgd #else 41 1.10 matt __RCSID("$NetBSD: floatdisf.c,v 1.10 2013/02/03 01:48:53 matt Exp $"); 42 1.3 cgd #endif 43 1.1 mycroft #endif /* LIBC_SCCS and not lint */ 44 1.1 mycroft 45 1.10 matt #if defined(SOFTFLOAT) || defined(__ARM_EABI__) 46 1.9 matt #include "softfloat/softfloat-for-gcc.h" 47 1.9 matt #endif 48 1.9 matt 49 1.1 mycroft #include "quad.h" 50 1.1 mycroft 51 1.1 mycroft /* 52 1.1 mycroft * Convert (signed) quad to float. 53 1.1 mycroft */ 54 1.1 mycroft float 55 1.7 matt __floatdisf(quad_t x) 56 1.1 mycroft { 57 1.1 mycroft float f; 58 1.1 mycroft union uu u; 59 1.1 mycroft int neg; 60 1.1 mycroft 61 1.1 mycroft /* 62 1.1 mycroft * Get an unsigned number first, by negating if necessary. 63 1.1 mycroft */ 64 1.1 mycroft if (x < 0) 65 1.1 mycroft u.q = -x, neg = 1; 66 1.1 mycroft else 67 1.1 mycroft u.q = x, neg = 0; 68 1.1 mycroft 69 1.1 mycroft /* 70 1.1 mycroft * Now u.ul[H] has the factor of 2^32 (or whatever) and u.ul[L] 71 1.5 scw * has the units. Ideally we could just set f, add INT_BITS to 72 1.1 mycroft * its exponent, and then add the units, but this is portable 73 1.1 mycroft * code and does not know how to get at an exponent. Machine- 74 1.1 mycroft * specific code may be able to do this more efficiently. 75 1.1 mycroft * 76 1.1 mycroft * Using double here may be excessive paranoia. 77 1.1 mycroft */ 78 1.8 christos f = (double)u.ul[H] * (((int)1 << (unsigned int)(INT_BITS - 2)) * 4.0); 79 1.1 mycroft f += u.ul[L]; 80 1.1 mycroft 81 1.1 mycroft return (neg ? -f : f); 82 1.1 mycroft } 83