1*8d67ca89SAndroid Build Coastguard Worker /*- 2*8d67ca89SAndroid Build Coastguard Worker * Copyright (c) 2004-2005 David Schultz <[email protected]> 3*8d67ca89SAndroid Build Coastguard Worker * All rights reserved. 4*8d67ca89SAndroid Build Coastguard Worker * 5*8d67ca89SAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without 6*8d67ca89SAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions 7*8d67ca89SAndroid Build Coastguard Worker * are met: 8*8d67ca89SAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright 9*8d67ca89SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer. 10*8d67ca89SAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright 11*8d67ca89SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the 12*8d67ca89SAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution. 13*8d67ca89SAndroid Build Coastguard Worker * 14*8d67ca89SAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15*8d67ca89SAndroid Build Coastguard Worker * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16*8d67ca89SAndroid Build Coastguard Worker * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17*8d67ca89SAndroid Build Coastguard Worker * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18*8d67ca89SAndroid Build Coastguard Worker * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19*8d67ca89SAndroid Build Coastguard Worker * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20*8d67ca89SAndroid Build Coastguard Worker * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21*8d67ca89SAndroid Build Coastguard Worker * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22*8d67ca89SAndroid Build Coastguard Worker * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23*8d67ca89SAndroid Build Coastguard Worker * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24*8d67ca89SAndroid Build Coastguard Worker * SUCH DAMAGE. 25*8d67ca89SAndroid Build Coastguard Worker * 26*8d67ca89SAndroid Build Coastguard Worker * $FreeBSD: src/lib/msun/arm/fenv.h,v 1.5 2005/03/16 19:03:45 das Exp $ 27*8d67ca89SAndroid Build Coastguard Worker */ 28*8d67ca89SAndroid Build Coastguard Worker 29*8d67ca89SAndroid Build Coastguard Worker #pragma once 30*8d67ca89SAndroid Build Coastguard Worker 31*8d67ca89SAndroid Build Coastguard Worker #include <sys/types.h> 32*8d67ca89SAndroid Build Coastguard Worker 33*8d67ca89SAndroid Build Coastguard Worker __BEGIN_DECLS 34*8d67ca89SAndroid Build Coastguard Worker 35*8d67ca89SAndroid Build Coastguard Worker /* 36*8d67ca89SAndroid Build Coastguard Worker * The ARM Cortex-A75 registers are described here: 37*8d67ca89SAndroid Build Coastguard Worker * 38*8d67ca89SAndroid Build Coastguard Worker * AArch64: 39*8d67ca89SAndroid Build Coastguard Worker * FPCR: http://infocenter.arm.com/help/topic/com.arm.doc.100403_0200_00_en/lau1442502503726.html 40*8d67ca89SAndroid Build Coastguard Worker * FPSR: http://infocenter.arm.com/help/topic/com.arm.doc.100403_0200_00_en/lau1442502526288.html 41*8d67ca89SAndroid Build Coastguard Worker * AArch32: 42*8d67ca89SAndroid Build Coastguard Worker * FPSCR: http://infocenter.arm.com/help/topic/com.arm.doc.100403_0200_00_en/lau1442504290459.html 43*8d67ca89SAndroid Build Coastguard Worker */ 44*8d67ca89SAndroid Build Coastguard Worker 45*8d67ca89SAndroid Build Coastguard Worker #if defined(__LP64__) 46*8d67ca89SAndroid Build Coastguard Worker typedef struct { 47*8d67ca89SAndroid Build Coastguard Worker /* FPCR, Floating-point Control Register. */ 48*8d67ca89SAndroid Build Coastguard Worker __uint32_t __control; 49*8d67ca89SAndroid Build Coastguard Worker /* FPSR, Floating-point Status Register. */ 50*8d67ca89SAndroid Build Coastguard Worker __uint32_t __status; 51*8d67ca89SAndroid Build Coastguard Worker } fenv_t; 52*8d67ca89SAndroid Build Coastguard Worker 53*8d67ca89SAndroid Build Coastguard Worker #else 54*8d67ca89SAndroid Build Coastguard Worker typedef __uint32_t fenv_t; 55*8d67ca89SAndroid Build Coastguard Worker #endif 56*8d67ca89SAndroid Build Coastguard Worker 57*8d67ca89SAndroid Build Coastguard Worker typedef __uint32_t fexcept_t; 58*8d67ca89SAndroid Build Coastguard Worker 59*8d67ca89SAndroid Build Coastguard Worker /* Exception flags. */ 60*8d67ca89SAndroid Build Coastguard Worker #define FE_INVALID 0x01 61*8d67ca89SAndroid Build Coastguard Worker #define FE_DIVBYZERO 0x02 62*8d67ca89SAndroid Build Coastguard Worker #define FE_OVERFLOW 0x04 63*8d67ca89SAndroid Build Coastguard Worker #define FE_UNDERFLOW 0x08 64*8d67ca89SAndroid Build Coastguard Worker #define FE_INEXACT 0x10 65*8d67ca89SAndroid Build Coastguard Worker #define FE_DENORMAL 0x80 66*8d67ca89SAndroid Build Coastguard Worker #define FE_ALL_EXCEPT (FE_DIVBYZERO | FE_INEXACT | FE_INVALID | FE_OVERFLOW | FE_UNDERFLOW | FE_DENORMAL) 67*8d67ca89SAndroid Build Coastguard Worker 68*8d67ca89SAndroid Build Coastguard Worker /* Rounding modes. */ 69*8d67ca89SAndroid Build Coastguard Worker #define FE_TONEAREST 0x0 70*8d67ca89SAndroid Build Coastguard Worker #define FE_UPWARD 0x1 71*8d67ca89SAndroid Build Coastguard Worker #define FE_DOWNWARD 0x2 72*8d67ca89SAndroid Build Coastguard Worker #define FE_TOWARDZERO 0x3 73*8d67ca89SAndroid Build Coastguard Worker 74*8d67ca89SAndroid Build Coastguard Worker __END_DECLS 75