Trailing-Edge
-
PDP-10 Archives
-
SRI_NIC_PERM_FS_1_19910112
-
kcc-4/lib/pml/pmlerr.c
There are 5 other files named pmlerr.c in the archive. Click here to see a list.
/************************************************************************
* *
* PORTABLE MATH LIBRARY -- ERROR HANDLER *
* *
* This is a sample PML library error handler. *
* It may be used as is, or another of the user's choice *
* substituted. *
* *
* In any case, the global "pmlerr" must be defined somewhere *
* in the user task, since many Portable Math Library routines *
* reference it. The other routines in this file are not called *
* by any library routines and may be omitted. *
* *
************************************************************************
*/
/*)LIBRARY
*/
#include <stdio.h>
#include "c:pmluse.h"
#include "pml.h"
static struct pml_err {
int flags; /* Flag word; bits defined in pml.h */
char *message; /* Error message */
};
static struct pml_err pml_errs[] = {
CONTINUE | COUNT | LOG, "DEXP overflow",
CONTINUE | COUNT | LOG, "DEXP underflow",
CONTINUE | COUNT | LOG, "DSCALE exponent overflow",
CONTINUE | COUNT | LOG, "DSQRT of negative argument",
CONTINUE | COUNT | LOG, "DLN of zero",
CONTINUE | COUNT | LOG, "DLN of negative argument",
CONTINUE | COUNT | LOG, "DACOS argument magnitude greater than 1.0",
CONTINUE | COUNT | LOG, "DASIN argument magnitude greater than 1.0",
CONTINUE | COUNT | LOG, "DTAN overflow",
CONTINUE | COUNT | LOG, "DCOSH overflow",
CONTINUE | COUNT | LOG, "DCOSH underflow",
CONTINUE | COUNT | LOG, "DSINH overflow",
CONTINUE | COUNT | LOG, "DSINH underflow",
CONTINUE | COUNT | LOG, "DASINH overflow",
CONTINUE | COUNT | LOG, "DACOSH argument less than 1.0",
CONTINUE | COUNT | LOG, "DACOSH overflow",
CONTINUE | COUNT | LOG, "DATANH argument magnitude greater than or = 1.0",
CONTINUE | COUNT | LOG, "DATAN underflow",
CONTINUE | COUNT | LOG, "Complex division by zero",
CONTINUE | COUNT | LOG, "Complex reciprocal of zero",
CONTINUE | COUNT | LOG, "DSCALE exponent underflow",
CONTINUE | COUNT | LOG, "DINT argument has no fractional part"
};
static int err_count = 0; /* Counter for PML errors */
static int err_limit = MAX_ERRORS; /* PML error limit */
/*
* +++ NAME +++
*
* PMLCFS Clear specified PML error handler flags
*
* +++ INDEX +++
*
* PMLCFS
* machine independent routines
* math libraries
*
* +++ DESCRIPTION +++
*
* Clear the specified PML error handler flags for the
* specified error. Two or more flags may be cleared simultaneously
* by "or-ing" them in the call, for example "LOG | CONTINUE".
* The manifest constants for the flags and error codes are
* defined in "c:pmluse.h".
*
* +++ USAGE +++
*
* pmlcfs(err_code,flags)
* int err_code;
* int flags;
*
* +++ PROGRAMMER +++
*
* Fred Fish
* Goodyear Aerospace Corp, Arizona Div.
* (602) 932-7000 work
* (602) 894-6881 home
*
* ---
*/
pmlcfs(err_code,flag_word)
register int err_code;
register int flag_word;
{
if (err_code < 0 || err_code > (sizeof(pml_errs)/sizeof(struct pml_err))) {
fprintf(stderr,"? PMLCFS --- invalid error code %d.\n",err_code);
} else {
pml_errs[err_code].flags &= ~flag_word;
}
}
/*
* +++ NAME +++
*
* PMLCNT Get PML error count and reset it to zero
*
* +++ INDEX +++
*
* PMLCNT
* machine independent routines
* math libraries
*
* +++ DESCRIPTION +++
*
* Returns the total number of PML errors seen
* prior to the call, and resets the error count to zero.
*
* +++ USAGE +++
*
* int pmlcnt()
*
* +++ PROGRAMMER +++
*
* Fred Fish
* Goodyear Aerospace Corp, Arizona Div.
* (602) 932-7000 work
* (602) 894-6881 home
*
* ---
*/
int pmlcnt()
{
register int rtn_val;
rtn_val = err_count;
err_count = 0;
return(rtn_val);
}
/*
* +++ NAME +++
*
* PMLERR Portable Math Library error handler
*
* +++ INDEX +++
*
* PMLERR
* machine independent routines
* math libraries
*
* +++ DESCRIPTION +++
*
* Provides a sample PML error handler. Does
* not use any available hardware "traps" so is machine
* independent. Generally only called internally by the
* other PML routines.
*
* There are currently three flags which control the
* response for specific errors:
*
* (1) LOG When set an error message is sent
* to the user terminal.
*
* (2) COUNT When set the error is counted
* against the PML error limit.
*
* (3) CONTINUE When set the task continues
* providing the error count has not
* exceeded the PML error limit.
*
* Each of these flags can be set or reset independently
* by "pmlsfs" or "pmlcfs" respectively.
*
* +++ USAGE +++
*
* pmlerr(err_code)
* int err_code;
*
* +++ PROGRAMMER +++
*
* Fred Fish
* Goodyear Aerospace Corp, Arizona Div.
* (602) 932-7000 work
* (602) 894-6881 home
*
* ---
*/
pmlerr(err_code)
register int err_code;
{
register struct pml_err *err;
if (err_code < 0 || err_code > (sizeof(pml_errs)/sizeof(struct pml_err))) {
fprintf(stderr,"? PMLERR --- invalid error code %d.\n",err_code);
} else {
err = &pml_errs[err_code];
if (err->flags & LOG) {
fprintf(stderr,"? WARNING --- %s.\n",err->message);
}
if (err->flags & COUNT) {
err_count++;
}
if ((err->flags & CONTINUE) && (err_count <= err_limit)) {
return;
} else {
fprintf(stderr,"? FATAL --- PML error limit exceeded.\n");
fprintf(stderr, "? FATAL --- Task aborted with %d error(s).\n",err_count);
exit();
}
}
}
/*
* +++ NAME +++
*
* PMLLIM Set Portable Math Library error limit
*
* +++ INDEX +++
*
* PMLLIM
* machine independent routines
* math libraries
*
* +++ DESCRIPTION +++
*
* Sets the PML error limit to the specified value
* and returns it previous value.
* Does not affect the current error count (which may be reset
* to zero by a call to "pmlcnt"). Note that the default error
* limit is set at compile time by the value in "pml.h".
*
* +++ USAGE +++
*
* int pmllim(limit)
* int limit;
*
* +++ PROGRAMMER +++
*
* Fred Fish
* Goodyear Aerospace Corp, Arizona Div.
* (602) 932-7000 work
* (602) 894-6881 home
*
* ---
*/
int pmllim(limit)
register int limit;
{
register int rtn_val;
rtn_val = err_limit;
err_limit = limit;
return(rtn_val);
}
/*
* +++ NAME +++
*
* PMLSFS Set specified PML error handler flags
*
* +++ INDEX +++
*
* PMLSFS
* machine independent routines
* math libraries
*
* +++ DESCRIPTION +++
*
* Set the specified PML error handler flags for the
* specified error. Two or more flags may be set simultaneously
* by "or-ing" them in the call, for example "LOG | CONTINUE".
* The manifest constants for the flags and error codes are
* defined in "c:pmluse.h".
*
* +++ USAGE +++
*
* pmlsfs(err_code,flags)
* int err_code;
* int flags;
*
* +++ PROGRAMMER +++
*
* Fred Fish
* Goodyear Aerospace Corp, Arizona Div.
* (602) 932-7000 work
* (602) 894-6881 home
*
* ---
*/
pmlsfs(err_code,flag_word)
register int err_code;
register int flag_word;
{
if (err_code < 0 || err_code > (sizeof(pml_errs)/sizeof(struct pml_err))) {
fprintf(stderr,"? ERRSET --- invalid error code %d.\n",err_code);
} else {
pml_errs[err_code].flags |= flag_word;
}
}