flt_rounds.c revision 1.1
11.1Smsaitoh/*	$NetBSD: flt_rounds.c,v 1.1 2000/01/05 14:07:32 msaitoh Exp $	*/
21.1Smsaitoh
31.1Smsaitoh/*
41.1Smsaitoh * Copyright (c) 1996 Mark Brinicombe
51.1Smsaitoh * All rights reserved.
61.1Smsaitoh *
71.1Smsaitoh * Redistribution and use in source and binary forms, with or without
81.1Smsaitoh * modification, are permitted provided that the following conditions
91.1Smsaitoh * are met:
101.1Smsaitoh * 1. Redistributions of source code must retain the above copyright
111.1Smsaitoh *    notice, this list of conditions and the following disclaimer.
121.1Smsaitoh * 2. Redistributions in binary form must reproduce the above copyright
131.1Smsaitoh *    notice, this list of conditions and the following disclaimer in the
141.1Smsaitoh *    documentation and/or other materials provided with the distribution.
151.1Smsaitoh * 3. All advertising materials mentioning features or use of this software
161.1Smsaitoh *    must display the following acknowledgement:
171.1Smsaitoh *      This product includes software developed by Mark Brinicombe
181.1Smsaitoh *	for the NetBSD Project.
191.1Smsaitoh * 4. The name of the author may not be used to endorse or promote products
201.1Smsaitoh *    derived from this software without specific prior written permission
211.1Smsaitoh *
221.1Smsaitoh * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
231.1Smsaitoh * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
241.1Smsaitoh * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
251.1Smsaitoh * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
261.1Smsaitoh * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
271.1Smsaitoh * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
281.1Smsaitoh * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
291.1Smsaitoh * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
301.1Smsaitoh * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
311.1Smsaitoh * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
321.1Smsaitoh */
331.1Smsaitoh
341.1Smsaitoh#include <sys/types.h>
351.1Smsaitoh#include <ieeefp.h>
361.1Smsaitoh
371.1Smsaitohstatic const int map[] = {
381.1Smsaitoh	1,	/* round to nearest */
391.1Smsaitoh	2,	/* round to positive infinity */
401.1Smsaitoh	3,	/* round to negative infinity */
411.1Smsaitoh	0	/* round to zero */
421.1Smsaitoh};
431.1Smsaitoh
441.1Smsaitoh/*
451.1Smsaitoh * Return the current FP rounding mode
461.1Smsaitoh *
471.1Smsaitoh * Returns:
481.1Smsaitoh *	0 - round to zero
491.1Smsaitoh *	1 - round to nearest
501.1Smsaitoh *	2 - round to postive infinity
511.1Smsaitoh *	3 - round to negative infinity
521.1Smsaitoh *
531.1Smsaitoh * ok all we need to do is get the current FP rounding mode
541.1Smsaitoh * index our map table and return the appropriate value.
551.1Smsaitoh *
561.1Smsaitoh * HOWEVER:
571.1Smsaitoh * The ARM FPA codes the rounding mode into the actual FP instructions
581.1Smsaitoh * so there is no such thing as a global rounding mode.
591.1Smsaitoh * The default is round to nearest if rounding is not explictly specified.
601.1Smsaitoh * FP instructions generated by GCC will not explicitly specify a rounding
611.1Smsaitoh * mode.
621.1Smsaitoh *
631.1Smsaitoh * So the best we can do it to return the rounding mode FP instructions
641.1Smsaitoh * use if rounding is not specified which is round to nearest.
651.1Smsaitoh *
661.1Smsaitoh * This could change in the future with new floating point emulators or
671.1Smsaitoh * soft float FP libraries.
681.1Smsaitoh */
691.1Smsaitoh
701.1Smsaitoh#include <sys/cdefs.h>
711.1Smsaitoh
721.1Smsaitohextern int __flt_rounds __P((void));
731.1Smsaitoh
741.1Smsaitohint
751.1Smsaitoh__flt_rounds()
761.1Smsaitoh{
771.1Smsaitoh	return(map[fpgetround()]);
781.1Smsaitoh}
79