Annotation of XNU/osfmk/mach/i386/fp_reg.h, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
                      3:  *
                      4:  * @APPLE_LICENSE_HEADER_START@
                      5:  * 
                      6:  * The contents of this file constitute Original Code as defined in and
                      7:  * are subject to the Apple Public Source License Version 1.1 (the
                      8:  * "License").  You may not use this file except in compliance with the
                      9:  * License.  Please obtain a copy of the License at
                     10:  * http://www.apple.com/publicsource and read it before using this file.
                     11:  * 
                     12:  * This Original Code and all software distributed under the License are
                     13:  * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
                     14:  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
                     15:  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
                     16:  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
                     17:  * License for the specific language governing rights and limitations
                     18:  * under the License.
                     19:  * 
                     20:  * @APPLE_LICENSE_HEADER_END@
                     21:  */
                     22: /*
                     23:  * @OSF_COPYRIGHT@
                     24:  */
                     25: /*
                     26:  * HISTORY
                     27:  * 
                     28:  * Revision 1.1.1.1  1998/09/22 21:05:31  wsanchez
                     29:  * Import of Mac OS X kernel (~semeria)
                     30:  *
                     31:  * Revision 1.1.1.1  1998/03/07 02:25:47  wsanchez
                     32:  * Import of OSF Mach kernel (~mburg)
                     33:  *
                     34:  * Revision 1.2.6.1  1994/09/23  02:37:03  ezf
                     35:  *     change marker to not FREE
                     36:  *     [1994/09/22  21:39:57  ezf]
                     37:  *
                     38:  * Revision 1.2.2.2  1993/06/09  02:40:30  gm
                     39:  *     Added to OSF/1 R1.3 from NMK15.0.
                     40:  *     [1993/06/02  21:16:11  jeffc]
                     41:  * 
                     42:  * Revision 1.2  1993/04/19  16:33:51  devrcs
                     43:  *     ansi C conformance changes
                     44:  *     [1993/02/02  18:56:01  david]
                     45:  * 
                     46:  * Revision 1.1  1992/09/30  02:30:43  robert
                     47:  *     Initial revision
                     48:  * 
                     49:  * $EndLog$
                     50:  */
                     51: /* CMU_HIST */
                     52: /*
                     53:  * Revision 2.1.1.1.2.1  92/03/03  16:21:23  jeffreyh
                     54:  *     Merged up to Trunk
                     55:  *     [92/02/26            jeffreyh]
                     56:  * 
                     57:  * Revision 2.4  92/02/26  13:10:29  elf
                     58:  *     Added stupid alaises to make i386/fpu.c compile. RVB will fix.
                     59:  *      
                     60:  *     [92/02/26            elf]
                     61:  * 
                     62:  * Revision 2.3  92/02/26  12:47:46  elf
                     63:  *     Installed from i386 directory.
                     64:  *     [92/02/26            danner]
                     65:  * 
                     66:  * 
                     67:  * Revision 2.2  92/01/03  20:19:47  dbg
                     68:  *     Move this file to mach/i386.  Add FP_NO..FP_387 codes for
                     69:  *     floating-point processor status.  Error bits in control
                     70:  *     register are masks, not enables.
                     71:  *     [91/10/19            dbg]
                     72:  * 
                     73:  */
                     74: /* CMU_ENDHIST */
                     75: /* 
                     76:  * Mach Operating System
                     77:  * Copyright (c) 1992-1989 Carnegie Mellon University
                     78:  * All Rights Reserved.
                     79:  * 
                     80:  * Permission to use, copy, modify and distribute this software and its
                     81:  * documentation is hereby granted, provided that both the copyright
                     82:  * notice and this permission notice appear in all copies of the
                     83:  * software, derivative works or modified versions, and any portions
                     84:  * thereof, and that both notices appear in supporting documentation.
                     85:  * 
                     86:  * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
                     87:  * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
                     88:  * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
                     89:  * 
                     90:  * Carnegie Mellon requests users of this software to return to
                     91:  * 
                     92:  *  Software Distribution Coordinator  or  [email protected]
                     93:  *  School of Computer Science
                     94:  *  Carnegie Mellon University
                     95:  *  Pittsburgh PA 15213-3890
                     96:  * 
                     97:  * any improvements or extensions that they make and grant Carnegie Mellon
                     98:  * the rights to redistribute these changes.
                     99:  */
                    100: /*
                    101:  */
                    102: 
                    103: #ifndef        _I386_FP_SAVE_H_
                    104: #define        _I386_FP_SAVE_H_
                    105: /*
                    106:  *     Floating point registers and status, as saved
                    107:  *     and restored by FP save/restore instructions.
                    108:  */
                    109: struct i386_fp_save    {
                    110:        unsigned short  fp_control;     /* control */
                    111:        unsigned short  fp_unused_1;
                    112:        unsigned short  fp_status;      /* status */
                    113:        unsigned short  fp_unused_2;
                    114:        unsigned short  fp_tag;         /* register tags */
                    115:        unsigned short  fp_unused_3;
                    116:        unsigned int    fp_eip;         /* eip at failed instruction */
                    117:        unsigned short  fp_cs;          /* cs at failed instruction */
                    118:        unsigned short  fp_opcode;      /* opcode of failed instruction */
                    119:        unsigned int    fp_dp;          /* data address */
                    120:        unsigned short  fp_ds;          /* data segment */
                    121:        unsigned short  fp_unused_4;
                    122: };
                    123: 
                    124: struct i386_fp_regs {
                    125:        unsigned short  fp_reg_word[5][8];
                    126:                                        /* space for 8 80-bit FP registers */
                    127: };
                    128: 
                    129: /*
                    130:  * Control register
                    131:  */
                    132: #define        FPC_IE          0x0001          /* enable invalid operation
                    133:                                           exception */
                    134: #define FPC_IM         FPC_IE
                    135: #define        FPC_DE          0x0002          /* enable denormalized operation
                    136:                                           exception */
                    137: #define FPC_DM         FPC_DE
                    138: #define        FPC_ZE          0x0004          /* enable zero-divide exception */
                    139: #define FPC_ZM         FPC_ZE
                    140: #define        FPC_OE          0x0008          /* enable overflow exception */
                    141: #define FPC_OM         FPC_OE
                    142: #define        FPC_UE          0x0010          /* enable underflow exception */
                    143: #define        FPC_PE          0x0020          /* enable precision exception */
                    144: #define        FPC_PC          0x0300          /* precision control: */
                    145: #define        FPC_PC_24       0x0000                  /* 24 bits */
                    146: #define        FPC_PC_53       0x0200                  /* 53 bits */
                    147: #define        FPC_PC_64       0x0300                  /* 64 bits */
                    148: #define        FPC_RC          0x0c00          /* rounding control: */
                    149: #define        FPC_RC_RN       0x0000                  /* round to nearest or even */
                    150: #define        FPC_RC_RD       0x0400                  /* round down */
                    151: #define        FPC_RC_RU       0x0800                  /* round up */
                    152: #define        FPC_RC_CHOP     0x0c00                  /* chop */
                    153: #define        FPC_IC          0x1000          /* infinity control (obsolete) */
                    154: #define        FPC_IC_PROJ     0x0000                  /* projective infinity */
                    155: #define        FPC_IC_AFF      0x1000                  /* affine infinity (std) */
                    156: 
                    157: /*
                    158:  * Status register
                    159:  */
                    160: #define        FPS_IE          0x0001          /* invalid operation */
                    161: #define        FPS_DE          0x0002          /* denormalized operand */
                    162: #define        FPS_ZE          0x0004          /* divide by zero */
                    163: #define        FPS_OE          0x0008          /* overflow */
                    164: #define        FPS_UE          0x0010          /* underflow */
                    165: #define        FPS_PE          0x0020          /* precision */
                    166: #define        FPS_SF          0x0040          /* stack flag */
                    167: #define        FPS_ES          0x0080          /* error summary */
                    168: #define        FPS_C0          0x0100          /* condition code bit 0 */
                    169: #define        FPS_C1          0x0200          /* condition code bit 1 */
                    170: #define        FPS_C2          0x0400          /* condition code bit 2 */
                    171: #define        FPS_TOS         0x3800          /* top-of-stack pointer */
                    172: #define        FPS_TOS_SHIFT   11
                    173: #define        FPS_C3          0x4000          /* condition code bit 3 */
                    174: #define        FPS_BUSY        0x8000          /* FPU busy */
                    175: 
                    176: /*
                    177:  * Kind of floating-point support provided by kernel.
                    178:  */
                    179: #define        FP_NO           0               /* no floating point */
                    180: #define        FP_SOFT         1               /* software FP emulator */
                    181: #define        FP_287          2               /* 80287 */
                    182: #define        FP_387          3               /* 80387 or 80486 */
                    183: 
                    184: #endif /* _I386_FP_SAVE_H_ */

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.