fsr.h revision 1.1
1/*	$NetBSD: fsr.h,v 1.1 1998/06/20 04:58:51 eeh Exp $ */
2
3/*
4 * Copyright (c) 1992, 1993
5 *	The Regents of the University of California.  All rights reserved.
6 *
7 * This software was developed by the Computer Systems Engineering group
8 * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and
9 * contributed to Berkeley.
10 *
11 * All advertising materials mentioning features or use of this software
12 * must display the following acknowledgement:
13 *	This product includes software developed by the University of
14 *	California, Lawrence Berkeley Laboratory.
15 *
16 * Redistribution and use in source and binary forms, with or without
17 * modification, are permitted provided that the following conditions
18 * are met:
19 * 1. Redistributions of source code must retain the above copyright
20 *    notice, this list of conditions and the following disclaimer.
21 * 2. Redistributions in binary form must reproduce the above copyright
22 *    notice, this list of conditions and the following disclaimer in the
23 *    documentation and/or other materials provided with the distribution.
24 * 3. All advertising materials mentioning features or use of this software
25 *    must display the following acknowledgement:
26 *	This product includes software developed by the University of
27 *	California, Berkeley and its contributors.
28 * 4. Neither the name of the University nor the names of its contributors
29 *    may be used to endorse or promote products derived from this software
30 *    without specific prior written permission.
31 *
32 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
33 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
34 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
35 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
36 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
37 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
38 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
39 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
40 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
41 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
42 * SUCH DAMAGE.
43 *
44 *	@(#)fsr.h	8.1 (Berkeley) 6/11/93
45 */
46
47#ifndef _MACHINE_FSR_H_
48#define	_MACHINE_FSR_H_
49
50/*
51 * Bits in FPRS
52 */
53#define FPRS_FEF	0x04		/* Enable FP -- must be set to enable FP regs */
54#define FPRS_DU		0x02		/* Dirty upper -- upper fp regs are dirty */
55#define FPRS_DL		0x01		/* Dirty lower -- lower fp regs are dirty */
56
57/*
58 * Bits in FSR.
59 */
60
61#define	FSR_RD		0xc0000000	/* rounding direction */
62#define	  FSR_RD_RN	0		/* round to nearest */
63#define	  FSR_RD_RZ	1		/* round towards 0 */
64#define	  FSR_RD_RP	2		/* round towards +inf */
65#define	  FSR_RD_RM	3		/* round towards -inf */
66#define	FSR_RD_SHIFT	30
67#define	FSR_RD_MASK	0x03
68
69#define	FSR_RP		0x30000000	/* extended rounding precision */
70#define	  FSR_RP_X	0		/* extended stays extended */
71#define	  FSR_RP_S	1		/* extended => single */
72#define	  FSR_RP_D	2		/* extended => double */
73#define	  FSR_RP_80	3		/* extended => 80-bit */
74#define	FSR_RP_SHIFT	28
75#define	FSR_RP_MASK	0x03
76
77#define	FSR_TEM		0x0f800000	/* trap enable mask */
78#define	FSR_TEM_SHIFT	23
79#define	FSR_TEM_MASK	0x1f
80
81#define	FSR_NS		0x00400000	/* ``nonstandard mode'' */
82#define	FSR_AU		0x00400000	/* aka abrupt underflow mode */
83#define	FSR_MBZ		0x00300000	/* reserved; must be zero */
84
85#define	FSR_VER		0x000e0000	/* version bits */
86#define	FSR_VER_SHIFT	17
87#define	FSR_VER_MASK	0x07
88
89#define	FSR_FTT		0x0001c000	/* FP trap type */
90#define	  FSR_TT_NONE	0		/* no trap */
91#define	  FSR_TT_IEEE	1		/* IEEE exception */
92#define	  FSR_TT_UNFIN	2		/* unfinished operation */
93#define	  FSR_TT_UNIMP	3		/* unimplemented operation */
94#define	  FSR_TT_SEQ	4		/* sequence error */
95#define	  FSR_TT_HWERR	5		/* hardware error (unrecoverable) */
96#define	FSR_FTT_SHIFT	14
97#define	FSR_FTT_MASK	0x03
98
99#define	FSR_QNE		0x00002000	/* queue not empty */
100#define	FSR_PR		0x00001000	/* partial result */
101
102#define	FSR_FCC		0x00000c00	/* FP condition codes */
103#define	  FSR_CC_EQ	0		/* f1 = f2 */
104#define	  FSR_CC_LT	1		/* f1 < f2 */
105#define	  FSR_CC_GT	2		/* f1 > f2 */
106#define	  FSR_CC_UO	3		/* (f1,f2) unordered */
107#define	FSR_FCC_SHIFT	10
108#define	FSR_FCC_MASK	0x03
109
110#define	FSR_AX	0x000003e0		/* accrued exceptions */
111#define	  FSR_AX_SHIFT	5
112#define	  FSR_AX_MASK	0x1f
113#define	FSR_CX	0x0000001f		/* current exceptions */
114#define	  FSR_CX_SHIFT	0
115#define	  FSR_CX_MASK	0x1f
116
117/* These are the 3 new v9 fcc's */
118#define	FSR_FCC3	0x06000000000	/* FP condition codes */
119#define	FSR_FCC3_SHIFT	36
120
121#define	FSR_FCC2	0x0c00000000	/* FP condition codes */
122#define	FSR_FCC2_SHIFT	34
123
124#define	FSR_FCC1	0x0600000000	/* FP condition codes */
125#define	FSR_FCC1_SHIFT	32
126
127
128/* The following exceptions apply to TEM, AX, and CX. */
129#define	FSR_NV	0x10			/* invalid operand */
130#define	FSR_OF	0x08			/* overflow */
131#define	FSR_UF	0x04			/* underflow */
132#define	FSR_DZ	0x02			/* division by zero */
133#define	FSR_NX	0x01			/* inexact result */
134
135#endif /* _MACHINE_FSR_H_ */
136