Viewing file: fpa11.h (2.08 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* NetWinder Floating Point Emulator (c) Rebel.com, 1998-1999 Direct questions, comments to Scott Bambrough <scottb@netwinder.org>
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
#ifndef __FPA11_H__ #define __FPA11_H__
/* includes */ #include "fpsr.h" /* FP control and status register definitions */ #include "softfloat.h"
/* Need task_struct */ #include <linux/sched.h>
#define typeNone 0x00 #define typeSingle 0x01 #define typeDouble 0x02 #define typeExtended 0x03
typedef union tagFPREG { float32 fSingle; float64 fDouble; floatx80 fExtended; } FPREG;
/* FPA11 device model */ typedef struct tagFPA11 { unsigned int *userRegisters; FPREG fpreg[8]; /* 8 floating point registers */ FPSR fpsr; /* floating point status register */ FPCR fpcr; /* floating point control register */ unsigned char fType[8]; /* type of floating point value held in floating point registers. One of none single, double or extended. */ int initflag; /* this is special. The kernel guarantees to set it to 0 when a thread is launched, so we can use it to detect whether this instance of the emulator needs to be initialised. */ } FPA11;
extern void resetFPA11(void); extern void SetRoundingMode(const unsigned int); extern void SetRoundingPrecision(const unsigned int);
#define GET_FPA11() ((FPA11 *)(¤t->thread.fpstate)) #define GET_USERREG() (GET_FPA11()->userRegisters)
#endif
|