NetBSD/sys/arch/pc532/fpu/ieee_dze.c
2003-07-15 02:54:31 +00:00

64 lines
1.9 KiB
C

/* $NetBSD: ieee_dze.c,v 1.2 2003/07/15 02:54:33 lukem Exp $ */
/*
* IEEE floating point support for NS32081 and NS32381 fpus.
* Copyright (c) 1995 Ian Dall
* All Rights Reserved.
*
* Permission to use, copy, modify and distribute this software and its
* documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation.
*
* IAN DALL ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" CONDITION.
* IAN DALL DISCLAIMS ANY LIABILITY OF ANY KIND FOR ANY DAMAGES
* WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
*/
/*
* File: ieee_dze.c
* Author: Ian Dall
* Date: November 1995
*
* Handle divide by zero, generating +-Infty as required.
*
* HISTORY
* 14-Dec-95 Ian Dall (Ian.Dall@dsto.defence.gov.au)
* First release.
*
*/
#include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: ieee_dze.c,v 1.2 2003/07/15 02:54:33 lukem Exp $");
#include "ieee_internal.h"
int ieee_dze(struct operand *op1, struct operand *op2,
struct operand *f0_op, int xopcode, state *state)
{
int user_trap = FPC_TT_NONE;
unsigned int fsr = state->FSR;
DP(1, "Divide by zero trap: xopcode = 0x%x\n", xopcode);
fsr |= FPC_DZF;
if (fsr & FPC_DZE) {
/* Users trap handler will fix it */
user_trap = FPC_TT_DIV0;
}
else {
/* Set dest to + or - infinity ? */
int sign1 = op2->data.d_bits.sign;
int sign2 = op1->data.d_bits.sign;
op2->data = infty;
op2->data.d_bits.sign = sign1 ^ sign2;
switch(xopcode) {
case LOGBF:
/* logb(0) gives a divide by zero exception according to ieee.
* No idea if the logbf instruction conforms, but just in case...
*/
op2->data.d_bits.sign = 1;
}
}
state->FSR = fsr;
return user_trap;
}