* Implement a few FPU instructions.
* Copyright (C) 1992,1993,1994
* W. Metzenthen, 22 Parker St, Ormond, Vic 3163,
* Australia. E-mail billm@vaxc.cc.monash.edu.au
* This copyright notice covers the redistribution and use of the
* FPU emulator developed by W. Metzenthen. It covers only its use
* in the 386BSD, FreeBSD and NetBSD operating systems. Any other
* use is not permitted under this copyright.
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must include information specifying
* that source code for the emulator is freely available and include
* a) an offer to provide the source code for a nominal distribution
* b) list at least two alternative methods whereby the source
* can be obtained, e.g. a publically accessible bulletin board
* and an anonymous ftp site from which the software can be
* 3. All advertising materials specifically mentioning features or use of
* this emulator must acknowledge that it was developed by W. Metzenthen.
* 4. The name of W. Metzenthen may not be used to endorse or promote
* products derived from this software without specific prior written
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
* W. METZENTHEN BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
* The purpose of this copyright, based upon the Berkeley copyright, is to
* ensure that the covered software remains freely available to everyone.
* The software (with necessary differences) is also available, but under
* the terms of the GNU copyleft, for the Linux operating system and for
* the djgpp ms-dos extender.
* W. Metzenthen June 1994.
* $Id: fpu_etc.c,v 1.2 1994/04/29 21:16:22 gclarkii Exp $
#include "reg_constant.h"
FPU_st0_ptr
->sign
^= SIGN_POS
^ SIGN_NEG
;
if (FPU_st0_tag
^ TW_Empty
) {
FPU_st0_ptr
->sign
= SIGN_POS
;
if ((FPU_st0_ptr
->exp
<= EXP_UNDER
) && (denormal_operand()))
#endif /* DENORM_OPERAND */
if (FPU_st0_ptr
->sign
== SIGN_POS
)
setcc(SW_C0
| SW_C2
| SW_C3
); /* Operand is not comparable */
if (FPU_st0_ptr
->sign
== SIGN_POS
)
setcc(SW_C0
| SW_C2
| SW_C3
);
EXCEPTION(EX_StackUnder
);
setcc(SW_C0
| SW_C2
| SW_C3
); /* Operand is not comparable */
EXCEPTION(EX_INTERNAL
| 0x14);
/* This will need to be changed if TW_Denormal is ever used. */
if (FPU_st0_ptr
->exp
<= EXP_UNDER
)
c
= SW_C2
| SW_C3
; /* Denormal */
if (FPU_st0_ptr
->sign
== SIGN_NEG
)
static FUNC fp_etc_table
[] = {
fchs
, fabs
, Un_impl
, Un_impl
, ftst_
, fxam
, Un_impl
, Un_impl
(fp_etc_table
[FPU_rm
]) ();